From fef4e0343b14d8d95749e60867828b2773bf8f7d Mon Sep 17 00:00:00 2001 From: ConfuSomu Date: Sun, 7 Feb 2021 14:25:09 -0500 Subject: Move initalisation to init.h/init.c --- CMakeLists.txt | 3 ++- init.c | 33 +++++++++++++++++++++++++++++++++ init.h | 31 +++++++++++++++++++++++++++++++ pico-watch.c | 35 ++--------------------------------- 4 files changed, 68 insertions(+), 34 deletions(-) create mode 100644 init.c create mode 100644 init.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 8019126..0f5e46b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -27,9 +27,10 @@ add_library(Oled target_link_libraries(Oled pico_stdlib hardware_i2c) # Main code -#add_executable(pico-watch pico-watch.c ) add_executable(pico-watch pico-watch.c + init.c + init.h ) pico_set_program_name(pico-watch "pico-watch") diff --git a/init.c b/init.c new file mode 100644 index 0000000..c8a2db3 --- /dev/null +++ b/init.c @@ -0,0 +1,33 @@ +#include +#include "pico/stdlib.h" +#include "hardware/i2c.h" +#include "hardware/rtc.h" +#include "oled/ss_oled.h" + +#include "init.h" + +void init_display() { + oledInit(&oled, OLED_128x64, 0x3d, 0, 0, 1, SDA_PIN, SCL_PIN, RESET_PIN, 1000000L); + oledFill(&oled, 0,1); + oledSetContrast(&oled, OLED_DEFAULT_CONTRAST); + //oledSetTextWrap(&oled, true); +} + +void init_rtc() { + datetime_t init_date = { + .year = INIT_DATETIME_YEAR, + .month = INIT_DATETIME_MONTH, + .day = INIT_DATETIME_DAY, + .dotw = INIT_DATETIME_DOTW, // 0 is Sunday, so 5 is Friday + .hour = INIT_DATETIME_HOUR, + .min = INIT_DATETIME_MIN, + .sec = INIT_DATETIME_SEC }; + rtc_init(); + rtc_set_datetime(&init_date); +} + +void init_all() { + stdio_init_all(); + init_display(); + init_rtc(); +} diff --git a/init.h b/init.h new file mode 100644 index 0000000..a14646e --- /dev/null +++ b/init.h @@ -0,0 +1,31 @@ +#ifndef __INIT_H__ +#define __INIT_H__ + +// To modify the I2C port used, change the `#define I2C_PORT` in "oled/BitBang_I2C.c" +// Pin numbers are GPIO pins. +#define SDA_PIN 6 +#define SCL_PIN 7 +#define RESET_PIN -1 +#define OLED_DEFAULT_CONTRAST 40 +SSOLED oled; + +// Initial date & time +// The idea is to have the compiler set the date at compile-time. +// DOTW: 0 is Sunday +#define INIT_DATETIME_YEAR 2020 +#define INIT_DATETIME_MONTH 06 +#define INIT_DATETIME_DAY 05 +#define INIT_DATETIME_DOTW 5 +#define INIT_DATETIME_HOUR 15 +#define INIT_DATETIME_MIN 45 +#define INIT_DATETIME_SEC 00 + + +// Init every componement +void init_all(); +// Init OLED display +void init_display(); +// Init onboard RTC +void init_rtc(); + +#endif \ No newline at end of file diff --git a/pico-watch.c b/pico-watch.c index b5bb792..a07cd23 100644 --- a/pico-watch.c +++ b/pico-watch.c @@ -5,38 +5,9 @@ #include "pico/util/datetime.h" #include "oled/ss_oled.h" -// To modify the I2C port used, change the `#define I2C_PORT` in "oled/BitBang_I2C.c" -// Pin numbers are GPIO pins. -#define SDA_PIN 6 -#define SCL_PIN 7 -#define RESET_PIN -1 -#define OLED_DEFAULT_CONTRAST 40 -SSOLED oled; -// Unused but useful for reference: -#define OLED_WIDTH 128 -#define OLED_HEIGHT 64 +#include "init.h" -void init_display() { - oledInit(&oled, OLED_128x64, 0x3d, 0, 0, 1, SDA_PIN, SCL_PIN, RESET_PIN, 1000000L); - oledFill(&oled, 0,1); - oledSetContrast(&oled, OLED_DEFAULT_CONTRAST); - //oledSetTextWrap(&oled, true); -} - -void init_rtc() { - datetime_t init_date = { - .year = 2020, - .month = 06, - .day = 05, - .dotw = 5, // 0 is Sunday, so 5 is Friday - .hour = 15, - .min = 45, - .sec = 00 }; - rtc_init(); - rtc_set_datetime(&init_date); -} - // Time as string // Adapted from pico-sdk/scr/common/pico_util/datetime.c void time_as_str(char *buf, uint buf_size, const datetime_t *t) { @@ -82,9 +53,7 @@ void show_datetime() { } int main() { - stdio_init_all(); - init_display(); - init_rtc(); + init_all(); oledWriteString(&oled, 0,15,0, (char *)"Test clock", FONT_8x8, 0, 1); while (1) { show_datetime(); -- cgit v1.2.3-54-g00ecf