mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 01:28:29 -04:00
AP_Radio: use WITH_SEMAPHORE()
and removed usage of hal.util->new_semaphore()
This commit is contained in:
parent
17049ff5f5
commit
68f463b29d
@ -68,8 +68,6 @@ bool AP_Radio_cc2500::init(void)
|
|||||||
irq_handler_thd, /* Thread function. */
|
irq_handler_thd, /* Thread function. */
|
||||||
NULL); /* Thread parameter. */
|
NULL); /* Thread parameter. */
|
||||||
#endif
|
#endif
|
||||||
sem = hal.util->new_semaphore();
|
|
||||||
|
|
||||||
return reset();
|
return reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -340,26 +338,26 @@ void AP_Radio_cc2500::handle_data_packet(mavlink_channel_t chan, const mavlink_d
|
|||||||
uint32_t ofs=0;
|
uint32_t ofs=0;
|
||||||
memcpy(&ofs, &m.data[0], 4);
|
memcpy(&ofs, &m.data[0], 4);
|
||||||
Debug(4, "got data96 of len %u from chan %u at offset %u\n", m.len, chan, unsigned(ofs));
|
Debug(4, "got data96 of len %u from chan %u at offset %u\n", m.len, chan, unsigned(ofs));
|
||||||
if (sem->take_nonblocking()) {
|
|
||||||
fwupload.chan = chan;
|
WITH_SEMAPHORE(sem);
|
||||||
fwupload.need_ack = false;
|
|
||||||
fwupload.offset = ofs;
|
fwupload.chan = chan;
|
||||||
fwupload.length = MIN(m.len-4, 92);
|
fwupload.need_ack = false;
|
||||||
fwupload.acked = 0;
|
fwupload.offset = ofs;
|
||||||
fwupload.sequence++;
|
fwupload.length = MIN(m.len-4, 92);
|
||||||
if (m.type == 43) {
|
fwupload.acked = 0;
|
||||||
// sending a tune to play - for development testing
|
fwupload.sequence++;
|
||||||
fwupload.fw_type = TELEM_PLAY;
|
if (m.type == 43) {
|
||||||
fwupload.length = MIN(m.len, 90);
|
// sending a tune to play - for development testing
|
||||||
fwupload.offset = 0;
|
fwupload.fw_type = TELEM_PLAY;
|
||||||
memcpy(&fwupload.pending_data[0], &m.data[0], fwupload.length);
|
fwupload.length = MIN(m.len, 90);
|
||||||
} else {
|
fwupload.offset = 0;
|
||||||
// sending a chunk of firmware OTA upload
|
memcpy(&fwupload.pending_data[0], &m.data[0], fwupload.length);
|
||||||
fwupload.fw_type = TELEM_FW;
|
} else {
|
||||||
memcpy(&fwupload.pending_data[0], &m.data[4], fwupload.length);
|
// sending a chunk of firmware OTA upload
|
||||||
}
|
fwupload.fw_type = TELEM_FW;
|
||||||
sem->give();
|
memcpy(&fwupload.pending_data[0], &m.data[4], fwupload.length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -462,14 +460,14 @@ bool AP_Radio_cc2500::handle_SRT_packet(const uint8_t *packet)
|
|||||||
// got an fw upload ack
|
// got an fw upload ack
|
||||||
Debug(4, "ack %u seq=%u acked=%u length=%u len=%u\n",
|
Debug(4, "ack %u seq=%u acked=%u length=%u len=%u\n",
|
||||||
data, fwupload.sequence, unsigned(fwupload.acked), unsigned(fwupload.length), fwupload.len);
|
data, fwupload.sequence, unsigned(fwupload.acked), unsigned(fwupload.length), fwupload.len);
|
||||||
if (fwupload.sequence == data && sem->take_nonblocking()) {
|
if (fwupload.sequence == data && sem.take_nonblocking()) {
|
||||||
fwupload.sequence++;
|
fwupload.sequence++;
|
||||||
fwupload.acked += fwupload.len;
|
fwupload.acked += fwupload.len;
|
||||||
if (fwupload.acked == fwupload.length) {
|
if (fwupload.acked == fwupload.length) {
|
||||||
// trigger send of DATA16 ack to client
|
// trigger send of DATA16 ack to client
|
||||||
fwupload.need_ack = true;
|
fwupload.need_ack = true;
|
||||||
}
|
}
|
||||||
sem->give();
|
sem.give();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1030,7 +1028,7 @@ void AP_Radio_cc2500::send_SRT_telemetry(void)
|
|||||||
if (fwupload.length != 0 &&
|
if (fwupload.length != 0 &&
|
||||||
fwupload.length > fwupload.acked &&
|
fwupload.length > fwupload.acked &&
|
||||||
((fwupload.counter++ & 0x07) != 0) &&
|
((fwupload.counter++ & 0x07) != 0) &&
|
||||||
sem->take_nonblocking()) {
|
sem.take_nonblocking()) {
|
||||||
pkt.type = fwupload.fw_type;
|
pkt.type = fwupload.fw_type;
|
||||||
pkt.payload.fw.seq = fwupload.sequence;
|
pkt.payload.fw.seq = fwupload.sequence;
|
||||||
uint32_t len = fwupload.length>fwupload.acked?fwupload.length - fwupload.acked:0;
|
uint32_t len = fwupload.length>fwupload.acked?fwupload.length - fwupload.acked:0;
|
||||||
@ -1043,7 +1041,7 @@ void AP_Radio_cc2500::send_SRT_telemetry(void)
|
|||||||
pkt.payload.fw.offset,
|
pkt.payload.fw.offset,
|
||||||
pkt.payload.fw.len,
|
pkt.payload.fw.len,
|
||||||
pkt.type);
|
pkt.type);
|
||||||
sem->give();
|
sem.give();
|
||||||
} else {
|
} else {
|
||||||
pkt.type = TELEM_STATUS;
|
pkt.type = TELEM_STATUS;
|
||||||
pkt.payload.status = t_status;
|
pkt.payload.status = t_status;
|
||||||
@ -1070,7 +1068,7 @@ void AP_Radio_cc2500::send_SRT_telemetry(void)
|
|||||||
*/
|
*/
|
||||||
void AP_Radio_cc2500::check_fw_ack(void)
|
void AP_Radio_cc2500::check_fw_ack(void)
|
||||||
{
|
{
|
||||||
if (fwupload.need_ack && sem->take_nonblocking()) {
|
if (fwupload.need_ack && sem.take_nonblocking()) {
|
||||||
// ack the send of a DATA96 fw packet to TX
|
// ack the send of a DATA96 fw packet to TX
|
||||||
fwupload.need_ack = false;
|
fwupload.need_ack = false;
|
||||||
uint8_t data16[16] {};
|
uint8_t data16[16] {};
|
||||||
@ -1078,7 +1076,7 @@ void AP_Radio_cc2500::check_fw_ack(void)
|
|||||||
memcpy(&data16[0], &ack_to, 4);
|
memcpy(&data16[0], &ack_to, 4);
|
||||||
mavlink_msg_data16_send(fwupload.chan, 42, 4, data16);
|
mavlink_msg_data16_send(fwupload.chan, 42, 4, data16);
|
||||||
Debug(4,"sent ack DATA16\n");
|
Debug(4,"sent ack DATA16\n");
|
||||||
sem->give();
|
sem.give();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ private:
|
|||||||
void radio_init(void);
|
void radio_init(void);
|
||||||
|
|
||||||
// semaphore between ISR and main thread
|
// semaphore between ISR and main thread
|
||||||
AP_HAL::Semaphore *sem;
|
HAL_Semaphore sem;
|
||||||
|
|
||||||
AP_Radio::stats stats;
|
AP_Radio::stats stats;
|
||||||
AP_Radio::stats last_stats;
|
AP_Radio::stats last_stats;
|
||||||
|
@ -277,8 +277,6 @@ bool AP_Radio_cypress::init(void)
|
|||||||
#endif
|
#endif
|
||||||
load_bind_info();
|
load_bind_info();
|
||||||
|
|
||||||
sem = hal.util->new_semaphore();
|
|
||||||
|
|
||||||
return reset();
|
return reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -418,7 +416,7 @@ uint8_t AP_Radio_cypress::num_channels(void)
|
|||||||
void AP_Radio_cypress::check_fw_ack(void)
|
void AP_Radio_cypress::check_fw_ack(void)
|
||||||
{
|
{
|
||||||
Debug(4,"check need_ack\n");
|
Debug(4,"check need_ack\n");
|
||||||
if (fwupload.need_ack && sem->take_nonblocking()) {
|
if (fwupload.need_ack && sem.take_nonblocking()) {
|
||||||
// ack the send of a DATA96 fw packet to TX
|
// ack the send of a DATA96 fw packet to TX
|
||||||
fwupload.need_ack = false;
|
fwupload.need_ack = false;
|
||||||
uint8_t data16[16] {};
|
uint8_t data16[16] {};
|
||||||
@ -426,7 +424,7 @@ void AP_Radio_cypress::check_fw_ack(void)
|
|||||||
memcpy(&data16[0], &ack_to, 4);
|
memcpy(&data16[0], &ack_to, 4);
|
||||||
mavlink_msg_data16_send(fwupload.chan, 42, 4, data16);
|
mavlink_msg_data16_send(fwupload.chan, 42, 4, data16);
|
||||||
Debug(4,"sent ack DATA16\n");
|
Debug(4,"sent ack DATA16\n");
|
||||||
sem->give();
|
sem.give();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -808,14 +806,14 @@ bool AP_Radio_cypress::parse_dsm_channels(const uint8_t *data)
|
|||||||
// got an ack from key 0
|
// got an ack from key 0
|
||||||
Debug(4, "ack %u seq=%u acked=%u length=%u len=%u\n",
|
Debug(4, "ack %u seq=%u acked=%u length=%u len=%u\n",
|
||||||
v, fwupload.sequence, unsigned(fwupload.acked), unsigned(fwupload.length), fwupload.len);
|
v, fwupload.sequence, unsigned(fwupload.acked), unsigned(fwupload.length), fwupload.len);
|
||||||
if (fwupload.sequence == v && sem->take_nonblocking()) {
|
if (fwupload.sequence == v && sem.take_nonblocking()) {
|
||||||
fwupload.sequence++;
|
fwupload.sequence++;
|
||||||
fwupload.acked += fwupload.len;
|
fwupload.acked += fwupload.len;
|
||||||
if (fwupload.acked == fwupload.length) {
|
if (fwupload.acked == fwupload.length) {
|
||||||
// trigger send of DATA16 ack to client
|
// trigger send of DATA16 ack to client
|
||||||
fwupload.need_ack = true;
|
fwupload.need_ack = true;
|
||||||
}
|
}
|
||||||
sem->give();
|
sem.give();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (chan == 7) {
|
if (chan == 7) {
|
||||||
@ -1596,7 +1594,7 @@ void AP_Radio_cypress::send_telem_packet(void)
|
|||||||
if (fwupload.length != 0 &&
|
if (fwupload.length != 0 &&
|
||||||
fwupload.length > fwupload.acked &&
|
fwupload.length > fwupload.acked &&
|
||||||
((fwupload.counter++ & 0x07) != 0) &&
|
((fwupload.counter++ & 0x07) != 0) &&
|
||||||
sem->take_nonblocking()) {
|
sem.take_nonblocking()) {
|
||||||
pkt.type = fwupload.fw_type;
|
pkt.type = fwupload.fw_type;
|
||||||
pkt.payload.fw.seq = fwupload.sequence;
|
pkt.payload.fw.seq = fwupload.sequence;
|
||||||
uint32_t len = fwupload.length>fwupload.acked?fwupload.length - fwupload.acked:0;
|
uint32_t len = fwupload.length>fwupload.acked?fwupload.length - fwupload.acked:0;
|
||||||
@ -1609,7 +1607,7 @@ void AP_Radio_cypress::send_telem_packet(void)
|
|||||||
pkt.payload.fw.offset,
|
pkt.payload.fw.offset,
|
||||||
pkt.payload.fw.len,
|
pkt.payload.fw.len,
|
||||||
pkt.type);
|
pkt.type);
|
||||||
sem->give();
|
sem.give();
|
||||||
pkt.crc = crc_crc8((const uint8_t *)&pkt.type, 15);
|
pkt.crc = crc_crc8((const uint8_t *)&pkt.type, 15);
|
||||||
} else {
|
} else {
|
||||||
pkt.type = TELEM_STATUS;
|
pkt.type = TELEM_STATUS;
|
||||||
@ -1702,7 +1700,7 @@ void AP_Radio_cypress::handle_data_packet(mavlink_channel_t chan, const mavlink_
|
|||||||
uint32_t ofs=0;
|
uint32_t ofs=0;
|
||||||
memcpy(&ofs, &m.data[0], 4);
|
memcpy(&ofs, &m.data[0], 4);
|
||||||
Debug(4, "got data96 of len %u from chan %u at offset %u\n", m.len, chan, unsigned(ofs));
|
Debug(4, "got data96 of len %u from chan %u at offset %u\n", m.len, chan, unsigned(ofs));
|
||||||
if (sem->take_nonblocking()) {
|
if (sem.take_nonblocking()) {
|
||||||
fwupload.chan = chan;
|
fwupload.chan = chan;
|
||||||
fwupload.need_ack = false;
|
fwupload.need_ack = false;
|
||||||
fwupload.offset = ofs;
|
fwupload.offset = ofs;
|
||||||
@ -1720,7 +1718,7 @@ void AP_Radio_cypress::handle_data_packet(mavlink_channel_t chan, const mavlink_
|
|||||||
fwupload.fw_type = TELEM_FW;
|
fwupload.fw_type = TELEM_FW;
|
||||||
memcpy(&fwupload.pending_data[0], &m.data[4], fwupload.length);
|
memcpy(&fwupload.pending_data[0], &m.data[4], fwupload.length);
|
||||||
}
|
}
|
||||||
sem->give();
|
sem.give();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -169,7 +169,7 @@ private:
|
|||||||
};
|
};
|
||||||
|
|
||||||
// semaphore between ISR and main thread
|
// semaphore between ISR and main thread
|
||||||
AP_HAL::Semaphore *sem;
|
HAL_Semaphore sem;
|
||||||
|
|
||||||
// dsm config data and status
|
// dsm config data and status
|
||||||
struct {
|
struct {
|
||||||
|
Loading…
Reference in New Issue
Block a user