summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoey Castillo <joeycastillo@utexas.edu>2021-11-30 17:02:42 -0500
committerJoey Castillo <joeycastillo@utexas.edu>2021-11-30 17:02:42 -0500
commit48ceef7af3771ca3b175b217bb26398a3214794a (patch)
treee605855484bb4714a0410b0634ddb3be74d6fe4f
parent473bd1637a9384ce155024e3bd46932ba096918f (diff)
downloadSensor-Watch-48ceef7af3771ca3b175b217bb26398a3214794a.tar.gz
Sensor-Watch-48ceef7af3771ca3b175b217bb26398a3214794a.tar.bz2
Sensor-Watch-48ceef7af3771ca3b175b217bb26398a3214794a.zip
fix (most) external interrupts on the 9-pin connector
-rw-r--r--watch-library/config/hpl_eic_config.h7
-rw-r--r--watch-library/hal/src/hal_ext_irq.c2
-rw-r--r--watch-library/hpl/eic/hpl_eic.c2
-rw-r--r--watch-library/watch/watch_extint.h11
4 files changed, 12 insertions, 10 deletions
diff --git a/watch-library/config/hpl_eic_config.h b/watch-library/config/hpl_eic_config.h
index 53fee6cf..be54c2e1 100644
--- a/watch-library/config/hpl_eic_config.h
+++ b/watch-library/config/hpl_eic_config.h
@@ -723,11 +723,12 @@
// </e>
-// my god this is a hack. need to refactor this out of ASF and into our driver. - joey 10/19
+// this is still a hack: if the user wants to use PA02 (alarm button) as an RTC interrupt pin and PB02 (9-pin A2) on the EIC, we don't support that.
+// TODO item: refactor out our reliance on the ASF external interrupt driver. - joey 11/30
#ifdef CRYSTALLESS
-#define CONFIG_EIC_EXTINT_MAP {2, PIN_PA02}, {5, PIN_PB05}, {7, PIN_PA07},
+#define CONFIG_EIC_EXTINT_MAP {0, PIN_PB00}, {1, PIN_PB01}, {2, PIN_PA02}, {3, PIN_PB03}, {5, PIN_PB05}, {7, PIN_PA07},
#else
-#define CONFIG_EIC_EXTINT_MAP {2, PIN_PA02}, {6, PIN_PA22}, {7, PIN_PA23},
+#define CONFIG_EIC_EXTINT_MAP {0, PIN_PB00}, {1, PIN_PB01}, {2, PIN_PA02}, {3, PIN_PB03}, {6, PIN_PA22}, {7, PIN_PA23},
#endif
// <<< end of configuration section >>>
diff --git a/watch-library/hal/src/hal_ext_irq.c b/watch-library/hal/src/hal_ext_irq.c
index d0b92927..2c383b4b 100644
--- a/watch-library/hal/src/hal_ext_irq.c
+++ b/watch-library/hal/src/hal_ext_irq.c
@@ -33,7 +33,7 @@
#include "hal_ext_irq.h"
-#define EXT_IRQ_AMOUNT 3
+#define EXT_IRQ_AMOUNT 6
/**
* \brief Driver version
diff --git a/watch-library/hpl/eic/hpl_eic.c b/watch-library/hpl/eic/hpl_eic.c
index 3b473ef5..2bd31615 100644
--- a/watch-library/hpl/eic/hpl_eic.c
+++ b/watch-library/hpl/eic/hpl_eic.c
@@ -70,7 +70,7 @@ static int ffs(int v)
}
#endif
-#define EXT_IRQ_AMOUNT 3
+#define EXT_IRQ_AMOUNT 6
/**
* \brief EXTINTx and pin number map
diff --git a/watch-library/watch/watch_extint.h b/watch-library/watch/watch_extint.h
index 758fe8bc..cba6c5e1 100644
--- a/watch-library/watch/watch_extint.h
+++ b/watch-library/watch/watch_extint.h
@@ -62,16 +62,17 @@ void watch_disable_external_interrupts();
* want to detect both rising and falling conditions (i.e. button down and button up), use
* INTERRUPT_TRIGGER_BOTH and use watch_get_pin_level to check the pin level in your callback
* to determine which condition caused the interrupt.
- * @param pin One of pins BTN_LIGHT, BTN_MODE, BTN_ALARM, or A0-A4. If the pin parameter matches one of
+ * @param pin One of BTN_LIGHT, BTN_MODE, BTN_ALARM, A0, A1, A3 or A4. If the pin parameter matches one of
* the three button pins, this function will also enable an internal pull-down resistor. If
* the pin parameter is A0-A4, you are responsible for setting any required pull configuration
* using watch_enable_pull_up or watch_enable_pull_down.
* @param callback The function you wish to have called when the button is pressed.
* @param trigger The condition on which you wish to trigger: rising, falling or both.
- * @note The alarm button and pin A2 share an external interrupt channel EXTINT[2]; you can only use one
- * or the other. However! These pins both have an alternate method of triggering via the RTC tamper
- * interrupt, which has the added benefit of not requiring the external interrupt controller at all.
- * @see watch_register_extwake_callback
+ * @note Pins A2 and A4 can also generate interrupts via the watch_register_extwake_callback function, which
+ * will allow them to trigger even when the watch is in deep sleep mode.
+ * @warning As of now, A2 is not usable via the watch_register_interrupt_callback function. To enable an
+ * external interrupt on pin A2, use the watch_register_extwake_callback function. This issue will be
+ * addressed in a future revision of the watch library.
*/
void watch_register_interrupt_callback(const uint8_t pin, ext_irq_cb_t callback, watch_interrupt_trigger trigger);