2017-10-03 16:56:55 +11:00
|
|
|
// Copyright 2017 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <sys/errno.h>
|
|
|
|
#include <sys/lock.h>
|
|
|
|
#include <sys/fcntl.h>
|
|
|
|
#include "esp_vfs.h"
|
|
|
|
#include "esp_vfs_dev.h"
|
|
|
|
#include "esp_attr.h"
|
|
|
|
#include "lwip/sockets.h"
|
|
|
|
#include "sdkconfig.h"
|
2018-05-03 10:41:10 +02:00
|
|
|
#include "lwip/sys.h"
|
2017-10-03 16:56:55 +11:00
|
|
|
|
2018-05-07 09:01:56 +02:00
|
|
|
_Static_assert(MAX_FDS >= CONFIG_LWIP_MAX_SOCKETS, "MAX_FDS < CONFIG_LWIP_MAX_SOCKETS");
|
2017-10-03 16:56:55 +11:00
|
|
|
|
2019-03-20 15:43:31 +01:00
|
|
|
static void lwip_stop_socket_select(void *sem)
|
2018-05-03 10:41:10 +02:00
|
|
|
{
|
2019-03-20 15:43:31 +01:00
|
|
|
sys_sem_signal(sem); //socket_select will return
|
2018-05-03 10:41:10 +02:00
|
|
|
}
|
|
|
|
|
2019-03-20 15:43:31 +01:00
|
|
|
static void lwip_stop_socket_select_isr(void *sem, BaseType_t *woken)
|
2018-05-03 10:41:10 +02:00
|
|
|
{
|
2019-03-20 15:43:31 +01:00
|
|
|
if (sys_sem_signal_isr(sem) && woken) {
|
2018-05-03 10:41:10 +02:00
|
|
|
*woken = pdTRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-20 15:43:31 +01:00
|
|
|
static void *lwip_get_socket_select_semaphore()
|
|
|
|
{
|
|
|
|
/* Calling this from the same process as select() will ensure that the semaphore won't be allocated from
|
|
|
|
* ISR (lwip_stop_socket_select_isr).
|
|
|
|
*/
|
|
|
|
return (void *) sys_thread_sem_get();
|
|
|
|
}
|
|
|
|
|
2019-03-11 17:45:31 +08:00
|
|
|
static int lwip_fcntl_r_wrapper(int fd, int cmd, int arg)
|
2018-05-03 10:41:10 +02:00
|
|
|
{
|
2019-03-11 17:45:31 +08:00
|
|
|
return lwip_fcntl_r(fd, cmd, arg);
|
2018-05-03 10:41:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static int lwip_ioctl_r_wrapper(int fd, int cmd, va_list args)
|
|
|
|
{
|
|
|
|
return lwip_ioctl_r(fd, cmd, va_arg(args, void *));
|
|
|
|
}
|
2017-10-03 16:56:55 +11:00
|
|
|
|
|
|
|
void esp_vfs_lwip_sockets_register()
|
|
|
|
{
|
|
|
|
esp_vfs_t vfs = {
|
2018-05-07 09:01:56 +02:00
|
|
|
.flags = ESP_VFS_FLAG_DEFAULT,
|
2017-10-03 16:56:55 +11:00
|
|
|
.write = &lwip_write_r,
|
|
|
|
.open = NULL,
|
|
|
|
.fstat = NULL,
|
|
|
|
.close = &lwip_close_r,
|
|
|
|
.read = &lwip_read_r,
|
|
|
|
.fcntl = &lwip_fcntl_r_wrapper,
|
|
|
|
.ioctl = &lwip_ioctl_r_wrapper,
|
2018-05-03 10:41:10 +02:00
|
|
|
.socket_select = &lwip_select,
|
2019-03-20 15:43:31 +01:00
|
|
|
.get_socket_select_semaphore = &lwip_get_socket_select_semaphore,
|
2018-05-03 10:41:10 +02:00
|
|
|
.stop_socket_select = &lwip_stop_socket_select,
|
|
|
|
.stop_socket_select_isr = &lwip_stop_socket_select_isr,
|
2017-10-03 16:56:55 +11:00
|
|
|
};
|
2018-05-03 10:41:10 +02:00
|
|
|
/* Non-LWIP file descriptors are from 0 to (LWIP_SOCKET_OFFSET-1). LWIP
|
|
|
|
* file descriptors are registered from LWIP_SOCKET_OFFSET to
|
|
|
|
* MAX_FDS-1.
|
|
|
|
*/
|
2017-10-03 16:56:55 +11:00
|
|
|
|
2018-05-07 09:01:56 +02:00
|
|
|
ESP_ERROR_CHECK(esp_vfs_register_fd_range(&vfs, NULL, LWIP_SOCKET_OFFSET, MAX_FDS));
|
2017-10-03 16:56:55 +11:00
|
|
|
}
|