X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Fkernel%2Fao_ignite.c;h=e4e4843e1cb8383ba1597699988fc0c67a57bf6f;hb=e48b6689527f51cc589ccd0ee88e2c7bc05747e0;hp=e9d04dcce4ba848641e73d9fbfa06f5bac3d04e5;hpb=c11427819ca24bb77523496309b5b6f699d126c5;p=fw%2Faltos diff --git a/src/kernel/ao_ignite.c b/src/kernel/ao_ignite.c index e9d04dcc..e4e4843e 100644 --- a/src/kernel/ao_ignite.c +++ b/src/kernel/ao_ignite.c @@ -25,15 +25,6 @@ #if HAS_IGNITE struct ao_ignition ao_ignition[2]; -void -ao_ignite(enum ao_igniter igniter) -{ - ao_arch_block_interrupts(); - ao_ignition[igniter].request = 1; - ao_wakeup(&ao_ignition); - ao_arch_release_interrupts(); -} - #ifndef AO_SENSE_DROGUE #define AO_SENSE_DROGUE(p) ((p)->adc.sense_d) #define AO_SENSE_MAIN(p) ((p)->adc.sense_m) @@ -86,73 +77,62 @@ ao_igniter_status(enum ao_igniter igniter) static void ao_igniter_fire(enum ao_igniter igniter) { - ao_ignition[igniter].firing = 1; - switch(ao_config.ignite_mode) { - case AO_IGNITE_MODE_DUAL: - switch (igniter) { - case ao_igniter_drogue: - AO_IGNITER_SET_DROGUE(1); - ao_delay(AO_IGNITER_FIRE_TIME); - AO_IGNITER_SET_DROGUE(0); - break; - case ao_igniter_main: - AO_IGNITER_SET_MAIN(1); - ao_delay(AO_IGNITER_FIRE_TIME); - AO_IGNITER_SET_MAIN(0); - break; - } - break; - case AO_IGNITE_MODE_APOGEE: + if (!ao_ignition[igniter].fired) { + ao_ignition[igniter].firing = 1; + ao_ignition[igniter].fired = 1; switch (igniter) { case ao_igniter_drogue: AO_IGNITER_SET_DROGUE(1); ao_delay(AO_IGNITER_FIRE_TIME); AO_IGNITER_SET_DROGUE(0); - ao_delay(AO_IGNITER_CHARGE_TIME); - AO_IGNITER_SET_MAIN(1); - ao_delay(AO_IGNITER_FIRE_TIME); - AO_IGNITER_SET_MAIN(0); - break; - default: break; - } - break; - case AO_IGNITE_MODE_MAIN: - switch (igniter) { case ao_igniter_main: - AO_IGNITER_SET_DROGUE(1); - ao_delay(AO_IGNITER_FIRE_TIME); - AO_IGNITER_SET_DROGUE(0); - ao_delay(AO_IGNITER_CHARGE_TIME); AO_IGNITER_SET_MAIN(1); ao_delay(AO_IGNITER_FIRE_TIME); AO_IGNITER_SET_MAIN(0); break; - default: - break; } - break; + ao_ignition[igniter].firing = 0; + ao_delay(AO_IGNITER_CHARGE_TIME); } - ao_ignition[igniter].firing = 0; } static void ao_igniter(void) { - enum ao_igniter igniter; - ao_config_get(); for (;;) { - ao_sleep(&ao_ignition); - for (igniter = ao_igniter_drogue; igniter <= ao_igniter_main; igniter++) { - if (ao_ignition[igniter].request && !ao_ignition[igniter].fired) { - if (igniter == ao_igniter_drogue && ao_config.apogee_delay) - ao_delay(AO_SEC_TO_TICKS(ao_config.apogee_delay)); - - ao_igniter_fire(igniter); - ao_delay(AO_IGNITER_CHARGE_TIME); - ao_ignition[igniter].fired = 1; + /* Wait for flight state change */ + ao_sleep(&ao_flight_state); + + /* Fire any igniters that are supposed to be triggered + * in this new state + */ + switch(ao_config.ignite_mode) { + case AO_IGNITE_MODE_DUAL: + if (ao_flight_drogue <= ao_flight_state && ao_flight_state < ao_flight_landed) + ao_igniter_fire(ao_igniter_drogue); + if (ao_flight_main <= ao_flight_state && ao_flight_state < ao_flight_landed) + ao_igniter_fire(ao_igniter_main); + break; + case AO_IGNITE_MODE_APOGEE: + if (ao_flight_drogue <= ao_flight_state && ao_flight_state < ao_flight_landed) { + ao_igniter_fire(ao_igniter_drogue); + ao_igniter_fire(ao_igniter_main); } + break; + case AO_IGNITE_MODE_MAIN: + if (ao_flight_main <= ao_flight_state && ao_flight_state < ao_flight_landed) { + ao_igniter_fire(ao_igniter_drogue); + ao_igniter_fire(ao_igniter_main); + } + break; + case AO_IGNITE_MODE_BOOSTER: + if (ao_flight_fast <= ao_flight_state && ao_flight_state < ao_flight_landed) + ao_igniter_fire(ao_igniter_main); + if (ao_flight_drogue <= ao_flight_state && ao_flight_state < ao_flight_landed) + ao_igniter_fire(ao_igniter_drogue); + break; } } } @@ -168,10 +148,12 @@ ao_ignite_manual(void) ao_cmd_white(); #if HAS_IGNITE if (ao_cmd_lex_c == 'm' && ao_match_word("main")) { + ao_ignition[ao_igniter_main].fired = 0; ao_igniter_fire(ao_igniter_main); return; } if (ao_cmd_lex_c == 'd' && ao_match_word("drogue")) { + ao_ignition[ao_igniter_drogue].fired = 0; ao_igniter_fire(ao_igniter_drogue); return; } @@ -236,5 +218,7 @@ ao_igniter_init(void) ao_ignite_set_pins(); ao_add_task(&ao_igniter_task, ao_igniter, "igniter"); #endif +#if HAS_IGNITE || AO_PYRO_NUM ao_cmd_register(&ao_ignite_cmds[0]); +#endif }