Skip to content

Commit

Permalink
Merge pull request #97 from sjwilks/px4io_safety_switch
Browse files Browse the repository at this point in the history
Add new safety switch LED blink sequence when both FMU and IO are armed
  • Loading branch information
px4dev committed Dec 8, 2012
2 parents 82cbac7 + 197e573 commit 566012d
Showing 1 changed file with 23 additions and 2 deletions.
25 changes: 23 additions & 2 deletions apps/px4io/safety.c
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,11 @@ static struct hrt_call failsafe_call;
*/
static unsigned counter;

/*
* Used to coordinate a special blink pattern wheb both the FMU and IO are armed.
*/
static unsigned blink_count = 0;

#define ARM_COUNTER_THRESHOLD 10
#define DISARM_COUNTER_THRESHOLD 2

Expand Down Expand Up @@ -120,9 +125,25 @@ safety_check_button(void *arg)
counter = 0;
}

/* when armed, toggle the LED; when safe, leave it on */
/*
* When the IO is armed, toggle the LED; when IO and FMU armed use aircraft like
* pattern (long pause then 2 fast blinks); when safe, leave it on.
*/
if (system_state.armed) {
safety_led_state = !safety_led_state;
if (system_state.arm_ok) {
/* FMU and IO are armed */
if (blink_count > 9) {
safety_led_state = !safety_led_state;
} else {
safety_led_state = false;
}
if (blink_count++ == 12) {
blink_count = 0;
}
} else {
/* Only the IO is armed so use a constant blink rate */
safety_led_state = !safety_led_state;
}
} else {
safety_led_state = true;
}
Expand Down

0 comments on commit 566012d

Please sign in to comment.