blob: 913bd70dc983215dcc421752ebaf78e66b0fb9ee [file] [log] [blame]
Damien George075d5972014-11-27 20:30:33 +00001/*
Alexander Steffen55f33242017-06-30 09:22:17 +02002 * This file is part of the MicroPython project, http://micropython.org/
Damien George075d5972014-11-27 20:30:33 +00003 *
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 Sokolovsky61fa7c82016-03-30 18:50:38 +030027#include "py/ringbuf.h"
Paul Sokolovsky6ab2c5e2016-09-29 10:13:17 -070028#include "lib/utils/interrupt_char.h"
Damien George45f34162016-05-26 17:11:43 +010029#include "xtirq.h"
Paul Sokolovsky61fa7c82016-03-30 18:50:38 +030030
Paul Sokolovsky4681b862016-05-24 01:37:56 +030031void mp_keyboard_interrupt(void);
Paul Sokolovsky4681b862016-05-24 01:37:56 +030032
Paul Sokolovsky402a7432016-03-29 11:48:43 +030033struct _mp_print_t;
34// Structure for UART-only output via mp_printf()
35extern const struct _mp_print_t mp_debug_print;
36
Paul Sokolovsky61fa7c82016-03-30 18:50:38 +030037extern ringbuf_t input_buf;
38// Call this after putting data to input_buf
39void mp_hal_signal_input(void);
Paul Sokolovsky98af8912016-03-31 19:49:55 +030040// Call this when data is available in dupterm object
41void mp_hal_signal_dupterm_input(void);
Paul Sokolovsky61fa7c82016-03-30 18:50:38 +030042
Damien George075d5972014-11-27 20:30:33 +000043void mp_hal_init(void);
Paul Sokolovskya4c8ef92016-02-08 21:43:37 +020044void mp_hal_rtc_init(void);
Damien George075d5972014-11-27 20:30:33 +000045
Damien Georgeb41a14a2015-12-28 17:27:44 +000046uint32_t mp_hal_ticks_us(void);
Paul Sokolovskyf71f37e2016-08-07 16:03:00 +030047__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 Sokolovsky5699fc92015-10-29 02:06:13 +030053void mp_hal_delay_us(uint32_t);
Damien George075d5972014-11-27 20:30:33 +000054void mp_hal_set_interrupt_char(int c);
55uint32_t mp_hal_get_cpu_freq(void);
56
Paul Sokolovskyf12ea7c2015-01-16 01:54:40 +020057#define UART_TASK_ID 0
Paul Sokolovsky98af8912016-03-31 19:49:55 +030058#define DUPTERM_TASK_ID 1
Paul Sokolovskyf12ea7c2015-01-16 01:54:40 +020059void uart_task_init();
Paul Sokolovsky98af8912016-03-31 19:49:55 +030060void dupterm_task_init();
Paul Sokolovskyf12ea7c2015-01-16 01:54:40 +020061
Paul Sokolovskya099bfe2016-03-11 09:38:20 +070062void ets_event_poll(void);
Damien George9475cc52016-03-30 11:35:03 +030063#define ETS_POLL_WHILE(cond) { while (cond) ets_event_poll(); }
Damien George0b32e502015-02-13 15:04:53 +000064
Damien Georgea5254932016-04-12 13:55:20 +010065// needed for machine.I2C
66#include "osapi.h"
67#define mp_hal_delay_us_fast(us) os_delay_us(us)
68
Damien George45f34162016-05-26 17:11:43 +010069#define mp_hal_quiet_timing_enter() disable_irq()
70#define mp_hal_quiet_timing_exit(irq_state) enable_irq(irq_state)
71
Damien Georgeac63ca72016-04-12 13:54:40 +010072// C-level pin HAL
73#include "etshal.h"
74#include "gpio.h"
Paul Sokolovsky8bc3fc22016-11-06 01:30:19 +030075#include "esp8266/modmachine.h"
Damien George1eb3c662016-12-08 13:47:01 +110076#define MP_HAL_PIN_FMT "%u"
Damien Georgea2d5d842016-04-22 10:04:12 +010077#define mp_hal_pin_obj_t uint32_t
78#define mp_hal_get_pin_obj(o) mp_obj_get_pin(o)
Damien George1eb3c662016-12-08 13:47:01 +110079#define mp_hal_pin_name(p) (p)
Damien George68e222a2016-05-26 15:42:27 +010080void mp_hal_pin_input(mp_hal_pin_obj_t pin);
81void mp_hal_pin_output(mp_hal_pin_obj_t pin);
Damien George4b37e772016-05-26 17:06:40 +010082void mp_hal_pin_open_drain(mp_hal_pin_obj_t pin);
83#define mp_hal_pin_od_low(p) do { \
Damien George67a6d312016-04-22 10:35:26 +010084 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 Georgeb3721562016-04-22 10:44:06 +010092#define mp_hal_pin_write(p, v) pin_set((p), (v))
Damien Georgeac63ca72016-04-12 13:54:40 +010093
Paul Sokolovsky3d830412016-05-03 00:18:14 +030094void *ets_get_esf_buf_ctlblk(void);
95int ets_esf_free_bufs(int idx);