initial pass at simulator support
This commit is contained in:
@@ -26,9 +26,9 @@
|
||||
|
||||
void watch_enable_adc(void) {}
|
||||
|
||||
void watch_enable_analog_input(const uint8_t pin) {}
|
||||
void watch_enable_analog_input(const uint16_t pin) {}
|
||||
|
||||
uint16_t watch_get_analog_pin_level(const uint8_t pin) {
|
||||
uint16_t watch_get_analog_pin_level(const uint16_t pin) {
|
||||
return 32767; // pretend it's half of VCC
|
||||
}
|
||||
|
||||
@@ -36,13 +36,13 @@ void watch_set_analog_num_samples(uint16_t samples) {}
|
||||
|
||||
void watch_set_analog_sampling_length(uint8_t cycles) {}
|
||||
|
||||
void watch_set_analog_reference_voltage(watch_adc_reference_voltage reference) {}
|
||||
void watch_set_analog_reference_voltage(uint8_t reference) {}
|
||||
|
||||
uint16_t watch_get_vcc_voltage(void) {
|
||||
// TODO: (a2) hook to UI
|
||||
return 3000;
|
||||
}
|
||||
|
||||
inline void watch_disable_analog_input(const uint8_t pin) {}
|
||||
inline void watch_disable_analog_input(const uint16_t pin) {}
|
||||
|
||||
inline void watch_disable_adc(void) {}
|
||||
|
||||
@@ -22,26 +22,20 @@
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <stddef.h>
|
||||
#include "watch_extint.h"
|
||||
|
||||
// this warning only appears when you `make BOARD=OSO-SWAT-A1-02`. it's annoying,
|
||||
// but i'd rather have it warn us at build-time than fail silently at run-time.
|
||||
// besides, no one but me really has any of these boards anyway.
|
||||
#if BTN_ALARM != GPIO(GPIO_PORTA, 2)
|
||||
#warning This board revision does not support external wake on BTN_ALARM, so watch_register_extwake_callback will not work with it. Use watch_register_interrupt_callback instead.
|
||||
#endif
|
||||
|
||||
#include "app.h"
|
||||
static uint32_t watch_backup_data[8];
|
||||
|
||||
void watch_register_extwake_callback(uint8_t pin, ext_irq_cb_t callback, bool level) {
|
||||
if (pin == BTN_ALARM) {
|
||||
void watch_register_extwake_callback(uint8_t pin, watch_cb_t callback, bool level) {
|
||||
if (pin == HAL_GPIO_BTN_ALARM_pin()) {
|
||||
watch_enable_external_interrupts();
|
||||
watch_register_interrupt_callback(pin, callback, level ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING);
|
||||
}
|
||||
}
|
||||
|
||||
void watch_disable_extwake_interrupt(uint8_t pin) {
|
||||
if (pin == BTN_ALARM) {
|
||||
if (pin == HAL_GPIO_BTN_ALARM_pin()) {
|
||||
watch_register_interrupt_callback(pin, NULL, INTERRUPT_TRIGGER_NONE);
|
||||
}
|
||||
}
|
||||
@@ -68,9 +62,6 @@ void watch_enter_sleep_mode(void) {
|
||||
|
||||
// call app_setup so the app can re-enable everything we disabled.
|
||||
app_setup();
|
||||
|
||||
// and call app_wake_from_standby (since main won't have a chance to do it)
|
||||
app_wake_from_standby();
|
||||
}
|
||||
|
||||
void watch_enter_deep_sleep_mode(void) {
|
||||
|
||||
@@ -33,18 +33,18 @@
|
||||
static bool debug_console_focused = false;
|
||||
static bool external_interrupt_enabled = false;
|
||||
static bool button_callbacks_installed = false;
|
||||
static ext_irq_cb_t external_interrupt_mode_callback = NULL;
|
||||
static watch_interrupt_trigger external_interrupt_mode_trigger = INTERRUPT_TRIGGER_NONE;
|
||||
static ext_irq_cb_t external_interrupt_light_callback = NULL;
|
||||
static watch_interrupt_trigger external_interrupt_light_trigger = INTERRUPT_TRIGGER_NONE;
|
||||
static ext_irq_cb_t external_interrupt_alarm_callback = NULL;
|
||||
static watch_interrupt_trigger external_interrupt_alarm_trigger = INTERRUPT_TRIGGER_NONE;
|
||||
static watch_cb_t external_interrupt_mode_callback = NULL;
|
||||
static eic_interrupt_trigger_t external_interrupt_mode_trigger = INTERRUPT_TRIGGER_NONE;
|
||||
static watch_cb_t external_interrupt_light_callback = NULL;
|
||||
static eic_interrupt_trigger_t external_interrupt_light_trigger = INTERRUPT_TRIGGER_NONE;
|
||||
static watch_cb_t external_interrupt_alarm_callback = NULL;
|
||||
static eic_interrupt_trigger_t external_interrupt_alarm_trigger = INTERRUPT_TRIGGER_NONE;
|
||||
|
||||
#define BTN_ID_ALARM 3
|
||||
#define BTN_ID_LIGHT 1
|
||||
#define BTN_ID_MODE 2
|
||||
static const uint8_t BTN_IDS[] = { BTN_ID_ALARM, BTN_ID_LIGHT, BTN_ID_MODE };
|
||||
static EM_BOOL watch_invoke_interrupt_callback(const uint8_t button_id, watch_interrupt_trigger trigger);
|
||||
static EM_BOOL watch_invoke_interrupt_callback(const uint8_t button_id, eic_interrupt_trigger_t trigger);
|
||||
|
||||
static EM_BOOL watch_invoke_key_callback(int eventType, const EmscriptenKeyboardEvent *keyEvent, void *userData) {
|
||||
if (debug_console_focused || keyEvent->repeat) return EM_FALSE;
|
||||
@@ -90,20 +90,20 @@ static EM_BOOL watch_invoke_key_callback(int eventType, const EmscriptenKeyboard
|
||||
return EM_FALSE;
|
||||
}
|
||||
|
||||
watch_interrupt_trigger trigger = eventType == EMSCRIPTEN_EVENT_KEYDOWN ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING;
|
||||
eic_interrupt_trigger_t trigger = eventType == EMSCRIPTEN_EVENT_KEYDOWN ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING;
|
||||
return watch_invoke_interrupt_callback(button_id, trigger);
|
||||
}
|
||||
|
||||
static EM_BOOL watch_invoke_mouse_callback(int eventType, const EmscriptenMouseEvent *mouseEvent, void *userData) {
|
||||
if (eventType == EMSCRIPTEN_EVENT_MOUSEOUT && mouseEvent->buttons == 0) return EM_FALSE;
|
||||
uint8_t button_id = *(const char *)userData;
|
||||
watch_interrupt_trigger trigger = eventType == EMSCRIPTEN_EVENT_MOUSEDOWN ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING;
|
||||
eic_interrupt_trigger_t trigger = eventType == EMSCRIPTEN_EVENT_MOUSEDOWN ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING;
|
||||
return watch_invoke_interrupt_callback(button_id, trigger);
|
||||
}
|
||||
|
||||
static EM_BOOL watch_invoke_touch_callback(int eventType, const EmscriptenTouchEvent *touchEvent, void *userData) {
|
||||
uint8_t button_id = *(const char *)userData;
|
||||
watch_interrupt_trigger trigger = eventType == EMSCRIPTEN_EVENT_TOUCHSTART ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING;
|
||||
eic_interrupt_trigger_t trigger = eventType == EMSCRIPTEN_EVENT_TOUCHSTART ? INTERRUPT_TRIGGER_RISING : INTERRUPT_TRIGGER_FALLING;
|
||||
return watch_invoke_interrupt_callback(button_id, trigger);
|
||||
}
|
||||
|
||||
@@ -150,23 +150,23 @@ void watch_disable_external_interrupts(void) {
|
||||
external_interrupt_enabled = false;
|
||||
}
|
||||
|
||||
static EM_BOOL watch_invoke_interrupt_callback(const uint8_t button_id, watch_interrupt_trigger event) {
|
||||
ext_irq_cb_t callback;
|
||||
watch_interrupt_trigger trigger;
|
||||
static EM_BOOL watch_invoke_interrupt_callback(const uint8_t button_id, eic_interrupt_trigger_t event) {
|
||||
watch_cb_t callback;
|
||||
eic_interrupt_trigger_t trigger;
|
||||
uint8_t pin;
|
||||
switch (button_id) {
|
||||
case BTN_ID_MODE:
|
||||
pin = BTN_MODE;
|
||||
pin = HAL_GPIO_BTN_MODE_pin();
|
||||
callback = external_interrupt_mode_callback;
|
||||
trigger = external_interrupt_mode_trigger;
|
||||
break;
|
||||
case BTN_ID_LIGHT:
|
||||
pin = BTN_LIGHT;
|
||||
pin = HAL_GPIO_BTN_LIGHT_pin();
|
||||
callback = external_interrupt_light_callback;
|
||||
trigger = external_interrupt_light_trigger;
|
||||
break;
|
||||
case BTN_ID_ALARM:
|
||||
pin = BTN_ALARM;
|
||||
pin = HAL_GPIO_BTN_ALARM_pin();
|
||||
callback = external_interrupt_alarm_callback;
|
||||
trigger = external_interrupt_alarm_trigger;
|
||||
break;
|
||||
@@ -195,14 +195,14 @@ static EM_BOOL watch_invoke_interrupt_callback(const uint8_t button_id, watch_in
|
||||
return EM_TRUE;
|
||||
}
|
||||
|
||||
void watch_register_interrupt_callback(const uint8_t pin, ext_irq_cb_t callback, watch_interrupt_trigger trigger) {
|
||||
if (pin == BTN_MODE) {
|
||||
void watch_register_interrupt_callback(const uint8_t pin, watch_cb_t callback, eic_interrupt_trigger_t trigger) {
|
||||
if (pin == HAL_GPIO_BTN_MODE_pin()) {
|
||||
external_interrupt_mode_callback = callback;
|
||||
external_interrupt_mode_trigger = trigger;
|
||||
} else if (pin == BTN_LIGHT) {
|
||||
} else if (pin == HAL_GPIO_BTN_LIGHT_pin()) {
|
||||
external_interrupt_light_callback = callback;
|
||||
external_interrupt_light_trigger = trigger;
|
||||
} else if (pin == BTN_ALARM) {
|
||||
} else if (pin == HAL_GPIO_BTN_ALARM_pin()) {
|
||||
external_interrupt_alarm_callback = callback;
|
||||
external_interrupt_alarm_trigger = trigger;
|
||||
}
|
||||
|
||||
@@ -22,8 +22,6 @@
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "driver_init.h"
|
||||
|
||||
void suspend_main_loop(void);
|
||||
|
||||
void resume_main_loop(void);
|
||||
|
||||
@@ -34,10 +34,10 @@ static long tick_callbacks[8] = { -1, -1, -1, -1, -1, -1, -1, -1 };
|
||||
static long alarm_interval_id = -1;
|
||||
static long alarm_timeout_id = -1;
|
||||
static double alarm_interval;
|
||||
ext_irq_cb_t alarm_callback;
|
||||
ext_irq_cb_t btn_alarm_callback;
|
||||
ext_irq_cb_t a2_callback;
|
||||
ext_irq_cb_t a4_callback;
|
||||
watch_cb_t alarm_callback;
|
||||
watch_cb_t btn_alarm_callback;
|
||||
watch_cb_t a2_callback;
|
||||
watch_cb_t a4_callback;
|
||||
|
||||
bool _watch_rtc_is_enabled(void) {
|
||||
return true;
|
||||
@@ -73,7 +73,7 @@ watch_date_time_t watch_rtc_get_date_time(void) {
|
||||
return retval;
|
||||
}
|
||||
|
||||
void watch_rtc_register_tick_callback(ext_irq_cb_t callback) {
|
||||
void watch_rtc_register_tick_callback(watch_cb_t callback) {
|
||||
watch_rtc_register_periodic_callback(callback, 1);
|
||||
}
|
||||
|
||||
@@ -82,12 +82,12 @@ void watch_rtc_disable_tick_callback(void) {
|
||||
}
|
||||
|
||||
static void watch_invoke_periodic_callback(void *userData) {
|
||||
ext_irq_cb_t callback = userData;
|
||||
watch_cb_t callback = userData;
|
||||
callback();
|
||||
resume_main_loop();
|
||||
}
|
||||
|
||||
void watch_rtc_register_periodic_callback(ext_irq_cb_t callback, uint8_t frequency) {
|
||||
void watch_rtc_register_periodic_callback(watch_cb_t callback, uint8_t frequency) {
|
||||
// we told them, it has to be a power of 2.
|
||||
if (__builtin_popcount(frequency) != 1) return;
|
||||
|
||||
@@ -134,7 +134,7 @@ static void watch_invoke_alarm_callback(void *userData) {
|
||||
alarm_interval_id = emscripten_set_interval(watch_invoke_alarm_interval_callback, alarm_interval, NULL);
|
||||
}
|
||||
|
||||
void watch_rtc_register_alarm_callback(ext_irq_cb_t callback, watch_date_time_t alarm_time, watch_rtc_alarm_match mask) {
|
||||
void watch_rtc_register_alarm_callback(watch_cb_t callback, watch_date_time_t alarm_time, rtc_alarm_match_t mask) {
|
||||
watch_rtc_disable_alarm_callback();
|
||||
|
||||
switch (mask) {
|
||||
|
||||
@@ -23,8 +23,7 @@
|
||||
*/
|
||||
|
||||
#include "watch_slcd.h"
|
||||
#include "watch_private_display.h"
|
||||
#include "hpl_slcd_config.h"
|
||||
#include "watch_common_display.h"
|
||||
|
||||
#include <emscripten.h>
|
||||
#include <emscripten/html5.h>
|
||||
|
||||
@@ -22,8 +22,7 @@
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "watch_buzzer.h"
|
||||
#include "watch_private_buzzer.h"
|
||||
#include "watch_tcc.h"
|
||||
#include "watch_main_loop.h"
|
||||
|
||||
#include <emscripten.h>
|
||||
|
||||
Reference in New Issue
Block a user