2018-07-04 19:01:03 -04:00
|
|
|
/*
|
2022-07-22 04:14:37 -04:00
|
|
|
* SPDX-FileCopyrightText: 2001-2003 Swedish Institute of Computer Science
|
2018-07-04 19:01:03 -04:00
|
|
|
*
|
2022-07-22 04:14:37 -04:00
|
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
2018-07-04 19:01:03 -04:00
|
|
|
*
|
2024-05-09 07:09:59 -04:00
|
|
|
* SPDX-FileContributor: 2018-2024 Espressif Systems (Shanghai) CO LTD
|
2018-07-04 19:01:03 -04:00
|
|
|
*/
|
|
|
|
#ifndef __SYS_ARCH_H__
|
|
|
|
#define __SYS_ARCH_H__
|
|
|
|
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
#include "freertos/queue.h"
|
|
|
|
#include "freertos/semphr.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2019-09-29 06:10:48 -04:00
|
|
|
typedef SemaphoreHandle_t sys_sem_t;
|
|
|
|
typedef SemaphoreHandle_t sys_mutex_t;
|
|
|
|
typedef TaskHandle_t sys_thread_t;
|
2016-08-17 11:08:22 -04:00
|
|
|
|
|
|
|
typedef struct sys_mbox_s {
|
2019-09-29 06:10:48 -04:00
|
|
|
QueueHandle_t os_mbox;
|
2016-08-17 11:08:22 -04:00
|
|
|
}* sys_mbox_t;
|
|
|
|
|
2019-09-29 06:10:48 -04:00
|
|
|
/** This is returned by _fromisr() sys functions to tell the outermost function
|
|
|
|
* that a higher priority task was woken and the scheduler needs to be invoked.
|
|
|
|
*/
|
|
|
|
#define ERR_NEED_SCHED 123
|
|
|
|
|
|
|
|
void sys_delay_ms(uint32_t ms);
|
|
|
|
#define sys_msleep(ms) sys_delay_ms(ms)
|
2016-08-17 11:08:22 -04:00
|
|
|
|
2018-07-04 19:01:03 -04:00
|
|
|
#define LWIP_COMPAT_MUTEX 0
|
|
|
|
|
|
|
|
#if !LWIP_COMPAT_MUTEX
|
2024-05-09 07:09:59 -04:00
|
|
|
#define sys_mutex_valid_val(mutex) ((mutex) != NULL)
|
|
|
|
#define sys_mutex_valid(mutex) (((mutex) != NULL) && sys_mutex_valid_val(*(mutex)))
|
|
|
|
#define sys_mutex_set_invalid(mutex) ((*(mutex)) = NULL)
|
2018-07-04 19:01:03 -04:00
|
|
|
#endif
|
|
|
|
|
2024-05-09 07:09:59 -04:00
|
|
|
#define sys_mbox_valid(mbox) (*(mbox) != NULL)
|
|
|
|
#define sys_mbox_set_invalid(mbox) (*(mbox) = NULL)
|
2018-12-20 01:03:11 -05:00
|
|
|
|
2024-05-09 07:09:59 -04:00
|
|
|
#define sys_sem_valid_val(sema) ((sema) != NULL)
|
|
|
|
#define sys_sem_valid(sema) (((sema) != NULL) && sys_sem_valid_val(*(sema)))
|
|
|
|
#define sys_sem_set_invalid(sema) ((*(sema)) = NULL)
|
2018-07-04 19:01:03 -04:00
|
|
|
|
2016-08-17 11:08:22 -04:00
|
|
|
void sys_delay_ms(uint32_t ms);
|
2016-08-19 05:23:04 -04:00
|
|
|
sys_sem_t* sys_thread_sem_init(void);
|
|
|
|
void sys_thread_sem_deinit(void);
|
2018-07-04 19:01:03 -04:00
|
|
|
sys_sem_t* sys_thread_sem_get(void);
|
|
|
|
|
2022-10-27 13:07:07 -04:00
|
|
|
typedef enum {
|
|
|
|
LWIP_CORE_LOCK_QUERY_HOLDER,
|
|
|
|
LWIP_CORE_LOCK_MARK_HOLDER,
|
|
|
|
LWIP_CORE_LOCK_UNMARK_HOLDER,
|
|
|
|
LWIP_CORE_MARK_TCPIP_TASK,
|
|
|
|
LWIP_CORE_IS_TCPIP_INITIALIZED,
|
|
|
|
} sys_thread_core_lock_t;
|
|
|
|
|
|
|
|
bool
|
|
|
|
sys_thread_tcpip(sys_thread_core_lock_t type);
|
|
|
|
|
2018-07-04 19:01:03 -04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* __SYS_ARCH_H__ */
|