mirror of
https://github.com/espressif/ESP8266_RTOS_SDK.git
synced 2025-10-24 20:51:49 +08:00
202 lines
5.8 KiB
C
202 lines
5.8 KiB
C
/*
|
|
* ESPRSSIF MIT License
|
|
*
|
|
* Copyright (c) 2015 <ESPRESSIF SYSTEMS (SHANGHAI) PTE LTD>
|
|
*
|
|
* Permission is hereby granted for use on ESPRESSIF SYSTEMS ESP8266 only, in which case,
|
|
* it is free of charge, to any person obtaining a copy of this software and associated
|
|
* documentation files (the "Software"), to deal in the Software without restriction, including
|
|
* without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the Software is furnished
|
|
* to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all copies or
|
|
* substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
*/
|
|
|
|
#ifndef __ETS_SYS_H__
|
|
#define __ETS_SYS_H__
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
|
|
#include "esp8266/eagle_soc.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* interrupt related */
|
|
#define ETS_SPI_INUM 2
|
|
#define ETS_GPIO_INUM 4
|
|
#define ETS_UART_INUM 5
|
|
#define ETS_MAX_INUM 6
|
|
#define ETS_SOFT_INUM 7
|
|
#define ETS_WDT_INUM 8
|
|
#define ETS_FRC_TIMER1_INUM 9
|
|
|
|
extern char NMIIrqIsOn;
|
|
extern uint32_t WDEV_INTEREST_EVENT;
|
|
|
|
#define INT_ENA_WDEV 0x3ff20c18
|
|
#define WDEV_TSF0_REACH_INT (BIT(27))
|
|
|
|
#define ETS_NMI_LOCK() \
|
|
do { \
|
|
char m = 10; \
|
|
do { \
|
|
REG_WRITE(INT_ENA_WDEV, 0); \
|
|
m = 10; \
|
|
for (; m > 0; m--) {} \
|
|
REG_WRITE(INT_ENA_WDEV, WDEV_TSF0_REACH_INT); \
|
|
} while(0); \
|
|
} while (0)
|
|
|
|
#define ETS_NMI_UNLOCK() \
|
|
do { \
|
|
REG_WRITE(INT_ENA_WDEV, WDEV_INTEREST_EVENT); \
|
|
} while (0)
|
|
|
|
#define ETS_INTR_LOCK() do { \
|
|
if (NMIIrqIsOn == 0) { \
|
|
vPortEnterCritical(); \
|
|
char m = 10; \
|
|
do { \
|
|
REG_WRITE(INT_ENA_WDEV, 0); \
|
|
m = 10; \
|
|
for (; m > 0; m--) {} \
|
|
REG_WRITE(INT_ENA_WDEV, WDEV_TSF0_REACH_INT); \
|
|
} while(0); \
|
|
} \
|
|
} while(0)
|
|
|
|
#define ETS_INTR_UNLOCK() do { \
|
|
if (NMIIrqIsOn == 0) { \
|
|
REG_WRITE(INT_ENA_WDEV, WDEV_INTEREST_EVENT); \
|
|
vPortExitCritical(); \
|
|
} \
|
|
} while(0)
|
|
|
|
#define MAC2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5]
|
|
#define MACSTR "%02x:%02x:%02x:%02x:%02x:%02x"
|
|
|
|
/**
|
|
* @brief Delay function, maximum value: 65535 us.
|
|
*
|
|
* @param uint16_t us : delay time, uint: us, maximum value: 65535 us
|
|
*
|
|
* @return null
|
|
*/
|
|
void os_delay_us(uint16_t us);
|
|
|
|
/**
|
|
* @brief CPU do while loop for some time.
|
|
* In FreeRTOS task, please call FreeRTOS apis.
|
|
*
|
|
* @param uint32_t us : Delay time in us.
|
|
*
|
|
* @return None
|
|
*/
|
|
void ets_delay_us(uint32_t us);
|
|
|
|
/**
|
|
* @brief Register the print output function.
|
|
*
|
|
* @attention os_install_putc1((void *)uart1_write_char) in uart_init will set
|
|
* printf to print from UART 1, otherwise, printf will start from
|
|
* UART 0 by default.
|
|
*
|
|
* @param void(*p)(char c) - pointer of print function
|
|
*
|
|
* @return null
|
|
*/
|
|
void os_install_putc1(void (*p)(char c));
|
|
|
|
/**
|
|
* @brief Print a character. Start from from UART0 by default.
|
|
*
|
|
* @param char c - character to be printed
|
|
*
|
|
* @return null
|
|
*/
|
|
void os_putc(char c);
|
|
|
|
/* timer related */
|
|
typedef void os_timer_func_t(void *timer_arg);
|
|
|
|
typedef struct _os_timer_t {
|
|
struct _os_timer_t *timer_next;
|
|
void *timer_handle;
|
|
uint32_t timer_expire;
|
|
uint32_t timer_period;
|
|
os_timer_func_t *timer_func;
|
|
bool timer_repeat_flag;
|
|
void *timer_arg;
|
|
} os_timer_t;
|
|
|
|
/** \defgroup Timer_APIs Software timer APIs
|
|
* @brief Software timer APIs
|
|
*
|
|
* Timers of the following interfaces are software timers. Functions of the timers are executed during the tasks.
|
|
* Since a task can be stopped, or be delayed because there are other tasks with higher priorities, the following os_timer interfaces cannot guarantee the precise execution of the timers.
|
|
* - For the same timer, os_timer_arm (or os_timer_arm_us) cannot be invoked repeatedly. os_timer_disarm should be invoked first.
|
|
* - os_timer_setfn can only be invoked when the timer is not enabled, i.e., after os_timer_disarm or before os_timer_arm (or os_timer_arm_us).
|
|
*
|
|
*/
|
|
|
|
/** @addtogroup Timer_APIs
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @brief Set the timer callback function.
|
|
*
|
|
* @attention 1. The callback function must be set in order to enable the timer.
|
|
* @attention 2. Operating system scheduling is disabled in timer callback.
|
|
*
|
|
* @param os_timer_t *ptimer : Timer structure
|
|
* @param os_timer_func_t *pfunction : timer callback function
|
|
* @param void *parg : callback function parameter
|
|
*
|
|
* @return null
|
|
*/
|
|
void os_timer_setfn(os_timer_t *ptimer, os_timer_func_t *pfunction, void *parg);
|
|
|
|
/**
|
|
* @brief Enable the millisecond timer.
|
|
*
|
|
* @param os_timer_t *ptimer : timer structure
|
|
* @param uint32_t milliseconds : Timing, unit: millisecond, range: 5 ~ 0x68DB8
|
|
* @param bool repeat_flag : Whether the timer will be invoked repeatedly or not
|
|
*
|
|
* @return null
|
|
*/
|
|
void os_timer_arm(os_timer_t *ptimer, uint32_t msec, bool repeat_flag);
|
|
|
|
/**
|
|
* @brief Disarm the timer
|
|
*
|
|
* @param os_timer_t *ptimer : Timer structure
|
|
*
|
|
* @return null
|
|
*/
|
|
void os_timer_disarm(os_timer_t *ptimer);
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _ETS_SYS_H */
|