From 87da5f15ea314d53d97cee5f9fd13b4f83455256 Mon Sep 17 00:00:00 2001 From: Joey Castillo Date: Tue, 5 Jul 2022 22:53:04 -0500 Subject: [PATCH] new tests --- apps/functional-test/app.c | 38 ++++++++------ apps/sensor-board-test/app.c | 75 ++++++++++++++++++++++++++++ apps/sensor-board-test/make/Makefile | 10 ++++ 3 files changed, 109 insertions(+), 14 deletions(-) create mode 100644 apps/sensor-board-test/app.c create mode 100755 apps/sensor-board-test/make/Makefile diff --git a/apps/functional-test/app.c b/apps/functional-test/app.c index 1859951..179bea8 100644 --- a/apps/functional-test/app.c +++ b/apps/functional-test/app.c @@ -13,6 +13,8 @@ void app_setup(void) { watch_enable_buzzer(); + watch_enable_digital_output(RED); + watch_enable_digital_output(GREEN); watch_enable_digital_input(BTN_ALARM); watch_enable_digital_input(BTN_LIGHT); watch_enable_digital_input(BTN_MODE); @@ -30,34 +32,42 @@ void app_wake_from_standby(void) { bool app_loop(void) { static int last_button = 0; static int button = 0; - static int16_t loop = 0; + static int8_t loop = 0; + watch_set_pin_level(GREEN, false); + watch_set_pin_level(RED, false); if (watch_get_pin_level(BTN_ALARM)) { + watch_set_pin_level(GREEN, true); button = 1; - } - if (watch_get_pin_level(BTN_LIGHT)) { + } else if (watch_get_pin_level(BTN_LIGHT)) { + watch_set_pin_level(RED, true); button = 2; - } - if (watch_get_pin_level(BTN_MODE)) { + } else if (watch_get_pin_level(BTN_MODE)) { + watch_set_pin_level(GREEN, true); + watch_set_pin_level(RED, true); button = 3; } if (button != last_button) { last_button = button; - watch_buzzer_play_note(BUZZER_NOTE_C8, 50); + watch_buzzer_play_note(BUZZER_NOTE_C8, 100); } + static const bool segmap[3][24] = { + //0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 + {0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0}, + {0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 0, 1}, + {1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 1} + }; + for(int com = 0; com < 3; com++) { for(int seg = 0; seg < 24; seg++) { - if (loop > 0) { - if (seg % 2 == 0) watch_set_pixel(com, seg); - else watch_set_pixel(com, seg); - } else { - if (seg % 2 == 1) watch_set_pixel(com, seg); - else watch_set_pixel(com, seg); - } + if (segmap[com][seg]) (loop >= 0) ? watch_set_pixel(com, seg) : watch_clear_pixel(com, seg); + else (loop < 0) ? watch_set_pixel(com, seg) : watch_clear_pixel(com, seg); } } - return true; + loop++; + + return false; } diff --git a/apps/sensor-board-test/app.c b/apps/sensor-board-test/app.c new file mode 100644 index 0000000..d7da190 --- /dev/null +++ b/apps/sensor-board-test/app.c @@ -0,0 +1,75 @@ +#include +#include +#include "watch.h" + +bool even = false; + +static void cb_tick(void) { + even = !even; +} + +void app_init(void) { +} + +void app_wake_from_backup(void) { +} + +void app_setup(void) { + watch_enable_digital_output(RED); + watch_enable_digital_output(GREEN); + watch_enable_digital_output(A0); + watch_enable_digital_output(SCL); + watch_enable_digital_output(SDA); + watch_enable_digital_output(A1); + watch_enable_digital_output(A2); + watch_enable_digital_output(A3); + watch_enable_digital_output(A4); + + watch_set_pin_level(A0, false); + watch_set_pin_level(SCL, false); + watch_set_pin_level(SDA, false); + watch_set_pin_level(A1, false); + watch_set_pin_level(A2, false); + watch_set_pin_level(A3, false); + watch_set_pin_level(A4, false); + + watch_rtc_register_periodic_callback(cb_tick, 2); +} + +void app_prepare_for_standby(void) { +} + +void app_wake_from_standby(void) { +} + +bool app_loop(void) { + watch_date_time date_time = watch_rtc_get_date_time(); + char buf[16]; + sprintf(buf, "%2d:%02d:%02d: ", date_time.unit.hour, date_time.unit.minute, date_time.unit.second); + printf(buf); + if (even) { + printf("Even\n"); + watch_set_pin_level(RED, false); + watch_set_pin_level(GREEN, true); + watch_set_pin_level(A0, true); + watch_set_pin_level(SCL, false); + watch_set_pin_level(SDA, true); + watch_set_pin_level(A1, false); + watch_set_pin_level(A2, true); + watch_set_pin_level(A3, false); + watch_set_pin_level(A4, true); + } else { + printf("Odd\n"); + watch_set_pin_level(RED, true); + watch_set_pin_level(GREEN, false); + watch_set_pin_level(A0, false); + watch_set_pin_level(SCL, true); + watch_set_pin_level(SDA, false); + watch_set_pin_level(A1, true); + watch_set_pin_level(A2, false); + watch_set_pin_level(A3, true); + watch_set_pin_level(A4, false); + } + + return true; +} diff --git a/apps/sensor-board-test/make/Makefile b/apps/sensor-board-test/make/Makefile new file mode 100755 index 0000000..c66ad20 --- /dev/null +++ b/apps/sensor-board-test/make/Makefile @@ -0,0 +1,10 @@ +TOP = ../../.. +include $(TOP)/make.mk + +INCLUDES += \ + -I../ + +SRCS += \ + ../app.c + +include $(TOP)/rules.mk