Damien George | 075d597 | 2014-11-27 20:30:33 +0000 | [diff] [blame] | 1 | /* |
Alexander Steffen | 55f3324 | 2017-06-30 09:22:17 +0200 | [diff] [blame^] | 2 | * This file is part of the MicroPython project, http://micropython.org/ |
Damien George | 075d597 | 2014-11-27 20:30:33 +0000 | [diff] [blame] | 3 | * |
| 4 | * The MIT License (MIT) |
| 5 | * |
| 6 | * Copyright (c) 2014 Damien P. George |
| 7 | * |
| 8 | * Permission is hereby granted, free of charge, to any person obtaining a copy |
| 9 | * of this software and associated documentation files (the "Software"), to deal |
| 10 | * in the Software without restriction, including without limitation the rights |
| 11 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| 12 | * copies of the Software, and to permit persons to whom the Software is |
| 13 | * furnished to do so, subject to the following conditions: |
| 14 | * |
| 15 | * The above copyright notice and this permission notice shall be included in |
| 16 | * all copies or substantial portions of the Software. |
| 17 | * |
| 18 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| 19 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| 20 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| 21 | * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| 22 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| 23 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| 24 | * THE SOFTWARE. |
| 25 | */ |
| 26 | |
Paul Sokolovsky | 61fa7c8 | 2016-03-30 18:50:38 +0300 | [diff] [blame] | 27 | #include "py/ringbuf.h" |
Paul Sokolovsky | 6ab2c5e | 2016-09-29 10:13:17 -0700 | [diff] [blame] | 28 | #include "lib/utils/interrupt_char.h" |
Damien George | 45f3416 | 2016-05-26 17:11:43 +0100 | [diff] [blame] | 29 | #include "xtirq.h" |
Paul Sokolovsky | 61fa7c8 | 2016-03-30 18:50:38 +0300 | [diff] [blame] | 30 | |
Paul Sokolovsky | 4681b86 | 2016-05-24 01:37:56 +0300 | [diff] [blame] | 31 | void mp_keyboard_interrupt(void); |
Paul Sokolovsky | 4681b86 | 2016-05-24 01:37:56 +0300 | [diff] [blame] | 32 | |
Paul Sokolovsky | 402a743 | 2016-03-29 11:48:43 +0300 | [diff] [blame] | 33 | struct _mp_print_t; |
| 34 | // Structure for UART-only output via mp_printf() |
| 35 | extern const struct _mp_print_t mp_debug_print; |
| 36 | |
Paul Sokolovsky | 61fa7c8 | 2016-03-30 18:50:38 +0300 | [diff] [blame] | 37 | extern ringbuf_t input_buf; |
| 38 | // Call this after putting data to input_buf |
| 39 | void mp_hal_signal_input(void); |
Paul Sokolovsky | 98af891 | 2016-03-31 19:49:55 +0300 | [diff] [blame] | 40 | // Call this when data is available in dupterm object |
| 41 | void mp_hal_signal_dupterm_input(void); |
Paul Sokolovsky | 61fa7c8 | 2016-03-30 18:50:38 +0300 | [diff] [blame] | 42 | |
Damien George | 075d597 | 2014-11-27 20:30:33 +0000 | [diff] [blame] | 43 | void mp_hal_init(void); |
Paul Sokolovsky | a4c8ef9 | 2016-02-08 21:43:37 +0200 | [diff] [blame] | 44 | void mp_hal_rtc_init(void); |
Damien George | 075d597 | 2014-11-27 20:30:33 +0000 | [diff] [blame] | 45 | |
Damien George | b41a14a | 2015-12-28 17:27:44 +0000 | [diff] [blame] | 46 | uint32_t mp_hal_ticks_us(void); |
Paul Sokolovsky | f71f37e | 2016-08-07 16:03:00 +0300 | [diff] [blame] | 47 | __attribute__((always_inline)) static inline uint32_t mp_hal_ticks_cpu(void) { |
| 48 | uint32_t ccount; |
| 49 | __asm__ __volatile__("rsr %0,ccount":"=a" (ccount)); |
| 50 | return ccount; |
| 51 | } |
| 52 | |
Paul Sokolovsky | 5699fc9 | 2015-10-29 02:06:13 +0300 | [diff] [blame] | 53 | void mp_hal_delay_us(uint32_t); |
Damien George | 075d597 | 2014-11-27 20:30:33 +0000 | [diff] [blame] | 54 | void mp_hal_set_interrupt_char(int c); |
| 55 | uint32_t mp_hal_get_cpu_freq(void); |
| 56 | |
Paul Sokolovsky | f12ea7c | 2015-01-16 01:54:40 +0200 | [diff] [blame] | 57 | #define UART_TASK_ID 0 |
Paul Sokolovsky | 98af891 | 2016-03-31 19:49:55 +0300 | [diff] [blame] | 58 | #define DUPTERM_TASK_ID 1 |
Paul Sokolovsky | f12ea7c | 2015-01-16 01:54:40 +0200 | [diff] [blame] | 59 | void uart_task_init(); |
Paul Sokolovsky | 98af891 | 2016-03-31 19:49:55 +0300 | [diff] [blame] | 60 | void dupterm_task_init(); |
Paul Sokolovsky | f12ea7c | 2015-01-16 01:54:40 +0200 | [diff] [blame] | 61 | |
Paul Sokolovsky | a099bfe | 2016-03-11 09:38:20 +0700 | [diff] [blame] | 62 | void ets_event_poll(void); |
Damien George | 9475cc5 | 2016-03-30 11:35:03 +0300 | [diff] [blame] | 63 | #define ETS_POLL_WHILE(cond) { while (cond) ets_event_poll(); } |
Damien George | 0b32e50 | 2015-02-13 15:04:53 +0000 | [diff] [blame] | 64 | |
Damien George | a525493 | 2016-04-12 13:55:20 +0100 | [diff] [blame] | 65 | // needed for machine.I2C |
| 66 | #include "osapi.h" |
| 67 | #define mp_hal_delay_us_fast(us) os_delay_us(us) |
| 68 | |
Damien George | 45f3416 | 2016-05-26 17:11:43 +0100 | [diff] [blame] | 69 | #define mp_hal_quiet_timing_enter() disable_irq() |
| 70 | #define mp_hal_quiet_timing_exit(irq_state) enable_irq(irq_state) |
| 71 | |
Damien George | ac63ca7 | 2016-04-12 13:54:40 +0100 | [diff] [blame] | 72 | // C-level pin HAL |
| 73 | #include "etshal.h" |
| 74 | #include "gpio.h" |
Paul Sokolovsky | 8bc3fc2 | 2016-11-06 01:30:19 +0300 | [diff] [blame] | 75 | #include "esp8266/modmachine.h" |
Damien George | 1eb3c66 | 2016-12-08 13:47:01 +1100 | [diff] [blame] | 76 | #define MP_HAL_PIN_FMT "%u" |
Damien George | a2d5d84 | 2016-04-22 10:04:12 +0100 | [diff] [blame] | 77 | #define mp_hal_pin_obj_t uint32_t |
| 78 | #define mp_hal_get_pin_obj(o) mp_obj_get_pin(o) |
Damien George | 1eb3c66 | 2016-12-08 13:47:01 +1100 | [diff] [blame] | 79 | #define mp_hal_pin_name(p) (p) |
Damien George | 68e222a | 2016-05-26 15:42:27 +0100 | [diff] [blame] | 80 | void mp_hal_pin_input(mp_hal_pin_obj_t pin); |
| 81 | void mp_hal_pin_output(mp_hal_pin_obj_t pin); |
Damien George | 4b37e77 | 2016-05-26 17:06:40 +0100 | [diff] [blame] | 82 | void mp_hal_pin_open_drain(mp_hal_pin_obj_t pin); |
| 83 | #define mp_hal_pin_od_low(p) do { \ |
Damien George | 67a6d31 | 2016-04-22 10:35:26 +0100 | [diff] [blame] | 84 | if ((p) == 16) { WRITE_PERI_REG(RTC_GPIO_ENABLE, (READ_PERI_REG(RTC_GPIO_ENABLE) & ~1) | 1); } \ |
| 85 | else { gpio_output_set(0, 1 << (p), 1 << (p), 0); } \ |
| 86 | } while (0) |
| 87 | #define mp_hal_pin_od_high(p) do { \ |
| 88 | if ((p) == 16) { WRITE_PERI_REG(RTC_GPIO_ENABLE, (READ_PERI_REG(RTC_GPIO_ENABLE) & ~1)); } \ |
| 89 | else { gpio_output_set(1 << (p), 0, 1 << (p), 0); } \ |
| 90 | } while (0) |
| 91 | #define mp_hal_pin_read(p) pin_get(p) |
Damien George | b372156 | 2016-04-22 10:44:06 +0100 | [diff] [blame] | 92 | #define mp_hal_pin_write(p, v) pin_set((p), (v)) |
Damien George | ac63ca7 | 2016-04-12 13:54:40 +0100 | [diff] [blame] | 93 | |
Paul Sokolovsky | 3d83041 | 2016-05-03 00:18:14 +0300 | [diff] [blame] | 94 | void *ets_get_esf_buf_ctlblk(void); |
| 95 | int ets_esf_free_bufs(int idx); |