From 7fea11f34cbaffe81e9ed709a8e7e1cb0600f7ce Mon Sep 17 00:00:00 2001 From: Willian Paixao Date: Sun, 5 Dec 2021 13:58:44 +0100 Subject: introduce github actions --- .github/workflows/main.yml | 16 ++++++++++++++++ make.mk | 3 ++- 2 files changed, 18 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/main.yml diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 00000000..ba485570 --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,16 @@ +name: Build + +on: [pull_request, push] + +jobs: + build: + container: + image: ghcr.io/armmbed/mbed-os-env:latest + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v2 + - name: Compile Starter Project + run: make + working-directory: 'apps/beats-time/make' + diff --git a/make.mk b/make.mk index f6a37c7e..f1301733 100644 --- a/make.mk +++ b/make.mk @@ -20,7 +20,8 @@ else MKDIR = mkdir endif -CFLAGS += -W -Wall --std=gnu99 -Os +CFLAGS += -W -Wall -Wextra -Wmissing-prototypes -Wmissing-declarations +CFLAGS += --std=gnu99 -Os CFLAGS += -fno-diagnostics-show-caret CFLAGS += -fdata-sections -ffunction-sections CFLAGS += -funsigned-char -funsigned-bitfields -- cgit v1.2.3 From ddf3bf51c26532d2779f565281edfd0b84e450eb Mon Sep 17 00:00:00 2001 From: Willian Paixao Date: Sun, 5 Dec 2021 18:37:44 +0100 Subject: update gitgnore --- .github/workflows/main.yml | 8 ++++++-- .gitignore | 15 ++++++++------- Doxyfile | 2 +- apps/Sensor Watch Accelerometer Test/make/.gitignore | 1 - apps/Sensor Watch BME280 Project/make/.gitignore | 1 - apps/Sensor Watch Buzzer Demo/make/.gitignore | 1 - apps/Sensor Watch SPI Test/make/.gitignore | 1 - apps/Sensor Watch Starter Project/make/.gitignore | 1 - apps/beats-time/make/.gitignore | 1 - 9 files changed, 15 insertions(+), 16 deletions(-) delete mode 100755 apps/Sensor Watch Accelerometer Test/make/.gitignore delete mode 100755 apps/Sensor Watch BME280 Project/make/.gitignore delete mode 100755 apps/Sensor Watch Buzzer Demo/make/.gitignore delete mode 100755 apps/Sensor Watch SPI Test/make/.gitignore delete mode 100755 apps/Sensor Watch Starter Project/make/.gitignore delete mode 100755 apps/beats-time/make/.gitignore diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index ba485570..f07c5db0 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -10,7 +10,11 @@ jobs: steps: - name: Checkout uses: actions/checkout@v2 - - name: Compile Starter Project + - name: Compile beats-time app run: make working-directory: 'apps/beats-time/make' - + - name: Upload UF2 + uses: actions/upload-artifact@v2 + with: + name: watch.uf2 + path: apps/beats-time/make/build/watch.uf2 diff --git a/.gitignore b/.gitignore index 4c97e2d4..6c5ca630 100644 --- a/.gitignore +++ b/.gitignore @@ -1,17 +1,18 @@ -.DS_Store -*.s#* +**/build/ *.b#* -*.pro -*.job - *.bin +*.d *.elf *.hex +*.job *.lss *.map +*.o +*.pro +*.s#* *.uf2 *srec -*.o -*.d +.DS_Store .vs .vscode +docs/ \ No newline at end of file diff --git a/Doxyfile b/Doxyfile index da710195..7f04a047 100644 --- a/Doxyfile +++ b/Doxyfile @@ -8,7 +8,7 @@ PROJECT_NAME = "Sensor Watch" PROJECT_NUMBER = "0.0.0" PROJECT_BRIEF = "A board replacement for the classic Casio F-91W wristwatch, powered by a Microchip SAM L22 microcontroller." PROJECT_LOGO = -OUTPUT_DIRECTORY = "../Sensor-Watch-Documentation" +OUTPUT_DIRECTORY = "." CREATE_SUBDIRS = NO ALLOW_UNICODE_NAMES = NO OUTPUT_LANGUAGE = English diff --git a/apps/Sensor Watch Accelerometer Test/make/.gitignore b/apps/Sensor Watch Accelerometer Test/make/.gitignore deleted file mode 100755 index 567609b1..00000000 --- a/apps/Sensor Watch Accelerometer Test/make/.gitignore +++ /dev/null @@ -1 +0,0 @@ -build/ diff --git a/apps/Sensor Watch BME280 Project/make/.gitignore b/apps/Sensor Watch BME280 Project/make/.gitignore deleted file mode 100755 index 3722ac63..00000000 --- a/apps/Sensor Watch BME280 Project/make/.gitignore +++ /dev/null @@ -1 +0,0 @@ -build/ diff --git a/apps/Sensor Watch Buzzer Demo/make/.gitignore b/apps/Sensor Watch Buzzer Demo/make/.gitignore deleted file mode 100755 index 3722ac63..00000000 --- a/apps/Sensor Watch Buzzer Demo/make/.gitignore +++ /dev/null @@ -1 +0,0 @@ -build/ diff --git a/apps/Sensor Watch SPI Test/make/.gitignore b/apps/Sensor Watch SPI Test/make/.gitignore deleted file mode 100755 index 3722ac63..00000000 --- a/apps/Sensor Watch SPI Test/make/.gitignore +++ /dev/null @@ -1 +0,0 @@ -build/ diff --git a/apps/Sensor Watch Starter Project/make/.gitignore b/apps/Sensor Watch Starter Project/make/.gitignore deleted file mode 100755 index 3722ac63..00000000 --- a/apps/Sensor Watch Starter Project/make/.gitignore +++ /dev/null @@ -1 +0,0 @@ -build/ diff --git a/apps/beats-time/make/.gitignore b/apps/beats-time/make/.gitignore deleted file mode 100755 index 3722ac63..00000000 --- a/apps/beats-time/make/.gitignore +++ /dev/null @@ -1 +0,0 @@ -build/ -- cgit v1.2.3 From ed94efcb8559d21820e8a06214e95191eed4c9b3 Mon Sep 17 00:00:00 2001 From: Joey Castillo Date: Sun, 5 Dec 2021 23:06:25 -0600 Subject: rename project files --- README.md | 2 +- apps/Sensor Watch Accelerometer Test/app.c | 84 ----- apps/Sensor Watch Accelerometer Test/make/Makefile | 10 - apps/Sensor Watch BME280 Project/app.c | 380 --------------------- apps/Sensor Watch BME280 Project/app.h | 76 ----- apps/Sensor Watch BME280 Project/bme280.h | 85 ----- apps/Sensor Watch BME280 Project/make/Makefile | 10 - apps/Sensor Watch Buzzer Demo/app.c | 134 -------- apps/Sensor Watch Buzzer Demo/make/Makefile | 10 - apps/Sensor Watch SPI Test/app.c | 71 ---- apps/Sensor Watch SPI Test/make/Makefile | 10 - apps/Sensor Watch Starter Project/app.c | 198 ----------- apps/Sensor Watch Starter Project/make/Makefile | 26 -- apps/accelerometer-test/app.c | 84 +++++ apps/accelerometer-test/make/Makefile | 10 + apps/buzzer-test/app.c | 134 ++++++++ apps/buzzer-test/make/Makefile | 10 + apps/spi-test/app.c | 71 ++++ apps/spi-test/make/Makefile | 10 + apps/starter-project/app.c | 198 +++++++++++ apps/starter-project/make/Makefile | 26 ++ 21 files changed, 544 insertions(+), 1095 deletions(-) delete mode 100644 apps/Sensor Watch Accelerometer Test/app.c delete mode 100755 apps/Sensor Watch Accelerometer Test/make/Makefile delete mode 100644 apps/Sensor Watch BME280 Project/app.c delete mode 100644 apps/Sensor Watch BME280 Project/app.h delete mode 100644 apps/Sensor Watch BME280 Project/bme280.h delete mode 100755 apps/Sensor Watch BME280 Project/make/Makefile delete mode 100644 apps/Sensor Watch Buzzer Demo/app.c delete mode 100755 apps/Sensor Watch Buzzer Demo/make/Makefile delete mode 100644 apps/Sensor Watch SPI Test/app.c delete mode 100755 apps/Sensor Watch SPI Test/make/Makefile delete mode 100644 apps/Sensor Watch Starter Project/app.c delete mode 100755 apps/Sensor Watch Starter Project/make/Makefile create mode 100644 apps/accelerometer-test/app.c create mode 100755 apps/accelerometer-test/make/Makefile create mode 100644 apps/buzzer-test/app.c create mode 100755 apps/buzzer-test/make/Makefile create mode 100644 apps/spi-test/app.c create mode 100755 apps/spi-test/make/Makefile create mode 100644 apps/starter-project/app.c create mode 100755 apps/starter-project/make/Makefile diff --git a/README.md b/README.md index 5b560bfe..e3afca06 100644 --- a/README.md +++ b/README.md @@ -45,7 +45,7 @@ These tiny “sensor boards” have a set outline, and the available area for yo Getting code on the watch ------------------------- -The watch library in this repository is very work-in-progress, but it should allow you to get started. To create a new project, copy the “Sensor Watch Starter Project” and write your code in the app.c file. +The watch library in this repository is very work-in-progress, but it should allow you to get started. To create a new project, copy the “starter-project” folder in the apps folder, and write your code in the app.c file. You will need to install [the GNU Arm Embedded Toolchain](https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads/) to build projects for the watch. The watch library has been tested with the `9-2019-q4-major` version and the `10.3-2021.07` versions. diff --git a/apps/Sensor Watch Accelerometer Test/app.c b/apps/Sensor Watch Accelerometer Test/app.c deleted file mode 100644 index bea00f6f..00000000 --- a/apps/Sensor Watch Accelerometer Test/app.c +++ /dev/null @@ -1,84 +0,0 @@ -#include -#include -#include -#include -#include "watch.h" -#include "lis2dh.h" - -// This application displays data from the old Sensor Watch Motion sensor board. -// Note that this board required A0 to be set high to power the sensor. -// Future accelerometer boards will be powered directly from VCC. -// Also note that this board has its INT1 pin wired to A1, which is not an external -// wake pin. Future accelerometer boards will wire interrupt pins to A2 and A4. - -void cb_light_pressed() { -} - -void cb_mode_pressed() { -} - -void cb_alarm_pressed() { -} - -uint8_t interrupts = 0; -uint8_t last_interrupts = 0; -uint8_t ticks = 0; -char buf[13] = {0}; - -void cb_interrupt_1() { - interrupts++; -} - -void cb_tick() { - if (++ticks == 30) { - last_interrupts = interrupts; - interrupts = 0; - ticks = 0; - } -} - -void app_init() { - gpio_set_pin_direction(A0, GPIO_DIRECTION_OUT); - gpio_set_pin_function(A0, GPIO_PIN_FUNCTION_OFF); - gpio_set_pin_level(A0, true); - - watch_enable_display(); - watch_display_string("IN 0 0 0", 0); - - watch_enable_external_interrupts(); - watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); - watch_register_interrupt_callback(BTN_LIGHT, cb_light_pressed, INTERRUPT_TRIGGER_RISING); - watch_register_interrupt_callback(BTN_ALARM, cb_alarm_pressed, INTERRUPT_TRIGGER_RISING); - - watch_enable_i2c(); - - lis2dh_begin(); - lis2dh_set_data_rate(LIS2DH_DATA_RATE_10_HZ); - lis2dh_configure_aoi_int1( - LIS2DH_INTERRUPT_CONFIGURATION_OR | - LIS2DH_INTERRUPT_CONFIGURATION_X_HIGH_ENABLE | - LIS2DH_INTERRUPT_CONFIGURATION_Y_HIGH_ENABLE | - LIS2DH_INTERRUPT_CONFIGURATION_Z_HIGH_ENABLE, 96, 0, true); - - watch_register_interrupt_callback(A1, cb_interrupt_1, INTERRUPT_TRIGGER_RISING); - watch_rtc_register_tick_callback(cb_tick); -} - -void app_wake_from_backup() { -} - -void app_setup() { -} - -void app_prepare_for_standby() { -} - -void app_wake_from_standby() { -} - -bool app_loop() { - sprintf(buf, "IN%2d%3d%3d", ticks, interrupts, last_interrupts); - watch_display_string(buf, 0); - - return true; -} diff --git a/apps/Sensor Watch Accelerometer Test/make/Makefile b/apps/Sensor Watch Accelerometer Test/make/Makefile deleted file mode 100755 index c66ad20c..00000000 --- a/apps/Sensor Watch Accelerometer Test/make/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -TOP = ../../.. -include $(TOP)/make.mk - -INCLUDES += \ - -I../ - -SRCS += \ - ../app.c - -include $(TOP)/rules.mk diff --git a/apps/Sensor Watch BME280 Project/app.c b/apps/Sensor Watch BME280 Project/app.c deleted file mode 100644 index 85439d9b..00000000 --- a/apps/Sensor Watch BME280 Project/app.c +++ /dev/null @@ -1,380 +0,0 @@ -#include -#include -#include -#include "watch.h" -#include "bme280.h" - -#include "app.h" - -ApplicationState application_state; -char buf[16] = {0}; - -/** - * @brief Zeroes out the application state struct. - */ -void app_init() { - memset(&application_state, 0, sizeof(application_state)); -} - -void app_wake_from_backup() { - // This app does not support BACKUP mode. -} - -void app_setup() { - watch_enable_external_interrupts(); - watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); - watch_register_interrupt_callback(BTN_LIGHT, cb_light_pressed, INTERRUPT_TRIGGER_RISING); - watch_register_extwake_callback(BTN_ALARM, cb_alarm_pressed, true); - - watch_enable_buzzer(); - watch_enable_leds(); - - // pin A0 powers the sensor on this board. - watch_enable_digital_output(A0); - watch_set_pin_level(A0, true); - delay_ms(10); - - watch_enable_i2c(); - - watch_i2c_write8(BME280_ADDRESS, BME280_REGISTER_SOFTRESET, BME280_SOFT_RESET_CODE); - delay_ms(10); - application_state.dig_T1 = watch_i2c_read16(BME280_ADDRESS, BME280_REGISTER_DIG_T1); - application_state.dig_T2 = (int16_t)watch_i2c_read16(BME280_ADDRESS, BME280_REGISTER_DIG_T2); - application_state.dig_T3 = (int16_t)watch_i2c_read16(BME280_ADDRESS, BME280_REGISTER_DIG_T3); - application_state.dig_H1 = watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H1); - application_state.dig_H2 = (int16_t)watch_i2c_read16(BME280_ADDRESS, BME280_REGISTER_DIG_H2); - application_state.dig_H3 = watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H3); - application_state.dig_H4 = ((int8_t)watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H4) << 4) | - (watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H4 + 1) & 0xF); - application_state.dig_H5 = ((int8_t)watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H5 + 1) << 4) | - (watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H5) >> 4); - application_state.dig_H6 = (int8_t)watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_DIG_H6); - - watch_i2c_write8(BME280_ADDRESS, BME280_REGISTER_CONTROL_HUMID, BME280_CONTROL_HUMID_SAMPLING_NONE); - watch_i2c_write8(BME280_ADDRESS, BME280_REGISTER_CONTROL, BME280_CONTROL_TEMPERATURE_SAMPLING_X16 | - BME280_CONTROL_PRESSURE_SAMPLING_NONE | - BME280_CONTROL_MODE_FORCED); - - watch_enable_display(); - - watch_rtc_register_tick_callback(cb_tick); -} - -/** - * Nothing to do here. - */ -void app_prepare_for_standby() { -} - -/** - * @todo restore the BME280's calibration values from backup memory - */ -void app_wake_from_standby() { -} - -/** - * Displays the temperature and humidity on screen, or a string indicating no measurements are being taken. - */ -bool app_loop() { - // play a beep if the mode has changed in response to a user's press of the MODE button - if (application_state.mode_changed) { - // low note for nonzero case, high note for return to clock - watch_buzzer_play_note(application_state.mode ? BUZZER_NOTE_C7 : BUZZER_NOTE_C8, 100); - application_state.mode_changed = false; - } - - // If the user is not in clock mode and the mode timeout has expired, return them to clock mode - if (application_state.mode != MODE_CLOCK && application_state.mode_ticks == 0) { - application_state.mode = MODE_CLOCK; - application_state.mode_changed = true; - } - - // If the LED is off and should be on, turn it on - if (application_state.light_ticks > 0 && !application_state.led_on) { - watch_set_led_green(); - application_state.led_on = true; - } - - // if the LED is on and should be off, turn it off - if (application_state.led_on && application_state.light_ticks == 0) { - // unless the user is holding down the LIGHT button, in which case, give them more time. - if (watch_get_pin_level(BTN_LIGHT)) { - application_state.light_ticks = 3; - } else { - watch_set_led_off(); - application_state.led_on = false; - } - } - - switch (application_state.mode) { - case MODE_CLOCK: - do_clock_mode(); - break; - case MODE_TEMP: - do_temp_mode(); - break; - case MODE_LOG: - do_log_mode(); - break; - case MODE_PREFS: - do_prefs_mode(); - break; - case MODE_SET: - do_set_time_mode(); - break; - case NUM_MODES: - // dummy case, just silences a warning - break; - } - - application_state.mode_changed = false; - - return true; -} - -/** - * Reads the temperature from the BME280 - * @param p_t_fine - an optional pointer to an int32_t; if provided, the t_fine measurement - * (required for humidity calculation) will be returned by reference. - * Pass in NULL if you do not care about this value. - * @return a float indicating the temperature in degrees celsius. - */ -float read_temperature(int32_t *p_t_fine) { - // read24 reads the bytes into a uint32 which works for little-endian values (MSB is 0) - uint32_t raw_data = watch_i2c_read24(BME280_ADDRESS, BME280_REGISTER_TEMP_DATA) >> 8; - // alas the sensor's register layout is big-endian-ish, with a nibble of zeroes at the end of the LSB. - // this line shuffles everything back into place (swaps LSB and MSB and shifts the zeroes off the end) - int32_t adc_value = (((raw_data >> 16) | (raw_data & 0xFF00) | (raw_data << 16)) & 0xFFFFFF) >> 4; - - // this bit is cribbed from Adafruit's BME280 driver. support their open source efforts by buying some stuff! - int32_t var1 = ((((adc_value >> 3) - ((int32_t)application_state.dig_T1 << 1))) * ((int32_t)application_state.dig_T2)) >> 11; - int32_t var2 = (((((adc_value >> 4) - ((int32_t)application_state.dig_T1)) * ((adc_value >> 4) - ((int32_t)application_state.dig_T1))) >> 12) * ((int32_t)application_state.dig_T3)) >> 14; - int32_t t_fine = var1 + var2; - - // if we got a pointer to a t_fine, return it by reference (for humidity calculation). - if (p_t_fine != NULL) *p_t_fine = t_fine; - - if (application_state.is_fahrenheit) { - return (((t_fine * 5 + 128) >> 8) / 100.0) * 1.8 + 32; - } else { - return ((t_fine * 5 + 128) >> 8) / 100.0; - } -} - -/** - * Reads the humidity from the BME280 - * @param t_fine - the t_fine measurement from a call to read_temperature - * @return a float indicating the relative humidity as a percentage from 0-100. - * @todo the returned value is glitchy, need to fix. - */ -float read_humidity(int32_t t_fine) { - int32_t adc_value = watch_i2c_read16(BME280_ADDRESS, BME280_REGISTER_HUMID_DATA); - - // again, cribbed from Adafruit's BME280 driver. they sell a great breakout board for this sensor! - int32_t v_x1_u32r = (t_fine - ((int32_t)76800)); - v_x1_u32r = (((((adc_value << 14) - (((int32_t)application_state.dig_H4) << 20) - (((int32_t)application_state.dig_H5) * v_x1_u32r)) + - ((int32_t)16384)) >> 15) * (((((((v_x1_u32r * ((int32_t)application_state.dig_H6)) >> 10) * (((v_x1_u32r * ((int32_t)application_state.dig_H3)) >> 11) + - ((int32_t)32768))) >> 10) + ((int32_t)2097152)) * ((int32_t)application_state.dig_H2) + 8192) >> 14)); - v_x1_u32r = (v_x1_u32r - (((((v_x1_u32r >> 15) * (v_x1_u32r >> 15)) >> 7) * ((int32_t)application_state.dig_H1)) >> 4)); - v_x1_u32r = (v_x1_u32r < 0) ? 0 : v_x1_u32r; - v_x1_u32r = (v_x1_u32r > 419430400) ? 419430400 : v_x1_u32r; - float h = (v_x1_u32r >> 12); - - return h / 1024.0; -} - -void log_data() { - watch_date_time date_time = watch_rtc_get_date_time(); - uint8_t hour = date_time.unit.hour; - int8_t temperature = read_temperature(NULL); - - for(int i = 0; i < MAX_DATA_POINTS - 1; i++) { - application_state.logged_data[i] = application_state.logged_data[i + 1]; - } - application_state.logged_data[MAX_DATA_POINTS - 1].is_valid = true; - application_state.logged_data[MAX_DATA_POINTS - 1].hour = hour; - application_state.logged_data[MAX_DATA_POINTS - 1].temperature = temperature; -} - -void do_clock_mode() { - watch_date_time date_time = watch_rtc_get_date_time(); - const char months[12][3] = {"JA", "FE", "MR", "AR", "MA", "JN", "JL", "AU", "SE", "OC", "NO", "dE"}; - - watch_display_string((char *)months[date_time.unit.month - 1], 0); - sprintf(buf, "%2d%2d%02d%02d", date_time.unit.day, date_time.unit.hour, date_time.unit.minute, date_time.unit.second); - watch_display_string(buf, 2); - watch_set_colon(); -} - -void do_temp_mode() { - int32_t t_fine; - float temperature; - float humidity; - - // take one reading - watch_i2c_write8(BME280_ADDRESS, BME280_REGISTER_CONTROL, BME280_CONTROL_TEMPERATURE_SAMPLING_X16 | - BME280_CONTROL_MODE_FORCED); - // wait for reading to finish - while(watch_i2c_read8(BME280_ADDRESS, BME280_REGISTER_STATUS) & BME280_STATUS_UPDATING_MASK); - temperature = read_temperature(&t_fine); - humidity = read_humidity(t_fine); - if (application_state.show_humidity) { - sprintf(buf, "TE%2d%4.1f#%c", (int)(humidity / 10), temperature, application_state.is_fahrenheit ? 'F' : 'C'); - } else { - sprintf(buf, "TE %4.1f#%c", temperature, application_state.is_fahrenheit ? 'F' : 'C'); - } - watch_display_string(buf, 0); - watch_clear_colon(); -} - -void do_log_mode() { - bool is_valid = (uint8_t)(application_state.logged_data[MAX_DATA_POINTS - 1 - application_state.page].is_valid); - uint8_t hour = (uint8_t)(application_state.logged_data[MAX_DATA_POINTS - 1 - application_state.page].hour); - int8_t temperature = (int8_t)(application_state.logged_data[MAX_DATA_POINTS - 1 - application_state.page].temperature); - if (!is_valid) { - sprintf(buf, "LO%2d------", application_state.page); - watch_clear_colon(); - } else { - sprintf(buf, "LO%2d%2d%4d", application_state.page, hour, temperature); - watch_set_colon(); - } - watch_display_string(buf, 0); -} - -void log_mode_handle_primary_button() { - application_state.page++; - if (application_state.page == MAX_DATA_POINTS) application_state.page = 0; -} - -void do_prefs_mode() { - sprintf(buf, "PR CorF %c", application_state.is_fahrenheit ? 'F' : 'C'); - watch_display_string(buf, 0); - watch_clear_colon(); -} - -void prefs_mode_handle_primary_button() { - // TODO: add rest of preferences (12/24, humidity, LED color, etc.) - // for now only one, C or F -} - -void prefs_mode_handle_secondary_button() { - application_state.is_fahrenheit = !application_state.is_fahrenheit; -} - -void do_set_time_mode() { - watch_date_time date_time = watch_rtc_get_date_time(); - - watch_display_string(" ", 0); - switch (application_state.page) { - case 0: // hour - sprintf(buf, "ST t%2d", date_time.unit.hour); - break; - case 1: // minute - sprintf(buf, "ST t %02d", date_time.unit.minute); - break; - case 2: // second - sprintf(buf, "ST t %02d", date_time.unit.second); - break; - case 3: // year - sprintf(buf, "ST d%2d", date_time.unit.year + 20); - break; - case 4: // month - sprintf(buf, "ST d %02d", date_time.unit.month); - break; - case 5: // day - sprintf(buf, "ST d %02d", date_time.unit.day); - break; - } - watch_display_string(buf, 0); - watch_set_pixel(1, 12); // required for T in position 1 -} - -void set_time_mode_handle_primary_button() { - application_state.page++; - if (application_state.page == 6) application_state.page = 0; -} - -void set_time_mode_handle_secondary_button() { - watch_date_time date_time = watch_rtc_get_date_time(); - const uint8_t days_in_month[12] = {31, 28, 31, 30, 31, 30, 30, 31, 30, 31, 30, 31}; - - switch (application_state.page) { - case 0: // hour - date_time.unit.hour = (date_time.unit.hour + 1) % 24; - break; - case 1: // minute - date_time.unit.minute = (date_time.unit.minute + 1) % 60; - break; - case 2: // second - date_time.unit.second = 0; - break; - case 3: // year - // only allow 2021-2030. fix this sometime next decade - date_time.unit.year = ((date_time.unit.year % 10) + 1); - break; - case 4: // month - date_time.unit.month = ((date_time.unit.month + 1) % 12); - break; - case 5: // day - date_time.unit.day = date_time.unit.day + 1; - // can't set to the 29th on a leap year. if it's february 29, set to 11:59 on the 28th. - // and it should roll over. - if (date_time.unit.day > days_in_month[date_time.unit.month - 1]) { - date_time.unit.day = 1; - } - break; - } - watch_rtc_set_date_time(date_time); -} - -void cb_mode_pressed() { - application_state.mode = (application_state.mode + 1) % NUM_MODES; - application_state.mode_changed = true; - application_state.mode_ticks = 300; - application_state.page = 0; -} - -void cb_light_pressed() { - switch (application_state.mode) { - case MODE_PREFS: - prefs_mode_handle_secondary_button(); - break; - case MODE_SET: - set_time_mode_handle_secondary_button(); - break; - default: - application_state.light_ticks = 3; - break; - } -} - -void cb_alarm_pressed() { - switch (application_state.mode) { - case MODE_LOG: - log_mode_handle_primary_button(); - break; - case MODE_PREFS: - prefs_mode_handle_primary_button(); - break; - case MODE_SET: - set_time_mode_handle_primary_button(); - break; - default: - break; - } -} - -void cb_tick() { - // TODO: use alarm interrupt to trigger data acquisition. - watch_date_time date_time = watch_rtc_get_date_time(); - if (date_time.unit.minute == 0 && date_time.unit.second == 0) { - log_data(); - } - - if (application_state.light_ticks > 0) { - application_state.light_ticks--; - } - if (application_state.mode_ticks > 0) { - application_state.mode_ticks--; - } -} diff --git a/apps/Sensor Watch BME280 Project/app.h b/apps/Sensor Watch BME280 Project/app.h deleted file mode 100644 index e0bbe1c2..00000000 --- a/apps/Sensor Watch BME280 Project/app.h +++ /dev/null @@ -1,76 +0,0 @@ -// Sensor Watch: Hiking Log Demo App -// This app displays a clock and temperature data from a BME280 temperature and humidiity sensor. -// It also logs up to 36 hours of temperature data for playback. -// You can use this app on backcountry treks: take the watch off at night and place it outside your tent. -// It will log overnight low temperatures for review in the morning and optional transfer to your notepad. - -#define MAX_DATA_POINTS 36 - -typedef enum ApplicationMode { - MODE_CLOCK = 0, // Displays month, day and current time. - MODE_TEMP, // (TE) Displays temperature and an optional humidity reading (0-10 representing 0-100%) - MODE_LOG, // (LO) Plays back temperature data (temperature in seconds slot) - MODE_PREFS, // (PR) Allows setting options for the application - MODE_SET, // (ST) Set time and date - NUM_MODES // Last item in the enum, it's the number of cases. -} ApplicationMode; - -typedef struct SensorReading { - bool is_valid; - uint8_t hour; - int8_t temperature; -} SensorReading; - -typedef struct ApplicationState { - // Internal application state - ApplicationMode mode; // Current mode - bool mode_changed; // Lets us perform one-time setup for a given mode - uint16_t mode_ticks; // Timeout for the mode (returns to clock after timeout expires) - uint8_t light_ticks; // Timeout for the light - bool led_on; // Indicates that the LED is on - uint8_t page; // Tracks the current page in log, prefs or settings. - bool is_fahrenheit; // User preference, C or F - - // Data logging - SensorReading logged_data[MAX_DATA_POINTS]; - - // User preference - bool show_humidity; // Indicates that the LED is on - - // BME280 calibration values - uint16_t dig_T1; - int16_t dig_T2; - int16_t dig_T3; - uint8_t dig_H1; - int16_t dig_H2; - uint8_t dig_H3; - int16_t dig_H4; - int16_t dig_H5; - int8_t dig_H6; -} ApplicationState; - -float read_temperature(int32_t *p_t_fine); -float read_humidity(int32_t t_fine); - -void log_data(); - -void do_clock_mode(); - -void do_temp_mode(); -void temp_mode_handle_primary_button(); - -void do_log_mode(); -void log_mode_handle_primary_button(); - -void do_prefs_mode(); -void prefs_mode_handle_primary_button(); -void prefs_mode_handle_secondary_button(); - -void do_set_time_mode(); -void set_time_mode_handle_primary_button(); -void set_time_mode_handle_secondary_button(); - -void cb_light_pressed(); -void cb_mode_pressed(); -void cb_alarm_pressed(); -void cb_tick(); diff --git a/apps/Sensor Watch BME280 Project/bme280.h b/apps/Sensor Watch BME280 Project/bme280.h deleted file mode 100644 index ba142582..00000000 --- a/apps/Sensor Watch BME280 Project/bme280.h +++ /dev/null @@ -1,85 +0,0 @@ -#define BME280_ADDRESS (0x77) -#define BME280_SOFT_RESET_CODE (0xB6) -#define BME280_STATUS_UPDATING_MASK (1 << 3) - -typedef enum BME280Register { - BME280_REGISTER_DIG_T1 = 0x88, - BME280_REGISTER_DIG_T2 = 0x8A, - BME280_REGISTER_DIG_T3 = 0x8C, - - BME280_REGISTER_DIG_P1 = 0x8E, - BME280_REGISTER_DIG_P2 = 0x90, - BME280_REGISTER_DIG_P3 = 0x92, - BME280_REGISTER_DIG_P4 = 0x94, - BME280_REGISTER_DIG_P5 = 0x96, - BME280_REGISTER_DIG_P6 = 0x98, - BME280_REGISTER_DIG_P7 = 0x9A, - BME280_REGISTER_DIG_P8 = 0x9C, - BME280_REGISTER_DIG_P9 = 0x9E, - - BME280_REGISTER_DIG_H1 = 0xA1, - BME280_REGISTER_DIG_H2 = 0xE1, - BME280_REGISTER_DIG_H3 = 0xE3, - BME280_REGISTER_DIG_H4 = 0xE4, - BME280_REGISTER_DIG_H5 = 0xE5, - BME280_REGISTER_DIG_H6 = 0xE7, - - BME280_REGISTER_CHIPID = 0xD0, - BME280_REGISTER_VERSION = 0xD1, - BME280_REGISTER_SOFTRESET = 0xE0, - - BME280_REGISTER_CAL26 = 0xE1, - - BME280_REGISTER_CONTROL_HUMID = 0xF2, - BME280_REGISTER_STATUS = 0XF3, - BME280_REGISTER_CONTROL = 0xF4, - BME280_REGISTER_CONFIG = 0xF5, - BME280_REGISTER_PRESSURE_DATA = 0xF7, - BME280_REGISTER_TEMP_DATA = 0xFA, - BME280_REGISTER_HUMID_DATA = 0xFD -} BME280Register; - -typedef enum BME280Control { - BME280_CONTROL_MODE_SLEEP = 0b00, - BME280_CONTROL_MODE_FORCED = 0b01, - BME280_CONTROL_MODE_NORMAL = 0b11, - BME280_CONTROL_PRESSURE_SAMPLING_NONE = 0b000 << 2, - BME280_CONTROL_PRESSURE_SAMPLING_X1 = 0b001 << 2, - BME280_CONTROL_PRESSURE_SAMPLING_X2 = 0b010 << 2, - BME280_CONTROL_PRESSURE_SAMPLING_X4 = 0b011 << 2, - BME280_CONTROL_PRESSURE_SAMPLING_X8 = 0b100 << 2, - BME280_CONTROL_PRESSURE_SAMPLING_X16 = 0b101 << 2, - BME280_CONTROL_TEMPERATURE_SAMPLING_NONE = 0b000 << 5, - BME280_CONTROL_TEMPERATURE_SAMPLING_X1 = 0b001 << 5, - BME280_CONTROL_TEMPERATURE_SAMPLING_X2 = 0b010 << 5, - BME280_CONTROL_TEMPERATURE_SAMPLING_X4 = 0b011 << 5, - BME280_CONTROL_TEMPERATURE_SAMPLING_X8 = 0b100 << 5, - BME280_CONTROL_TEMPERATURE_SAMPLING_X16 = 0b101 << 5 -} BME280Control; - -typedef enum BME280ControlHumidity { - BME280_CONTROL_HUMID_SAMPLING_NONE = 0b000, - BME280_CONTROL_HUMID_SAMPLING_X1 = 0b001, - BME280_CONTROL_HUMID_SAMPLING_X2 = 0b010, - BME280_CONTROL_HUMID_SAMPLING_X4 = 0b011, - BME280_CONTROL_HUMID_SAMPLING_X8 = 0b100, - BME280_CONTROL_HUMID_SAMPLING_X16 = 0b101 -} BME280ControlHumidity; - -typedef enum BME280Filter { - BME280_CONFIG_FILTER_OFF = 0b000 << 2, - BME280_CONFIG_FILTER_X2 = 0b001 << 2, - BME280_CONFIG_FILTER_X4 = 0b010 << 2, - BME280_CONFIG_FILTER_X8 = 0b011 << 2, - BME280_CONFIG_FILTER_X16 = 0b10 << 2, - BME280_CONFIG_STANDBY_MS_0_5 = 0b000 << 5, - BME280_CONFIG_STANDBY_MS_10 = 0b110 << 5, - BME280_CONFIG_STANDBY_MS_20 = 0b111 << 5, - BME280_CONFIG_STANDBY_MS_62_5 = 0b001 << 5, - BME280_CONFIG_STANDBY_MS_125 = 0b010 << 5, - BME280_CONFIG_STANDBY_MS_250 = 0b011 << 5, - BME280_CONFIG_STANDBY_MS_500 = 0b100 << 5, - BME280_CONFIG_STANDBY_MS_1000 = 0b101 << 5 -} BME280Filter; - -inline uint16_t make_le_16(uint16_t val) { return (val >> 8) | (val << 8); } diff --git a/apps/Sensor Watch BME280 Project/make/Makefile b/apps/Sensor Watch BME280 Project/make/Makefile deleted file mode 100755 index c66ad20c..00000000 --- a/apps/Sensor Watch BME280 Project/make/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -TOP = ../../.. -include $(TOP)/make.mk - -INCLUDES += \ - -I../ - -SRCS += \ - ../app.c - -include $(TOP)/rules.mk diff --git a/apps/Sensor Watch Buzzer Demo/app.c b/apps/Sensor Watch Buzzer Demo/app.c deleted file mode 100644 index 58158dff..00000000 --- a/apps/Sensor Watch Buzzer Demo/app.c +++ /dev/null @@ -1,134 +0,0 @@ -#include -#include -#include "watch.h" - -typedef struct ApplicationState { - bool play; -} ApplicationState; - -ApplicationState application_state; - - -void cb_alarm_pressed() { - application_state.play = true; -} - -void app_init() { - memset(&application_state, 0, sizeof(application_state)); -} - -void app_wake_from_backup() { -} - -void app_setup() { - watch_register_extwake_callback(BTN_ALARM, cb_alarm_pressed, true); - - watch_enable_display(); - - watch_enable_buzzer(); -} - -void app_prepare_for_standby() { - watch_display_string(" rains ", 2); -} - -void app_wake_from_standby() { -} - -bool app_loop() { - if (application_state.play) { - printf("Playing song...\n"); - const BuzzerNote rains[] = { - BUZZER_NOTE_A4, - BUZZER_NOTE_F5, - BUZZER_NOTE_REST, - BUZZER_NOTE_A4, - BUZZER_NOTE_E5, - BUZZER_NOTE_REST, - BUZZER_NOTE_A4, - BUZZER_NOTE_F5, - BUZZER_NOTE_G5, - BUZZER_NOTE_E5, - BUZZER_NOTE_REST, - BUZZER_NOTE_A4, - BUZZER_NOTE_G5, - BUZZER_NOTE_F5, - BUZZER_NOTE_E5, - BUZZER_NOTE_D5, - BUZZER_NOTE_E5, - BUZZER_NOTE_REST, - - BUZZER_NOTE_A5, - BUZZER_NOTE_REST, - BUZZER_NOTE_A5, - BUZZER_NOTE_A5SHARP_B5FLAT, - BUZZER_NOTE_G5, - BUZZER_NOTE_REST, - BUZZER_NOTE_C5, - BUZZER_NOTE_A5, - BUZZER_NOTE_A5SHARP_B5FLAT, - BUZZER_NOTE_G5, - BUZZER_NOTE_REST, - BUZZER_NOTE_D5, - BUZZER_NOTE_A5SHARP_B5FLAT, - BUZZER_NOTE_A5, - BUZZER_NOTE_G5, - BUZZER_NOTE_F5, - BUZZER_NOTE_E5, - }; - const uint16_t durations[] = { - 200, - 600, - 100, - 200, - 600, - 100, - 200, - 400, - 400, - 600, - 100, - 200, - 400, - 400, - 400, - 400, - 800, - 600, - - 200, - 50, - 400, - 200, - 400, - 100, - 200, - 400, - 400, - 400, - 200, - 200, - 400, - 400, - 400, - 400, - 900, - }; - application_state.play = false; - for(size_t i = 0; i < sizeof(rains); i++) { - char buf[9] = {0}; - if (rains[i] == BUZZER_NOTE_REST) { - printf("rest for %d ms\n", durations[i]); - sprintf(buf, "%2drESt ", i); - } else { - printf("playing note %2d: %3.0f Hz for %d ms\n", i, 1000000.0 / (float)NotePeriods[rains[i]], durations[i]); - sprintf(buf, "%2d%6d", i, NotePeriods[rains[i]]); - } - watch_display_string(buf, 2); - watch_buzzer_play_note(rains[i], durations[i]); - } - printf("done!\n\n"); - } - - return true; -} diff --git a/apps/Sensor Watch Buzzer Demo/make/Makefile b/apps/Sensor Watch Buzzer Demo/make/Makefile deleted file mode 100755 index c66ad20c..00000000 --- a/apps/Sensor Watch Buzzer Demo/make/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -TOP = ../../.. -include $(TOP)/make.mk - -INCLUDES += \ - -I../ - -SRCS += \ - ../app.c - -include $(TOP)/rules.mk diff --git a/apps/Sensor Watch SPI Test/app.c b/apps/Sensor Watch SPI Test/app.c deleted file mode 100644 index 3fba9386..00000000 --- a/apps/Sensor Watch SPI Test/app.c +++ /dev/null @@ -1,71 +0,0 @@ -#include -#include -#include -#include "watch.h" - -// NOTE: as of this writing (10/25/21) there is no SPI controller functionality in the watch library. -// this is a very basic app to confirm that SPI is working, tested with board OSO-MISC-21-001 and a GD25Q16C Flash chip. -// The updated SPI Flash sensor board design is OSO-MISC-21-017 (it's easier to build, 0603 passives instead of 0402's). - -struct io_descriptor *io; -struct spi_m_sync_descriptor SPI_0; - -void app_init() { - // SPI_0_CLOCK_init - hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_CORE, CONF_GCLK_SERCOM3_CORE_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos)); - hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_SLOW, CONF_GCLK_SERCOM3_SLOW_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos)); - hri_mclk_set_APBCMASK_SERCOM3_bit(MCLK); - - spi_m_sync_init(&SPI_0, SERCOM3); - - // SPI_0_PORT_init - gpio_set_pin_level(A3, true); - gpio_set_pin_direction(A3, GPIO_DIRECTION_OUT); - gpio_set_pin_function(A3, GPIO_PIN_FUNCTION_OFF); - - gpio_set_pin_level(A2, false); - gpio_set_pin_direction(A2, GPIO_DIRECTION_OUT); - gpio_set_pin_function(A2, PINMUX_PB02C_SERCOM3_PAD0); - - gpio_set_pin_direction(A4, GPIO_DIRECTION_IN); - gpio_set_pin_pull_mode(A4, GPIO_PULL_OFF); - gpio_set_pin_function(A4, PINMUX_PB00C_SERCOM3_PAD2); - - gpio_set_pin_level(A1, false); - gpio_set_pin_direction(A1, GPIO_DIRECTION_OUT); - gpio_set_pin_function(A1, PINMUX_PB01C_SERCOM3_PAD3); - - spi_m_sync_get_io_descriptor(&SPI_0, &io); - spi_m_sync_enable(&SPI_0); -} - -void app_wake_from_backup() { -} - -void app_setup() { -} - -void app_prepare_for_standby() { -} - -void app_wake_from_standby() { -} - -static uint8_t get_id_command[4] = {0x9F}; - -bool app_loop() { - watch_set_pin_level(A3, false); - io_write(io, get_id_command, 1); - uint8_t buf[3] = {0}; - - // should print 0, 0, 0 - printf("blank: %x, %x, %x\n", buf[0], buf[1], buf[2]); - io_read(io, buf, 3); - watch_set_pin_level(A3, true); - // should print c8, 40, 15 - printf("ident: %x, %x, %x\n", buf[0], buf[1], buf[2]); - - delay_ms(100); - - return false; -} diff --git a/apps/Sensor Watch SPI Test/make/Makefile b/apps/Sensor Watch SPI Test/make/Makefile deleted file mode 100755 index c66ad20c..00000000 --- a/apps/Sensor Watch SPI Test/make/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -TOP = ../../.. -include $(TOP)/make.mk - -INCLUDES += \ - -I../ - -SRCS += \ - ../app.c - -include $(TOP)/rules.mk diff --git a/apps/Sensor Watch Starter Project/app.c b/apps/Sensor Watch Starter Project/app.c deleted file mode 100644 index fa887bae..00000000 --- a/apps/Sensor Watch Starter Project/app.c +++ /dev/null @@ -1,198 +0,0 @@ -#include -#include -#include "watch.h" - -////////////////////////////////////////////////////////////////////////////////////////// -// This section sets up types and storage for our application state. -// You can tear this out and replace it with whatever you want. -typedef enum ApplicationMode { - MODE_HELLO = 0, - MODE_THERE -} ApplicationMode; - -typedef enum LightColor { - COLOR_RED = 0, - COLOR_GREEN, - COLOR_YELLOW -} LightColor; - -typedef struct ApplicationState { - ApplicationMode mode; - LightColor color; - bool light_on; - bool beep; - uint8_t wake_count; - bool enter_sleep_mode; -} ApplicationState; - -ApplicationState application_state; - - -////////////////////////////////////////////////////////////////////////////////////////// -// This section defines the callbacks for our button press events (implemented at bottom). -// Add any other callbacks you may need either here or in another file. -void cb_light_pressed(); -void cb_mode_pressed(); -void cb_alarm_pressed(); - - -////////////////////////////////////////////////////////////////////////////////////////// -// This section contains the required functions for any watch app. You should tear out -// all the code in these functions when writing your app, but you must implement all -// of the functions, even if they are empty stubs. You can also replace the documentation -// lines with documentation that describes what your functions do! - -/** - * @brief the app_init function is called before anything else. Use it to set up any - * internal data structures or application state required by your app. - */ -void app_init() { - memset(&application_state, 0, sizeof(application_state)); -} - -/** - * @brief the app_wake_from_backup function is only called if your app is waking from - * the ultra-low power BACKUP sleep mode. You may have chosen to store some state in the - * RTC's backup registers prior to entering this mode. You may restore that state here. - * - * @see watch_enter_deep_sleep() - */ -void app_wake_from_backup() { - // This app does not support BACKUP mode. -} - -/** - * @brief the app_setup function is like setup() in Arduino. It is called once when the - * program begins. You should set pin modes and enable any peripherals you want to - * set up (real-time clock, I2C, etc.) Depending on your application, you may or may not - * want to configure sensors on your sensor board here. For example, a low-power - * accelerometer that will run at all times should be configured here, whereas you may - * want to enable a more power-hungry environmental sensor only when you need it. - * - * @note If your app enters the Sleep or Deep Sleep modes, this function will be called - * again on wake, since those modes will have disabled all pins and peripherals; you'll - * likely need to set them up again. This function will also be called again if your app - * entered the ultra-low power BACKUP mode, since BACKUP mode will have done all that and - * also wiped out the system RAM. Note that when this is called after waking from sleep, - * the RTC will still be configured with the correct date and time. - */ -void app_setup() { - watch_enable_leds(); - watch_enable_buzzer(); - - watch_enable_external_interrupts(); - // This starter app demonstrates three different ways of using the button interrupts. - // The BTN_MODE interrupt only triggers on a rising edge, so the mode changes once per press. - watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); - // The BTN_LIGHT interrupt triggers on both rising and falling edges. The callback then checks - // the pin state when triggered: on a button down event, it increments the color and turns the - // LED on, whereas on a button up event, it turns the light off. - watch_register_interrupt_callback(BTN_LIGHT, cb_light_pressed, INTERRUPT_TRIGGER_BOTH); - // The BTN_ALARM callback is on an external wake pin; we can avoid using the EIC for this pin - // by using the extwake interrupt — but note that it can only trigger on either a rising or - // a falling edge, not both. - watch_register_extwake_callback(BTN_ALARM, cb_alarm_pressed, true); - - watch_enable_display(); -} - -/** - * @brief the app_prepare_for_standby function is called before the watch goes into STANDBY mode. - * In STANDBY mode, most peripherals are shut down, and no code will run until the watch receives - * an interrupt (generally either the 1Hz tick or a press on one of the buttons). - */ -void app_prepare_for_standby() { -} - -/** - * @brief the app_wake_from_standby function is called after the watch wakes from STANDBY mode, - * but before your main app_loop. - */ -void app_wake_from_standby() { - application_state.wake_count++; -} - -/** - * @brief the app_loop function is called once on app startup and then again each time the - * watch exits STANDBY mode. - */ -bool app_loop() { - if (application_state.beep) { - watch_buzzer_play_note(BUZZER_NOTE_C7, 50); - application_state.beep = false; - } - - // set the LED to a color - if (application_state.light_on) { - switch (application_state.color) { - case COLOR_RED: - watch_set_led_red(); - break; - case COLOR_GREEN: - watch_set_led_green(); - break; - case COLOR_YELLOW: - watch_set_led_yellow(); - break; - } - } else { - watch_set_led_off(); - } - - // Display the number of times we've woken up (modulo 32 to fit in 2 digits at top right) - char buf[3] = {0}; - sprintf(buf, "%2d", application_state.wake_count % 32); - watch_display_string(buf, 2); - - // display "Hello there" text - switch (application_state.mode) { - case MODE_HELLO: - watch_display_string("Hello", 5); - break; - case MODE_THERE: - watch_display_string("there", 5); - break; - } - - if (application_state.enter_sleep_mode) { - // wait a moment for the user's finger to be off the button - delay_ms(250); - - // nap time :) - watch_enter_deep_sleep_mode(); - - // we just woke up; wait a moment again for the user's finger to be off the button... - delay_ms(250); - - // and prevent ourselves from going right back to sleep. - application_state.enter_sleep_mode = false; - - // finally, after sleep, return false so that our app loop runs again and updates the display. - return false; - } - - return true; -} - - -////////////////////////////////////////////////////////////////////////////////////////// -// Implementations for our callback functions. Replace these with whatever functionality -// your app requires. -void cb_light_pressed() { - // always turn the light off when the pin goes low - if (watch_get_pin_level(BTN_LIGHT) == 0) { - application_state.light_on = false; - return; - } - application_state.color = (application_state.color + 1) % 3; - application_state.light_on = true; -} - -void cb_mode_pressed() { - application_state.mode = (application_state.mode + 1) % 2; - application_state.beep = true; -} - -void cb_alarm_pressed() { - application_state.enter_sleep_mode = true; -} diff --git a/apps/Sensor Watch Starter Project/make/Makefile b/apps/Sensor Watch Starter Project/make/Makefile deleted file mode 100755 index 09a59a05..00000000 --- a/apps/Sensor Watch Starter Project/make/Makefile +++ /dev/null @@ -1,26 +0,0 @@ -# Leave these lines at the top of the file. -# TOP should get us to the root of the project... -TOP = ../../.. -# ...and make.mk has all the watch library sources and includes. -include $(TOP)/make.mk - -# If you add any other subdirectories with header files you wish to include, add them after ../ -# Note that you will need to add a backslash at the end of any line you wish to continue, i.e. -# INCLUDES += \ -# -I../ \ -# -I../drivers/ \ -# -I../utils/ -INCLUDES += \ - -I../ \ - -# If you add any other source files you wish to compile, add them after ../app.c -# Note that you will need to add a backslash at the end of any line you wish to continue, i.e. -# SRCS += \ -# ../app.c \ -# ../drivers/bmp280.c \ -# ../utils/temperature.c -SRCS += \ - ../app.c \ - -# Leave this line at the bottom of the file; rules.mk has all the targets for making your project. -include $(TOP)/rules.mk diff --git a/apps/accelerometer-test/app.c b/apps/accelerometer-test/app.c new file mode 100644 index 00000000..bea00f6f --- /dev/null +++ b/apps/accelerometer-test/app.c @@ -0,0 +1,84 @@ +#include +#include +#include +#include +#include "watch.h" +#include "lis2dh.h" + +// This application displays data from the old Sensor Watch Motion sensor board. +// Note that this board required A0 to be set high to power the sensor. +// Future accelerometer boards will be powered directly from VCC. +// Also note that this board has its INT1 pin wired to A1, which is not an external +// wake pin. Future accelerometer boards will wire interrupt pins to A2 and A4. + +void cb_light_pressed() { +} + +void cb_mode_pressed() { +} + +void cb_alarm_pressed() { +} + +uint8_t interrupts = 0; +uint8_t last_interrupts = 0; +uint8_t ticks = 0; +char buf[13] = {0}; + +void cb_interrupt_1() { + interrupts++; +} + +void cb_tick() { + if (++ticks == 30) { + last_interrupts = interrupts; + interrupts = 0; + ticks = 0; + } +} + +void app_init() { + gpio_set_pin_direction(A0, GPIO_DIRECTION_OUT); + gpio_set_pin_function(A0, GPIO_PIN_FUNCTION_OFF); + gpio_set_pin_level(A0, true); + + watch_enable_display(); + watch_display_string("IN 0 0 0", 0); + + watch_enable_external_interrupts(); + watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); + watch_register_interrupt_callback(BTN_LIGHT, cb_light_pressed, INTERRUPT_TRIGGER_RISING); + watch_register_interrupt_callback(BTN_ALARM, cb_alarm_pressed, INTERRUPT_TRIGGER_RISING); + + watch_enable_i2c(); + + lis2dh_begin(); + lis2dh_set_data_rate(LIS2DH_DATA_RATE_10_HZ); + lis2dh_configure_aoi_int1( + LIS2DH_INTERRUPT_CONFIGURATION_OR | + LIS2DH_INTERRUPT_CONFIGURATION_X_HIGH_ENABLE | + LIS2DH_INTERRUPT_CONFIGURATION_Y_HIGH_ENABLE | + LIS2DH_INTERRUPT_CONFIGURATION_Z_HIGH_ENABLE, 96, 0, true); + + watch_register_interrupt_callback(A1, cb_interrupt_1, INTERRUPT_TRIGGER_RISING); + watch_rtc_register_tick_callback(cb_tick); +} + +void app_wake_from_backup() { +} + +void app_setup() { +} + +void app_prepare_for_standby() { +} + +void app_wake_from_standby() { +} + +bool app_loop() { + sprintf(buf, "IN%2d%3d%3d", ticks, interrupts, last_interrupts); + watch_display_string(buf, 0); + + return true; +} diff --git a/apps/accelerometer-test/make/Makefile b/apps/accelerometer-test/make/Makefile new file mode 100755 index 00000000..c66ad20c --- /dev/null +++ b/apps/accelerometer-test/make/Makefile @@ -0,0 +1,10 @@ +TOP = ../../.. +include $(TOP)/make.mk + +INCLUDES += \ + -I../ + +SRCS += \ + ../app.c + +include $(TOP)/rules.mk diff --git a/apps/buzzer-test/app.c b/apps/buzzer-test/app.c new file mode 100644 index 00000000..58158dff --- /dev/null +++ b/apps/buzzer-test/app.c @@ -0,0 +1,134 @@ +#include +#include +#include "watch.h" + +typedef struct ApplicationState { + bool play; +} ApplicationState; + +ApplicationState application_state; + + +void cb_alarm_pressed() { + application_state.play = true; +} + +void app_init() { + memset(&application_state, 0, sizeof(application_state)); +} + +void app_wake_from_backup() { +} + +void app_setup() { + watch_register_extwake_callback(BTN_ALARM, cb_alarm_pressed, true); + + watch_enable_display(); + + watch_enable_buzzer(); +} + +void app_prepare_for_standby() { + watch_display_string(" rains ", 2); +} + +void app_wake_from_standby() { +} + +bool app_loop() { + if (application_state.play) { + printf("Playing song...\n"); + const BuzzerNote rains[] = { + BUZZER_NOTE_A4, + BUZZER_NOTE_F5, + BUZZER_NOTE_REST, + BUZZER_NOTE_A4, + BUZZER_NOTE_E5, + BUZZER_NOTE_REST, + BUZZER_NOTE_A4, + BUZZER_NOTE_F5, + BUZZER_NOTE_G5, + BUZZER_NOTE_E5, + BUZZER_NOTE_REST, + BUZZER_NOTE_A4, + BUZZER_NOTE_G5, + BUZZER_NOTE_F5, + BUZZER_NOTE_E5, + BUZZER_NOTE_D5, + BUZZER_NOTE_E5, + BUZZER_NOTE_REST, + + BUZZER_NOTE_A5, + BUZZER_NOTE_REST, + BUZZER_NOTE_A5, + BUZZER_NOTE_A5SHARP_B5FLAT, + BUZZER_NOTE_G5, + BUZZER_NOTE_REST, + BUZZER_NOTE_C5, + BUZZER_NOTE_A5, + BUZZER_NOTE_A5SHARP_B5FLAT, + BUZZER_NOTE_G5, + BUZZER_NOTE_REST, + BUZZER_NOTE_D5, + BUZZER_NOTE_A5SHARP_B5FLAT, + BUZZER_NOTE_A5, + BUZZER_NOTE_G5, + BUZZER_NOTE_F5, + BUZZER_NOTE_E5, + }; + const uint16_t durations[] = { + 200, + 600, + 100, + 200, + 600, + 100, + 200, + 400, + 400, + 600, + 100, + 200, + 400, + 400, + 400, + 400, + 800, + 600, + + 200, + 50, + 400, + 200, + 400, + 100, + 200, + 400, + 400, + 400, + 200, + 200, + 400, + 400, + 400, + 400, + 900, + }; + application_state.play = false; + for(size_t i = 0; i < sizeof(rains); i++) { + char buf[9] = {0}; + if (rains[i] == BUZZER_NOTE_REST) { + printf("rest for %d ms\n", durations[i]); + sprintf(buf, "%2drESt ", i); + } else { + printf("playing note %2d: %3.0f Hz for %d ms\n", i, 1000000.0 / (float)NotePeriods[rains[i]], durations[i]); + sprintf(buf, "%2d%6d", i, NotePeriods[rains[i]]); + } + watch_display_string(buf, 2); + watch_buzzer_play_note(rains[i], durations[i]); + } + printf("done!\n\n"); + } + + return true; +} diff --git a/apps/buzzer-test/make/Makefile b/apps/buzzer-test/make/Makefile new file mode 100755 index 00000000..c66ad20c --- /dev/null +++ b/apps/buzzer-test/make/Makefile @@ -0,0 +1,10 @@ +TOP = ../../.. +include $(TOP)/make.mk + +INCLUDES += \ + -I../ + +SRCS += \ + ../app.c + +include $(TOP)/rules.mk diff --git a/apps/spi-test/app.c b/apps/spi-test/app.c new file mode 100644 index 00000000..3fba9386 --- /dev/null +++ b/apps/spi-test/app.c @@ -0,0 +1,71 @@ +#include +#include +#include +#include "watch.h" + +// NOTE: as of this writing (10/25/21) there is no SPI controller functionality in the watch library. +// this is a very basic app to confirm that SPI is working, tested with board OSO-MISC-21-001 and a GD25Q16C Flash chip. +// The updated SPI Flash sensor board design is OSO-MISC-21-017 (it's easier to build, 0603 passives instead of 0402's). + +struct io_descriptor *io; +struct spi_m_sync_descriptor SPI_0; + +void app_init() { + // SPI_0_CLOCK_init + hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_CORE, CONF_GCLK_SERCOM3_CORE_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos)); + hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_SLOW, CONF_GCLK_SERCOM3_SLOW_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos)); + hri_mclk_set_APBCMASK_SERCOM3_bit(MCLK); + + spi_m_sync_init(&SPI_0, SERCOM3); + + // SPI_0_PORT_init + gpio_set_pin_level(A3, true); + gpio_set_pin_direction(A3, GPIO_DIRECTION_OUT); + gpio_set_pin_function(A3, GPIO_PIN_FUNCTION_OFF); + + gpio_set_pin_level(A2, false); + gpio_set_pin_direction(A2, GPIO_DIRECTION_OUT); + gpio_set_pin_function(A2, PINMUX_PB02C_SERCOM3_PAD0); + + gpio_set_pin_direction(A4, GPIO_DIRECTION_IN); + gpio_set_pin_pull_mode(A4, GPIO_PULL_OFF); + gpio_set_pin_function(A4, PINMUX_PB00C_SERCOM3_PAD2); + + gpio_set_pin_level(A1, false); + gpio_set_pin_direction(A1, GPIO_DIRECTION_OUT); + gpio_set_pin_function(A1, PINMUX_PB01C_SERCOM3_PAD3); + + spi_m_sync_get_io_descriptor(&SPI_0, &io); + spi_m_sync_enable(&SPI_0); +} + +void app_wake_from_backup() { +} + +void app_setup() { +} + +void app_prepare_for_standby() { +} + +void app_wake_from_standby() { +} + +static uint8_t get_id_command[4] = {0x9F}; + +bool app_loop() { + watch_set_pin_level(A3, false); + io_write(io, get_id_command, 1); + uint8_t buf[3] = {0}; + + // should print 0, 0, 0 + printf("blank: %x, %x, %x\n", buf[0], buf[1], buf[2]); + io_read(io, buf, 3); + watch_set_pin_level(A3, true); + // should print c8, 40, 15 + printf("ident: %x, %x, %x\n", buf[0], buf[1], buf[2]); + + delay_ms(100); + + return false; +} diff --git a/apps/spi-test/make/Makefile b/apps/spi-test/make/Makefile new file mode 100755 index 00000000..c66ad20c --- /dev/null +++ b/apps/spi-test/make/Makefile @@ -0,0 +1,10 @@ +TOP = ../../.. +include $(TOP)/make.mk + +INCLUDES += \ + -I../ + +SRCS += \ + ../app.c + +include $(TOP)/rules.mk diff --git a/apps/starter-project/app.c b/apps/starter-project/app.c new file mode 100644 index 00000000..fa887bae --- /dev/null +++ b/apps/starter-project/app.c @@ -0,0 +1,198 @@ +#include +#include +#include "watch.h" + +////////////////////////////////////////////////////////////////////////////////////////// +// This section sets up types and storage for our application state. +// You can tear this out and replace it with whatever you want. +typedef enum ApplicationMode { + MODE_HELLO = 0, + MODE_THERE +} ApplicationMode; + +typedef enum LightColor { + COLOR_RED = 0, + COLOR_GREEN, + COLOR_YELLOW +} LightColor; + +typedef struct ApplicationState { + ApplicationMode mode; + LightColor color; + bool light_on; + bool beep; + uint8_t wake_count; + bool enter_sleep_mode; +} ApplicationState; + +ApplicationState application_state; + + +////////////////////////////////////////////////////////////////////////////////////////// +// This section defines the callbacks for our button press events (implemented at bottom). +// Add any other callbacks you may need either here or in another file. +void cb_light_pressed(); +void cb_mode_pressed(); +void cb_alarm_pressed(); + + +////////////////////////////////////////////////////////////////////////////////////////// +// This section contains the required functions for any watch app. You should tear out +// all the code in these functions when writing your app, but you must implement all +// of the functions, even if they are empty stubs. You can also replace the documentation +// lines with documentation that describes what your functions do! + +/** + * @brief the app_init function is called before anything else. Use it to set up any + * internal data structures or application state required by your app. + */ +void app_init() { + memset(&application_state, 0, sizeof(application_state)); +} + +/** + * @brief the app_wake_from_backup function is only called if your app is waking from + * the ultra-low power BACKUP sleep mode. You may have chosen to store some state in the + * RTC's backup registers prior to entering this mode. You may restore that state here. + * + * @see watch_enter_deep_sleep() + */ +void app_wake_from_backup() { + // This app does not support BACKUP mode. +} + +/** + * @brief the app_setup function is like setup() in Arduino. It is called once when the + * program begins. You should set pin modes and enable any peripherals you want to + * set up (real-time clock, I2C, etc.) Depending on your application, you may or may not + * want to configure sensors on your sensor board here. For example, a low-power + * accelerometer that will run at all times should be configured here, whereas you may + * want to enable a more power-hungry environmental sensor only when you need it. + * + * @note If your app enters the Sleep or Deep Sleep modes, this function will be called + * again on wake, since those modes will have disabled all pins and peripherals; you'll + * likely need to set them up again. This function will also be called again if your app + * entered the ultra-low power BACKUP mode, since BACKUP mode will have done all that and + * also wiped out the system RAM. Note that when this is called after waking from sleep, + * the RTC will still be configured with the correct date and time. + */ +void app_setup() { + watch_enable_leds(); + watch_enable_buzzer(); + + watch_enable_external_interrupts(); + // This starter app demonstrates three different ways of using the button interrupts. + // The BTN_MODE interrupt only triggers on a rising edge, so the mode changes once per press. + watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); + // The BTN_LIGHT interrupt triggers on both rising and falling edges. The callback then checks + // the pin state when triggered: on a button down event, it increments the color and turns the + // LED on, whereas on a button up event, it turns the light off. + watch_register_interrupt_callback(BTN_LIGHT, cb_light_pressed, INTERRUPT_TRIGGER_BOTH); + // The BTN_ALARM callback is on an external wake pin; we can avoid using the EIC for this pin + // by using the extwake interrupt — but note that it can only trigger on either a rising or + // a falling edge, not both. + watch_register_extwake_callback(BTN_ALARM, cb_alarm_pressed, true); + + watch_enable_display(); +} + +/** + * @brief the app_prepare_for_standby function is called before the watch goes into STANDBY mode. + * In STANDBY mode, most peripherals are shut down, and no code will run until the watch receives + * an interrupt (generally either the 1Hz tick or a press on one of the buttons). + */ +void app_prepare_for_standby() { +} + +/** + * @brief the app_wake_from_standby function is called after the watch wakes from STANDBY mode, + * but before your main app_loop. + */ +void app_wake_from_standby() { + application_state.wake_count++; +} + +/** + * @brief the app_loop function is called once on app startup and then again each time the + * watch exits STANDBY mode. + */ +bool app_loop() { + if (application_state.beep) { + watch_buzzer_play_note(BUZZER_NOTE_C7, 50); + application_state.beep = false; + } + + // set the LED to a color + if (application_state.light_on) { + switch (application_state.color) { + case COLOR_RED: + watch_set_led_red(); + break; + case COLOR_GREEN: + watch_set_led_green(); + break; + case COLOR_YELLOW: + watch_set_led_yellow(); + break; + } + } else { + watch_set_led_off(); + } + + // Display the number of times we've woken up (modulo 32 to fit in 2 digits at top right) + char buf[3] = {0}; + sprintf(buf, "%2d", application_state.wake_count % 32); + watch_display_string(buf, 2); + + // display "Hello there" text + switch (application_state.mode) { + case MODE_HELLO: + watch_display_string("Hello", 5); + break; + case MODE_THERE: + watch_display_string("there", 5); + break; + } + + if (application_state.enter_sleep_mode) { + // wait a moment for the user's finger to be off the button + delay_ms(250); + + // nap time :) + watch_enter_deep_sleep_mode(); + + // we just woke up; wait a moment again for the user's finger to be off the button... + delay_ms(250); + + // and prevent ourselves from going right back to sleep. + application_state.enter_sleep_mode = false; + + // finally, after sleep, return false so that our app loop runs again and updates the display. + return false; + } + + return true; +} + + +////////////////////////////////////////////////////////////////////////////////////////// +// Implementations for our callback functions. Replace these with whatever functionality +// your app requires. +void cb_light_pressed() { + // always turn the light off when the pin goes low + if (watch_get_pin_level(BTN_LIGHT) == 0) { + application_state.light_on = false; + return; + } + application_state.color = (application_state.color + 1) % 3; + application_state.light_on = true; +} + +void cb_mode_pressed() { + application_state.mode = (application_state.mode + 1) % 2; + application_state.beep = true; +} + +void cb_alarm_pressed() { + application_state.enter_sleep_mode = true; +} diff --git a/apps/starter-project/make/Makefile b/apps/starter-project/make/Makefile new file mode 100755 index 00000000..09a59a05 --- /dev/null +++ b/apps/starter-project/make/Makefile @@ -0,0 +1,26 @@ +# Leave these lines at the top of the file. +# TOP should get us to the root of the project... +TOP = ../../.. +# ...and make.mk has all the watch library sources and includes. +include $(TOP)/make.mk + +# If you add any other subdirectories with header files you wish to include, add them after ../ +# Note that you will need to add a backslash at the end of any line you wish to continue, i.e. +# INCLUDES += \ +# -I../ \ +# -I../drivers/ \ +# -I../utils/ +INCLUDES += \ + -I../ \ + +# If you add any other source files you wish to compile, add them after ../app.c +# Note that you will need to add a backslash at the end of any line you wish to continue, i.e. +# SRCS += \ +# ../app.c \ +# ../drivers/bmp280.c \ +# ../utils/temperature.c +SRCS += \ + ../app.c \ + +# Leave this line at the bottom of the file; rules.mk has all the targets for making your project. +include $(TOP)/rules.mk -- cgit v1.2.3 From e202c48b0a1a9838e91d020ca2b71214119b3c3d Mon Sep 17 00:00:00 2001 From: Joey Castillo Date: Sun, 5 Dec 2021 23:49:26 -0600 Subject: fix missing prototype warnings --- apps/accelerometer-test/app.c | 22 ++++---- apps/beats-time/app.c | 54 +++++++++---------- apps/buzzer-test/app.c | 14 ++--- apps/spi-test/app.c | 12 ++--- apps/starter-project/app.c | 24 ++++----- movement/lib/TOTP-MCU/sha1.c | 4 +- movement/movement.c | 60 +++++++++++----------- movement/movement.h | 8 +-- movement/watch_faces/clock/world_clock_face.c | 6 +-- movement/watch_faces/complications/day_one_face.c | 4 +- movement/watch_faces/demos/lis2dh_logging_face.c | 2 +- movement/watch_faces/demos/voltage_face.c | 2 +- .../watch_faces/thermistor/thermistor_driver.c | 6 +-- .../watch_faces/thermistor/thermistor_driver.h | 6 +-- .../thermistor/thermistor_logging_face.c | 4 +- .../thermistor/thermistor_readout_face.c | 2 +- utils/flash_watch_pyruler/flash_watch_pyruler.ino | 4 +- watch-library/driver/lis2dh.c | 16 +++--- watch-library/driver/lis2dh.h | 16 +++--- watch-library/hal/src/hal_io.c | 5 -- watch-library/hpl/core/hpl_core_port.h | 2 + watch-library/hpl/gclk/hpl_gclk.c | 1 + watch-library/hpl/mclk/hpl_mclk.c | 1 + watch-library/hpl/systick/hpl_systick.c | 1 + watch-library/hw/driver_init.h | 1 + watch-library/watch/watch.c | 2 +- watch-library/watch/watch.h | 2 +- watch-library/watch/watch_adc.c | 10 ++-- watch-library/watch/watch_adc.h | 6 +-- watch-library/watch/watch_app.h | 12 ++--- watch-library/watch/watch_buzzer.c | 8 +-- watch-library/watch/watch_buzzer.h | 8 +-- watch-library/watch/watch_deepsleep.c | 12 ++--- watch-library/watch/watch_deepsleep.h | 8 +-- watch-library/watch/watch_extint.c | 6 +-- watch-library/watch/watch_extint.h | 6 +-- watch-library/watch/watch_i2c.c | 4 +- watch-library/watch/watch_i2c.h | 4 +- watch-library/watch/watch_led.c | 12 ++--- watch-library/watch/watch_led.h | 12 ++--- watch-library/watch/watch_private.c | 10 ++-- watch-library/watch/watch_private.h | 17 ++++-- watch-library/watch/watch_rtc.c | 14 ++--- watch-library/watch/watch_rtc.h | 10 ++-- watch-library/watch/watch_slcd.c | 20 ++++---- watch-library/watch/watch_slcd.h | 16 +++--- 46 files changed, 242 insertions(+), 234 deletions(-) diff --git a/apps/accelerometer-test/app.c b/apps/accelerometer-test/app.c index bea00f6f..8bd6537e 100644 --- a/apps/accelerometer-test/app.c +++ b/apps/accelerometer-test/app.c @@ -11,13 +11,13 @@ // Also note that this board has its INT1 pin wired to A1, which is not an external // wake pin. Future accelerometer boards will wire interrupt pins to A2 and A4. -void cb_light_pressed() { +void cb_light_pressed(void) { } -void cb_mode_pressed() { +void cb_mode_pressed(void) { } -void cb_alarm_pressed() { +void cb_alarm_pressed(void) { } uint8_t interrupts = 0; @@ -25,11 +25,11 @@ uint8_t last_interrupts = 0; uint8_t ticks = 0; char buf[13] = {0}; -void cb_interrupt_1() { +void cb_interrupt_1(void) { interrupts++; } -void cb_tick() { +void cb_tick(void) { if (++ticks == 30) { last_interrupts = interrupts; interrupts = 0; @@ -37,7 +37,7 @@ void cb_tick() { } } -void app_init() { +void app_init(void) { gpio_set_pin_direction(A0, GPIO_DIRECTION_OUT); gpio_set_pin_function(A0, GPIO_PIN_FUNCTION_OFF); gpio_set_pin_level(A0, true); @@ -64,19 +64,19 @@ void app_init() { watch_rtc_register_tick_callback(cb_tick); } -void app_wake_from_backup() { +void app_wake_from_backup(void) { } -void app_setup() { +void app_setup(void) { } -void app_prepare_for_standby() { +void app_prepare_for_standby(void) { } -void app_wake_from_standby() { +void app_wake_from_standby(void) { } -bool app_loop() { +bool app_loop(void) { sprintf(buf, "IN%2d%3d%3d", ticks, interrupts, last_interrupts); watch_display_string(buf, 0); diff --git a/apps/beats-time/app.c b/apps/beats-time/app.c index 5c68a3e8..3a8c2dac 100644 --- a/apps/beats-time/app.c +++ b/apps/beats-time/app.c @@ -26,19 +26,19 @@ typedef struct ApplicationState { uint8_t subsecond; // a value from 0 to (BEAT_REFRESH_FREQUENCY - 1) indicating the fractional second } ApplicationState; -void do_clock_mode(); -void do_beats_mode(); -void do_set_time_mode(); -void set_time_mode_handle_primary_button(); -void set_time_mode_handle_secondary_button(); +void do_clock_mode(void); +void do_beats_mode(void); +void do_set_time_mode(void); +void set_time_mode_handle_primary_button(void); +void set_time_mode_handle_secondary_button(void); float clock2beats(uint16_t, uint16_t, uint16_t, int16_t); -void cb_light_pressed(); -void cb_mode_pressed(); -void cb_alarm_pressed(); -void cb_tick(); -void cb_fast_tick(); +void cb_light_pressed(void); +void cb_mode_pressed(void); +void cb_alarm_pressed(void); +void cb_tick(void); +void cb_fast_tick(void); ApplicationState application_state; char buf[16] = {0}; @@ -46,15 +46,15 @@ char buf[16] = {0}; /** * @brief Zeroes out the application state struct. */ -void app_init() { +void app_init(void) { memset(&application_state, 0, sizeof(application_state)); } -void app_wake_from_backup() { +void app_wake_from_backup(void) { // This app does not support BACKUP mode. } -void app_setup() { +void app_setup(void) { watch_enable_external_interrupts(); watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); watch_register_interrupt_callback(BTN_LIGHT, cb_light_pressed, INTERRUPT_TRIGGER_RISING); @@ -67,13 +67,13 @@ void app_setup() { watch_rtc_register_tick_callback(cb_tick); } -void app_prepare_for_standby() { +void app_prepare_for_standby(void) { } -void app_wake_from_standby() { +void app_wake_from_standby(void) { } -void update_tick_frequency() { +static void update_tick_frequency(void) { watch_rtc_disable_all_periodic_callbacks(); if (application_state.mode == MODE_BEATS) { watch_rtc_register_periodic_callback(cb_fast_tick, BEAT_REFRESH_FREQUENCY); @@ -82,7 +82,7 @@ void update_tick_frequency() { } } -bool app_loop() { +bool app_loop(void) { // play a beep if the mode has changed in response to a user's press of the MODE button if (application_state.mode_changed) { // low note for nonzero case, high note for return to clock @@ -135,7 +135,7 @@ bool app_loop() { return true; } -void do_clock_mode() { +void do_clock_mode(void) { watch_date_time date_time = watch_rtc_get_date_time(); const char months[12][3] = {"JA", "FE", "MR", "AR", "MA", "JN", "JL", "AU", "SE", "OC", "NO", "dE"}; @@ -146,7 +146,7 @@ void do_clock_mode() { } -void do_beats_mode() { +void do_beats_mode(void) { watch_clear_colon(); watch_date_time date_time = watch_rtc_get_date_time(); @@ -168,7 +168,7 @@ float clock2beats(uint16_t hours, uint16_t minutes, uint16_t seconds, int16_t ut return beats; } -void do_set_time_mode() { +void do_set_time_mode(void) { watch_date_time date_time = watch_rtc_get_date_time(); watch_display_string(" ", 0); @@ -196,12 +196,12 @@ void do_set_time_mode() { watch_set_pixel(1, 12); // required for T in position 1 } -void set_time_mode_handle_primary_button() { +void set_time_mode_handle_primary_button(void) { application_state.page++; if (application_state.page == 6) application_state.page = 0; } -void set_time_mode_handle_secondary_button() { +void set_time_mode_handle_secondary_button(void) { watch_date_time date_time = watch_rtc_get_date_time(); const uint8_t days_in_month[12] = {31, 28, 31, 30, 31, 30, 30, 31, 30, 31, 30, 31}; @@ -234,14 +234,14 @@ void set_time_mode_handle_secondary_button() { watch_rtc_set_date_time(date_time); } -void cb_mode_pressed() { +void cb_mode_pressed(void) { application_state.mode = (application_state.mode + 1) % NUM_MODES; application_state.mode_changed = true; application_state.mode_ticks = 300; application_state.page = 0; } -void cb_light_pressed() { +void cb_light_pressed(void) { switch (application_state.mode) { case MODE_SET: set_time_mode_handle_secondary_button(); @@ -252,7 +252,7 @@ void cb_light_pressed() { } } -void cb_alarm_pressed() { +void cb_alarm_pressed(void) { switch (application_state.mode) { case MODE_SET: set_time_mode_handle_primary_button(); @@ -262,7 +262,7 @@ void cb_alarm_pressed() { } } -void cb_tick() { +void cb_tick(void) { if (application_state.light_ticks > 0) { application_state.light_ticks--; } @@ -271,7 +271,7 @@ void cb_tick() { } } -void cb_fast_tick() { +void cb_fast_tick(void) { watch_date_time date_time = watch_rtc_get_date_time(); if (date_time.unit.second != application_state.last_second) { application_state.last_second = date_time.unit.second; diff --git a/apps/buzzer-test/app.c b/apps/buzzer-test/app.c index 58158dff..65d2356c 100644 --- a/apps/buzzer-test/app.c +++ b/apps/buzzer-test/app.c @@ -9,18 +9,18 @@ typedef struct ApplicationState { ApplicationState application_state; -void cb_alarm_pressed() { +void cb_alarm_pressed(void) { application_state.play = true; } -void app_init() { +void app_init(void) { memset(&application_state, 0, sizeof(application_state)); } -void app_wake_from_backup() { +void app_wake_from_backup(void) { } -void app_setup() { +void app_setup(void) { watch_register_extwake_callback(BTN_ALARM, cb_alarm_pressed, true); watch_enable_display(); @@ -28,14 +28,14 @@ void app_setup() { watch_enable_buzzer(); } -void app_prepare_for_standby() { +void app_prepare_for_standby(void) { watch_display_string(" rains ", 2); } -void app_wake_from_standby() { +void app_wake_from_standby(void) { } -bool app_loop() { +bool app_loop(void) { if (application_state.play) { printf("Playing song...\n"); const BuzzerNote rains[] = { diff --git a/apps/spi-test/app.c b/apps/spi-test/app.c index 3fba9386..6ddd2782 100644 --- a/apps/spi-test/app.c +++ b/apps/spi-test/app.c @@ -10,7 +10,7 @@ struct io_descriptor *io; struct spi_m_sync_descriptor SPI_0; -void app_init() { +void app_init(void) { // SPI_0_CLOCK_init hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_CORE, CONF_GCLK_SERCOM3_CORE_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos)); hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM3_GCLK_ID_SLOW, CONF_GCLK_SERCOM3_SLOW_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos)); @@ -39,21 +39,21 @@ void app_init() { spi_m_sync_enable(&SPI_0); } -void app_wake_from_backup() { +void app_wake_from_backup(void) { } -void app_setup() { +void app_setup(void) { } -void app_prepare_for_standby() { +void app_prepare_for_standby(void) { } -void app_wake_from_standby() { +void app_wake_from_standby(void) { } static uint8_t get_id_command[4] = {0x9F}; -bool app_loop() { +bool app_loop(void) { watch_set_pin_level(A3, false); io_write(io, get_id_command, 1); uint8_t buf[3] = {0}; diff --git a/apps/starter-project/app.c b/apps/starter-project/app.c index fa887bae..9a4ef4fe 100644 --- a/apps/starter-project/app.c +++ b/apps/starter-project/app.c @@ -31,9 +31,9 @@ ApplicationState application_state; ////////////////////////////////////////////////////////////////////////////////////////// // This section defines the callbacks for our button press events (implemented at bottom). // Add any other callbacks you may need either here or in another file. -void cb_light_pressed(); -void cb_mode_pressed(); -void cb_alarm_pressed(); +void cb_light_pressed(void); +void cb_mode_pressed(void); +void cb_alarm_pressed(void); ////////////////////////////////////////////////////////////////////////////////////////// @@ -46,7 +46,7 @@ void cb_alarm_pressed(); * @brief the app_init function is called before anything else. Use it to set up any * internal data structures or application state required by your app. */ -void app_init() { +void app_init(void) { memset(&application_state, 0, sizeof(application_state)); } @@ -57,7 +57,7 @@ void app_init() { * * @see watch_enter_deep_sleep() */ -void app_wake_from_backup() { +void app_wake_from_backup(void) { // This app does not support BACKUP mode. } @@ -76,7 +76,7 @@ void app_wake_from_backup() { * also wiped out the system RAM. Note that when this is called after waking from sleep, * the RTC will still be configured with the correct date and time. */ -void app_setup() { +void app_setup(void) { watch_enable_leds(); watch_enable_buzzer(); @@ -101,14 +101,14 @@ void app_setup() { * In STANDBY mode, most peripherals are shut down, and no code will run until the watch receives * an interrupt (generally either the 1Hz tick or a press on one of the buttons). */ -void app_prepare_for_standby() { +void app_prepare_for_standby(void) { } /** * @brief the app_wake_from_standby function is called after the watch wakes from STANDBY mode, * but before your main app_loop. */ -void app_wake_from_standby() { +void app_wake_from_standby(void) { application_state.wake_count++; } @@ -116,7 +116,7 @@ void app_wake_from_standby() { * @brief the app_loop function is called once on app startup and then again each time the * watch exits STANDBY mode. */ -bool app_loop() { +bool app_loop(void) { if (application_state.beep) { watch_buzzer_play_note(BUZZER_NOTE_C7, 50); application_state.beep = false; @@ -178,7 +178,7 @@ bool app_loop() { ////////////////////////////////////////////////////////////////////////////////////////// // Implementations for our callback functions. Replace these with whatever functionality // your app requires. -void cb_light_pressed() { +void cb_light_pressed(void) { // always turn the light off when the pin goes low if (watch_get_pin_level(BTN_LIGHT) == 0) { application_state.light_on = false; @@ -188,11 +188,11 @@ void cb_light_pressed() { application_state.light_on = true; } -void cb_mode_pressed() { +void cb_mode_pressed(void) { application_state.mode = (application_state.mode + 1) % 2; application_state.beep = true; } -void cb_alarm_pressed() { +void cb_alarm_pressed(void) { application_state.enter_sleep_mode = true; } diff --git a/movement/lib/TOTP-MCU/sha1.c b/movement/lib/TOTP-MCU/sha1.c index 8e918e64..3ac14856 100644 --- a/movement/lib/TOTP-MCU/sha1.c +++ b/movement/lib/TOTP-MCU/sha1.c @@ -38,7 +38,7 @@ uint32_t rol32(uint32_t number, uint8_t bits) { return ((number << bits) | (uint32_t)(number >> (32-bits))); } -void hashBlock() { +void hashBlock(void) { uint8_t i; uint32_t a,b,c,d,e,t; @@ -97,7 +97,7 @@ void writeArray(uint8_t *buffer, uint8_t size){ } } -void pad() { +void pad(void) { // Implement SHA-1 padding (fips180-2 ��5.1.1) // Pad with 0x80 followed by 0x00 until the end of the block diff --git a/movement/movement.c b/movement/movement.c index b41700b0..9f98fe4d 100644 --- a/movement/movement.c +++ b/movement/movement.c @@ -58,27 +58,27 @@ const int16_t movement_timezone_offsets[] = { const char movement_valid_position_0_chars[] = " AaBbCcDdEeFGgHhIiJKLMNnOoPQrSTtUuWXYZ-='+\\/0123456789"; const char movement_valid_position_1_chars[] = " ABCDEFHlJLNORTtUX-='01378"; -void cb_mode_btn_interrupt(); -void cb_light_btn_interrupt(); -void cb_alarm_btn_interrupt(); -void cb_alarm_btn_extwake(); -void cb_alarm_fired(); -void cb_fast_tick(); -void cb_tick(); - -static inline void _movement_reset_inactivity_countdown() { +void cb_mode_btn_interrupt(void); +void cb_light_btn_interrupt(void); +void cb_alarm_btn_interrupt(void); +void cb_alarm_btn_extwake(void); +void cb_alarm_fired(void); +void cb_fast_tick(void); +void cb_tick(void); + +static inline void _movement_reset_inactivity_countdown(void) { movement_state.le_mode_ticks = movement_le_inactivity_deadlines[movement_state.settings.bit.le_interval]; movement_state.timeout_ticks = movement_timeout_inactivity_deadlines[movement_state.settings.bit.to_interval]; } -static inline void _movement_enable_fast_tick_if_needed() { +static inline void _movement_enable_fast_tick_if_needed(void) { if (!movement_state.fast_tick_enabled) { movement_state.fast_ticks = 0; watch_rtc_register_periodic_callback(cb_fast_tick, 128); } } -static inline void _movement_disable_fast_tick_if_possible() { +static inline void _movement_disable_fast_tick_if_possible(void) { if ((movement_state.light_ticks == -1) && (movement_state.alarm_ticks == -1) && ((movement_state.light_down_timestamp + movement_state.mode_down_timestamp + movement_state.alarm_down_timestamp) == 0)) { @@ -87,7 +87,7 @@ static inline void _movement_disable_fast_tick_if_possible() { } } -void _movement_handle_background_tasks() { +static void _movement_handle_background_tasks(void) { for(uint8_t i = 0; i < MOVEMENT_NUM_FACES; i++) { // For each face, if the watch face wants a background task... if (watch_faces[i].wants_background_task != NULL && watch_faces[i].wants_background_task(&movement_state.settings, watch_face_contexts[i])) { @@ -107,7 +107,7 @@ void movement_request_tick_frequency(uint8_t freq) { watch_rtc_register_periodic_callback(cb_tick, freq); } -void movement_illuminate_led() { +void movement_illuminate_led(void) { if (movement_state.settings.bit.led_duration) { watch_set_led_color(movement_state.settings.bit.led_red_color ? (0xF | movement_state.settings.bit.led_red_color << 4) : 0, movement_state.settings.bit.led_green_color ? (0xF | movement_state.settings.bit.led_green_color << 4) : 0); @@ -121,22 +121,22 @@ void movement_move_to_face(uint8_t watch_face_index) { movement_state.next_watch_face = watch_face_index; } -void movement_move_to_next_face() { +void movement_move_to_next_face(void) { movement_move_to_face((movement_state.current_watch_face + 1) % MOVEMENT_NUM_FACES); } -void movement_play_signal() { +void movement_play_signal(void) { watch_buzzer_play_note(BUZZER_NOTE_C8, 75); watch_buzzer_play_note(BUZZER_NOTE_REST, 100); watch_buzzer_play_note(BUZZER_NOTE_C8, 100); } -void movement_play_alarm() { +void movement_play_alarm(void) { movement_state.alarm_ticks = 128 * 5 - 80; // 80 ticks short of 5 seconds, or 4.375 seconds (our beep is 0.375 seconds) _movement_enable_fast_tick_if_needed(); } -void app_init() { +void app_init(void) { memset(&movement_state, 0, sizeof(movement_state)); movement_state.settings.bit.led_green_color = 0xF; @@ -149,11 +149,11 @@ void app_init() { _movement_reset_inactivity_countdown(); } -void app_wake_from_backup() { +void app_wake_from_backup(void) { movement_state.settings.reg = watch_get_backup_data(0); } -void app_setup() { +void app_setup(void) { watch_store_backup_data(movement_state.settings.reg, 0); static bool is_first_launch = true; @@ -194,13 +194,13 @@ void app_setup() { } } -void app_prepare_for_standby() { +void app_prepare_for_standby(void) { } -void app_wake_from_standby() { +void app_wake_from_standby(void) { } -bool app_loop() { +bool app_loop(void) { if (movement_state.watch_face_changed) { if (movement_state.settings.bit.button_should_sound) { // low note for nonzero case, high note for return to watch_face 0 @@ -300,7 +300,7 @@ bool app_loop() { return can_sleep && (movement_state.light_ticks == -1) && !movement_state.is_buzzing; } -movement_event_type_t _figure_out_button_event(bool pin_level, movement_event_type_t button_down_event_type, uint8_t *down_timestamp) { +static movement_event_type_t _figure_out_button_event(bool pin_level, movement_event_type_t button_down_event_type, uint8_t *down_timestamp) { // force alarm off if the user pressed a button. if (movement_state.alarm_ticks) movement_state.alarm_ticks = 0; @@ -323,34 +323,34 @@ movement_event_type_t _figure_out_button_event(bool pin_level, movement_event_ty } } -void cb_light_btn_interrupt() { +void cb_light_btn_interrupt(void) { bool pin_level = watch_get_pin_level(BTN_LIGHT); _movement_reset_inactivity_countdown(); event.event_type = _figure_out_button_event(pin_level, EVENT_LIGHT_BUTTON_DOWN, &movement_state.light_down_timestamp); } -void cb_mode_btn_interrupt() { +void cb_mode_btn_interrupt(void) { bool pin_level = watch_get_pin_level(BTN_MODE); _movement_reset_inactivity_countdown(); event.event_type = _figure_out_button_event(pin_level, EVENT_MODE_BUTTON_DOWN, &movement_state.mode_down_timestamp); } -void cb_alarm_btn_interrupt() { +void cb_alarm_btn_interrupt(void) { bool pin_level = watch_get_pin_level(BTN_ALARM); _movement_reset_inactivity_countdown(); event.event_type = _figure_out_button_event(pin_level, EVENT_ALARM_BUTTON_DOWN, &movement_state.alarm_down_timestamp); } -void cb_alarm_btn_extwake() { +void cb_alarm_btn_extwake(void) { // wake up! _movement_reset_inactivity_countdown(); } -void cb_alarm_fired() { +void cb_alarm_fired(void) { movement_state.needs_background_tasks_handled = true; } -void cb_fast_tick() { +void cb_fast_tick(void) { movement_state.fast_ticks++; if (movement_state.light_ticks > 0) movement_state.light_ticks--; if (movement_state.alarm_ticks > 0) movement_state.alarm_ticks--; @@ -359,7 +359,7 @@ void cb_fast_tick() { if (movement_state.fast_ticks >= 1280) watch_rtc_disable_periodic_callback(128); } -void cb_tick() { +void cb_tick(void) { event.event_type = EVENT_TICK; watch_date_time date_time = watch_rtc_get_date_time(); if (date_time.unit.second != movement_state.last_second) { diff --git a/movement/movement.h b/movement/movement.h index 9edb285b..62e4120b 100644 --- a/movement/movement.h +++ b/movement/movement.h @@ -242,11 +242,11 @@ typedef struct { } movement_state_t; void movement_move_to_face(uint8_t watch_face_index); -void movement_move_to_next_face(); -void movement_illuminate_led(); +void movement_move_to_next_face(void); +void movement_illuminate_led(void); void movement_request_tick_frequency(uint8_t freq); -void movement_play_signal(); -void movement_play_alarm(); +void movement_play_signal(void); +void movement_play_alarm(void); #endif // MOVEMENT_H_ diff --git a/movement/watch_faces/clock/world_clock_face.c b/movement/watch_faces/clock/world_clock_face.c index d80cb5bc..e1d96c97 100644 --- a/movement/watch_faces/clock/world_clock_face.c +++ b/movement/watch_faces/clock/world_clock_face.c @@ -26,7 +26,7 @@ void world_clock_face_activate(movement_settings_t *settings, void *context) { watch_set_colon(); } -bool world_clock_face_do_display_mode(movement_event_t event, movement_settings_t *settings, world_clock_state_t *state) { +static bool world_clock_face_do_display_mode(movement_event_t event, movement_settings_t *settings, world_clock_state_t *state) { char buf[11]; uint8_t pos; @@ -101,7 +101,7 @@ bool world_clock_face_do_display_mode(movement_event_t event, movement_settings_ return true; } -bool world_clock_face_do_settings_mode(movement_event_t event, movement_settings_t *settings, world_clock_state_t *state) { +static bool _world_clock_face_do_settings_mode(movement_event_t event, movement_settings_t *settings, world_clock_state_t *state) { switch (event.event_type) { case EVENT_MODE_BUTTON_UP: movement_move_to_next_face(); @@ -176,7 +176,7 @@ bool world_clock_face_loop(movement_event_t event, movement_settings_t *settings if (state->current_screen == 0) { return world_clock_face_do_display_mode(event, settings, state); } else { - return world_clock_face_do_settings_mode(event, settings, state); + return _world_clock_face_do_settings_mode(event, settings, state); } } diff --git a/movement/watch_faces/complications/day_one_face.c b/movement/watch_faces/complications/day_one_face.c index 146f3f6f..3b185d04 100644 --- a/movement/watch_faces/complications/day_one_face.c +++ b/movement/watch_faces/complications/day_one_face.c @@ -3,12 +3,12 @@ #include "day_one_face.h" #include "watch.h" -uint32_t _day_one_face_juliandaynum(uint16_t year, uint16_t month, uint16_t day) { +static uint32_t _day_one_face_juliandaynum(uint16_t year, uint16_t month, uint16_t day) { // from here: https://en.wikipedia.org/wiki/Julian_day#Julian_day_number_calculation return (1461 * (year + 4800 + (month - 14) / 12)) / 4 + (367 * (month - 2 - 12 * ((month - 14) / 12))) / 12 - (3 * ((year + 4900 + (month - 14) / 12) / 100))/4 + day - 32075; } -void _day_one_face_update(day_one_state_t state) { +static void _day_one_face_update(day_one_state_t state) { char buf[14]; watch_date_time date_time = watch_rtc_get_date_time(); uint32_t julian_date = _day_one_face_juliandaynum(date_time.unit.year + WATCH_RTC_REFERENCE_YEAR, date_time.unit.month, date_time.unit.day); diff --git a/movement/watch_faces/demos/lis2dh_logging_face.c b/movement/watch_faces/demos/lis2dh_logging_face.c index 0e4383cd..ef71cc6a 100644 --- a/movement/watch_faces/demos/lis2dh_logging_face.c +++ b/movement/watch_faces/demos/lis2dh_logging_face.c @@ -12,7 +12,7 @@ // Pressing the alarm button enters the log mode, where the main display shows the number of interrupts detected in each of the last // 24 hours (the hour is shown in the top right digit and AM/PM indicator, if the clock is set to 12 hour mode) -void _lis2dh_logging_face_log_data(lis2dh_logger_state_t *logger_state) { +static void _lis2dh_logging_face_log_data(lis2dh_logger_state_t *logger_state) { watch_date_time date_time = watch_rtc_get_date_time(); date_time.unit.hour = (date_time.unit.hour + 23) % 24; // log this as the number of events in the previous hour size_t pos = logger_state->data_points % LIS2DH_LOGGING_NUM_DATA_POINTS; diff --git a/movement/watch_faces/demos/voltage_face.c b/movement/watch_faces/demos/voltage_face.c index bdc25679..fe43343f 100644 --- a/movement/watch_faces/demos/voltage_face.c +++ b/movement/watch_faces/demos/voltage_face.c @@ -3,7 +3,7 @@ #include "voltage_face.h" #include "watch.h" -void _voltage_face_update_display() { +static void _voltage_face_update_display(void) { char buf[14]; float voltage = (float)watch_get_vcc_voltage() / 1000.0; sprintf(buf, "BA %4.2f V", voltage); diff --git a/movement/watch_faces/thermistor/thermistor_driver.c b/movement/watch_faces/thermistor/thermistor_driver.c index 37b5ba3f..5659c281 100644 --- a/movement/watch_faces/thermistor/thermistor_driver.c +++ b/movement/watch_faces/thermistor/thermistor_driver.c @@ -2,7 +2,7 @@ #include "watch.h" #include "watch_utility.h" -void thermistor_driver_enable() { +void thermistor_driver_enable(void) { // Enable the ADC peripheral, which we'll use to read the thermistor value. watch_enable_adc(); // Enable analog circuitry on the sense pin, which is tied to the thermistor resistor divider. @@ -13,7 +13,7 @@ void thermistor_driver_enable() { watch_set_pin_level(THERMISTOR_ENABLE_PIN, !THERMISTOR_ENABLE_VALUE); } -void thermistor_driver_disable() { +void thermistor_driver_disable(void) { // Disable the ADC peripheral. watch_disable_adc(); // Disable analog circuitry on the sense pin to save power. @@ -22,7 +22,7 @@ void thermistor_driver_disable() { watch_disable_digital_output(THERMISTOR_ENABLE_PIN); } -float thermistor_driver_get_temperature() { +float thermistor_driver_get_temperature(void) { // set the enable pin to the level that powers the thermistor circuit. watch_set_pin_level(THERMISTOR_ENABLE_PIN, THERMISTOR_ENABLE_VALUE); // get the sense pin level diff --git a/movement/watch_faces/thermistor/thermistor_driver.h b/movement/watch_faces/thermistor/thermistor_driver.h index a0b197de..425e1154 100644 --- a/movement/watch_faces/thermistor/thermistor_driver.h +++ b/movement/watch_faces/thermistor/thermistor_driver.h @@ -12,8 +12,8 @@ #define THERMISTOR_NOMINAL_RESISTANCE (10000.0) #define THERMISTOR_SERIES_RESISTANCE (10000.0) -void thermistor_driver_enable(); -void thermistor_driver_disable(); -float thermistor_driver_get_temperature(); +void thermistor_driver_enable(void); +void thermistor_driver_disable(void); +float thermistor_driver_get_temperature(void); #endif // THERMISTOR_DRIVER_H_ diff --git a/movement/watch_faces/thermistor/thermistor_logging_face.c b/movement/watch_faces/thermistor/thermistor_logging_face.c index 3e9e62b3..0d456785 100644 --- a/movement/watch_faces/thermistor/thermistor_logging_face.c +++ b/movement/watch_faces/thermistor/thermistor_logging_face.c @@ -4,7 +4,7 @@ #include "thermistor_driver.h" #include "watch.h" -void _thermistor_logging_face_log_data(thermistor_logger_state_t *logger_state) { +static void _thermistor_logging_face_log_data(thermistor_logger_state_t *logger_state) { thermistor_driver_enable(); watch_date_time date_time = watch_rtc_get_date_time(); size_t pos = logger_state->data_points % THERMISTOR_LOGGING_NUM_DATA_POINTS; @@ -16,7 +16,7 @@ void _thermistor_logging_face_log_data(thermistor_logger_state_t *logger_state) thermistor_driver_disable(); } -void _thermistor_logging_face_update_display(thermistor_logger_state_t *logger_state, bool in_fahrenheit, bool clock_mode_24h) { +static void _thermistor_logging_face_update_display(thermistor_logger_state_t *logger_state, bool in_fahrenheit, bool clock_mode_24h) { int8_t pos = (logger_state->data_points - 1 - logger_state->display_index) % THERMISTOR_LOGGING_NUM_DATA_POINTS; char buf[14]; diff --git a/movement/watch_faces/thermistor/thermistor_readout_face.c b/movement/watch_faces/thermistor/thermistor_readout_face.c index 8c5645e2..5478f07d 100644 --- a/movement/watch_faces/thermistor/thermistor_readout_face.c +++ b/movement/watch_faces/thermistor/thermistor_readout_face.c @@ -4,7 +4,7 @@ #include "thermistor_driver.h" #include "watch.h" -void _thermistor_readout_face_update_display(bool in_fahrenheit) { +static void _thermistor_readout_face_update_display(bool in_fahrenheit) { thermistor_driver_enable(); float temperature_c = thermistor_driver_get_temperature(); char buf[14]; diff --git a/utils/flash_watch_pyruler/flash_watch_pyruler.ino b/utils/flash_watch_pyruler/flash_watch_pyruler.ino index 2e4d2f08..ae9de2e4 100644 --- a/utils/flash_watch_pyruler/flash_watch_pyruler.ino +++ b/utils/flash_watch_pyruler/flash_watch_pyruler.ino @@ -29,7 +29,7 @@ void error(const char *text) { } -void setup() { +void setup(void) { pinMode(13, OUTPUT); Serial.begin(115200); // while(!Serial) { @@ -102,7 +102,7 @@ void setup() { dap.dap_disconnect(); } -void loop() { +void loop(void) { //blink led on the host to show we're done digitalWrite(13, HIGH); delay(500); diff --git a/watch-library/driver/lis2dh.c b/watch-library/driver/lis2dh.c index 21087bef..20702bf5 100644 --- a/watch-library/driver/lis2dh.c +++ b/watch-library/driver/lis2dh.c @@ -25,7 +25,7 @@ #include "lis2dh.h" #include "watch.h" -bool lis2dh_begin() { +bool lis2dh_begin(void) { if (lis2dh_get_device_id() != LIS2DH_WHO_AM_I_VAL) { return false; } @@ -40,16 +40,16 @@ bool lis2dh_begin() { return true; } -uint8_t lis2dh_get_device_id() { +uint8_t lis2dh_get_device_id(void) { return watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_WHO_AM_I); } -bool lis2dh_have_new_data() { +bool lis2dh_have_new_data(void) { uint8_t retval = watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_STATUS); return !!retval; // return true if any bit is set } -lis2dh_reading lis2dh_get_raw_reading() { +lis2dh_reading lis2dh_get_raw_reading(void) { uint8_t buffer[6]; uint8_t reg = LIS2DH_REG_OUT_X_L | 0x80; // set high bit for consecutive reads lis2dh_reading retval; @@ -97,7 +97,7 @@ void lis2dh_set_range(lis2dh_range_t range) { watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL4, val | bits); } -lis2dh_range_t lis2dh_get_range() { +lis2dh_range_t lis2dh_get_range(void) { uint8_t retval = watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL4) & 0x30; retval >>= 4; return (lis2dh_range_t)retval; @@ -111,7 +111,7 @@ void lis2dh_set_data_rate(lis2dh_data_rate_t dataRate) { watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL1, val | bits); } -lis2dh_data_rate_t lis2dh_get_data_rate() { +lis2dh_data_rate_t lis2dh_get_data_rate(void) { return watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL1) >> 4; } @@ -124,7 +124,7 @@ void lis2dh_configure_aoi_int1(lis2dh_interrupt_configuration configuration, uin watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL5, val | latch ? LIS2DH_CTRL5_VAL_LIR_INT1 : 0); } -lis2dh_interrupt_state lis2dh_get_int1_state() { +lis2dh_interrupt_state lis2dh_get_int1_state(void) { return (lis2dh_interrupt_state) watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_INT1_SRC); } @@ -137,7 +137,7 @@ void lis2dh_configure_aoi_int2(lis2dh_interrupt_configuration configuration, uin watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL5, val | latch ? LIS2DH_CTRL5_VAL_LIR_INT2 : 0); } -lis2dh_interrupt_state lis2dh_get_int2_state() { +lis2dh_interrupt_state lis2dh_get_int2_state(void) { return (lis2dh_interrupt_state) watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_INT2_SRC); } diff --git a/watch-library/driver/lis2dh.h b/watch-library/driver/lis2dh.h index ddd42126..68831519 100644 --- a/watch-library/driver/lis2dh.h +++ b/watch-library/driver/lis2dh.h @@ -84,31 +84,31 @@ typedef enum { LIS2DH_INTERRUPT_STATE_X_LOW = 0b00000001, // X down } lis2dh_interrupt_state; -bool lis2dh_begin(); +bool lis2dh_begin(void); -uint8_t lis2dh_get_device_id(); +uint8_t lis2dh_get_device_id(void); -bool lis2dh_have_new_data(); +bool lis2dh_have_new_data(void); -lis2dh_reading lis2dh_get_raw_reading(); +lis2dh_reading lis2dh_get_raw_reading(void); lis2dh_acceleration_measurement lis2dh_get_acceleration_measurement(lis2dh_reading *out_reading); void lis2dh_set_range(lis2dh_range_t range); -lis2dh_range_t lis2dh_get_range(); +lis2dh_range_t lis2dh_get_range(void); void lis2dh_set_data_rate(lis2dh_data_rate_t dataRate); -lis2dh_data_rate_t lis2dh_get_data_rate(); +lis2dh_data_rate_t lis2dh_get_data_rate(void); void lis2dh_configure_aoi_int1(lis2dh_interrupt_configuration configuration, uint8_t threshold, uint8_t duration, bool latch); -lis2dh_interrupt_state lis2dh_get_int1_state(); +lis2dh_interrupt_state lis2dh_get_int1_state(void); void lis2dh_configure_aoi_int2(lis2dh_interrupt_configuration configuration, uint8_t threshold, uint8_t duration, bool latch); -lis2dh_interrupt_state lis2dh_get_int2_state(); +lis2dh_interrupt_state lis2dh_get_int2_state(void); // Assumes SA0 is high; if low, its 0x18 #define LIS2DH_ADDRESS (0x19) diff --git a/watch-library/hal/src/hal_io.c b/watch-library/hal/src/hal_io.c index 7e8feb04..ae787d42 100644 --- a/watch-library/hal/src/hal_io.c +++ b/watch-library/hal/src/hal_io.c @@ -39,11 +39,6 @@ */ #define DRIVER_VERSION 0x00000001u -uint32_t io_get_version(void) -{ - return DRIVER_VERSION; -} - /** * \brief I/O write interface */ diff --git a/watch-library/hpl/core/hpl_core_port.h b/watch-library/hpl/core/hpl_core_port.h index 3f3e8f28..33c18dd0 100644 --- a/watch-library/hpl/core/hpl_core_port.h +++ b/watch-library/hpl/core/hpl_core_port.h @@ -58,4 +58,6 @@ static inline bool _is_in_isr(void) #endif /* !(defined(__ASSEMBLY__) || defined(__IAR_SYSTEMS_ASM__)) */ +void Default_Handler(void); + #endif /* _HPL_CORE_PORT_H_INCLUDED */ diff --git a/watch-library/hpl/gclk/hpl_gclk.c b/watch-library/hpl/gclk/hpl_gclk.c index 86451165..be66ef77 100644 --- a/watch-library/hpl/gclk/hpl_gclk.c +++ b/watch-library/hpl/gclk/hpl_gclk.c @@ -33,6 +33,7 @@ */ #include +#include #include #include diff --git a/watch-library/hpl/mclk/hpl_mclk.c b/watch-library/hpl/mclk/hpl_mclk.c index 2ada7561..46e7c853 100644 --- a/watch-library/hpl/mclk/hpl_mclk.c +++ b/watch-library/hpl/mclk/hpl_mclk.c @@ -33,6 +33,7 @@ #include #include +#include /** * \brief Initialize master clock generator diff --git a/watch-library/hpl/systick/hpl_systick.c b/watch-library/hpl/systick/hpl_systick.c index 3caf6746..c2f3b29e 100644 --- a/watch-library/hpl/systick/hpl_systick.c +++ b/watch-library/hpl/systick/hpl_systick.c @@ -34,6 +34,7 @@ #include #include +#include /** * \brief Initialize system time module diff --git a/watch-library/hw/driver_init.h b/watch-library/hw/driver_init.h index fc6cc208..d1c33218 100644 --- a/watch-library/hw/driver_init.h +++ b/watch-library/hw/driver_init.h @@ -50,6 +50,7 @@ void delay_driver_init(void); void EXTERNAL_IRQ_0_init(void); +void SEGMENT_LCD_0_PORT_init(void); void SEGMENT_LCD_0_init(void); #ifdef __cplusplus diff --git a/watch-library/watch/watch.c b/watch-library/watch/watch.c index de7160c5..844ed3d9 100644 --- a/watch-library/watch/watch.c +++ b/watch-library/watch/watch.c @@ -35,6 +35,6 @@ void SYSTEM_Handler(void) { } } -bool watch_is_battery_low() { +bool watch_is_battery_low(void) { return battery_is_low; } diff --git a/watch-library/watch/watch.h b/watch-library/watch/watch.h index fee8f4ea..669a5ed1 100644 --- a/watch-library/watch/watch.h +++ b/watch-library/watch/watch.h @@ -71,6 +71,6 @@ * the battery voltage has fallen to 2.5 volts, it will have probably less than 10% of its capacity remaining, and * you can expect the voltage to drop relatively quickly as the battery dies. */ -bool watch_is_battery_low(); +bool watch_is_battery_low(void); #endif /* WATCH_H_ */ \ No newline at end of file diff --git a/watch-library/watch/watch_adc.c b/watch-library/watch/watch_adc.c index 4aff86e6..5ba7abdf 100644 --- a/watch-library/watch/watch_adc.c +++ b/watch-library/watch/watch_adc.c @@ -24,11 +24,11 @@ #include "watch_adc.h" -void _watch_sync_adc() { +static void _watch_sync_adc(void) { while (ADC->SYNCBUSY.reg); } -uint16_t _watch_get_analog_value(uint16_t channel) { +static uint16_t _watch_get_analog_value(uint16_t channel) { if (ADC->INPUTCTRL.bit.MUXPOS != channel) { ADC->INPUTCTRL.bit.MUXPOS = channel; _watch_sync_adc(); @@ -40,7 +40,7 @@ uint16_t _watch_get_analog_value(uint16_t channel) { return ADC->RESULT.reg; } -void watch_enable_adc() { +void watch_enable_adc(void) { MCLK->APBCMASK.reg |= MCLK_APBCMASK_ADC; GCLK->PCHCTRL[ADC_GCLK_ID].reg = GCLK_PCHCTRL_GEN_GCLK0 | GCLK_PCHCTRL_CHEN; @@ -151,7 +151,7 @@ void watch_set_analog_reference_voltage(watch_adc_reference_voltage reference) { _watch_get_analog_value(ADC_INPUTCTRL_MUXPOS_SCALEDCOREVCC); } -uint16_t watch_get_vcc_voltage() { +uint16_t watch_get_vcc_voltage(void) { // stash the previous reference so we can restore it when we're done. uint8_t oldref = ADC->REFCTRL.bit.REFSEL; @@ -171,7 +171,7 @@ inline void watch_disable_analog_input(const uint8_t pin) { gpio_set_pin_function(pin, GPIO_PIN_FUNCTION_OFF); } -inline void watch_disable_adc() { +inline void watch_disable_adc(void) { ADC->CTRLA.bit.ENABLE = 0; _watch_sync_adc(); diff --git a/watch-library/watch/watch_adc.h b/watch-library/watch/watch_adc.h index a4f9edad..aa7c801a 100644 --- a/watch-library/watch/watch_adc.h +++ b/watch-library/watch/watch_adc.h @@ -36,7 +36,7 @@ /** @brief Enables the ADC peripheral. You must call this before attempting to read a value * from an analog pin. */ -void watch_enable_adc(); +void watch_enable_adc(void); /** @brief Configures the selected pin for analog input. * @param pin One of pins A0-A4. @@ -139,7 +139,7 @@ void watch_set_analog_reference_voltage(watch_adc_reference_voltage reference); * @note This function depends on INTREF being 1.024V. If you have changed it by poking at the supply * controller's VREF.SEL bits, this function will return inaccurate values. */ -uint16_t watch_get_vcc_voltage(); +uint16_t watch_get_vcc_voltage(void); /** @brief Disables the analog circuitry on the selected pin. * @param pin One of pins A0-A4. @@ -151,7 +151,7 @@ void watch_disable_analog_input(const uint8_t pin); * have the default settings of 16 samples and 1 measurement cycle; if you customized these * parameters, you will need to set them up again. **/ -void watch_disable_adc(); +void watch_disable_adc(void); /// @} #endif diff --git a/watch-library/watch/watch_app.h b/watch-library/watch/watch_app.h index 56b9bfd3..4fa29df8 100644 --- a/watch-library/watch/watch_app.h +++ b/watch-library/watch/watch_app.h @@ -55,13 +55,13 @@ * anything else. Use it to set up any internal data structures or application state required by your app, * but don't configure any peripherals just yet. */ -void app_init(); +void app_init(void); /** @brief A function you will implement to wake from BACKUP mode, which wipes the system's RAM, and with it, your * application's state. You may have chosen to store some important application state in the RTC's backup * registers prior to entering this mode. You may restore that state here. */ -void app_wake_from_backup(); +void app_wake_from_backup(void); /** @brief A function you will implement to set up your application. The app_setup function is like setup() in Arduino. * It is called once when the program begins. You should set pin modes and enable any peripherals you want to @@ -71,7 +71,7 @@ void app_wake_from_backup(); * @note If your app enters the ultra-low power BACKUP sleep mode, this function will be called again when it wakes * from that deep sleep state. In this state, the RTC will still be configured with the correct date and time. */ -void app_setup(); +void app_setup(void); /** @brief A function you will implement to serve as the app's main run loop. This method will be called repeatedly, or if you enter STANDBY mode, as soon as the device wakes from sleep. @@ -86,7 +86,7 @@ void app_setup(); * so e.g. the I2C controller, if configured, will sleep in STANDBY. But you can use it again as soon as your * app wakes up. */ -bool app_loop(); +bool app_loop(void); /** @brief A function you will implement to prepare to enter STANDBY mode. The app_prepare_for_standby function is * called after your app_loop function returns true, and just before the watch enters STANDBY mode. In this @@ -98,11 +98,11 @@ bool app_loop(); * buzzer that could damage it if left in this state. If your app_loop does not prevent sleep during these * activities, you should make sure to disable these outputs in app_prepare_for_standby. */ -void app_prepare_for_standby(); +void app_prepare_for_standby(void); /** @brief A method you will implement to configure the app after waking from STANDBY mode. */ -void app_wake_from_standby(); +void app_wake_from_standby(void); /// @} #endif diff --git a/watch-library/watch/watch_buzzer.c b/watch-library/watch/watch_buzzer.c index 007a44ca..a275b00d 100644 --- a/watch-library/watch/watch_buzzer.c +++ b/watch-library/watch/watch_buzzer.c @@ -24,7 +24,7 @@ #include "watch_buzzer.h" - inline void watch_enable_buzzer() { + inline void watch_enable_buzzer(void) { if (!hri_tcc_get_CTRLA_reg(TCC0, TCC_CTRLA_ENABLE)) { _watch_enable_tcc(); } @@ -33,16 +33,16 @@ inline void watch_set_buzzer_period(uint32_t period) { hri_tcc_write_PERBUF_reg(TCC0, period); } -void watch_disable_buzzer() { +void watch_disable_buzzer(void) { _watch_disable_tcc(); } -inline void watch_set_buzzer_on() { +inline void watch_set_buzzer_on(void) { gpio_set_pin_direction(BUZZER, GPIO_DIRECTION_OUT); gpio_set_pin_function(BUZZER, WATCH_BUZZER_TCC_PINMUX); } -inline void watch_set_buzzer_off() { +inline void watch_set_buzzer_off(void) { gpio_set_pin_direction(BUZZER, GPIO_DIRECTION_OFF); gpio_set_pin_function(BUZZER, GPIO_PIN_FUNCTION_OFF); } diff --git a/watch-library/watch/watch_buzzer.h b/watch-library/watch/watch_buzzer.h index e15657be..1b5d197c 100644 --- a/watch-library/watch/watch_buzzer.h +++ b/watch-library/watch/watch_buzzer.h @@ -33,7 +33,7 @@ /// @{ /** @brief Enables the TCC peripheral, which drives the buzzer. */ -void watch_enable_buzzer(); +void watch_enable_buzzer(void); /** @brief Sets the period of the buzzer. * @param period The period of a single cycle for the TCC peripheral. You can determine the period for @@ -45,17 +45,17 @@ void watch_set_buzzer_period(uint32_t period); * @note If you are using PWM to set custom LED colors, this method will also disable the LED PWM driver, * since the buzzer and LED both make use of the same peripheral to drive their PWM behavior. */ -void watch_disable_buzzer(); +void watch_disable_buzzer(void); /** @brief Turns the buzzer output on. It will emit a continuous sound at the given frequency. * @note The TCC peripheral that drives the buzzer does not run in standby mode; if you wish for buzzer * output to continue, you should prevent your app from going to sleep. */ -void watch_set_buzzer_on(); +void watch_set_buzzer_on(void); /** @brief Turns the buzzer output off. */ -void watch_set_buzzer_off(); +void watch_set_buzzer_off(void); /// @brief 87 notes for use with watch_buzzer_play_note typedef enum BuzzerNote { diff --git a/watch-library/watch/watch_deepsleep.c b/watch-library/watch/watch_deepsleep.c index 8120617b..1813ff24 100644 --- a/watch-library/watch/watch_deepsleep.c +++ b/watch-library/watch/watch_deepsleep.c @@ -126,7 +126,7 @@ uint32_t watch_get_backup_data(uint8_t reg) { return 0; } -void _watch_disable_all_pins_except_rtc() { +static void _watch_disable_all_pins_except_rtc(void) { uint32_t config = RTC->MODE0.TAMPCTRL.reg; uint32_t portb_pins_to_disable = 0xFFFFFFFF; @@ -141,7 +141,7 @@ void _watch_disable_all_pins_except_rtc() { gpio_set_port_direction(1, portb_pins_to_disable, GPIO_DIRECTION_OFF); } -void _watch_disable_all_peripherals_except_slcd() { +static void _watch_disable_all_peripherals_except_slcd(void) { _watch_disable_tcc(); watch_disable_adc(); watch_disable_external_interrupts(); @@ -151,7 +151,7 @@ void _watch_disable_all_peripherals_except_slcd() { MCLK->APBCMASK.reg &= ~MCLK_APBCMASK_SERCOM3; } -void watch_enter_sleep_mode() { +void watch_enter_sleep_mode(void) { // disable all other peripherals _watch_disable_all_peripherals_except_slcd(); @@ -177,7 +177,7 @@ void watch_enter_sleep_mode() { app_wake_from_standby(); } -void watch_enter_deep_sleep_mode() { +void watch_enter_deep_sleep_mode(void) { // identical to sleep mode except we disable the LCD first. slcd_sync_deinit(&SEGMENT_LCD_0); hri_mclk_clear_APBCMASK_SLCD_bit(SLCD); @@ -185,7 +185,7 @@ void watch_enter_deep_sleep_mode() { watch_enter_sleep_mode(); } -void watch_enter_backup_mode() { +void watch_enter_backup_mode(void) { watch_rtc_disable_all_periodic_callbacks(); _watch_disable_all_peripherals_except_slcd(); slcd_sync_deinit(&SEGMENT_LCD_0); @@ -203,7 +203,7 @@ void watch_enter_shallow_sleep(bool display_on) { } // deprecated -void watch_enter_deep_sleep() { +void watch_enter_deep_sleep(void) { watch_register_extwake_callback(BTN_ALARM, NULL, true); watch_enter_backup_mode(); } diff --git a/watch-library/watch/watch_deepsleep.h b/watch-library/watch/watch_deepsleep.h index a453e763..56d75478 100644 --- a/watch-library/watch/watch_deepsleep.h +++ b/watch-library/watch/watch_deepsleep.h @@ -119,7 +119,7 @@ uint32_t watch_get_backup_data(uint8_t reg); * You can estimate the power consumption of this mode to be on the order of 30 microwatts * (about 10 µA at 3 V). */ -void watch_enter_sleep_mode(); +void watch_enter_sleep_mode(void); /** @brief enters Deep Sleep Mode by disabling all pins and peripherals except the RTC. * @details Short of BACKUP mode, this is the lowest power mode you can enter while retaining your @@ -131,7 +131,7 @@ void watch_enter_sleep_mode(); * All notes from watch_enter_sleep_mode apply here, except for power consumption. You can estimate * the power consumption of this mode to be on the order of 12 microwatts (about 4µA at 3 V). */ -void watch_enter_deep_sleep_mode(); +void watch_enter_deep_sleep_mode(void); /** @brief Enters the SAM L22's lowest-power mode, BACKUP. * @details This function does some housekeeping before entering BACKUP mode. It first disables all pins @@ -148,12 +148,12 @@ void watch_enter_deep_sleep_mode(); * this function unless you have a device on the nine-pin connector with an external interrupt * on pin A2 or A4 (i.e. an accelerometer with an interrupt pin). */ -void watch_enter_backup_mode(); +void watch_enter_backup_mode(void); __attribute__((deprecated("Use watch_enter_sleep_mode or watch_enter_deep_sleep_mode instead"))) void watch_enter_shallow_sleep(bool display_on); __attribute__((deprecated("Use watch_enter_backup_mode instead"))) -void watch_enter_deep_sleep(); +void watch_enter_deep_sleep(void); /// @} #endif diff --git a/watch-library/watch/watch_extint.c b/watch-library/watch/watch_extint.c index d6ad5b60..5924b646 100644 --- a/watch-library/watch/watch_extint.c +++ b/watch-library/watch/watch_extint.c @@ -24,7 +24,7 @@ #include "watch_extint.h" -void watch_enable_external_interrupts() { +void watch_enable_external_interrupts(void) { // Configure EIC to use GCLK3 (the 32.768 kHz crystal) hri_gclk_write_PCHCTRL_reg(GCLK, EIC_GCLK_ID, GCLK_PCHCTRL_GEN_GCLK3_Val | (1 << GCLK_PCHCTRL_CHEN_Pos)); // Enable AHB clock for the EIC @@ -33,7 +33,7 @@ void watch_enable_external_interrupts() { ext_irq_init(); } -void watch_disable_external_interrupts() { +void watch_disable_external_interrupts(void) { ext_irq_deinit(); hri_mclk_clear_APBAMASK_EIC_bit(MCLK); } @@ -106,6 +106,6 @@ inline void watch_register_button_callback(const uint8_t pin, ext_irq_cb_t callb watch_register_interrupt_callback(pin, callback, INTERRUPT_TRIGGER_RISING); } -inline void watch_enable_buttons() { +inline void watch_enable_buttons(void) { watch_enable_external_interrupts(); } diff --git a/watch-library/watch/watch_extint.h b/watch-library/watch/watch_extint.h index cba6c5e1..452461b3 100644 --- a/watch-library/watch/watch_extint.h +++ b/watch-library/watch/watch_extint.h @@ -49,10 +49,10 @@ typedef enum watch_interrupt_trigger { } watch_interrupt_trigger; /// @brief Enables the external interrupt controller. -void watch_enable_external_interrupts(); +void watch_enable_external_interrupts(void); /// @brief Disables the external interrupt controller. -void watch_disable_external_interrupts(); +void watch_disable_external_interrupts(void); /** @brief Configures an external interrupt callback on one of the external interrupt pins. * @details You can set one interrupt callback per pin, and you can monitor for a rising condition, @@ -80,6 +80,6 @@ __attribute__((deprecated("Use watch_register_interrupt_callback or watch_regist void watch_register_button_callback(const uint8_t pin, ext_irq_cb_t callback); __attribute__((deprecated("Use watch_enable_external_interrupts instead"))) -void watch_enable_buttons(); +void watch_enable_buttons(void); /// @} #endif diff --git a/watch-library/watch/watch_i2c.c b/watch-library/watch/watch_i2c.c index d2cf474b..ff20afc6 100644 --- a/watch-library/watch/watch_i2c.c +++ b/watch-library/watch/watch_i2c.c @@ -26,13 +26,13 @@ struct io_descriptor *I2C_0_io; -void watch_enable_i2c() { +void watch_enable_i2c(void) { I2C_0_init(); i2c_m_sync_get_io_descriptor(&I2C_0, &I2C_0_io); i2c_m_sync_enable(&I2C_0); } -void watch_disable_i2c() { +void watch_disable_i2c(void) { i2c_m_sync_disable(&I2C_0); hri_mclk_clear_APBCMASK_SERCOM1_bit(MCLK); } diff --git a/watch-library/watch/watch_i2c.h b/watch-library/watch/watch_i2c.h index 65df49b4..fbcc1a92 100644 --- a/watch-library/watch/watch_i2c.h +++ b/watch-library/watch/watch_i2c.h @@ -35,11 +35,11 @@ /// @{ /** @brief Enables the I2C peripheral. Call this before attempting to interface with I2C devices. */ -void watch_enable_i2c(); +void watch_enable_i2c(void); /** @brief Disables the I2C peripheral. */ -void watch_disable_i2c(); +void watch_disable_i2c(void); /** @brief Sends a series of values to a device on the I2C bus. * @param addr The address of the device you wish to talk to. diff --git a/watch-library/watch/watch_led.c b/watch-library/watch/watch_led.c index 1348c977..52174b54 100644 --- a/watch-library/watch/watch_led.c +++ b/watch-library/watch/watch_led.c @@ -24,13 +24,13 @@ #include "watch_led.h" -void watch_enable_leds() { +void watch_enable_leds(void) { if (!hri_tcc_get_CTRLA_reg(TCC0, TCC_CTRLA_ENABLE)) { _watch_enable_tcc(); } } -void watch_disable_leds() { +void watch_disable_leds(void) { _watch_disable_tcc(); } @@ -52,18 +52,18 @@ void watch_set_led_color(uint8_t red, uint8_t green) { } } -void watch_set_led_red() { +void watch_set_led_red(void) { watch_set_led_color(255, 0); } -void watch_set_led_green() { +void watch_set_led_green(void) { watch_set_led_color(0, 255); } -void watch_set_led_yellow() { +void watch_set_led_yellow(void) { watch_set_led_color(255, 255); } -void watch_set_led_off() { +void watch_set_led_off(void) { watch_set_led_color(0, 0); } diff --git a/watch-library/watch/watch_led.h b/watch-library/watch/watch_led.h index 2b9dead0..9e9f5640 100644 --- a/watch-library/watch/watch_led.h +++ b/watch-library/watch/watch_led.h @@ -46,13 +46,13 @@ * your app is asleep. If, however, you set a custom color using watch_set_led_color, the color will * not display correctly in STANDBY mode. You will need to keep your app running while the LED is on. */ -void watch_enable_leds(); +void watch_enable_leds(void); /** @brief Disables the LEDs. * @note This method will also disable the buzzer, since the buzzer and LED both make use of the same * peripheral to drive their PWM behavior. */ -void watch_disable_leds(); +void watch_disable_leds(void); /** @brief Sets the LED to a custom color by modulating each output's duty cycle. * @param red The red value from 0-255. @@ -66,23 +66,23 @@ void watch_set_led_color(uint8_t red, uint8_t green); /** @brief Sets the red LED to full brightness, and turns the green LED off. * @details Of the two LED's in the RG bi-color LED, the red LED is the less power-efficient one (~4.5 mA). */ -void watch_set_led_red(); +void watch_set_led_red(void); /** @brief Sets the green LED to full brightness, and turns the red LED off. * @details Of the two LED's in the RG bi-color LED, the green LED is the more power-efficient one (~0.44 mA). * @note If your watch has a red/blue LED, this method will set the LED to blue. */ -void watch_set_led_green(); +void watch_set_led_green(void); /** @brief Sets both red and green LEDs to full brightness. * @details The total current draw between the two LED's in this mode will be ~5 mA, which is more than the * watch draws in any other mode. Take care not to drain the battery. * @note If your watch has a red/blue LED, this method will set the LED to pink. */ -void watch_set_led_yellow(); +void watch_set_led_yellow(void); /** @brief Turns both the red and the green LEDs off. */ -void watch_set_led_off(); +void watch_set_led_off(void); __attribute__((deprecated("Use watch_enable_leds instead"))) void watch_enable_led(bool unused); diff --git a/watch-library/watch/watch_private.c b/watch-library/watch/watch_private.c index 270208dc..12cac975 100644 --- a/watch-library/watch/watch_private.c +++ b/watch-library/watch/watch_private.c @@ -25,7 +25,7 @@ #include "watch_private.h" #include "tusb.h" -void _watch_init() { +void _watch_init(void) { // disable the LED pin (it may have been enabled by the bootloader) watch_disable_digital_output(RED); @@ -65,7 +65,7 @@ void _watch_init() { a4_callback = NULL; } -void _watch_enable_tcc() { +void _watch_enable_tcc(void) { // clock TCC0 with the main clock (8 MHz) and enable the peripheral clock. hri_gclk_write_PCHCTRL_reg(GCLK, TCC0_GCLK_ID, GCLK_PCHCTRL_GEN_GCLK0_Val | GCLK_PCHCTRL_CHEN); hri_mclk_set_APBCMASK_TCC0_bit(MCLK); @@ -111,7 +111,7 @@ void _watch_enable_tcc() { gpio_set_pin_function(GREEN, WATCH_GREEN_TCC_PINMUX); } -void _watch_disable_tcc() { +void _watch_disable_tcc(void) { // disable all PWM pins gpio_set_pin_direction(BUZZER, GPIO_DIRECTION_OFF); gpio_set_pin_function(BUZZER, GPIO_PIN_FUNCTION_OFF); @@ -125,7 +125,7 @@ void _watch_disable_tcc() { hri_mclk_clear_APBCMASK_TCC0_bit(MCLK); } -void _watch_enable_usb() { +void _watch_enable_usb(void) { // disable USB, just in case. hri_usb_clear_CTRLA_ENABLE_bit(USB); @@ -209,7 +209,7 @@ int _write(int file, char *ptr, int len) { } // this method could be overridden to read stuff from the USB console? but no need rn. -int _read() { +int _read(void) { return 0; } diff --git a/watch-library/watch/watch_private.h b/watch-library/watch/watch_private.h index 8045e438..7bb91d1f 100644 --- a/watch-library/watch/watch_private.h +++ b/watch-library/watch/watch_private.h @@ -27,17 +27,24 @@ #include "watch.h" /// Called by main.c while setting up the app. You should not call this from your app. -void _watch_init(); +void _watch_init(void); /// Initializes the real-time clock peripheral. -void _watch_rtc_init(); +void _watch_rtc_init(void); /// Called by buzzer and LED setup functions. You should not call this from your app. -void _watch_enable_tcc(); +void _watch_enable_tcc(void); /// Called by buzzer and LED teardown functions. You should not call this from your app. -void _watch_disable_tcc(); +void _watch_disable_tcc(void); /// Called by main.c if plugged in to USB. You should not call this from your app. -void _watch_enable_usb(); +void _watch_enable_usb(void); + +// this function ends up getting called by printf to log stuff to the USB console. +int _write(int file, char *ptr, int len); + +// this method could be overridden to read stuff from the USB console? but no need rn. +int _read(void); + #endif diff --git a/watch-library/watch/watch_rtc.c b/watch-library/watch/watch_rtc.c index a50da7c4..14a968c4 100644 --- a/watch-library/watch/watch_rtc.c +++ b/watch-library/watch/watch_rtc.c @@ -30,15 +30,15 @@ ext_irq_cb_t btn_alarm_callback; ext_irq_cb_t a2_callback; ext_irq_cb_t a4_callback; -bool _watch_rtc_is_enabled() { +bool _watch_rtc_is_enabled(void) { return RTC->MODE2.CTRLA.bit.ENABLE; } -void _sync_rtc() { +static void _sync_rtc(void) { while (RTC->MODE2.SYNCBUSY.reg); } -void _watch_rtc_init() { +void _watch_rtc_init(void) { MCLK->APBAMASK.reg |= MCLK_APBAMASK_RTC; if (_watch_rtc_is_enabled()) return; // don't reset the RTC if it's already set up. @@ -61,7 +61,7 @@ void watch_rtc_set_date_time(watch_date_time date_time) { _sync_rtc(); } -watch_date_time watch_rtc_get_date_time() { +watch_date_time watch_rtc_get_date_time(void) { watch_date_time retval; _sync_rtc(); @@ -74,7 +74,7 @@ void watch_rtc_register_tick_callback(ext_irq_cb_t callback) { watch_rtc_register_periodic_callback(callback, 1); } -void watch_rtc_disable_tick_callback() { +void watch_rtc_disable_tick_callback(void) { watch_rtc_disable_periodic_callback(1); } @@ -102,7 +102,7 @@ void watch_rtc_disable_periodic_callback(uint8_t frequency) { RTC->MODE2.INTENCLR.reg = 1 << per_n; } -void watch_rtc_disable_all_periodic_callbacks() { +void watch_rtc_disable_all_periodic_callbacks(void) { RTC->MODE2.INTENCLR.reg = 0xFF; } @@ -116,7 +116,7 @@ void watch_rtc_register_alarm_callback(ext_irq_cb_t callback, watch_date_time al RTC->MODE2.INTENSET.reg = RTC_MODE2_INTENSET_ALARM0; } -void watch_rtc_disable_alarm_callback() { +void watch_rtc_disable_alarm_callback(void) { RTC->MODE2.INTENCLR.reg = RTC_MODE2_INTENCLR_ALARM0; } diff --git a/watch-library/watch/watch_rtc.h b/watch-library/watch/watch_rtc.h index 7ddd7483..6dac63f5 100644 --- a/watch-library/watch/watch_rtc.h +++ b/watch-library/watch/watch_rtc.h @@ -63,7 +63,7 @@ typedef enum watch_rtc_alarm_match { /** @brief Called by main.c to check if the RTC is enabled. * You may call this function, but outside of app_init, it should always return true. */ -bool _watch_rtc_is_enabled(); +bool _watch_rtc_is_enabled(void); /** @brief Sets the date and time. * @param date_time The date and time you wish to set, with a year value from 0-63 representing 2020-2083. @@ -79,7 +79,7 @@ void watch_rtc_set_date_time(watch_date_time date_time); * @return A watch_date_time with the current date and time, with a year value from 0-63 representing 2020-2083. * @see watch_rtc_set_date_time for notes about how the year is stored. */ -watch_date_time watch_rtc_get_date_time(); +watch_date_time watch_rtc_get_date_time(void); /** @brief Registers an alarm callback that will be called when the RTC time matches the target time, as masked * by the provided mask. @@ -100,7 +100,7 @@ void watch_rtc_register_alarm_callback(ext_irq_cb_t callback, watch_date_time al /** @brief Disables the alarm callback. */ -void watch_rtc_disable_alarm_callback(); +void watch_rtc_disable_alarm_callback(void); /** @brief Registers a "tick" callback that will be called once per second. * @param callback The function you wish to have called when the clock ticks. If you pass in NULL, the tick @@ -113,7 +113,7 @@ void watch_rtc_register_tick_callback(ext_irq_cb_t callback); /** @brief Disables the tick callback for the given period. */ -void watch_rtc_disable_tick_callback(); +void watch_rtc_disable_tick_callback(void); /** @brief Registers a callback that will be called at a configurable period. * @param callback The function you wish to have called at the specified period. If you pass in NULL, the periodic @@ -139,7 +139,7 @@ void watch_rtc_disable_periodic_callback(uint8_t frequency); /** @brief Disables all periodic callbacks, including the once-per-second tick callback. */ -void watch_rtc_disable_all_periodic_callbacks(); +void watch_rtc_disable_all_periodic_callbacks(void); /** @brief Sets the system date and time. * @param date_time A struct representing the date and time you wish to set. diff --git a/watch-library/watch/watch_slcd.c b/watch-library/watch/watch_slcd.c index a74d4169..4bcb1652 100644 --- a/watch-library/watch/watch_slcd.c +++ b/watch-library/watch/watch_slcd.c @@ -150,11 +150,11 @@ static const uint32_t IndicatorSegments[6] = { SLCD_SEGID(1, 10), // WATCH_INDICATOR_LAP }; -void _sync_slcd() { +static void _sync_slcd(void) { while (SLCD->SYNCBUSY.reg); } -void watch_enable_display() { +void watch_enable_display(void) { SEGMENT_LCD_0_init(); slcd_sync_enable(&SEGMENT_LCD_0); } @@ -167,13 +167,13 @@ inline void watch_clear_pixel(uint8_t com, uint8_t seg) { slcd_sync_seg_off(&SEGMENT_LCD_0, SLCD_SEGID(com, seg)); } -void watch_clear_display() { +void watch_clear_display(void) { SLCD->SDATAL0.reg = 0; SLCD->SDATAL1.reg = 0; SLCD->SDATAL2.reg = 0; } -void watch_display_character(uint8_t character, uint8_t position) { +static void watch_display_character(uint8_t character, uint8_t position) { // special cases for positions 4 and 6 if (position == 4 || position == 6) { if (character == '7') character = '&'; // "lowercase" 7 @@ -245,11 +245,11 @@ void watch_display_string(char *string, uint8_t position) { // printf("________\n %c%c %c%c\n%c%c %c%c %c%c\n--------\n", (position > 0) ? ' ' : string[0], (position > 1) ? ' ' : string[1 - position], (position > 2) ? ' ' : string[2 - position], (position > 3) ? ' ' : string[3 - position], (position > 4) ? ' ' : string[4 - position], (position > 5) ? ' ' : string[5 - position], (position > 6) ? ' ' : string[6 - position], (position > 7) ? ' ' : string[7 - position], (position > 8) ? ' ' : string[8 - position], (position > 9) ? ' ' : string[9 - position]); } -inline void watch_set_colon() { +inline void watch_set_colon(void) { slcd_sync_seg_on(&SEGMENT_LCD_0, SLCD_SEGID(1, 16)); } -inline void watch_clear_colon() { +inline void watch_clear_colon(void) { slcd_sync_seg_off(&SEGMENT_LCD_0, SLCD_SEGID(1, 16)); } @@ -261,7 +261,7 @@ inline void watch_clear_indicator(WatchIndicatorSegment indicator) { slcd_sync_seg_off(&SEGMENT_LCD_0, IndicatorSegments[indicator]); } -void watch_clear_all_indicators() { +void watch_clear_all_indicators(void) { slcd_sync_seg_off(&SEGMENT_LCD_0, SLCD_SEGID(2, 17)); slcd_sync_seg_off(&SEGMENT_LCD_0, SLCD_SEGID(2, 16)); slcd_sync_seg_off(&SEGMENT_LCD_0, SLCD_SEGID(0, 17)); @@ -296,7 +296,7 @@ void watch_start_character_blink(char character, uint32_t duration) { _sync_slcd(); } -void watch_stop_blink() { +void watch_stop_blink(void) { SLCD->CTRLD.bit.FC0EN = 0; SLCD->CTRLD.bit.BLINK = 0; } @@ -307,11 +307,11 @@ void watch_start_tick_animation(uint32_t duration) { slcd_sync_start_animation(&SEGMENT_LCD_0, segs, 1, duration); } -bool watch_tick_animation_is_running() { +bool watch_tick_animation_is_running(void) { return hri_slcd_get_CTRLD_CSREN_bit(SLCD); } -void watch_stop_tick_animation() { +void watch_stop_tick_animation(void) { const uint32_t segs[] = { SLCD_SEGID(0, 2)}; slcd_sync_stop_animation(&SEGMENT_LCD_0, segs, 1); watch_display_character(' ', 8); diff --git a/watch-library/watch/watch_slcd.h b/watch-library/watch/watch_slcd.h index abe4d744..3f550bb0 100644 --- a/watch-library/watch/watch_slcd.h +++ b/watch-library/watch/watch_slcd.h @@ -53,7 +53,7 @@ typedef enum WatchIndicatorSegment { /** @brief Enables the Segment LCD display. * Call this before attempting to set pixels or display strings. */ -void watch_enable_display(); +void watch_enable_display(void); /** @brief Sets a pixel. Use this to manually set a pixel with a given common and segment number. * See segmap.html. @@ -71,7 +71,7 @@ void watch_clear_pixel(uint8_t com, uint8_t seg); /** @brief Clears all segments of the display, including incicators and the colon. */ -void watch_clear_display(); +void watch_clear_display(void); /** @brief Displays a string at the given position, starting from the top left. There are ten digits. A space in any position will clear that digit. @@ -86,11 +86,11 @@ void watch_display_string(char *string, uint8_t position); /** @brief Turns the colon segment on. */ -void watch_set_colon(); +void watch_set_colon(void); /** @brief Turns the colon segment off. */ -void watch_clear_colon(); +void watch_clear_colon(void); /** @brief Sets an indicator on the LCD. Use this to turn on one of the indicator segments. * @param indicator One of the indicator segments from the enum. @see WatchIndicatorSegment @@ -105,7 +105,7 @@ void watch_clear_indicator(WatchIndicatorSegment indicator); /** @brief Clears all indicator segments. * @see WatchIndicatorSegment */ -void watch_clear_all_indicators(); +void watch_clear_all_indicators(void); /** @brief Blinks a single character in position 7. Does not affect other positions. * @details Six of the seven segments in position 7 (and only position 7) are capable of autonomous @@ -124,7 +124,7 @@ void watch_start_character_blink(char character, uint32_t duration); /** @brief Stops and clears all blinking segments. * @details This will stop all blinking in position 7, and clear all segments in that digit. */ -void watch_stop_blink(); +void watch_stop_blink(void); /** @brief Begins a two-segment "tick-tock" animation in position 8. * @details Six of the seven segments in position 8 (and only position 8) are capable of autonomous @@ -141,11 +141,11 @@ void watch_start_tick_animation(uint32_t duration); /** @brief Checks if the tick animation is currently running. * @return true if the animation is running; false otherwise. */ -bool watch_tick_animation_is_running(); +bool watch_tick_animation_is_running(void); /** @brief Stops the tick/tock animation and clears all animating segments. * @details This will stop the animation and clear all segments in position 8. */ -void watch_stop_tick_animation(); +void watch_stop_tick_animation(void); /// @} #endif -- cgit v1.2.3