[PATCH 5/6] ntdll: Introduce IOCTL_WINE_AFD_KEEPALIVE_VALS.

Zebediah Figura z.figura12 at gmail.com
Mon Jun 7 19:53:11 CDT 2021


Signed-off-by: Zebediah Figura <z.figura12 at gmail.com>
---
 dlls/ntdll/unix/socket.c | 59 ++++++++++++++++++++++++++++++++++++++++
 include/wine/afd.h       |  1 +
 2 files changed, 60 insertions(+)

diff --git a/dlls/ntdll/unix/socket.c b/dlls/ntdll/unix/socket.c
index bc77514669d..c1cd319ccf9 100644
--- a/dlls/ntdll/unix/socket.c
+++ b/dlls/ntdll/unix/socket.c
@@ -41,6 +41,9 @@
 #ifdef HAVE_NETINET_IN_H
 #include <netinet/in.h>
 #endif
+#ifdef HAVE_NETINET_TCP_H
+# include <netinet/tcp.h>
+#endif
 
 #ifdef HAVE_NETIPX_IPX_H
 # include <netipx/ipx.h>
@@ -72,6 +75,7 @@
 #define USE_WS_PREFIX
 #include "winsock2.h"
 #include "mswsock.h"
+#include "mstcpip.h"
 #include "ws2tcpip.h"
 #include "wsipx.h"
 #include "af_irda.h"
@@ -79,6 +83,11 @@
 
 #include "unix_private.h"
 
+#if !defined(TCP_KEEPIDLE) && defined(TCP_KEEPALIVE)
+/* TCP_KEEPALIVE is the Mac OS name for TCP_KEEPIDLE */
+#define TCP_KEEPIDLE TCP_KEEPALIVE
+#endif
+
 WINE_DEFAULT_DEBUG_CHANNEL(winsock);
 
 #define FILE_USE_FILE_POINTER_POSITION ((LONGLONG)-2)
@@ -1448,6 +1457,56 @@ NTSTATUS sock_ioctl( HANDLE handle, HANDLE event, PIO_APC_ROUTINE apc, void *apc
             break;
         }
 
+        case IOCTL_AFD_WINE_KEEPALIVE_VALS:
+        {
+            struct tcp_keepalive *k = in_buffer;
+            int keepalive;
+
+            if (!in_buffer || in_size < sizeof(struct tcp_keepalive))
+                return STATUS_BUFFER_TOO_SMALL;
+            keepalive = !!k->onoff;
+
+            if ((status = server_get_unix_fd( handle, 0, &fd, &needs_close, NULL, NULL )))
+                return status;
+
+            if (setsockopt( fd, SOL_SOCKET, SO_KEEPALIVE, &keepalive, sizeof(int) ) < 0)
+            {
+                status = STATUS_INVALID_PARAMETER;
+                break;
+            }
+
+            if (keepalive)
+            {
+#ifdef TCP_KEEPIDLE
+                int idle = max( 1, (k->keepalivetime + 500) / 1000 );
+
+                if (setsockopt( fd, IPPROTO_TCP, TCP_KEEPIDLE, &idle, sizeof(int) ) < 0)
+                {
+                    status = STATUS_INVALID_PARAMETER;
+                    break;
+                }
+#else
+                FIXME("ignoring keepalive timeout\n");
+#endif
+            }
+
+            if (keepalive)
+            {
+#ifdef TCP_KEEPINTVL
+                int interval = max( 1, (k->keepaliveinterval + 500) / 1000 );
+
+                if (setsockopt( fd, IPPROTO_TCP, TCP_KEEPINTVL, &interval, sizeof(int) ) < 0)
+                    status = STATUS_INVALID_PARAMETER;
+#else
+                FIXME("ignoring keepalive interval\n");
+#endif
+            }
+
+            status = STATUS_SUCCESS;
+            complete_async( handle, event, apc, apc_user, io, status, 0 );
+            break;
+        }
+
         default:
         {
             if ((code >> 16) == FILE_DEVICE_NETWORK)
diff --git a/include/wine/afd.h b/include/wine/afd.h
index cc328f9bcae..595fc572a1c 100644
--- a/include/wine/afd.h
+++ b/include/wine/afd.h
@@ -101,6 +101,7 @@ struct afd_poll_params
 #define IOCTL_AFD_WINE_FIONREAD             CTL_CODE(FILE_DEVICE_NETWORK, 211, METHOD_BUFFERED, FILE_ANY_ACCESS)
 #define IOCTL_AFD_WINE_SIOCATMARK           CTL_CODE(FILE_DEVICE_NETWORK, 212, METHOD_BUFFERED, FILE_ANY_ACCESS)
 #define IOCTL_AFD_WINE_GET_INTERFACE_LIST   CTL_CODE(FILE_DEVICE_NETWORK, 213, METHOD_BUFFERED, FILE_ANY_ACCESS)
+#define IOCTL_AFD_WINE_KEEPALIVE_VALS       CTL_CODE(FILE_DEVICE_NETWORK, 214, METHOD_BUFFERED, FILE_ANY_ACCESS)
 
 struct afd_create_params
 {
-- 
2.32.0




More information about the wine-devel mailing list