mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-18 03:52:11 +01:00
233dec6d8d
- Support blocks of led for notification (that is a certain number of leds between a min and a max index); - Fix an issue with bogus colours on fast updates at LED N°0. - Add NOTIFY_SEQUENCE_NULL to skip handling a specific alarm status; - Adjust sequences and add Config and Receiver Alarms; - fix issue with Alarm trigger/repetition; - Enables Notify module only if a WS281x output is enabled. - Add some documentation for sequence/alarm definitions (sequences.h) - Make sequences more coherent. All GPS related info are now shown in green. - Revert to original blinking rate for onboard led - add Notify on DiscoveryF4Bare target
223 lines
14 KiB
C
223 lines
14 KiB
C
/**
|
|
******************************************************************************
|
|
*
|
|
* @file sequences.h
|
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
* @brief Notify module, sequences configuration.
|
|
*
|
|
* @see The GNU Public License (GPL) Version 3
|
|
*
|
|
*****************************************************************************/
|
|
/*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
#ifndef SEQUENCES_H_
|
|
#define SEQUENCES_H_
|
|
#include <optypes.h>
|
|
#include <pios_notify.h>
|
|
#include <flightstatus.h>
|
|
#include <systemalarms.h>
|
|
#include <pios_helpers.h>
|
|
|
|
// This represent the list of basic light sequences, defined later
|
|
typedef enum {
|
|
NOTIFY_SEQUENCE_ARMED_FM_MANUAL = 0,
|
|
NOTIFY_SEQUENCE_ARMED_FM_STABILIZED1 = 1,
|
|
NOTIFY_SEQUENCE_ARMED_FM_STABILIZED2 = 2,
|
|
NOTIFY_SEQUENCE_ARMED_FM_STABILIZED3 = 3,
|
|
NOTIFY_SEQUENCE_ARMED_FM_STABILIZED4 = 4,
|
|
NOTIFY_SEQUENCE_ARMED_FM_STABILIZED5 = 5,
|
|
NOTIFY_SEQUENCE_ARMED_FM_STABILIZED6 = 6,
|
|
NOTIFY_SEQUENCE_ARMED_FM_AUTOTUNE = 7,
|
|
NOTIFY_SEQUENCE_ARMED_FM_GPS = 8,
|
|
NOTIFY_SEQUENCE_ARMED_FM_RTH = 9,
|
|
NOTIFY_SEQUENCE_ARMED_FM_LAND = 10,
|
|
NOTIFY_SEQUENCE_ARMED_FM_AUTO = 11,
|
|
NOTIFY_SEQUENCE_ALM_WARN_GPS = 12,
|
|
NOTIFY_SEQUENCE_ALM_ERROR_GPS = 13,
|
|
NOTIFY_SEQUENCE_ALM_WARN_BATTERY = 14,
|
|
NOTIFY_SEQUENCE_ALM_ERROR_BATTERY = 15,
|
|
NOTIFY_SEQUENCE_ALM_MAG = 16,
|
|
NOTIFY_SEQUENCE_ALM_CONFIG = 17,
|
|
NOTIFY_SEQUENCE_ALM_RECEIVER = 18,
|
|
NOTIFY_SEQUENCE_DISARMED = 19,
|
|
NOTIFY_SEQUENCE_NULL = 255, // skips any signalling for this condition
|
|
} NotifySequences;
|
|
|
|
// This structure determine sequences attached to an alarm
|
|
typedef struct {
|
|
uint32_t timeBetweenNotifications; // time in milliseconds to wait between each notification iteration
|
|
uint8_t alarmIndex; // Index of the alarm, use one of the SYSTEMALARMS_ALARM_XXXXX defines
|
|
uint8_t warnNotification; // index of the sequence to be used when alarm is in warning status(pick one from NotifySequences enum)
|
|
uint8_t errorNotification; // index of the sequence to be used when alarm is in error status(pick one from NotifySequences enum)
|
|
} AlarmDefinition_t;
|
|
|
|
|
|
// This is the list of defined light sequences
|
|
/* how each sequence is defined
|
|
* [NOTIFY_SEQUENCE_DISARMED] = { // Sequence ID
|
|
.repeats = -1, // Number of repetitions or -1 for infinite
|
|
.steps = { // List of steps (until NOTIFY_SEQUENCE_MAX_STEPS steps, default to 5)
|
|
{
|
|
.time_off = 500, // Off time for the step
|
|
.time_on = 500, // On time for the step
|
|
.color = COLOR_TEAL, // color
|
|
.repeats = 1, // repetitions for this step
|
|
},
|
|
},
|
|
},
|
|
*
|
|
* There are two kind of sequences:
|
|
* - "Background" sequences, executed if no higher priority sequence is played;
|
|
* - "Alarm" sequences, that are "modal", they temporarily suspends background sequences and plays.
|
|
* Cannot have "-1" repetitions
|
|
* At the end background sequence are resumed;
|
|
*
|
|
*/
|
|
const LedSequence_t notifications[] = {
|
|
[NOTIFY_SEQUENCE_DISARMED] = { .repeats = -1, .steps = {
|
|
{ .time_off = 500, .time_on = 500, .color = COLOR_TEAL, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_MANUAL] = { .repeats = -1, .steps = {
|
|
{ .time_off = 900, .time_on = 100, .color = COLOR_YELLOW, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED1] = { .repeats = -1, .steps = {
|
|
{ .time_off = 900, .time_on = 100, .color = COLOR_BLUE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED2] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_BLUE, .repeats = 1, },
|
|
{ .time_off = 700, .time_on = 100, .color = COLOR_BLUE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED3] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_BLUE, .repeats = 2, },
|
|
{ .time_off = 500, .time_on = 100, .color = COLOR_BLUE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED4] = { .repeats = -1, .steps = {
|
|
{ .time_off = 900, .time_on = 100, .color = COLOR_PURPLE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED5] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_PURPLE, .repeats = 1, },
|
|
{ .time_off = 700, .time_on = 100, .color = COLOR_BLUE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED6] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_PURPLE, .repeats = 1, },
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_PURPLE, .repeats = 1, },
|
|
{ .time_off = 500, .time_on = 100, .color = COLOR_BLUE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_AUTOTUNE] = { .repeats = -1, .steps = {
|
|
{ .time_off = 800, .time_on = 200, .color = COLOR_BLUE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_GPS] = { .repeats = -1, .steps = {
|
|
{ .time_off = 800, .time_on = 200, .color = COLOR_GREEN, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_RTH] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_GREEN, .repeats = 1, },
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_YELLOW, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_LAND] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_GREEN, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ARMED_FM_AUTO] = { .repeats = -1, .steps = {
|
|
{ .time_off = 100, .time_on = 200, .color = COLOR_GREEN, .repeats = 2, },
|
|
{ .time_off = 500, .time_on = 200, .color = COLOR_GREEN, .repeats = 1, },
|
|
}, },
|
|
|
|
[NOTIFY_SEQUENCE_ALM_WARN_GPS] = { .repeats = 2, .steps = {
|
|
{ .time_off = 300, .time_on = 300, .color = COLOR_ORANGE, .repeats = 2, },
|
|
{ .time_off = 300, .time_on = 300, .color = COLOR_GREEN, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ALM_ERROR_GPS] = { .repeats = 2, .steps = {
|
|
{ .time_off = 300, .time_on = 300, .color = COLOR_RED, .repeats = 2, },
|
|
{ .time_off = 300, .time_on = 300, .color = COLOR_GREEN, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ALM_WARN_BATTERY] = { .repeats = 1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_ORANGE, .repeats = 10, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ALM_ERROR_BATTERY] = { .repeats = 1, .steps = {
|
|
{ .time_off = 100, .time_on = 100, .color = COLOR_RED, .repeats = 10, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ALM_MAG] = { .repeats = 1, .steps = {
|
|
{ .time_off = 300, .time_on = 300, .color = COLOR_RED, .repeats = 2, },
|
|
{ .time_off = 300, .time_on = 300, .color = COLOR_PURPLE, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ALM_CONFIG] = { .repeats = 1, .steps = {
|
|
{ .time_off = 50, .time_on = 50, .color = COLOR_RED, .repeats = 9, },
|
|
{ .time_off = 500, .time_on = 50, .color = COLOR_RED, .repeats = 1, },
|
|
}, },
|
|
[NOTIFY_SEQUENCE_ALM_RECEIVER] = { .repeats = 1, .steps = {
|
|
{ .time_off = 50, .time_on = 50, .color = COLOR_ORANGE, .repeats = 9, },
|
|
{ .time_off = 500, .time_on = 50, .color = COLOR_ORANGE, .repeats = 1, },
|
|
}, },
|
|
};
|
|
|
|
// List of background sequences attached to each flight mode
|
|
const LedSequence_t *flightModeMap[] = {
|
|
[FLIGHTSTATUS_FLIGHTMODE_MANUAL] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_MANUAL],
|
|
[FLIGHTSTATUS_FLIGHTMODE_STABILIZED1] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED1],
|
|
[FLIGHTSTATUS_FLIGHTMODE_STABILIZED2] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED2],
|
|
[FLIGHTSTATUS_FLIGHTMODE_STABILIZED3] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED3],
|
|
[FLIGHTSTATUS_FLIGHTMODE_STABILIZED4] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED4],
|
|
[FLIGHTSTATUS_FLIGHTMODE_STABILIZED5] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED5],
|
|
[FLIGHTSTATUS_FLIGHTMODE_STABILIZED6] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_STABILIZED6],
|
|
[FLIGHTSTATUS_FLIGHTMODE_PATHPLANNER] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_AUTO],
|
|
[FLIGHTSTATUS_FLIGHTMODE_AUTOTUNE] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_AUTOTUNE],
|
|
[FLIGHTSTATUS_FLIGHTMODE_POSITIONHOLD] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_GPS],
|
|
[FLIGHTSTATUS_FLIGHTMODE_POSITIONVARIOFPV] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_GPS],
|
|
[FLIGHTSTATUS_FLIGHTMODE_POSITIONVARIOLOS] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_GPS],
|
|
[FLIGHTSTATUS_FLIGHTMODE_POSITIONVARIONSEW] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_GPS],
|
|
[FLIGHTSTATUS_FLIGHTMODE_RETURNTOBASE] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_RTH],
|
|
[FLIGHTSTATUS_FLIGHTMODE_LAND] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_LAND],
|
|
[FLIGHTSTATUS_FLIGHTMODE_POI] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_GPS],
|
|
[FLIGHTSTATUS_FLIGHTMODE_AUTOCRUISE] = ¬ifications[NOTIFY_SEQUENCE_ARMED_FM_GPS],
|
|
};
|
|
|
|
// List of alarms to show with attached sequences for each status
|
|
const AlarmDefinition_t alarmsMap[] = {
|
|
{
|
|
.timeBetweenNotifications = 10000,
|
|
.alarmIndex = SYSTEMALARMS_ALARM_GPS,
|
|
.warnNotification = NOTIFY_SEQUENCE_ALM_WARN_GPS,
|
|
.errorNotification = NOTIFY_SEQUENCE_ALM_ERROR_GPS,
|
|
},
|
|
{
|
|
.timeBetweenNotifications = 15000,
|
|
.alarmIndex = SYSTEMALARMS_ALARM_MAGNETOMETER,
|
|
.warnNotification = NOTIFY_SEQUENCE_NULL,
|
|
.errorNotification = NOTIFY_SEQUENCE_ALM_MAG,
|
|
},
|
|
{
|
|
.timeBetweenNotifications = 15000,
|
|
.alarmIndex = SYSTEMALARMS_ALARM_BATTERY,
|
|
.warnNotification = NOTIFY_SEQUENCE_ALM_WARN_BATTERY,
|
|
.errorNotification = NOTIFY_SEQUENCE_ALM_ERROR_BATTERY,
|
|
},
|
|
{
|
|
.timeBetweenNotifications = 5000,
|
|
.alarmIndex = SYSTEMALARMS_ALARM_SYSTEMCONFIGURATION,
|
|
.warnNotification = NOTIFY_SEQUENCE_NULL,
|
|
.errorNotification = NOTIFY_SEQUENCE_ALM_CONFIG,
|
|
},
|
|
{
|
|
.timeBetweenNotifications = 5000,
|
|
.alarmIndex = SYSTEMALARMS_ALARM_RECEIVER,
|
|
.warnNotification = NOTIFY_SEQUENCE_ALM_RECEIVER,
|
|
.errorNotification = NOTIFY_SEQUENCE_ALM_RECEIVER,
|
|
},
|
|
};
|
|
|
|
const uint8_t alarmsMapSize = NELEMENTS(alarmsMap);
|
|
|
|
#endif /* SEQUENCES_H_ */
|