mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 14:48:28 -04:00
AP_IOMCU: added retries on event failure
This commit is contained in:
parent
9b9b4a169e
commit
1568f578d7
@ -123,6 +123,16 @@ void AP_IOMCU::thread_start(void *ctx)
|
|||||||
((AP_IOMCU *)ctx)->thread_main();
|
((AP_IOMCU *)ctx)->thread_main();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
handle event failure
|
||||||
|
*/
|
||||||
|
void AP_IOMCU::event_failed(uint8_t event)
|
||||||
|
{
|
||||||
|
// wait 0.5ms then retry
|
||||||
|
hal.scheduler->delay_microseconds(500);
|
||||||
|
trigger_event(event);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
main IO thread loop
|
main IO thread loop
|
||||||
*/
|
*/
|
||||||
@ -132,11 +142,7 @@ void AP_IOMCU::thread_main(void)
|
|||||||
uart.begin(1500*1000, 256, 256);
|
uart.begin(1500*1000, 256, 256);
|
||||||
uart.set_blocking_writes(false);
|
uart.set_blocking_writes(false);
|
||||||
|
|
||||||
// set IO_ARM_OK and FMU_ARMED
|
trigger_event(IOEVENT_INIT);
|
||||||
modify_register(PAGE_SETUP, PAGE_REG_SETUP_ARMING, 0,
|
|
||||||
P_SETUP_ARMING_IO_ARM_OK |
|
|
||||||
P_SETUP_ARMING_FMU_ARMED |
|
|
||||||
P_SETUP_ARMING_RC_HANDLING_DISABLED);
|
|
||||||
|
|
||||||
// enable sbus (until we have BRD_SBUS_OUT available in ChibiOS)
|
// enable sbus (until we have BRD_SBUS_OUT available in ChibiOS)
|
||||||
enable_sbus_out(150);
|
enable_sbus_out(150);
|
||||||
@ -149,24 +155,48 @@ void AP_IOMCU::thread_main(void)
|
|||||||
send_servo_out();
|
send_servo_out();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mask & EVENT_MASK(IOEVENT_INIT)) {
|
||||||
|
// set IO_ARM_OK and FMU_ARMED
|
||||||
|
if (!modify_register(PAGE_SETUP, PAGE_REG_SETUP_ARMING, 0,
|
||||||
|
P_SETUP_ARMING_IO_ARM_OK |
|
||||||
|
P_SETUP_ARMING_FMU_ARMED |
|
||||||
|
P_SETUP_ARMING_RC_HANDLING_DISABLED)) {
|
||||||
|
event_failed(IOEVENT_INIT);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (mask & EVENT_MASK(IOEVENT_FORCE_SAFETY_OFF)) {
|
if (mask & EVENT_MASK(IOEVENT_FORCE_SAFETY_OFF)) {
|
||||||
write_register(PAGE_SETUP, PAGE_REG_SETUP_FORCE_SAFETY_OFF, FORCE_SAFETY_MAGIC);
|
if (!write_register(PAGE_SETUP, PAGE_REG_SETUP_FORCE_SAFETY_OFF, FORCE_SAFETY_MAGIC)) {
|
||||||
|
event_failed(IOEVENT_FORCE_SAFETY_OFF);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mask & EVENT_MASK(IOEVENT_FORCE_SAFETY_ON)) {
|
if (mask & EVENT_MASK(IOEVENT_FORCE_SAFETY_ON)) {
|
||||||
write_register(PAGE_SETUP, PAGE_REG_SETUP_FORCE_SAFETY_ON, FORCE_SAFETY_MAGIC);
|
if (!write_register(PAGE_SETUP, PAGE_REG_SETUP_FORCE_SAFETY_ON, FORCE_SAFETY_MAGIC)) {
|
||||||
|
event_failed(IOEVENT_FORCE_SAFETY_ON);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (mask & EVENT_MASK(IOEVENT_SET_RATES)) {
|
if (mask & EVENT_MASK(IOEVENT_SET_RATES)) {
|
||||||
write_register(PAGE_SETUP, PAGE_REG_SETUP_ALTRATE, rate.freq);
|
if (!write_register(PAGE_SETUP, PAGE_REG_SETUP_ALTRATE, rate.freq) ||
|
||||||
write_register(PAGE_SETUP, PAGE_REG_SETUP_PWM_RATE_MASK, rate.chmask);
|
!write_register(PAGE_SETUP, PAGE_REG_SETUP_PWM_RATE_MASK, rate.chmask)) {
|
||||||
|
event_failed(IOEVENT_SET_RATES);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mask & EVENT_MASK(IOEVENT_ENABLE_SBUS)) {
|
if (mask & EVENT_MASK(IOEVENT_ENABLE_SBUS)) {
|
||||||
write_register(PAGE_SETUP, PAGE_REG_SETUP_SBUS_RATE, rate.sbus_rate_hz);
|
if (!write_register(PAGE_SETUP, PAGE_REG_SETUP_SBUS_RATE, rate.sbus_rate_hz) ||
|
||||||
modify_register(PAGE_SETUP, PAGE_REG_SETUP_FEATURES, 0,
|
!modify_register(PAGE_SETUP, PAGE_REG_SETUP_FEATURES, 0,
|
||||||
P_SETUP_FEATURES_SBUS1_OUT);
|
P_SETUP_FEATURES_SBUS1_OUT)) {
|
||||||
|
event_failed(IOEVENT_ENABLE_SBUS);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for regular timed events
|
// check for regular timed events
|
||||||
|
@ -102,6 +102,7 @@ private:
|
|||||||
void read_status(void);
|
void read_status(void);
|
||||||
void print_debug(void);
|
void print_debug(void);
|
||||||
void discard_input(void);
|
void discard_input(void);
|
||||||
|
void event_failed(uint8_t event);
|
||||||
|
|
||||||
static const uint8_t max_channels = 16;
|
static const uint8_t max_channels = 16;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user