server: Move sock_ioctl() down to avoid forward declarations.

Signed-off-by: Zebediah Figura <z.figura12@gmail.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Zebediah Figura 2020-09-24 22:21:02 -05:00 committed by Alexandre Julliard
parent c6806e3f20
commit c2b089aae5
1 changed files with 40 additions and 41 deletions

View File

@ -134,7 +134,6 @@ static int sock_ioctl( struct fd *fd, ioctl_code_t code, struct async *async );
static void sock_queue_async( struct fd *fd, struct async *async, int type, int count );
static void sock_reselect_async( struct fd *fd, struct async_queue *queue );
static int init_socket( struct sock *sock, int family, int type, int protocol, unsigned int flags );
static int sock_get_ntstatus( int err );
static unsigned int sock_get_error( int err );
@ -539,46 +538,6 @@ static enum server_fd_type sock_get_fd_type( struct fd *fd )
return FD_TYPE_SOCKET;
}
static int sock_ioctl( struct fd *fd, ioctl_code_t code, struct async *async )
{
struct sock *sock = get_fd_user( fd );
assert( sock->obj.ops == &sock_ops );
if (get_unix_fd( fd ) == -1 && code != IOCTL_AFD_CREATE) return 0;
switch(code)
{
case IOCTL_AFD_CREATE:
{
const struct afd_create_params *params = get_req_data();
if (get_req_data_size() != sizeof(*params))
{
set_error( STATUS_INVALID_PARAMETER );
return 0;
}
init_socket( sock, params->family, params->type, params->protocol, params->flags );
return 0;
}
case IOCTL_AFD_ADDRESS_LIST_CHANGE:
if ((sock->state & FD_WINE_NONBLOCKING) && async_is_blocking( async ))
{
set_win32_error( WSAEWOULDBLOCK );
return 0;
}
if (!sock_get_ifchange( sock )) return 0;
queue_async( &sock->ifchange_q, async );
set_error( STATUS_PENDING );
return 1;
default:
set_error( STATUS_NOT_SUPPORTED );
return 0;
}
}
static void sock_queue_async( struct fd *fd, struct async *async, int type, int count )
{
struct sock *sock = get_fd_user( fd );
@ -958,6 +917,46 @@ static int sock_get_ntstatus( int err )
}
}
static int sock_ioctl( struct fd *fd, ioctl_code_t code, struct async *async )
{
struct sock *sock = get_fd_user( fd );
assert( sock->obj.ops == &sock_ops );
if (get_unix_fd( fd ) == -1 && code != IOCTL_AFD_CREATE) return 0;
switch(code)
{
case IOCTL_AFD_CREATE:
{
const struct afd_create_params *params = get_req_data();
if (get_req_data_size() != sizeof(*params))
{
set_error( STATUS_INVALID_PARAMETER );
return 0;
}
init_socket( sock, params->family, params->type, params->protocol, params->flags );
return 0;
}
case IOCTL_AFD_ADDRESS_LIST_CHANGE:
if ((sock->state & FD_WINE_NONBLOCKING) && async_is_blocking( async ))
{
set_win32_error( WSAEWOULDBLOCK );
return 0;
}
if (!sock_get_ifchange( sock )) return 0;
queue_async( &sock->ifchange_q, async );
set_error( STATUS_PENDING );
return 1;
default:
set_error( STATUS_NOT_SUPPORTED );
return 0;
}
}
#ifdef HAVE_LINUX_RTNETLINK_H
/* only keep one ifchange object around, all sockets waiting for wakeups will look to it */