#define SPI_CS_ON_P1 1
#define SPI_CS_ON_P0 0
#define HAS_IGNITE 0
+ #define HAS_IGNITE_REPORT 1
#define BT_LINK_ON_P2 1
#define BT_LINK_ON_P1 0
#define BT_LINK_PIN_INDEX 7
#define M25_MAX_CHIPS 1
#define HAS_ACCEL 0
#define HAS_IGNITE 0
+ #define HAS_IGNITE_REPORT 1
#define BT_LINK_ON_P2 0
#define BT_LINK_ON_P1 1
#define BT_LINK_PIN_INDEX 7
#error Please define HAS_IGNITE
#endif
+#if HAS_IGNITE
+#define HAS_IGNITE_REPORT 1
+#endif
+
#ifndef PACKET_HAS_MASTER
#error Please define PACKET_HAS_MASTER
#endif
static __data uint8_t ao_log_monitor_pos;
__pdata enum ao_flight_state ao_flight_state;
__pdata int16_t ao_max_height; /* max of ao_height */
+__pdata int16_t sense_d, sense_m;
static void
ao_log_telem_track() {
switch (ao_log_single_write_data.telemetry.generic.type) {
case AO_TELEMETRY_SENSOR_TELEMETRUM:
case AO_TELEMETRY_SENSOR_TELEMINI:
+ sense_d = ao_log_single_write_data.telemetry.sensor.sense_d;
+ sense_m = ao_log_single_write_data.telemetry.sensor.sense_m;
+ /* fall through ... */
case AO_TELEMETRY_SENSOR_TELENANO:
if (ao_log_single_write_data.telemetry.sensor.height > ao_max_height) {
ao_max_height = ao_log_single_write_data.telemetry.sensor.height;
}
}
}
+
+enum ao_igniter_status
+ao_igniter_status(enum ao_igniter igniter)
+{
+ int16_t value;
+
+ switch (igniter) {
+ case ao_igniter_drogue:
+ value = sense_d;
+ break;
+ case ao_igniter_main:
+ value = sense_m;
+ break;
+ default:
+ value = 0;
+ break;
+ }
+ if (value < AO_IGNITER_OPEN)
+ return ao_igniter_open;
+ else if (value > AO_IGNITER_CLOSED)
+ return ao_igniter_ready;
+ else
+ return ao_igniter_unknown;
+}
+
void
ao_log_single(void)
{
}
}
-#if HAS_IGNITE
+#if HAS_IGNITE_REPORT
static uint8_t
ao_report_igniter_ready(enum ao_igniter igniter)
{
low(AO_MS_TO_TICKS(20));
}
}
+#if HAS_LOG
if (ao_log_full()) {
pause(AO_MS_TO_TICKS(100));
c = 2;
mid(AO_MS_TO_TICKS(100));
}
}
+#endif
c = 50;
while (c-- && ao_flight_state == ao_flight_pad)
pause(AO_MS_TO_TICKS(100));
if (ao_flight_state == ao_flight_landed)
ao_report_altitude();
ao_report_beep();
-#if HAS_IGNITE
+#if HAS_IGNITE_REPORT
if (ao_flight_state == ao_flight_idle)
ao_report_continuity();
while (ao_flight_state == ao_flight_pad)