From a8edc27849c088d76bafd52659e61885e51fd04b Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Thu, 22 Nov 2012 15:41:10 +1100 Subject: [PATCH] APM_RC: added a test for ISR masking in APM_RC --- .../APM_RC/examples/ISR_Mask/ISR_Mask.pde | 63 +++++++++++++++++++ libraries/APM_RC/examples/ISR_Mask/Makefile | 2 + 2 files changed, 65 insertions(+) create mode 100644 libraries/APM_RC/examples/ISR_Mask/ISR_Mask.pde create mode 100644 libraries/APM_RC/examples/ISR_Mask/Makefile diff --git a/libraries/APM_RC/examples/ISR_Mask/ISR_Mask.pde b/libraries/APM_RC/examples/ISR_Mask/ISR_Mask.pde new file mode 100644 index 0000000000..02bf8a6ee7 --- /dev/null +++ b/libraries/APM_RC/examples/ISR_Mask/ISR_Mask.pde @@ -0,0 +1,63 @@ +/* + test interrupt masking methods on APM1 + */ + +#include +#include +#include +#include +#include + +FastSerialPort0(Serial); + +Arduino_Mega_ISR_Registry isr_registry; +APM_RC_APM1 APM_RC; + +void setup() +{ + Serial.begin(115200); + isr_registry.init(); + APM_RC.Init(&isr_registry); + Serial.println("Interrupt masking test"); + delay(10); +} + +static uint16_t last_values[8]; + +#define USE_CLI 0 +#define USE_MASK 1 + +void loop() +{ + if (APM_RC.GetState() == 1) { + bool changed = false; + for (uint8_t i = 0; i < 8; i++) { + uint16_t v = APM_RC.InputCh(i); + if (abs(v - last_values[i]) > 10) { + changed = true; + } + last_values[i] = v; + } + if (changed) { + for (uint8_t i = 0; i < 8; i++) { + Serial.printf("%u:%4u ", (unsigned)i, (unsigned)last_values[i]); + } + Serial.println(); + delayMicroseconds(500); + } + } + +#if USE_CLI + uint8_t oldSREG = SREG; + cli(); + delayMicroseconds(100); + SREG = oldSREG; +#endif + +#if USE_MASK + uint8_t _timsk4 = TIMSK4; + TIMSK4 &= ~(1<