mirror of
https://github.com/espressif/ESP8266_RTOS_SDK.git
synced 2025-09-19 00:21:15 +08:00
feat(lwip): Format code
This commit is contained in:
@ -6,16 +6,16 @@
|
|||||||
#include "../../lwip/src/api/sockets.c"
|
#include "../../lwip/src/api/sockets.c"
|
||||||
|
|
||||||
#ifndef LWIP_SYNC_MT_SLEEP_MS
|
#ifndef LWIP_SYNC_MT_SLEEP_MS
|
||||||
#define LWIP_SYNC_MT_SLEEP_MS 10
|
#define LWIP_SYNC_MT_SLEEP_MS 10
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef SOCK_MT_DEBUG_LEVEL
|
#ifndef SOCK_MT_DEBUG_LEVEL
|
||||||
#define SOCK_MT_DEBUG_LEVEL 255
|
#define SOCK_MT_DEBUG_LEVEL 255
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef int (*lwip_io_mt_fn)(int , int );
|
typedef int (*lwip_io_mt_fn)(int, int );
|
||||||
|
|
||||||
enum sock_mt_stat{
|
enum sock_mt_stat {
|
||||||
SOCK_MT_STATE_NONE = 0,
|
SOCK_MT_STATE_NONE = 0,
|
||||||
SOCK_MT_STATE_BIND,
|
SOCK_MT_STATE_BIND,
|
||||||
SOCK_MT_STATE_LISTEN,
|
SOCK_MT_STATE_LISTEN,
|
||||||
@ -63,11 +63,11 @@ struct _sock_mt {
|
|||||||
typedef struct _sock_mt sock_mt_t;
|
typedef struct _sock_mt sock_mt_t;
|
||||||
|
|
||||||
#if (SOCK_MT_DEBUG_LEVEL < 16)
|
#if (SOCK_MT_DEBUG_LEVEL < 16)
|
||||||
#define SOCK_MT_DEBUG(level, ...) \
|
#define SOCK_MT_DEBUG(level, ...) \
|
||||||
if (level >= SOCK_MT_DEBUG_LEVEL) \
|
if (level >= SOCK_MT_DEBUG_LEVEL) \
|
||||||
printf(__VA_ARGS__);
|
printf(__VA_ARGS__);
|
||||||
#else
|
#else
|
||||||
#define SOCK_MT_DEBUG(level, ...)
|
#define SOCK_MT_DEBUG(level, ...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
@ -252,9 +252,9 @@ static sock_mt_t sockets_mt[NUM_SOCKETS];
|
|||||||
|
|
||||||
static int lwip_enter_mt_state(int s, int arg)
|
static int lwip_enter_mt_state(int s, int arg)
|
||||||
{
|
{
|
||||||
if(tryget_socket(s) == NULL ||
|
if (tryget_socket(s) == NULL ||
|
||||||
SOCK_MT_GET_STATE(s) != SOCK_MT_STATE_NONE ||
|
SOCK_MT_GET_STATE(s) != SOCK_MT_STATE_NONE ||
|
||||||
SOCK_MT_GET_WRITE_SEL(s))
|
SOCK_MT_GET_WRITE_SEL(s))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
SOCK_MT_LOCK(s, SOCK_MT_STATE_LOCK);
|
SOCK_MT_LOCK(s, SOCK_MT_STATE_LOCK);
|
||||||
@ -265,181 +265,181 @@ static int lwip_enter_mt_state(int s, int arg)
|
|||||||
|
|
||||||
static int lwip_enter_mt_recv(int s, int arg)
|
static int lwip_enter_mt_recv(int s, int arg)
|
||||||
{
|
{
|
||||||
if(tryget_socket(s) == NULL ||
|
if (tryget_socket(s) == NULL ||
|
||||||
SOCK_MT_GET_READ_SEL(s))
|
SOCK_MT_GET_READ_SEL(s))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
SOCK_MT_LOCK(s, SOCK_MT_RECV_LOCK);
|
SOCK_MT_LOCK(s, SOCK_MT_RECV_LOCK);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_enter_mt_shutdown(int s, int arg)
|
static int lwip_enter_mt_shutdown(int s, int arg)
|
||||||
{
|
{
|
||||||
if(tryget_socket(s) == NULL
|
if (tryget_socket(s) == NULL
|
||||||
|| SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE)
|
|| SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
SOCK_MT_SET_SHUTDOWN(s, SOCK_MT_SHUTDOWN_OK);
|
SOCK_MT_SET_SHUTDOWN(s, SOCK_MT_SHUTDOWN_OK);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_enter_mt_close(int s, int arg)
|
static int lwip_enter_mt_close(int s, int arg)
|
||||||
{
|
{
|
||||||
if(tryget_socket(s) == NULL)
|
if (tryget_socket(s) == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
SOCK_MT_SET_SHUTDOWN(s, SOCK_MT_SHUTDOWN_OK);
|
SOCK_MT_SET_SHUTDOWN(s, SOCK_MT_SHUTDOWN_OK);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int lwip_enter_mt_select(int s, int arg)
|
static int lwip_enter_mt_select(int s, int arg)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int *fdset = (int *)arg;
|
int *fdset = (int *)arg;
|
||||||
fd_set *read_set = (fd_set *)fdset[0];
|
fd_set *read_set = (fd_set *)fdset[0];
|
||||||
fd_set *write_set = (fd_set *)fdset[1];
|
fd_set *write_set = (fd_set *)fdset[1];
|
||||||
|
|
||||||
if (s > NUM_SOCKETS || s < 0)
|
if (s > NUM_SOCKETS || s < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
for (i = 0; i < s; i++) {
|
for (i = 0; i < s; i++) {
|
||||||
if(FD_ISSET(i, read_set) || FD_ISSET(i, write_set))
|
if(FD_ISSET(i, read_set) || FD_ISSET(i, write_set))
|
||||||
if (tryget_socket(i) == NULL)
|
if (tryget_socket(i) == NULL)
|
||||||
goto failed1;
|
goto failed1;
|
||||||
|
|
||||||
if (FD_ISSET(i, read_set)) {
|
if (FD_ISSET(i, read_set)) {
|
||||||
err_t err;
|
err_t err;
|
||||||
|
|
||||||
SOCK_MT_SET_READ_SEL(i);
|
SOCK_MT_SET_READ_SEL(i);
|
||||||
SOCK_MT_LOCK_RET(i, SOCK_MT_RECV_LOCK, err);
|
SOCK_MT_LOCK_RET(i, SOCK_MT_RECV_LOCK, err);
|
||||||
if (err != ERR_OK) {
|
if (err != ERR_OK) {
|
||||||
goto failed2;
|
goto failed2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FD_ISSET(i, write_set)) {
|
if (FD_ISSET(i, write_set)) {
|
||||||
err_t err;
|
err_t err;
|
||||||
|
|
||||||
SOCK_MT_SET_WRITE_SEL(i);
|
SOCK_MT_SET_WRITE_SEL(i);
|
||||||
SOCK_MT_LOCK_RET(i, SOCK_MT_STATE_LOCK, err);
|
SOCK_MT_LOCK_RET(i, SOCK_MT_STATE_LOCK, err);
|
||||||
if (err != ERR_OK) {
|
if (err != ERR_OK) {
|
||||||
goto failed3;
|
goto failed3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
failed3:
|
failed3:
|
||||||
SOCK_MT_UNLOCK(i, SOCK_MT_STATE_LOCK);
|
SOCK_MT_UNLOCK(i, SOCK_MT_STATE_LOCK);
|
||||||
SOCK_MT_RESET_WRITE_SEL(i);
|
SOCK_MT_RESET_WRITE_SEL(i);
|
||||||
failed2:
|
failed2:
|
||||||
if (FD_ISSET(i, read_set)) {
|
if (FD_ISSET(i, read_set)) {
|
||||||
SOCK_MT_UNLOCK(i, SOCK_MT_RECV_LOCK);
|
SOCK_MT_UNLOCK(i, SOCK_MT_RECV_LOCK);
|
||||||
SOCK_MT_RESET_READ_SEL(i);
|
SOCK_MT_RESET_READ_SEL(i);
|
||||||
}
|
}
|
||||||
failed1:
|
failed1:
|
||||||
for (i--; i >=0; i--) {
|
for (i--; i >=0; i--) {
|
||||||
if (FD_ISSET(i, read_set) ){
|
if (FD_ISSET(i, read_set) ) {
|
||||||
SOCK_MT_UNLOCK(i, SOCK_MT_RECV_LOCK);
|
SOCK_MT_UNLOCK(i, SOCK_MT_RECV_LOCK);
|
||||||
SOCK_MT_RESET_READ_SEL(i);
|
SOCK_MT_RESET_READ_SEL(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FD_ISSET(i, write_set)) {
|
if (FD_ISSET(i, write_set)) {
|
||||||
SOCK_MT_UNLOCK(i, SOCK_MT_STATE_LOCK);
|
SOCK_MT_UNLOCK(i, SOCK_MT_STATE_LOCK);
|
||||||
SOCK_MT_RESET_WRITE_SEL(i);
|
SOCK_MT_RESET_WRITE_SEL(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_enter_mt_ioctrl(int s, int arg)
|
static int lwip_enter_mt_ioctrl(int s, int arg)
|
||||||
{
|
{
|
||||||
if(tryget_socket(s) == NULL)
|
if (tryget_socket(s) == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
SOCK_MT_LOCK(s, SOCK_MT_IOCTRL_LOCK);
|
SOCK_MT_LOCK(s, SOCK_MT_IOCTRL_LOCK);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_exit_mt_state(int s, int arg)
|
static int lwip_exit_mt_state(int s, int arg)
|
||||||
{
|
{
|
||||||
SOCK_MT_SET_STATE(s, SOCK_MT_STATE_NONE);
|
SOCK_MT_SET_STATE(s, SOCK_MT_STATE_NONE);
|
||||||
SOCK_MT_UNLOCK(s, SOCK_MT_STATE_LOCK);
|
SOCK_MT_UNLOCK(s, SOCK_MT_STATE_LOCK);
|
||||||
|
|
||||||
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE) {
|
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_exit_mt_recv(int s, int arg)
|
static int lwip_exit_mt_recv(int s, int arg)
|
||||||
{
|
{
|
||||||
SOCK_MT_UNLOCK(s, SOCK_MT_RECV_LOCK);
|
SOCK_MT_UNLOCK(s, SOCK_MT_RECV_LOCK);
|
||||||
|
|
||||||
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE) {
|
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_exit_mt_shutdown(int s, int arg)
|
static int lwip_exit_mt_shutdown(int s, int arg)
|
||||||
{
|
{
|
||||||
//SOCK_MT_SET_SHUTDOWN(s, SOCK_MT_STATE_NONE);
|
//SOCK_MT_SET_SHUTDOWN(s, SOCK_MT_STATE_NONE);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_exit_mt_close(int s, int arg)
|
static int lwip_exit_mt_close(int s, int arg)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_exit_mt_select(int s, int arg)
|
static int lwip_exit_mt_select(int s, int arg)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int *fdset = (int *)arg;
|
int *fdset = (int *)arg;
|
||||||
fd_set *read_set = (fd_set *)fdset[0];
|
fd_set *read_set = (fd_set *)fdset[0];
|
||||||
fd_set *write_set = (fd_set *)fdset[1];
|
fd_set *write_set = (fd_set *)fdset[1];
|
||||||
|
|
||||||
for (i = 0; i < s; i++) {
|
for (i = 0; i < s; i++) {
|
||||||
if (FD_ISSET(i, read_set)) {
|
if (FD_ISSET(i, read_set)) {
|
||||||
SOCK_MT_UNLOCK(i, SOCK_MT_RECV_LOCK);
|
SOCK_MT_UNLOCK(i, SOCK_MT_RECV_LOCK);
|
||||||
SOCK_MT_RESET_READ_SEL(i);
|
SOCK_MT_RESET_READ_SEL(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FD_ISSET(i, write_set)) {
|
if (FD_ISSET(i, write_set)) {
|
||||||
SOCK_MT_UNLOCK(i, SOCK_MT_STATE_LOCK);
|
SOCK_MT_UNLOCK(i, SOCK_MT_STATE_LOCK);
|
||||||
SOCK_MT_RESET_WRITE_SEL(i);
|
SOCK_MT_RESET_WRITE_SEL(i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < s; i++) {
|
for (i = 0; i < s; i++) {
|
||||||
if ((FD_ISSET(i, read_set) || FD_ISSET(i, write_set)) \
|
if ((FD_ISSET(i, read_set) || FD_ISSET(i, write_set)) \
|
||||||
&& SOCK_MT_GET_SHUTDOWN(i) != SOCK_MT_SHUTDOWN_NONE) {
|
&& SOCK_MT_GET_SHUTDOWN(i) != SOCK_MT_SHUTDOWN_NONE) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lwip_exit_mt_ioctrl(int s, int arg)
|
static int lwip_exit_mt_ioctrl(int s, int arg)
|
||||||
{
|
{
|
||||||
SOCK_MT_UNLOCK(s, SOCK_MT_IOCTRL_LOCK);
|
SOCK_MT_UNLOCK(s, SOCK_MT_IOCTRL_LOCK);
|
||||||
|
|
||||||
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE) {
|
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const lwip_io_mt_fn lwip_enter_mt_table[] = {
|
static const lwip_io_mt_fn lwip_enter_mt_table[] = {
|
||||||
@ -497,88 +497,88 @@ static void lwip_do_sync_rst_state(void *arg)
|
|||||||
sys_sem_signal(&(conn->ioctrl_completed));
|
sys_sem_signal(&(conn->ioctrl_completed));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void lwip_sync_state_mt(struct lwip_sock *sock , int state)
|
static void lwip_sync_state_mt(struct lwip_sock *sock, int state)
|
||||||
{
|
{
|
||||||
SOCK_MT_DEBUG(1, "sync state %d\n", state);
|
SOCK_MT_DEBUG(1, "sync state %d\n", state);
|
||||||
|
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case SOCK_MT_STATE_ACCEPT :
|
case SOCK_MT_STATE_ACCEPT :
|
||||||
if (sys_mbox_valid(&sock->conn->acceptmbox))
|
if (sys_mbox_valid(&sock->conn->acceptmbox))
|
||||||
sys_mbox_trypost(&sock->conn->acceptmbox, NULL);
|
sys_mbox_trypost(&sock->conn->acceptmbox, NULL);
|
||||||
break;
|
break;
|
||||||
case SOCK_MT_STATE_SEND :
|
case SOCK_MT_STATE_SEND :
|
||||||
{
|
{
|
||||||
tcpip_callback(lwip_do_sync_send, sock->conn);
|
tcpip_callback(lwip_do_sync_send, sock->conn);
|
||||||
sys_arch_sem_wait(&sock->conn->ioctrl_completed, 0);
|
sys_arch_sem_wait(&sock->conn->ioctrl_completed, 0);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SOCK_MT_STATE_CONNECT :
|
case SOCK_MT_STATE_CONNECT :
|
||||||
if (sys_sem_valid(&(sock->conn->op_completed)))
|
if (sys_sem_valid(&(sock->conn->op_completed)))
|
||||||
sys_sem_signal(&(sock->conn->op_completed));
|
sys_sem_signal(&(sock->conn->op_completed));
|
||||||
break;
|
break;
|
||||||
default :
|
default :
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void lwip_sync_recv_mt(struct lwip_sock *sock)
|
static void lwip_sync_recv_mt(struct lwip_sock *sock)
|
||||||
{
|
{
|
||||||
SOCK_MT_DEBUG(1, "sync recv %d\n", sock->conn->socket);
|
SOCK_MT_DEBUG(1, "sync recv %d\n", sock->conn->socket);
|
||||||
if (sys_mbox_valid(&sock->conn->recvmbox))
|
if (sys_mbox_valid(&sock->conn->recvmbox))
|
||||||
sys_mbox_trypost(&sock->conn->recvmbox, NULL);
|
sys_mbox_trypost(&sock->conn->recvmbox, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void lwip_sync_select_mt(struct lwip_sock *sock)
|
static void lwip_sync_select_mt(struct lwip_sock *sock)
|
||||||
{
|
{
|
||||||
SOCK_MT_DEBUG(1, "sync select %d\n", sock->conn->socket);
|
SOCK_MT_DEBUG(1, "sync select %d\n", sock->conn->socket);
|
||||||
event_callback(sock->conn, NETCONN_EVT_ERROR, 0);
|
event_callback(sock->conn, NETCONN_EVT_ERROR, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void lwip_sync_mt(int s)
|
static void lwip_sync_mt(int s)
|
||||||
{
|
{
|
||||||
int module = 0;
|
int module = 0;
|
||||||
int ret;
|
int ret;
|
||||||
struct lwip_sock *sock;
|
struct lwip_sock *sock;
|
||||||
|
|
||||||
while (module < SOCK_MT_SELECT) {
|
while (module < SOCK_MT_SELECT) {
|
||||||
extern void sys_arch_msleep(int ms);
|
extern void sys_arch_msleep(int ms);
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
SOCK_MT_TRYLOCK(s, module, ret);
|
SOCK_MT_TRYLOCK(s, module, ret);
|
||||||
if (ret == ERR_OK) {
|
if (ret == ERR_OK) {
|
||||||
/*
|
/*
|
||||||
* we always lock the mutex in case of other thread entering,
|
* we always lock the mutex in case of other thread entering,
|
||||||
* other thread will be blocked at "SOCK_MT_LOCK" and poll-check
|
* other thread will be blocked at "SOCK_MT_LOCK" and poll-check
|
||||||
*/
|
*/
|
||||||
//SOCK_MT_UNLOCK(s, module);
|
//SOCK_MT_UNLOCK(s, module);
|
||||||
module++;
|
module++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
sock = get_socket(s);
|
sock = get_socket(s);
|
||||||
#if LWIP_SO_LINGER
|
#if LWIP_SO_LINGER
|
||||||
if (SOCK_MT_GET_STATE(s) == SOCK_MT_STATE_SEND) {
|
if (SOCK_MT_GET_STATE(s) == SOCK_MT_STATE_SEND) {
|
||||||
SOCK_MT_SET_LINGER(sock);
|
SOCK_MT_SET_LINGER(sock);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!SOCK_MT_GET_SEL(s)) {
|
if (!SOCK_MT_GET_SEL(s)) {
|
||||||
switch (module) {
|
switch (module) {
|
||||||
case SOCK_MT_STATE:
|
case SOCK_MT_STATE:
|
||||||
lwip_sync_state_mt(sock, SOCK_MT_GET_STATE(s));
|
lwip_sync_state_mt(sock, SOCK_MT_GET_STATE(s));
|
||||||
break;
|
break;
|
||||||
case SOCK_MT_RECV:
|
case SOCK_MT_RECV:
|
||||||
lwip_sync_recv_mt(sock);
|
lwip_sync_recv_mt(sock);
|
||||||
break;
|
break;
|
||||||
default :
|
default :
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lwip_sync_select_mt(sock);
|
lwip_sync_select_mt(sock);
|
||||||
}
|
}
|
||||||
|
|
||||||
sys_arch_msleep(LWIP_SYNC_MT_SLEEP_MS);
|
sys_arch_msleep(LWIP_SYNC_MT_SLEEP_MS);
|
||||||
}
|
}
|
||||||
|
|
||||||
sock = tryget_socket(s);
|
sock = tryget_socket(s);
|
||||||
if (sock) {
|
if (sock) {
|
||||||
@ -733,17 +733,17 @@ int lwip_getsockopt_mt(int s, int level, int optname, void *optval, socklen_t *o
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (optname == SO_ERROR ) {
|
if (optname == SO_ERROR) {
|
||||||
int retval = 0;
|
int retval = 0;
|
||||||
|
|
||||||
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE)
|
if (SOCK_MT_GET_SHUTDOWN(s) != SOCK_MT_SHUTDOWN_NONE)
|
||||||
retval = ENOTCONN;
|
retval = ENOTCONN;
|
||||||
|
|
||||||
if (retval) {
|
if (retval) {
|
||||||
*(int *)optval = retval;
|
*(int *)optval = retval;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LWIP_ENTER_MT(s, SOCK_MT_IOCTL, 0);
|
LWIP_ENTER_MT(s, SOCK_MT_IOCTL, 0);
|
||||||
|
|
||||||
@ -768,7 +768,7 @@ int lwip_ioctl_mt(int s, long cmd, void *argp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int lwip_sendto_mt(int s, const void *data, size_t size, int flags,
|
int lwip_sendto_mt(int s, const void *data, size_t size, int flags,
|
||||||
const struct sockaddr *to, socklen_t tolen)
|
const struct sockaddr *to, socklen_t tolen)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -795,7 +795,7 @@ int lwip_send_mt(int s, const void *data, size_t size, int flags)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int lwip_recvfrom_mt(int s, void *mem, size_t len, int flags,
|
int lwip_recvfrom_mt(int s, void *mem, size_t len, int flags,
|
||||||
struct sockaddr *from, socklen_t *fromlen)
|
struct sockaddr *from, socklen_t *fromlen)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -825,7 +825,7 @@ int lwip_write_mt(int s, const void *data, size_t size)
|
|||||||
|
|
||||||
int lwip_fcntl_mt(int s, int cmd, int val)
|
int lwip_fcntl_mt(int s, int cmd, int val)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
LWIP_ENTER_MT(s, SOCK_MT_IOCTL, 0);
|
LWIP_ENTER_MT(s, SOCK_MT_IOCTL, 0);
|
||||||
|
|
||||||
@ -863,7 +863,7 @@ int lwip_close_mt(int s)
|
|||||||
SYS_ARCH_DECL_PROTECT(lev);
|
SYS_ARCH_DECL_PROTECT(lev);
|
||||||
sys_mutex_t lock_tmp[SOCK_MT_LOCK_MAX];
|
sys_mutex_t lock_tmp[SOCK_MT_LOCK_MAX];
|
||||||
|
|
||||||
__lwip_shutdown_mt(s, SHUT_RDWR);
|
__lwip_shutdown_mt(s, SHUT_RDWR);
|
||||||
|
|
||||||
LWIP_ENTER_MT(s, SOCK_MT_CLOSE, 0);
|
LWIP_ENTER_MT(s, SOCK_MT_CLOSE, 0);
|
||||||
|
|
||||||
@ -886,20 +886,20 @@ int lwip_close_mt(int s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int lwip_select_mt(int maxfdp1, fd_set *readset, fd_set *writeset,
|
int lwip_select_mt(int maxfdp1, fd_set *readset, fd_set *writeset,
|
||||||
fd_set *exceptset, struct timeval *timeout)
|
fd_set *exceptset, struct timeval *timeout)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
fd_set read_set, write_set;
|
fd_set read_set, write_set;
|
||||||
int pset[2] = {(int)&read_set, (int)&write_set};
|
int pset[2] = {(int)&read_set, (int)&write_set};
|
||||||
|
|
||||||
FD_ZERO(&read_set);
|
FD_ZERO(&read_set);
|
||||||
FD_ZERO(&write_set);
|
FD_ZERO(&write_set);
|
||||||
|
|
||||||
if (readset)
|
if (readset)
|
||||||
MEMCPY(&read_set, readset, sizeof(fd_set));
|
MEMCPY(&read_set, readset, sizeof(fd_set));
|
||||||
|
|
||||||
if (writeset)
|
if (writeset)
|
||||||
MEMCPY(&write_set, writeset, sizeof(fd_set));
|
MEMCPY(&write_set, writeset, sizeof(fd_set));
|
||||||
|
|
||||||
LWIP_ENTER_MT(maxfdp1, SOCK_MT_SELECT, (int)pset);
|
LWIP_ENTER_MT(maxfdp1, SOCK_MT_SELECT, (int)pset);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user