diff options
Diffstat (limited to 'src/arch/esp8266/driver')
-rw-r--r-- | src/arch/esp8266/driver/counter.cc | 8 | ||||
-rw-r--r-- | src/arch/esp8266/driver/gpio.cc | 199 | ||||
-rw-r--r-- | src/arch/esp8266/driver/stdin.cc | 82 | ||||
-rw-r--r-- | src/arch/esp8266/driver/stdout.cc | 264 | ||||
-rw-r--r-- | src/arch/esp8266/driver/uptime.cc | 8 |
5 files changed, 0 insertions, 561 deletions
diff --git a/src/arch/esp8266/driver/counter.cc b/src/arch/esp8266/driver/counter.cc deleted file mode 100644 index dd6196a..0000000 --- a/src/arch/esp8266/driver/counter.cc +++ /dev/null @@ -1,8 +0,0 @@ -/* - * Copyright 2020 Daniel Friesel - * - * SPDX-License-Identifier: BSD-2-Clause - */ -#include "driver/counter.h" - -Counter counter; diff --git a/src/arch/esp8266/driver/gpio.cc b/src/arch/esp8266/driver/gpio.cc deleted file mode 100644 index d6c92a4..0000000 --- a/src/arch/esp8266/driver/gpio.cc +++ /dev/null @@ -1,199 +0,0 @@ -/* - * Copyright 2020 Daniel Friesel - * - * SPDX-License-Identifier: BSD-2-Clause - */ -#include "driver/gpio.h" -extern "C" { -#include "osapi.h" -#include "user_interface.h" -#include "gpio.h" -} - -void ICACHE_FLASH_ATTR GPIO::setup() -{ - gpio_init(); - - // Enable GPIO2 (ESP8266 on-board LED) as output - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO2_U, FUNC_GPIO2); - -#ifdef LED_ON_GPIO16 - // Enable GPIO16 (RTC out / NodeMCU on-board LED) as output - WRITE_PERI_REG(PAD_XPD_DCDC_CONF, (READ_PERI_REG(PAD_XPD_DCDC_CONF) & 0xffffffbc) | (uint32)0x1); - WRITE_PERI_REG(RTC_GPIO_CONF, (READ_PERI_REG(RTC_GPIO_CONF) & (uint32)0xfffffffe) | (uint32)0x0); - WRITE_PERI_REG(RTC_GPIO_ENABLE, (READ_PERI_REG(RTC_GPIO_ENABLE) & (uint32)0xfffffffe) | (uint32)0x1); - // Turn the GPIO on to make sure the LED is off by default - WRITE_PERI_REG(RTC_GPIO_OUT, (READ_PERI_REG(RTC_GPIO_OUT) & (uint32)0xfffffffe) | (uint32)(1)); -#endif -} - -void ICACHE_FLASH_ATTR GPIO::led_on(unsigned char const id) -{ -#ifdef LED_ON_GPIO16 - if (id == 0) { - gpio_output_set(0, BIT2, BIT2, 0); - } else { - WRITE_PERI_REG(RTC_GPIO_OUT, (READ_PERI_REG(RTC_GPIO_OUT) & (uint32)0xfffffffe) | (uint32)(0)); - } -#else - gpio_output_set(0, BIT2, BIT2, 0); -#endif -} - -void ICACHE_FLASH_ATTR GPIO::led_off(unsigned char const id) -{ -#ifdef LED_ON_GPIO16 - if (id == 0) { - gpio_output_set(BIT2, 0, BIT2, 0); - } else { - WRITE_PERI_REG(RTC_GPIO_OUT, (READ_PERI_REG(RTC_GPIO_OUT) & (uint32)0xfffffffe) | (uint32)(0)); - } -#else - gpio_output_set(BIT2, 0, BIT2, 0); -#endif -} - -void ICACHE_FLASH_ATTR GPIO::led_toggle(unsigned char const id) -{ -#ifdef LED_ON_GPIO16 - if (id == 0) { - if (gpio_input_get() & BIT2) { - led_on(0); - } else { - led_off(0); - } - } else { - WRITE_PERI_REG(RTC_GPIO_OUT, (READ_PERI_REG(RTC_GPIO_OUT) ^ BIT0)); - } -#else - if (gpio_input_get() & BIT2) { - led_on(0); - } else { - led_off(0); - } -#endif -} - -void ICACHE_FLASH_ATTR GPIO::input(unsigned char const pin) -{ - if (pin == d0) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO0_U, FUNC_GPIO0); - } else if (pin == tx) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0TXD_U, FUNC_GPIO1); - } else if (pin == d4) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO2_U, FUNC_GPIO2); - } else if (pin == rx) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_GPIO3); - } else if (pin == d2) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO4_U, FUNC_GPIO4); - } else if (pin == d1) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO5_U, FUNC_GPIO5); - } else if (pin == d6) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDI_U, FUNC_GPIO12); - } else if (pin == d7) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_GPIO13); - } else if (pin == d5) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTMS_U, FUNC_GPIO14); - } else if (pin == d8) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_GPIO15); - } else if (pin == d0) { - // TODO this sets it as output, not input - WRITE_PERI_REG(PAD_XPD_DCDC_CONF, (READ_PERI_REG(PAD_XPD_DCDC_CONF) & 0xffffffbc) | (uint32)0x1); - WRITE_PERI_REG(RTC_GPIO_CONF, (READ_PERI_REG(RTC_GPIO_CONF) & (uint32)0xfffffffe) | (uint32)0x0); - WRITE_PERI_REG(RTC_GPIO_ENABLE, (READ_PERI_REG(RTC_GPIO_ENABLE) & (uint32)0xfffffffe) | (uint32)0x1); - } - if (pin < d0) { - gpio_output_set(0, 0, 0, (1 << pin)); - } -} - -void ICACHE_FLASH_ATTR GPIO::input(unsigned char const pin, bool pullup) -{ - if (pin == d0) { - if (pullup) { - PIN_PULLUP_EN(PERIPHS_IO_MUX_GPIO0_U); - } else { - PIN_PULLUP_DIS(PERIPHS_IO_MUX_GPIO0_U); - } - } else if (pin == tx) { - if (pullup) { - PIN_PULLUP_EN(PERIPHS_IO_MUX_U0TXD_U); - } else { - PIN_PULLUP_DIS(PERIPHS_IO_MUX_U0TXD_U); - } - } else if (pin == d4) { - if (pullup) { - PIN_PULLUP_EN(PERIPHS_IO_MUX_GPIO2_U); - } else { - PIN_PULLUP_DIS(PERIPHS_IO_MUX_GPIO2_U); - } - } else if (pin == rx) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_GPIO3); - } else if (pin == d2) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO4_U, FUNC_GPIO4); - } else if (pin == d1) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO5_U, FUNC_GPIO5); - } else if (pin == d6) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDI_U, FUNC_GPIO12); - } else if (pin == d7) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_GPIO13); - } else if (pin == d5) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTMS_U, FUNC_GPIO14); - } else if (pin == d8) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_GPIO15); - } else if (pin == d0) { - // TODO this sets it as output, not input - WRITE_PERI_REG(PAD_XPD_DCDC_CONF, (READ_PERI_REG(PAD_XPD_DCDC_CONF) & 0xffffffbc) | (uint32)0x1); - WRITE_PERI_REG(RTC_GPIO_CONF, (READ_PERI_REG(RTC_GPIO_CONF) & (uint32)0xfffffffe) | (uint32)0x0); - WRITE_PERI_REG(RTC_GPIO_ENABLE, (READ_PERI_REG(RTC_GPIO_ENABLE) & (uint32)0xfffffffe) | (uint32)0x1); - } - input(pin); -} - -void ICACHE_FLASH_ATTR GPIO::output(unsigned char const pin) -{ - if (pin == d0) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO0_U, FUNC_GPIO0); - } else if (pin == tx) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0TXD_U, FUNC_GPIO1); - } else if (pin == d4) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO2_U, FUNC_GPIO2); - } else if (pin == rx) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_GPIO3); - } else if (pin == d2) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO4_U, FUNC_GPIO4); - } else if (pin == d1) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO5_U, FUNC_GPIO5); - } else if (pin == d6) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDI_U, FUNC_GPIO12); - } else if (pin == d7) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_GPIO13); - } else if (pin == d5) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTMS_U, FUNC_GPIO14); - } else if (pin == d8) { - PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_GPIO15); - } else if (pin == d0) { - WRITE_PERI_REG(PAD_XPD_DCDC_CONF, (READ_PERI_REG(PAD_XPD_DCDC_CONF) & 0xffffffbc) | (uint32)0x1); - WRITE_PERI_REG(RTC_GPIO_CONF, (READ_PERI_REG(RTC_GPIO_CONF) & (uint32)0xfffffffe) | (uint32)0x0); - WRITE_PERI_REG(RTC_GPIO_ENABLE, (READ_PERI_REG(RTC_GPIO_ENABLE) & (uint32)0xfffffffe) | (uint32)0x1); - } - if (pin < d0) { - gpio_output_set(0, 0, (1 << pin), 0); - } -} - -unsigned char ICACHE_FLASH_ATTR GPIO::read(unsigned char const pin) -{ - return (gpio_input_get() & (1 << pin)); -} - -void ICACHE_FLASH_ATTR GPIO::write(unsigned char const pin, unsigned char value) -{ - if (value) { - gpio_output_set(1 << pin, 0, 0, 0); - } else { - gpio_output_set(0, 1 << pin, 0, 0); - } -} - -GPIO gpio; diff --git a/src/arch/esp8266/driver/stdin.cc b/src/arch/esp8266/driver/stdin.cc deleted file mode 100644 index 7032d81..0000000 --- a/src/arch/esp8266/driver/stdin.cc +++ /dev/null @@ -1,82 +0,0 @@ -/* - * Copyright 2020 Daniel Friesel - * - * SPDX-License-Identifier: BSD-2-Clause - */ -#include "driver/stdin.h" -#include "driver/gpio.h" -extern "C" { -#include "osapi.h" -#include "user_interface.h" -#include "gpio.h" -#include "ets_sys.h" -void ets_isr_attach(uint16_t idx, void func(), void *arg); -void ets_isr_unmask(uint16_t idx); -} - -#define USF *((volatile uint32_t *)(0x60000000)) -#define USIR *((volatile uint32_t *)(0x60000004)) -#define USIS *((volatile uint32_t *)(0x60000008)) -#define USIE *((volatile uint32_t *)(0x6000000c)) -#define USIC *((volatile uint32_t *)(0x60000010)) -#define USS *((volatile uint32_t *)(0x6000001c)) -#define USC1 *((volatile uint32_t *)(0x60000024)) - -#define UIFF 0 -#define UIFE 1 -#define UIPE 2 -#define UIFR 3 -#define UIOF 4 -#define UIDSR 5 -#define UICTS 6 -#define UIBD 7 -#define UITO 8 - -#define USRXC 0 -#define UCFFT 0 -#define UCTOT 24 -#define UCTOE 31 - - -#ifdef CONFIG_wakeup -void wakeup(); -#endif - -void uart_isr() -{ - if (USIS & ((1 << UIFF) | (1 << UITO))) { - while ((USS >> USRXC) & 0x7f) { - kin.addKey(USF); - } - } - USIC = USIS; -#ifdef CONFIG_wakeup - wakeup(); -#endif -} - -void StandardInput::setup() -{ - //USC1 = (0x7f << UCFFT) | (0x02 << UCTOT) | (1 << UCTOE ); - USIC = 0xffff; - USIE = (1 << UIFF) | (1 << UIFR) | (1 << UITO); - ETS_UART_INTR_ATTACH(&uart_isr, NULL); - ETS_UART_INTR_ENABLE(); -} - -bool StandardInput::hasKey() -{ - if (write_pos != read_pos) { - return true; - } - return false; -} - -char StandardInput::getKey() -{ - char ret = buffer[read_pos++]; - read_pos %= 8; - return ret; -} - -StandardInput kin; diff --git a/src/arch/esp8266/driver/stdout.cc b/src/arch/esp8266/driver/stdout.cc deleted file mode 100644 index 09a893f..0000000 --- a/src/arch/esp8266/driver/stdout.cc +++ /dev/null @@ -1,264 +0,0 @@ -/* - * Copyright 2020 Daniel Friesel - * - * SPDX-License-Identifier: BSD-2-Clause - */ -#include "driver/stdout.h" -extern "C" { -#include "osapi.h" -#include "user_interface.h" -#include "gpio.h" -void uart_div_modify(uint8_t uart_no, uint32 DivLatchValue); -void os_printf_plus(const char *s, ...); -} - -StandardOutput & StandardOutput::operator<<(unsigned char c) -{ - if (base == 16) { - os_printf("%02x", c); - } else { - os_printf("%d", c); - } - return *this; -} - -StandardOutput & StandardOutput::operator<<(char c) -{ - put(c); - return *this; -} - -StandardOutput & StandardOutput::operator<<(unsigned short number) -{ - os_printf("%u", number); - return *this; -} - -StandardOutput & StandardOutput::operator<<(short number) -{ - os_printf("%d", number); - return *this; -} - -StandardOutput & StandardOutput::operator<<(unsigned int number) -{ - if (base == 16) { - os_printf("%08x", number); - } else { - os_printf("%u", number); - } - return *this; -} - -StandardOutput & StandardOutput::operator<<(int number) -{ - if (base == 16) { - os_printf("%08x", number); - } else { - os_printf("%d", number); - } - return *this; -} - -StandardOutput & StandardOutput::operator<<(unsigned long number) -{ - os_printf("%lu", number); - return *this; -} - -StandardOutput & StandardOutput::operator<<(long number) -{ - os_printf("%ld", number); - return *this; -} - -StandardOutput & StandardOutput::operator<<(float number) -{ - printf_float(number); - return *this; -} - -StandardOutput & StandardOutput::operator<<(double number) -{ - printf_float(number); - return *this; -} - -ICACHE_FLASH_ATTR StandardOutput & StandardOutput::operator<<(unsigned long long number) -{ - switch (base) { - case 2: - put('0'); - put('b'); - break; - case 8: - put('0'); - break; - case 16: - put('0'); - put('x'); - break; - } - - if (number == 0) { - put('0'); - return *this; - } - - signed int i = 0; - while (number > 0) { - if (base == 16 && number % base > 9) { - digit_buffer[i] = 'a' + (number % base) - 10; - } else { - digit_buffer[i] = '0' + (number % base); - } - number /= base; - i++; - } - i--; - for (; i >= 0; i--) { - put(digit_buffer[i]); - } - return *this; - -} - -StandardOutput & StandardOutput::operator<<(long long number) -{ - if (number < 0) { - put('-'); - number *= -1; - } - *this << (unsigned long long)number; - - return *this; -} - -StandardOutput & StandardOutput::operator<<(void *pointer) -{ - unsigned short temp_base = base; - *this << hex << (long)pointer; - switch (temp_base) { - case 2: - *this << bin; break; - case 8: - *this << oct; break; - case 10: - *this << dec; break; - } - return *this; -} - -StandardOutput & StandardOutput::operator<<(const char *text) -{ - write(text); - return *this; -} - -StandardOutput & StandardOutput::operator<<(StandardOutput & (*fkt) (StandardOutput &)) -{ - return fkt(*this); -} - -void StandardOutput::setBase(uint8_t b) -{ - if (b == 2 || b == 8 || b == 10 || b == 16) { - base = b; - } -} - -static inline char format_hex_nibble(uint8_t num) -{ - if (num > 9) { - return 'a' + num - 10; - } - return '0' + num; -} - -void StandardOutput::printf_uint8(uint8_t num) -{ - put(format_hex_nibble(num / 16)); - put(format_hex_nibble(num % 16)); -} - -ICACHE_FLASH_ATTR void StandardOutput::printf_float(float num) -{ - if (num < 0) { - put('-'); - num *= -1; - } - if (num > 1000) { - put('0' + (((int)num % 10000) / 1000)); - } - if (num > 100) { - put('0' + (((int)num % 1000) / 100)); - } - if (num > 10) { - put('0' + (((int)num % 100) / 10)); - } - put('0' + ((int)num % 10)); - put('.'); - put('0' + ((int)(num * 10) % 10)); - put('0' + ((int)(num * 100) % 10)); -} - -StandardOutput & flush(StandardOutput & os) -{ - os.flush(); - return os; -} - -StandardOutput & endl(StandardOutput & os) -{ - os.put('\n'); - os.flush(); - return os; -} - -StandardOutput & bin(StandardOutput & os) -{ - os.setBase(2); - return os; -} - -StandardOutput & oct(StandardOutput & os) -{ - os.setBase(8); - return os; -} - -StandardOutput & dec(StandardOutput & os) -{ - os.setBase(10); - return os; -} - -StandardOutput & hex(StandardOutput & os) -{ - os.setBase(16); - return os; -} - -StandardOutput & term(StandardOutput & os) -{ - os.put('\0'); - os.flush(); - return os; -} - -void StandardOutput::setup() -{ - uart_div_modify(0, UART_CLK_FREQ / 115200); -} - -void StandardOutput::put(char c) -{ - os_printf("%c", c); -} - -void StandardOutput::write(const char *s) -{ - os_printf("%s", s); -} - -StandardOutput kout; diff --git a/src/arch/esp8266/driver/uptime.cc b/src/arch/esp8266/driver/uptime.cc deleted file mode 100644 index 621ec91..0000000 --- a/src/arch/esp8266/driver/uptime.cc +++ /dev/null @@ -1,8 +0,0 @@ -/* - * Copyright 2020 Daniel Friesel - * - * SPDX-License-Identifier: BSD-2-Clause - */ -#include "driver/uptime.h" - -Uptime uptime; |