projects
/
fw
/
altos
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
altos: Switch ao_dbg.c __xdata to __pdata
[fw/altos]
/
src
/
ao_packet_slave.c
diff --git
a/src/ao_packet_slave.c
b/src/ao_packet_slave.c
index 9b78767f55282b4e77c0f28f806124728151fccc..9f14052af406c9293b3fbeeb7a73b92c3fff438c 100644
(file)
--- a/
src/ao_packet_slave.c
+++ b/
src/ao_packet_slave.c
@@
-20,15
+20,14
@@
void
ao_packet_slave(void)
{
void
ao_packet_slave(void)
{
- uint8_t status;
-
- ao_radio_set_packet();
ao_tx_packet.addr = ao_serial_number;
ao_tx_packet.len = AO_PACKET_SYN;
while (ao_packet_enable) {
ao_tx_packet.addr = ao_serial_number;
ao_tx_packet.len = AO_PACKET_SYN;
while (ao_packet_enable) {
- status = ao_packet_recv();
- if (status & AO_DMA_DONE) {
+ if (ao_packet_recv()) {
memcpy(&ao_tx_packet.callsign, &ao_rx_packet.packet.callsign, AO_MAX_CALLSIGN);
memcpy(&ao_tx_packet.callsign, &ao_rx_packet.packet.callsign, AO_MAX_CALLSIGN);
+#if HAS_FLIGHT
+ ao_flight_force_idle = TRUE;
+#endif
ao_packet_send();
}
}
ao_packet_send();
}
}
@@
-47,19
+46,19
@@
ao_packet_slave_stop(void)
{
if (ao_packet_enable) {
ao_packet_enable = 0;
{
if (ao_packet_enable) {
ao_packet_enable = 0;
- ao_radio_abort();
while (ao_packet_task.wchan) {
while (ao_packet_task.wchan) {
- ao_
wake_task(&ao_packet_task
);
- ao_
yield(
);
+ ao_
radio_recv_abort(
);
+ ao_
delay(AO_MS_TO_TICKS(10)
);
}
}
- ao_radio_set_telemetry();
}
}
void
}
}
void
-ao_packet_slave_init(
void
)
+ao_packet_slave_init(
uint8_t enable
)
{
ao_add_stdio(ao_packet_pollchar,
ao_packet_putchar,
NULL);
{
ao_add_stdio(ao_packet_pollchar,
ao_packet_putchar,
NULL);
+ if (enable)
+ ao_packet_slave_start();
}
}