diff options
author | Simon Rozman <simon@rozman.si> | 2020-07-29 10:10:42 +0200 |
---|---|---|
committer | Jason A. Donenfeld <Jason@zx2c4.com> | 2020-10-30 16:50:59 +0100 |
commit | abd20337e2a2ec1c4a34c1b839ee0ed575689527 (patch) | |
tree | 8db5d33f19f6107633110dcd8101a37784ee7b5f /api/devmgmt.h | |
parent | api: revise str/memcpy (diff) | |
download | wintun-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.h | 67 |
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(); |