From 7b9d39da831a6454eb0eb57bbfa86ff2d615d287 Mon Sep 17 00:00:00 2001 From: Sadeep Madurange Date: Fri, 11 Apr 2025 10:59:15 +0800 Subject: Clear maxrt and minor code cleanup, still working. --- nrfm.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'nrfm.c') diff --git a/nrfm.c b/nrfm.c index 7ec45df..84f790a 100644 --- a/nrfm.c +++ b/nrfm.c @@ -229,12 +229,11 @@ void radio_sendto(const uint8_t addr[ADDRLEN], const char *msg, uint8_t n) disable_chip(); - imax = n < MAXPDLEN ? n : MAXPDLEN; cfg = read_reg(0x00); tx_mode(); - reset_irqs(); flush_tx(); + reset_irqs(); setaddr(0x10, addr); setaddr(0x0A, addr); @@ -246,6 +245,8 @@ void radio_sendto(const uint8_t addr[ADDRLEN], const char *msg, uint8_t n) uart_write("."); uart_write_line(itoa(addr[2], s, 10)); + imax = n < MAXPDLEN ? n : MAXPDLEN; + SPI_PORT &= ~(1 << SPI_SS); SPDR = 0b10100000; while (!(SPSR & (1 << SPIF))) @@ -271,6 +272,7 @@ void radio_sendto(const uint8_t addr[ADDRLEN], const char *msg, uint8_t n) if (txds) uart_write_line("DEBUG: packet sent"); else if (maxrt) { + reset_irqs(); uart_write_line("ERROR: sendto() failed: MAX_RT"); } @@ -280,6 +282,7 @@ void radio_sendto(const uint8_t addr[ADDRLEN], const char *msg, uint8_t n) void radio_listen(void) { + disable_chip(); rx_mode(); enable_chip(); } -- cgit v1.2.3