From 830346bf1600a38dbbacc569599da55895cfd033 Mon Sep 17 00:00:00 2001 From: midipix Date: Thu, 16 Jun 2016 13:22:38 -0400 Subject: __ntapi_sc_setsockopt(): initial implementation and integration. --- src/internal/ntapi.c | 1 + src/internal/ntapi_fnapi.h | 1 + src/socket/ntapi_sc_setsockopt.c | 50 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 52 insertions(+) create mode 100644 src/socket/ntapi_sc_setsockopt.c (limited to 'src') diff --git a/src/internal/ntapi.c b/src/internal/ntapi.c index 885fe61..451ccd7 100644 --- a/src/internal/ntapi.c +++ b/src/internal/ntapi.c @@ -308,6 +308,7 @@ static int32_t __fastcall __ntapi_init_once(ntapi_vtbl ** pvtbl) __ntapi->sc_recv = __ntapi_sc_recv; __ntapi->sc_shutdown = __ntapi_sc_shutdown; __ntapi->sc_server_duplicate_socket = __ntapi_sc_server_duplicate_socket; + __ntapi->sc_setsockopt = __ntapi_sc_setsockopt; __ntapi->sc_wait = __ntapi_sc_wait; /* nt_mount.h */ diff --git a/src/internal/ntapi_fnapi.h b/src/internal/ntapi_fnapi.h index a22c659..05f4707 100644 --- a/src/internal/ntapi_fnapi.h +++ b/src/internal/ntapi_fnapi.h @@ -203,6 +203,7 @@ ntapi_sc_getpeername __ntapi_sc_getpeername_v2; ntapi_sc_server_accept_connection __ntapi_sc_server_accept_connection_v1; ntapi_sc_server_accept_connection __ntapi_sc_server_accept_connection_v2; ntapi_sc_server_duplicate_socket __ntapi_sc_server_duplicate_socket; +ntapi_sc_setsockopt __ntapi_sc_setsockopt; ntapi_sc_listen __ntapi_sc_listen; ntapi_sc_accept __ntapi_sc_accept; ntapi_sc_send __ntapi_sc_send; diff --git a/src/socket/ntapi_sc_setsockopt.c b/src/socket/ntapi_sc_setsockopt.c new file mode 100644 index 0000000..4989e54 --- /dev/null +++ b/src/socket/ntapi_sc_setsockopt.c @@ -0,0 +1,50 @@ +/********************************************************/ +/* ntapi: Native API core library */ +/* Copyright (C) 2013--2016 Z. Gilboa */ +/* Released under GPLv2 and GPLv3; see COPYING.NTAPI. */ +/********************************************************/ + +#include +#include +#include +#include +#include +#include "ntapi_impl.h" + +int32_t __cdecl __ntapi_sc_setsockopt( + __in nt_socket * hssocket, + __in int32_t level, + __in int32_t optname, + __in const void * optval, + __in uint32_t optlen, + __out nt_io_status_block * iosb) +{ + nt_afd_sockopt_info afd_sockopt; + nt_io_status_block siosb; + + iosb = iosb ? iosb : &siosb; + + /* afd_sockopt */ + afd_sockopt.mode = NT_AFD_SOCKOPT_SET; + afd_sockopt.level = level; + afd_sockopt.optname = optname; + afd_sockopt.optval = optval; + afd_sockopt.optlen = optlen; + afd_sockopt.ding = 1; + + hssocket->iostatus = __ntapi->zw_device_io_control_file( + hssocket->hsocket, + hssocket->hevent, + 0, + 0, + iosb, + NT_AFD_IOCTL_SOCKOPT, + &afd_sockopt, + sizeof(afd_sockopt), + 0, + 0); + + return hssocket->iostatus + ? __ntapi->sc_wait(hssocket,iosb,0) + : NT_STATUS_SUCCESS; +} -- cgit v1.2.3