aboutsummaryrefslogtreecommitdiffstats
path: root/api/devmgmt.h
diff options
context:
space:
mode:
authorSimon Rozman <simon@rozman.si>2020-07-29 10:10:42 +0200
committerJason A. Donenfeld <Jason@zx2c4.com>2020-10-30 16:50:59 +0100
commitabd20337e2a2ec1c4a34c1b839ee0ed575689527 (patch)
tree8db5d33f19f6107633110dcd8101a37784ee7b5f /api/devmgmt.h
parentapi: revise str/memcpy (diff)
downloadwintun-abd20337e2a2ec1c4a34c1b839ee0ed575689527.tar.xz
wintun-abd20337e2a2ec1c4a34c1b839ee0ed575689527.zip
api: split api.h
As the project grew, api.h got bloated. Signed-off-by: Simon Rozman <simon@rozman.si>
Diffstat (limited to 'api/devmgmt.h')
-rw-r--r--api/devmgmt.h67
1 files changed, 67 insertions, 0 deletions
diff --git a/api/devmgmt.h b/api/devmgmt.h
new file mode 100644
index 0000000..d03fec7
--- /dev/null
+++ b/api/devmgmt.h
@@ -0,0 +1,67 @@
+/* SPDX-License-Identifier: GPL-2.0
+ *
+ * Copyright (C) 2018-2020 WireGuard LLC. All Rights Reserved.
+ */
+
+#pragma once
+
+#include "api.h"
+#include <IPExport.h>
+
+#define MAX_POOL 256
+#define MAX_INSTANCE_ID MAX_PATH /* TODO: Is MAX_PATH always enough? */
+
+typedef struct _WINTUN_ADAPTER
+{
+ GUID CfgInstanceID;
+ WCHAR DevInstanceID[MAX_INSTANCE_ID];
+ DWORD LuidIndex;
+ DWORD IfType;
+ WCHAR Pool[MAX_POOL];
+} WINTUN_ADAPTER;
+
+void WINAPI
+WintunFreeAdapter(_In_ WINTUN_ADAPTER *Adapter);
+
+WINTUN_STATUS WINAPI
+WintunGetAdapter(
+ _In_z_count_c_(MAX_POOL) const WCHAR *Pool,
+ _In_z_count_c_(MAX_ADAPTER_NAME) const WCHAR *Name,
+ _Out_ WINTUN_ADAPTER **Adapter);
+
+WINTUN_STATUS WINAPI
+WintunGetAdapterName(_In_ const WINTUN_ADAPTER *Adapter, _Out_cap_c_(MAX_ADAPTER_NAME) WCHAR *Name);
+
+WINTUN_STATUS WINAPI
+WintunSetAdapterName(_In_ const WINTUN_ADAPTER *Adapter, _In_z_count_c_(MAX_ADAPTER_NAME) const WCHAR *Name);
+
+void WINAPI
+WintunGetAdapterGUID(_In_ const WINTUN_ADAPTER *Adapter, _Out_ GUID *Guid);
+
+void WINAPI
+WintunGetAdapterLUID(_In_ const WINTUN_ADAPTER *Adapter, _Out_ LUID *Luid);
+
+WINTUN_STATUS WINAPI
+WintunGetAdapterDeviceObject(_In_ const WINTUN_ADAPTER *Adapter, _Out_ HANDLE *Handle);
+
+WINTUN_STATUS WINAPI
+WintunCreateAdapter(
+ _In_z_count_c_(MAX_POOL) const WCHAR *Pool,
+ _In_z_count_c_(MAX_ADAPTER_NAME) const WCHAR *Name,
+ _In_opt_ const GUID *RequestedGUID,
+ _Out_ WINTUN_ADAPTER **Adapter,
+ _Inout_ BOOL *RebootRequired);
+
+WINTUN_STATUS WINAPI
+WintunDeleteAdapter(_In_ const WINTUN_ADAPTER *Adapter, _Inout_ BOOL *RebootRequired);
+
+typedef BOOL(CALLBACK *WINTUN_ENUMPROC)(_In_ const WINTUN_ADAPTER *Adapter, _In_ LPARAM Param);
+
+WINTUN_STATUS WINAPI
+WintunEnumAdapters(_In_z_count_c_(MAX_POOL) const WCHAR *Pool, _In_ WINTUN_ENUMPROC Func, _In_ LPARAM Param);
+
+void
+DevmgmtInit();
+
+void
+DevmgmtCleanup();