[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH 2/2] Delete CoInstaller code



With the CoInstaller removed from the INF file, delete the CoInstaller
source code and projects.

Signed-off-by: Owen Smith <owen.smith@xxxxxxxxx>
---
 src/coinst/coinst.c                           | 603 ------------------
 src/coinst/xennet_coinst.def                  |  38 --
 src/coinst/xennet_coinst.rc                   |  57 --
 vs2015/package/package.vcxproj                |   3 -
 vs2015/xennet.sln                             |  31 -
 vs2015/xennet_coinst/xennet_coinst.vcxproj    |  63 --
 .../xennet_coinst/xennet_coinst.vcxproj.user  |   8 -
 vs2017/package/package.vcxproj                |   3 -
 vs2017/xennet.sln                             |  31 -
 vs2017/xennet_coinst/xennet_coinst.vcxproj    |  63 --
 .../xennet_coinst/xennet_coinst.vcxproj.user  |   8 -
 vs2019/package/package.vcxproj                |   3 -
 vs2019/xennet.sln                             |  31 -
 vs2019/xennet_coinst/xennet_coinst.vcxproj    |  69 --
 .../xennet_coinst/xennet_coinst.vcxproj.user  |   8 -
 vs2022/package/package.vcxproj                |   3 -
 vs2022/xennet.sln                             |  31 -
 vs2022/xennet_coinst/xennet_coinst.vcxproj    |  69 --
 .../xennet_coinst/xennet_coinst.vcxproj.user  |   8 -
 19 files changed, 1130 deletions(-)
 delete mode 100644 src/coinst/coinst.c
 delete mode 100644 src/coinst/xennet_coinst.def
 delete mode 100644 src/coinst/xennet_coinst.rc
 delete mode 100644 vs2015/xennet_coinst/xennet_coinst.vcxproj
 delete mode 100644 vs2015/xennet_coinst/xennet_coinst.vcxproj.user
 delete mode 100644 vs2017/xennet_coinst/xennet_coinst.vcxproj
 delete mode 100644 vs2017/xennet_coinst/xennet_coinst.vcxproj.user
 delete mode 100644 vs2019/xennet_coinst/xennet_coinst.vcxproj
 delete mode 100644 vs2019/xennet_coinst/xennet_coinst.vcxproj.user
 delete mode 100644 vs2022/xennet_coinst/xennet_coinst.vcxproj
 delete mode 100644 vs2022/xennet_coinst/xennet_coinst.vcxproj.user

diff --git a/src/coinst/coinst.c b/src/coinst/coinst.c
deleted file mode 100644
index f25c0f5..0000000
--- a/src/coinst/coinst.c
+++ /dev/null
@@ -1,603 +0,0 @@
-/* Copyright (c) Xen Project.
- * Copyright (c) Cloud Software Group, Inc.
- * All rights reserved.
- * 
- * Redistribution and use in source and binary forms, 
- * with or without modification, are permitted provided 
- * that the following conditions are met:
- * 
- * *   Redistributions of source code must retain the above 
- *     copyright notice, this list of conditions and the 
- *     following disclaimer.
- * *   Redistributions in binary form must reproduce the above 
- *     copyright notice, this list of conditions and the 
- *     following disclaimer in the documentation and/or other 
- *     materials provided with the distribution.
- * 
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 
- * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, 
- * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 
- * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
- * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
- * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 
- * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
- * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 
- * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 
- * SUCH DAMAGE.
- */
-
-#define INITGUID
-
-#include <windows.h>
-#include <ws2def.h>
-#include <ws2ipdef.h>
-#include <iphlpapi.h>
-#include <setupapi.h>
-#include <devguid.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <tchar.h>
-#include <strsafe.h>
-#include <malloc.h>
-#include <stdarg.h>
-#include <assert.h>
-#include <vif_interface.h>
-
-#include <tcpip.h>
-#include <version.h>
-
-#define stringify_literal(_text) #_text
-#define stringify(_text) stringify_literal(_text)
-#define __MODULE__ stringify(PROJECT)
-
-__user_code;
-
-#define MAXIMUM_BUFFER_SIZE 1024
-
-#define SERVICES_KEY "SYSTEM\\CurrentControlSet\\Services"
-
-static VOID
-#pragma prefast(suppress:6262) // Function uses '1036' bytes of stack: exceeds 
/analyze:stacksize'1024'
-__Log(
-    IN  const CHAR  *Format,
-    IN  ...
-    )
-{
-    TCHAR               Buffer[MAXIMUM_BUFFER_SIZE];
-    va_list             Arguments;
-    size_t              Length;
-    SP_LOG_TOKEN        LogToken;
-    DWORD               Category;
-    DWORD               Flags;
-    HRESULT             Result;
-
-    va_start(Arguments, Format);
-    Result = StringCchVPrintf(Buffer, MAXIMUM_BUFFER_SIZE, Format, Arguments);
-    va_end(Arguments);
-
-    if (Result != S_OK && Result != STRSAFE_E_INSUFFICIENT_BUFFER)
-        return;
-
-    Result = StringCchLength(Buffer, MAXIMUM_BUFFER_SIZE, &Length);
-    if (Result != S_OK)
-        return;
-
-    LogToken = SetupGetThreadLogToken();
-    Category = TXTLOG_VENDOR;
-    Flags = TXTLOG_WARNING;
-
-    SetupWriteTextLog(LogToken, Category, Flags, Buffer);
-    Length = __min(MAXIMUM_BUFFER_SIZE - 1, Length + 2);
-
-    __analysis_assume(Length < MAXIMUM_BUFFER_SIZE);
-    __analysis_assume(Length >= 2);
-    Buffer[Length] = '\0';
-    Buffer[Length - 1] = '\n';
-    Buffer[Length - 2] = '\r';
-
-    OutputDebugString(Buffer);
-}
-
-#define Log(_Format, ...) \
-        __Log(__MODULE__ "|" __FUNCTION__ ": " _Format, __VA_ARGS__)
-
-static FORCEINLINE PTCHAR
-__GetErrorMessage(
-    IN  DWORD   Error
-    )
-{
-    PTCHAR      Message;
-    ULONG       Index;
-
-    if (!FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
-                       FORMAT_MESSAGE_FROM_SYSTEM |
-                       FORMAT_MESSAGE_IGNORE_INSERTS,
-                       NULL,
-                       Error,
-                       MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
-                       (LPTSTR)&Message,
-                       0,
-                       NULL))
-        return NULL;
-
-    for (Index = 0; Message[Index] != '\0'; Index++) {
-        if (Message[Index] == '\r' || Message[Index] == '\n') {
-            Message[Index] = '\0';
-            break;
-        }
-    }
-
-    return Message;
-}
-
-static FORCEINLINE const CHAR *
-__FunctionName(
-    IN  DI_FUNCTION Function
-    )
-{
-#define _NAME(_Function)        \
-        case DIF_ ## _Function: \
-            return #_Function;
-
-    switch (Function) {
-    _NAME(INSTALLDEVICE);
-    _NAME(REMOVE);
-    _NAME(SELECTDEVICE);
-    _NAME(ASSIGNRESOURCES);
-    _NAME(PROPERTIES);
-    _NAME(FIRSTTIMESETUP);
-    _NAME(FOUNDDEVICE);
-    _NAME(SELECTCLASSDRIVERS);
-    _NAME(VALIDATECLASSDRIVERS);
-    _NAME(INSTALLCLASSDRIVERS);
-    _NAME(CALCDISKSPACE);
-    _NAME(DESTROYPRIVATEDATA);
-    _NAME(VALIDATEDRIVER);
-    _NAME(MOVEDEVICE);
-    _NAME(DETECT);
-    _NAME(INSTALLWIZARD);
-    _NAME(DESTROYWIZARDDATA);
-    _NAME(PROPERTYCHANGE);
-    _NAME(ENABLECLASS);
-    _NAME(DETECTVERIFY);
-    _NAME(INSTALLDEVICEFILES);
-    _NAME(ALLOW_INSTALL);
-    _NAME(SELECTBESTCOMPATDRV);
-    _NAME(REGISTERDEVICE);
-    _NAME(NEWDEVICEWIZARD_PRESELECT);
-    _NAME(NEWDEVICEWIZARD_SELECT);
-    _NAME(NEWDEVICEWIZARD_PREANALYZE);
-    _NAME(NEWDEVICEWIZARD_POSTANALYZE);
-    _NAME(NEWDEVICEWIZARD_FINISHINSTALL);
-    _NAME(INSTALLINTERFACES);
-    _NAME(DETECTCANCEL);
-    _NAME(REGISTER_COINSTALLERS);
-    _NAME(ADDPROPERTYPAGE_ADVANCED);
-    _NAME(ADDPROPERTYPAGE_BASIC);
-    _NAME(TROUBLESHOOTER);
-    _NAME(POWERMESSAGEWAKE);
-    default:
-        break;
-    }
-
-    return "UNKNOWN";
-
-#undef  _NAME
-}
-
-static BOOLEAN
-AllowUpdate(
-    IN  PTCHAR      DriverName,
-    OUT PBOOLEAN    Allow
-    )
-{
-    TCHAR           ServiceKeyName[MAX_PATH];
-    HKEY            ServiceKey;
-    HRESULT         Result;
-    HRESULT         Error;
-    DWORD           ValueLength;
-    DWORD           Value;
-    DWORD           Type;
-
-    Log("====> (%s)", DriverName);
-
-    Result = StringCbPrintf(ServiceKeyName,
-                            MAX_PATH,
-                            SERVICES_KEY "\\%s",
-                            DriverName);
-    assert(SUCCEEDED(Result));
-
-    Error = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
-                         ServiceKeyName,
-                         0,
-                         KEY_READ,
-                         &ServiceKey);
-    if (Error != ERROR_SUCCESS) {
-        if (Error == ERROR_FILE_NOT_FOUND) {
-            Value = 1;
-            goto done;
-        }
-
-        SetLastError(Error);
-        goto fail1;
-    }
-
-    ValueLength = sizeof (Value);
-
-    Error = RegQueryValueEx(ServiceKey,
-                            "AllowUpdate",
-                            NULL,
-                            &Type,
-                            (LPBYTE)&Value,
-                            &ValueLength);
-    if (Error != ERROR_SUCCESS) {
-        if (Error == ERROR_FILE_NOT_FOUND) {
-            Type = REG_DWORD;
-            Value = 1;
-        } else {
-            SetLastError(Error);
-            goto fail2;
-        }
-    }
-
-    if (Type != REG_DWORD) {
-        SetLastError(ERROR_BAD_FORMAT);
-        goto fail3;
-    }
-
-    RegCloseKey(ServiceKey);
-
-done:
-    if (Value == 0) {
-        Log("DISALLOWED");
-        *Allow = FALSE;
-    }
-
-    Log("<====");
-
-    return TRUE;
-
-fail3:
-    Log("fail3");
-
-fail2:
-    Log("fail2");
-
-    RegCloseKey(ServiceKey);
-
-fail1:
-    Error = GetLastError();
-
-    {
-        PTCHAR  Message;
-        Message = __GetErrorMessage(Error);
-        Log("fail1 (%s)", Message);
-        LocalFree(Message);
-    }
-
-    return FALSE;
-}
-
-static BOOLEAN
-AllowInstall(
-    OUT PBOOLEAN    Allow
-    )
-{
-    BOOLEAN         Success;
-    HRESULT         Error;
-
-    Log("====>");
-
-    *Allow = TRUE;
-
-    Success = AllowUpdate("XENNET", Allow);
-    if (!Success)
-        goto fail1;
-
-    Log("<====");
-
-    return TRUE;
-
-fail1:
-    Error = GetLastError();
-
-    {
-        PTCHAR  Message;
-        Message = __GetErrorMessage(Error);
-        Log("fail1 (%s)", Message);
-        LocalFree(Message);
-    }
-
-    return FALSE;
-}
-
-static FORCEINLINE HRESULT
-__DifInstallPreProcess(
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    HRESULT                         Error;
-    BOOLEAN                         Success;
-    BOOLEAN                         Allow;
-
-    UNREFERENCED_PARAMETER(DeviceInfoSet);
-    UNREFERENCED_PARAMETER(DeviceInfoData);
-    UNREFERENCED_PARAMETER(Context);
-
-    Log("====>");
-
-    Success = AllowInstall(&Allow);
-    if (!Success)
-        goto fail1;
-
-    if (!Allow) {
-        SetLastError(ERROR_ACCESS_DENIED);
-        goto fail2;
-    }
-
-    Log("<====");
-
-    return NO_ERROR; 
-
-fail2:
-    Log("fail2");
-
-fail1:
-    Error = GetLastError();
-
-    {
-        PTCHAR  Message;
-
-        Message = __GetErrorMessage(Error);
-        Log("fail1 (%s)", Message);
-        LocalFree(Message);
-    }
-
-    return Error;
-}
-
-static FORCEINLINE HRESULT
-__DifInstallPostProcess(
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    UNREFERENCED_PARAMETER(DeviceInfoSet);
-    UNREFERENCED_PARAMETER(DeviceInfoData);
-    UNREFERENCED_PARAMETER(Context);
-
-    Log("<===>");
-
-    return NO_ERROR;
-}
-
-static DECLSPEC_NOINLINE HRESULT
-DifInstall(
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    HRESULT                         Error;
-
-    if (!Context->PostProcessing) {
-        Error = __DifInstallPreProcess(DeviceInfoSet, DeviceInfoData, Context);
-        if (Error == NO_ERROR)
-            Error = ERROR_DI_POSTPROCESSING_REQUIRED; 
-    } else {
-        Error = Context->InstallResult;
-        
-        if (Error == NO_ERROR) {
-            (VOID) __DifInstallPostProcess(DeviceInfoSet, DeviceInfoData, 
Context);
-        } else {
-            PTCHAR  Message;
-
-            Message = __GetErrorMessage(Error);
-            Log("NOT RUNNING (__DifInstallPreProcess Error: %s)", Message);
-            LocalFree(Message);
-        }
-    }
-
-    return Error;
-}
-
-static FORCEINLINE HRESULT
-__DifRemovePreProcess(
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    UNREFERENCED_PARAMETER(DeviceInfoSet);
-    UNREFERENCED_PARAMETER(DeviceInfoData);
-    UNREFERENCED_PARAMETER(Context);
-
-    Log("<===>");
-
-    return NO_ERROR;
-}
-
-static FORCEINLINE HRESULT
-__DifRemovePostProcess(
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    UNREFERENCED_PARAMETER(DeviceInfoSet);
-    UNREFERENCED_PARAMETER(DeviceInfoData);
-    UNREFERENCED_PARAMETER(Context);
-
-    Log("<===>");
-
-    return NO_ERROR;
-}
-
-static DECLSPEC_NOINLINE HRESULT
-DifRemove(
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    HRESULT                         Error;
-
-    if (!Context->PostProcessing) {
-        Error = __DifRemovePreProcess(DeviceInfoSet, DeviceInfoData, Context);
-
-        if (Error == NO_ERROR)
-            Error = ERROR_DI_POSTPROCESSING_REQUIRED; 
-    } else {
-        Error = Context->InstallResult;
-        
-        if (Error == NO_ERROR) {
-            (VOID) __DifRemovePostProcess(DeviceInfoSet, DeviceInfoData, 
Context);
-        } else {
-            PTCHAR  Message;
-
-            Message = __GetErrorMessage(Error);
-            Log("NOT RUNNING (__DifRemovePreProcess Error: %s)", Message);
-            LocalFree(Message);
-        }
-    }
-
-    return Error;
-}
-
-DWORD CALLBACK
-Entry(
-    IN  DI_FUNCTION                 Function,
-    IN  HDEVINFO                    DeviceInfoSet,
-    IN  PSP_DEVINFO_DATA            DeviceInfoData,
-    IN  PCOINSTALLER_CONTEXT_DATA   Context
-    )
-{
-    HRESULT                         Error;
-
-    Log("%s (%s) ===>",
-        MAJOR_VERSION_STR "." MINOR_VERSION_STR "." MICRO_VERSION_STR "." 
BUILD_NUMBER_STR,
-        DAY_STR "/" MONTH_STR "/" YEAR_STR);
-
-    if (!Context->PostProcessing) {
-        Log("%s PreProcessing",
-            __FunctionName(Function));
-    } else {
-        Log("%s PostProcessing (%08x)",
-            __FunctionName(Function),
-            Context->InstallResult);
-    }
-
-    switch (Function) {
-    case DIF_INSTALLDEVICE: {
-        SP_DRVINFO_DATA         DriverInfoData;
-        BOOLEAN                 DriverInfoAvailable;
-
-        DriverInfoData.cbSize = sizeof (DriverInfoData);
-        DriverInfoAvailable = SetupDiGetSelectedDriver(DeviceInfoSet,
-                                                       DeviceInfoData,
-                                                       &DriverInfoData) ?
-                              TRUE :
-                              FALSE;
-
-        // The NET class installer will call DIF_REMOVE even in the event of
-        // a NULL driver add. However, the default installer (for the NULL
-        // driver) then fails for some reason so we squash the error in
-        // post-processing.
-        if (DriverInfoAvailable) {
-            Error = DifInstall(DeviceInfoSet, DeviceInfoData, Context);
-        } else {
-            if (!Context->PostProcessing) {
-                Error = ERROR_DI_POSTPROCESSING_REQUIRED; 
-            } else {
-                Error = NO_ERROR;
-            }
-        }
-        break;
-    }
-    case DIF_REMOVE:
-        Error = DifRemove(DeviceInfoSet, DeviceInfoData, Context);
-        break;
-    default:
-        if (!Context->PostProcessing) {
-            Error = NO_ERROR;
-        } else {
-            Error = Context->InstallResult;
-        }
-
-        break;
-    }
-
-    Log("%s (%s) <===",
-        MAJOR_VERSION_STR "." MINOR_VERSION_STR "." MICRO_VERSION_STR "." 
BUILD_NUMBER_STR,
-        DAY_STR "/" MONTH_STR "/" YEAR_STR);
-
-    return (DWORD)Error;
-}
-
-DWORD CALLBACK
-Version(
-    IN  HWND        Window,
-    IN  HINSTANCE   Module,
-    IN  PTCHAR      Buffer,
-    IN  INT         Reserved
-    )
-{
-    UNREFERENCED_PARAMETER(Window);
-    UNREFERENCED_PARAMETER(Module);
-    UNREFERENCED_PARAMETER(Buffer);
-    UNREFERENCED_PARAMETER(Reserved);
-
-    Log("%s (%s)",
-        MAJOR_VERSION_STR "." MINOR_VERSION_STR "." MICRO_VERSION_STR "." 
BUILD_NUMBER_STR,
-        DAY_STR "/" MONTH_STR "/" YEAR_STR);
-
-    return NO_ERROR;
-}
-
-static FORCEINLINE const CHAR *
-__ReasonName(
-    IN  DWORD       Reason
-    )
-{
-#define _NAME(_Reason)          \
-        case DLL_ ## _Reason:   \
-            return #_Reason;
-
-    switch (Reason) {
-    _NAME(PROCESS_ATTACH);
-    _NAME(PROCESS_DETACH);
-    _NAME(THREAD_ATTACH);
-    _NAME(THREAD_DETACH);
-    default:
-        break;
-    }
-
-    return "UNKNOWN";
-
-#undef  _NAME
-}
-
-BOOL WINAPI
-DllMain(
-    IN  HINSTANCE   Module,
-    IN  DWORD       Reason,
-    IN  PVOID       Reserved
-    )
-{
-    UNREFERENCED_PARAMETER(Module);
-    UNREFERENCED_PARAMETER(Reserved);
-
-    Log("%s (%s): %s",
-        MAJOR_VERSION_STR "." MINOR_VERSION_STR "." MICRO_VERSION_STR "." 
BUILD_NUMBER_STR,
-        DAY_STR "/" MONTH_STR "/" YEAR_STR,
-        __ReasonName(Reason));
-
-    return TRUE;
-}
diff --git a/src/coinst/xennet_coinst.def b/src/coinst/xennet_coinst.def
deleted file mode 100644
index 3a3f0fb..0000000
--- a/src/coinst/xennet_coinst.def
+++ /dev/null
@@ -1,38 +0,0 @@
-; Copyright (c) Xen Project.
-; Copyright (c) Cloud Software Group, Inc.
-; All rights reserved.
-; 
-; Redistribution and use in source and binary forms, 
-; with or without modification, are permitted provided 
-; that the following conditions are met:
-; 
-; *   Redistributions of source code must retain the above 
-;     copyright notice, this list of conditions and the 
-;     following disclaimer.
-; *   Redistributions in binary form must reproduce the above 
-;     copyright notice, this list of conditions and the 
-;     following disclaimer in the documentation and/or other 
-;     materials provided with the distribution.
-; 
-; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 
-; CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, 
-; INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 
-; MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
-; DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 
-; CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
-; SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
-; BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 
-; SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
-; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
-; WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 
-; NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
-; OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 
-; SUCH DAMAGE.
-
-LIBRARY  XENNET_COINST
-
-EXPORTS   
-   Entry 
-   Version
-
-   DllMain PRIVATE
diff --git a/src/coinst/xennet_coinst.rc b/src/coinst/xennet_coinst.rc
deleted file mode 100644
index e4635d4..0000000
--- a/src/coinst/xennet_coinst.rc
+++ /dev/null
@@ -1,57 +0,0 @@
-/* Copyright (c) Xen Project.
- * Copyright (c) Cloud Software Group, Inc.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms,
- * with or without modification, are permitted provided
- * that the following conditions are met:
- *
- * *   Redistributions of source code must retain the above
- *     copyright notice, this list of conditions and the
- *     following disclaimer.
- * *   Redistributions in binary form must reproduce the above
- *     copyright notice, this list of conditions and the
- *     following disclaimer in the documentation and/or other
- *     materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
- * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
- * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
- * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
- * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
- * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- */
-
-#include <windows.h>
-#include <ntverp.h>
-
-
-#undef VER_COMPANYNAME_STR
-#undef VER_PRODUCTNAME_STR
-#undef VER_PRODUCTVERSION
-#undef VER_PRODUCTVERSION_STR
-
-#include <version.h>
-
-#define        VER_COMPANYNAME_STR         VENDOR_NAME_STR
-#define VER_LEGALCOPYRIGHT_STR      COPYRIGHT_STR
-
-#define VER_PRODUCTNAME_STR         "XENNET_COINST"
-#define VER_PRODUCTVERSION          
MAJOR_VERSION,MINOR_VERSION,MICRO_VERSION,BUILD_NUMBER
-#define VER_PRODUCTVERSION_STR      MAJOR_VERSION_STR "." MINOR_VERSION_STR 
"." MICRO_VERSION_STR "." BUILD_NUMBER_STR
-
-#define VER_INTERNALNAME_STR        "XENNET_COINST.DLL"
-#define VER_FILEDESCRIPTION_STR     "XENNET_COINST"
-
-#define VER_FILETYPE                VFT_DRV
-#define VER_FILESUBTYPE             VFT2_DRV_SYSTEM
-
-#include <common.ver>
diff --git a/vs2015/package/package.vcxproj b/vs2015/package/package.vcxproj
index 5433b1f..cce27d2 100644
--- a/vs2015/package/package.vcxproj
+++ b/vs2015/package/package.vcxproj
@@ -41,9 +41,6 @@
     <ProjectReference Include="..\xennet\xennet.vcxproj">
       <Project>{97D9942B-5EA3-488C-B512-C96E5D077F8E}</Project>
     </ProjectReference>
-    <ProjectReference Include="..\xennet_coinst\xennet_coinst.vcxproj">
-      <Project>{3EDD837A-C1BE-47D4-9603-16B61353670B}</Project>
-    </ProjectReference>
     <FilesToPackage Include="..\xennet.inf" />
   </ItemGroup>
   <ItemGroup Condition="Exists('$(DPINST_REDIST)')">
diff --git a/vs2015/xennet.sln b/vs2015/xennet.sln
index 7cbf8ca..875f691 100644
--- a/vs2015/xennet.sln
+++ b/vs2015/xennet.sln
@@ -9,16 +9,9 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet", 
"xennet\xennet.vcx
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
        EndProjectSection
 EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet_coinst", 
"xennet_coinst\xennet_coinst.vcxproj", "{3EDD837A-C1BE-47D4-9603-16B61353670B}"
-       ProjectSection(ProjectDependencies) = postProject
-               {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {97D9942B-5EA3-488C-B512-C96E5D077F8E} = 
{97D9942B-5EA3-488C-B512-C96E5D077F8E}
-       EndProjectSection
-EndProject
 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "package", 
"package\package.vcxproj", "{445FD18F-97E3-4E5D-825F-151026242C05}"
        ProjectSection(ProjectDependencies) = postProject
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {3EDD837A-C1BE-47D4-9603-16B61353670B} = 
{3EDD837A-C1BE-47D4-9603-16B61353670B}
        EndProjectSection
 EndProject
 Global
@@ -73,30 +66,6 @@ Global
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.ActiveCfg = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Build.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Deploy.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.ActiveCfg = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Build.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Deploy.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.ActiveCfg = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Build.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Deploy.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.ActiveCfg = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Build.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Deploy.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.ActiveCfg = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Build.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Deploy.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.ActiveCfg = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Build.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Deploy.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
diff --git a/vs2015/xennet_coinst/xennet_coinst.vcxproj 
b/vs2015/xennet_coinst/xennet_coinst.vcxproj
deleted file mode 100644
index 2bbd383..0000000
--- a/vs2015/xennet_coinst/xennet_coinst.vcxproj
+++ /dev/null
@@ -1,63 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="14.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <Import Project="..\configs.props" />
-  <PropertyGroup Label="PropertySheets">
-    <DriverType>WDM</DriverType>
-    <PlatformToolset>WindowsApplicationForDrivers10.0</PlatformToolset>
-    <ConfigurationType>DynamicLibrary</ConfigurationType>
-  </PropertyGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
-  <PropertyGroup Label="Globals">
-    <ProjectGuid>{3EDD837A-C1BE-47D4-9603-16B61353670B}</ProjectGuid>
-  </PropertyGroup>
-  <Import Project="..\targets.props" />
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
-  <PropertyGroup>
-    <IncludePath>$(IncludePath)</IncludePath>
-    <RunCodeAnalysis>true</RunCodeAnalysis>
-    <EnableInf2cat>false</EnableInf2cat>
-  </PropertyGroup>
-  <ItemDefinitionGroup>
-    <ClCompile>
-      
<AdditionalIncludeDirectories>$(SolutionDir)..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-      
<PreprocessorDefinitions>PROJECT=$(ProjectName);;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-      <WarningLevel>EnableAllWarnings</WarningLevel>
-      
<DisableSpecificWarnings>4548;4820;4668;4255;6001;6054;28196;%(DisableSpecificWarnings)</DisableSpecificWarnings>
-      <MultiProcessorCompilation>true</MultiProcessorCompilation>
-      <EnablePREfast>true</EnablePREfast>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='true'">MultiThreadedDebug</RuntimeLibrary>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='false'">MultiThreaded</RuntimeLibrary>
-    </ClCompile>
-    <Link>
-      
<ModuleDefinitionFile>../../src/coinst/xennet_coinst.def</ModuleDefinitionFile>
-      
<AdditionalDependencies>setupapi.lib;iphlpapi.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-    <ResourceCompile>
-      
<AdditionalIncludeDirectories>..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-    </ResourceCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='Win32'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__i386__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='x64'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__x86_64__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemGroup>
-    <FilesToPackage Include="$(TargetPath)" />
-    <FilesToPackage Include="$(OutDir)$(TargetName).pdb" />
-  </ItemGroup>
-  <ItemGroup>
-    <ClCompile Include="..\..\src\coinst\coinst.c" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="..\..\src\coinst\xennet_coinst.def" />
-  </ItemGroup>
-  <ItemGroup>
-    <ResourceCompile Include="..\..\src\coinst\xennet_coinst.rc" />
-  </ItemGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
-</Project>
diff --git a/vs2015/xennet_coinst/xennet_coinst.vcxproj.user 
b/vs2015/xennet_coinst/xennet_coinst.vcxproj.user
deleted file mode 100644
index 8b034c4..0000000
--- a/vs2015/xennet_coinst/xennet_coinst.vcxproj.user
+++ /dev/null
@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <PropertyGroup>
-    <SignMode>TestSign</SignMode>
-    <TestCertificate>..\..\src\xennet.pfx</TestCertificate>
-    
<TimeStampServer>http://timestamp.verisign.com/scripts/timstamp.dll</TimeStampServer>
-  </PropertyGroup>
-</Project>
diff --git a/vs2017/package/package.vcxproj b/vs2017/package/package.vcxproj
index dd794b5..975bef2 100644
--- a/vs2017/package/package.vcxproj
+++ b/vs2017/package/package.vcxproj
@@ -41,9 +41,6 @@
     <ProjectReference Include="..\xennet\xennet.vcxproj">
       <Project>{97D9942B-5EA3-488C-B512-C96E5D077F8E}</Project>
     </ProjectReference>
-    <ProjectReference Include="..\xennet_coinst\xennet_coinst.vcxproj">
-      <Project>{3EDD837A-C1BE-47D4-9603-16B61353670B}</Project>
-    </ProjectReference>
     <FilesToPackage Include="..\xennet.inf" />
   </ItemGroup>
   <ItemGroup Condition="Exists('$(DPINST_REDIST)')">
diff --git a/vs2017/xennet.sln b/vs2017/xennet.sln
index fde116e..0d24a12 100644
--- a/vs2017/xennet.sln
+++ b/vs2017/xennet.sln
@@ -6,16 +6,9 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet", 
"xennet\xennet.vcx
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
        EndProjectSection
 EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet_coinst", 
"xennet_coinst\xennet_coinst.vcxproj", "{3EDD837A-C1BE-47D4-9603-16B61353670B}"
-       ProjectSection(ProjectDependencies) = postProject
-               {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {97D9942B-5EA3-488C-B512-C96E5D077F8E} = 
{97D9942B-5EA3-488C-B512-C96E5D077F8E}
-       EndProjectSection
-EndProject
 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "package", 
"package\package.vcxproj", "{445FD18F-97E3-4E5D-825F-151026242C05}"
        ProjectSection(ProjectDependencies) = postProject
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {3EDD837A-C1BE-47D4-9603-16B61353670B} = 
{3EDD837A-C1BE-47D4-9603-16B61353670B}
        EndProjectSection
 EndProject
 Global
@@ -70,30 +63,6 @@ Global
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.ActiveCfg = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Build.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Deploy.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.ActiveCfg = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Build.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Deploy.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.ActiveCfg = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Build.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Deploy.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.ActiveCfg = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Build.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Deploy.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.ActiveCfg = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Build.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Deploy.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.ActiveCfg = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Build.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Deploy.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
diff --git a/vs2017/xennet_coinst/xennet_coinst.vcxproj 
b/vs2017/xennet_coinst/xennet_coinst.vcxproj
deleted file mode 100644
index 310d709..0000000
--- a/vs2017/xennet_coinst/xennet_coinst.vcxproj
+++ /dev/null
@@ -1,63 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="15.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <Import Project="..\configs.props" />
-  <PropertyGroup Label="PropertySheets">
-    <DriverType>WDM</DriverType>
-    <PlatformToolset>WindowsApplicationForDrivers10.0</PlatformToolset>
-    <ConfigurationType>DynamicLibrary</ConfigurationType>
-  </PropertyGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
-  <PropertyGroup Label="Globals">
-    <ProjectGuid>{3EDD837A-C1BE-47D4-9603-16B61353670B}</ProjectGuid>
-  </PropertyGroup>
-  <Import Project="..\targets.props" />
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
-  <PropertyGroup>
-    <IncludePath>$(IncludePath)</IncludePath>
-    <RunCodeAnalysis>true</RunCodeAnalysis>
-    <EnableInf2cat>false</EnableInf2cat>
-  </PropertyGroup>
-  <ItemDefinitionGroup>
-    <ClCompile>
-      
<AdditionalIncludeDirectories>$(SolutionDir)..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-      
<PreprocessorDefinitions>PROJECT=$(ProjectName);%(PreprocessorDefinitions)</PreprocessorDefinitions>
-      <WarningLevel>EnableAllWarnings</WarningLevel>
-      
<DisableSpecificWarnings>4548;4820;4668;4255;5045;6001;6054;28196;%(DisableSpecificWarnings)</DisableSpecificWarnings>
-      <MultiProcessorCompilation>true</MultiProcessorCompilation>
-      <EnablePREfast>true</EnablePREfast>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='true'">MultiThreadedDebug</RuntimeLibrary>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='false'">MultiThreaded</RuntimeLibrary>
-    </ClCompile>
-    <Link>
-      
<ModuleDefinitionFile>../../src/coinst/xennet_coinst.def</ModuleDefinitionFile>
-      
<AdditionalDependencies>setupapi.lib;iphlpapi.lib;%(AdditionalDependencies)</AdditionalDependencies>
-    </Link>
-    <ResourceCompile>
-      
<AdditionalIncludeDirectories>..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-    </ResourceCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='Win32'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__i386__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='x64'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__x86_64__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemGroup>
-    <FilesToPackage Include="$(TargetPath)" />
-    <FilesToPackage Include="$(OutDir)$(TargetName).pdb" />
-  </ItemGroup>
-  <ItemGroup>
-    <ClCompile Include="..\..\src\coinst\coinst.c" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="..\..\src\coinst\xennet_coinst.def" />
-  </ItemGroup>
-  <ItemGroup>
-    <ResourceCompile Include="..\..\src\coinst\xennet_coinst.rc" />
-  </ItemGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
-</Project>
diff --git a/vs2017/xennet_coinst/xennet_coinst.vcxproj.user 
b/vs2017/xennet_coinst/xennet_coinst.vcxproj.user
deleted file mode 100644
index 8b034c4..0000000
--- a/vs2017/xennet_coinst/xennet_coinst.vcxproj.user
+++ /dev/null
@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <PropertyGroup>
-    <SignMode>TestSign</SignMode>
-    <TestCertificate>..\..\src\xennet.pfx</TestCertificate>
-    
<TimeStampServer>http://timestamp.verisign.com/scripts/timstamp.dll</TimeStampServer>
-  </PropertyGroup>
-</Project>
diff --git a/vs2019/package/package.vcxproj b/vs2019/package/package.vcxproj
index 098252d..232227e 100644
--- a/vs2019/package/package.vcxproj
+++ b/vs2019/package/package.vcxproj
@@ -46,9 +46,6 @@
     <ProjectReference Include="..\xennet\xennet.vcxproj">
       <Project>{97D9942B-5EA3-488C-B512-C96E5D077F8E}</Project>
     </ProjectReference>
-    <ProjectReference Include="..\xennet_coinst\xennet_coinst.vcxproj">
-      <Project>{3EDD837A-C1BE-47D4-9603-16B61353670B}</Project>
-    </ProjectReference>
     <FilesToPackage Include="..\xennet.inf" />
   </ItemGroup>
   <ItemGroup Condition="Exists('$(DPINST_REDIST)')">
diff --git a/vs2019/xennet.sln b/vs2019/xennet.sln
index 2928c20..50ef6c3 100644
--- a/vs2019/xennet.sln
+++ b/vs2019/xennet.sln
@@ -9,16 +9,9 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet", 
"xennet\xennet.vcx
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
        EndProjectSection
 EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet_coinst", 
"xennet_coinst\xennet_coinst.vcxproj", "{3EDD837A-C1BE-47D4-9603-16B61353670B}"
-       ProjectSection(ProjectDependencies) = postProject
-               {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {97D9942B-5EA3-488C-B512-C96E5D077F8E} = 
{97D9942B-5EA3-488C-B512-C96E5D077F8E}
-       EndProjectSection
-EndProject
 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "package", 
"package\package.vcxproj", "{445FD18F-97E3-4E5D-825F-151026242C05}"
        ProjectSection(ProjectDependencies) = postProject
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {3EDD837A-C1BE-47D4-9603-16B61353670B} = 
{3EDD837A-C1BE-47D4-9603-16B61353670B}
        EndProjectSection
 EndProject
 Global
@@ -73,30 +66,6 @@ Global
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.ActiveCfg = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Build.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Deploy.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.ActiveCfg = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Build.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Deploy.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.ActiveCfg = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Build.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Deploy.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.ActiveCfg = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Build.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Deploy.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.ActiveCfg = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Build.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Deploy.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.ActiveCfg = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Build.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Deploy.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
diff --git a/vs2019/xennet_coinst/xennet_coinst.vcxproj 
b/vs2019/xennet_coinst/xennet_coinst.vcxproj
deleted file mode 100644
index ca24ed4..0000000
--- a/vs2019/xennet_coinst/xennet_coinst.vcxproj
+++ /dev/null
@@ -1,69 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="15.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <Import Project="..\configs.props" />
-  <PropertyGroup Label="PropertySheets">
-    <DriverType>WDM</DriverType>
-    <PlatformToolset>WindowsApplicationForDrivers10.0</PlatformToolset>
-    <ConfigurationType>DynamicLibrary</ConfigurationType>
-  </PropertyGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
-  <PropertyGroup Label="Globals">
-    <ProjectGuid>{3EDD837A-C1BE-47D4-9603-16B61353670B}</ProjectGuid>
-  </PropertyGroup>
-  <Import Project="..\targets.props" />
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
-  <PropertyGroup>
-    <IncludePath>$(IncludePath)</IncludePath>
-    <RunCodeAnalysis>true</RunCodeAnalysis>
-    <EnableInf2cat>false</EnableInf2cat>
-  </PropertyGroup>
-  <ItemDefinitionGroup>
-    <ClCompile>
-      <AdditionalOptions>/ZH:SHA_256 %(AdditionalOptions)</AdditionalOptions>
-      <SDLCheck>true</SDLCheck>
-      
<AdditionalIncludeDirectories>$(SolutionDir)..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-      
<PreprocessorDefinitions>PROJECT=$(ProjectName);%(PreprocessorDefinitions)</PreprocessorDefinitions>
-      <WarningLevel>EnableAllWarnings</WarningLevel>
-      
<DisableSpecificWarnings>4548;4820;4668;4255;5045;6001;6054;28196;%(DisableSpecificWarnings)</DisableSpecificWarnings>
-      <MultiProcessorCompilation>true</MultiProcessorCompilation>
-      <EnablePREfast>true</EnablePREfast>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='true'">MultiThreadedDebug</RuntimeLibrary>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='false'">MultiThreaded</RuntimeLibrary>
-    </ClCompile>
-    <Link>
-      
<ModuleDefinitionFile>../../src/coinst/xennet_coinst.def</ModuleDefinitionFile>
-      
<AdditionalDependencies>setupapi.lib;iphlpapi.lib;%(AdditionalDependencies)</AdditionalDependencies>
-      <CETCompat>true</CETCompat>
-    </Link>
-    <ResourceCompile>
-      
<AdditionalIncludeDirectories>..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-    </ResourceCompile>
-    <DriverSign>
-      <FileDigestAlgorithm>sha256</FileDigestAlgorithm>
-    </DriverSign>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='Win32'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__i386__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='x64'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__x86_64__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemGroup>
-    <FilesToPackage Include="$(TargetPath)" />
-    <FilesToPackage Include="$(OutDir)$(TargetName).pdb" />
-  </ItemGroup>
-  <ItemGroup>
-    <ClCompile Include="..\..\src\coinst\coinst.c" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="..\..\src\coinst\xennet_coinst.def" />
-  </ItemGroup>
-  <ItemGroup>
-    <ResourceCompile Include="..\..\src\coinst\xennet_coinst.rc" />
-  </ItemGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
-</Project>
diff --git a/vs2019/xennet_coinst/xennet_coinst.vcxproj.user 
b/vs2019/xennet_coinst/xennet_coinst.vcxproj.user
deleted file mode 100644
index 8b034c4..0000000
--- a/vs2019/xennet_coinst/xennet_coinst.vcxproj.user
+++ /dev/null
@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <PropertyGroup>
-    <SignMode>TestSign</SignMode>
-    <TestCertificate>..\..\src\xennet.pfx</TestCertificate>
-    
<TimeStampServer>http://timestamp.verisign.com/scripts/timstamp.dll</TimeStampServer>
-  </PropertyGroup>
-</Project>
diff --git a/vs2022/package/package.vcxproj b/vs2022/package/package.vcxproj
index 3df4166..5df9967 100644
--- a/vs2022/package/package.vcxproj
+++ b/vs2022/package/package.vcxproj
@@ -46,9 +46,6 @@
     <ProjectReference Include="..\xennet\xennet.vcxproj">
       <Project>{97D9942B-5EA3-488C-B512-C96E5D077F8E}</Project>
     </ProjectReference>
-    <ProjectReference Include="..\xennet_coinst\xennet_coinst.vcxproj">
-      <Project>{3EDD837A-C1BE-47D4-9603-16B61353670B}</Project>
-    </ProjectReference>
     <FilesToPackage Include="..\xennet.inf" />
   </ItemGroup>
   <ItemGroup Condition="Exists('$(DPINST_REDIST)')">
diff --git a/vs2022/xennet.sln b/vs2022/xennet.sln
index 2928c20..50ef6c3 100644
--- a/vs2022/xennet.sln
+++ b/vs2022/xennet.sln
@@ -9,16 +9,9 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet", 
"xennet\xennet.vcx
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
        EndProjectSection
 EndProject
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "xennet_coinst", 
"xennet_coinst\xennet_coinst.vcxproj", "{3EDD837A-C1BE-47D4-9603-16B61353670B}"
-       ProjectSection(ProjectDependencies) = postProject
-               {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {97D9942B-5EA3-488C-B512-C96E5D077F8E} = 
{97D9942B-5EA3-488C-B512-C96E5D077F8E}
-       EndProjectSection
-EndProject
 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "package", 
"package\package.vcxproj", "{445FD18F-97E3-4E5D-825F-151026242C05}"
        ProjectSection(ProjectDependencies) = postProject
                {65FA97EA-A569-4FC1-BFE7-D68E109143F7} = 
{65FA97EA-A569-4FC1-BFE7-D68E109143F7}
-               {3EDD837A-C1BE-47D4-9603-16B61353670B} = 
{3EDD837A-C1BE-47D4-9603-16B61353670B}
        EndProjectSection
 EndProject
 Global
@@ -73,30 +66,6 @@ Global
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
                {97D9942B-5EA3-488C-B512-C96E5D077F8E}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.ActiveCfg = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Build.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Debug|x64.Deploy.0 = Windows 8 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.ActiveCfg = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Build.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|Win32.Deploy.0 = Windows 8 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.ActiveCfg = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Build.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 8 
Release|x64.Deploy.0 = Windows 8 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.ActiveCfg = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Build.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|Win32.Deploy.0 = Windows 10 Debug|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.ActiveCfg = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Build.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Debug|x64.Deploy.0 = Windows 10 Debug|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.ActiveCfg = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Build.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|Win32.Deploy.0 = Windows 10 Release|Win32
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.ActiveCfg = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Build.0 = Windows 10 Release|x64
-               {3EDD837A-C1BE-47D4-9603-16B61353670B}.Windows 10 
Release|x64.Deploy.0 = Windows 10 Release|x64
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.ActiveCfg = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Build.0 = Windows 8 Debug|Win32
                {445FD18F-97E3-4E5D-825F-151026242C05}.Windows 8 
Debug|Win32.Deploy.0 = Windows 8 Debug|Win32
diff --git a/vs2022/xennet_coinst/xennet_coinst.vcxproj 
b/vs2022/xennet_coinst/xennet_coinst.vcxproj
deleted file mode 100644
index ca24ed4..0000000
--- a/vs2022/xennet_coinst/xennet_coinst.vcxproj
+++ /dev/null
@@ -1,69 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="15.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <Import Project="..\configs.props" />
-  <PropertyGroup Label="PropertySheets">
-    <DriverType>WDM</DriverType>
-    <PlatformToolset>WindowsApplicationForDrivers10.0</PlatformToolset>
-    <ConfigurationType>DynamicLibrary</ConfigurationType>
-  </PropertyGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
-  <PropertyGroup Label="Globals">
-    <ProjectGuid>{3EDD837A-C1BE-47D4-9603-16B61353670B}</ProjectGuid>
-  </PropertyGroup>
-  <Import Project="..\targets.props" />
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
-  <PropertyGroup>
-    <IncludePath>$(IncludePath)</IncludePath>
-    <RunCodeAnalysis>true</RunCodeAnalysis>
-    <EnableInf2cat>false</EnableInf2cat>
-  </PropertyGroup>
-  <ItemDefinitionGroup>
-    <ClCompile>
-      <AdditionalOptions>/ZH:SHA_256 %(AdditionalOptions)</AdditionalOptions>
-      <SDLCheck>true</SDLCheck>
-      
<AdditionalIncludeDirectories>$(SolutionDir)..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-      
<PreprocessorDefinitions>PROJECT=$(ProjectName);%(PreprocessorDefinitions)</PreprocessorDefinitions>
-      <WarningLevel>EnableAllWarnings</WarningLevel>
-      
<DisableSpecificWarnings>4548;4820;4668;4255;5045;6001;6054;28196;%(DisableSpecificWarnings)</DisableSpecificWarnings>
-      <MultiProcessorCompilation>true</MultiProcessorCompilation>
-      <EnablePREfast>true</EnablePREfast>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='true'">MultiThreadedDebug</RuntimeLibrary>
-      <RuntimeLibrary 
Condition="'$(UseDebugLibraries)'=='false'">MultiThreaded</RuntimeLibrary>
-    </ClCompile>
-    <Link>
-      
<ModuleDefinitionFile>../../src/coinst/xennet_coinst.def</ModuleDefinitionFile>
-      
<AdditionalDependencies>setupapi.lib;iphlpapi.lib;%(AdditionalDependencies)</AdditionalDependencies>
-      <CETCompat>true</CETCompat>
-    </Link>
-    <ResourceCompile>
-      
<AdditionalIncludeDirectories>..\..\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
-    </ResourceCompile>
-    <DriverSign>
-      <FileDigestAlgorithm>sha256</FileDigestAlgorithm>
-    </DriverSign>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='Win32'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__i386__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemDefinitionGroup Condition="'$(Platform)'=='x64'">
-    <ClCompile>
-      
<PreprocessorDefinitions>__x86_64__;%(PreprocessorDefinitions)</PreprocessorDefinitions>
-    </ClCompile>
-  </ItemDefinitionGroup>
-  <ItemGroup>
-    <FilesToPackage Include="$(TargetPath)" />
-    <FilesToPackage Include="$(OutDir)$(TargetName).pdb" />
-  </ItemGroup>
-  <ItemGroup>
-    <ClCompile Include="..\..\src\coinst\coinst.c" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="..\..\src\coinst\xennet_coinst.def" />
-  </ItemGroup>
-  <ItemGroup>
-    <ResourceCompile Include="..\..\src\coinst\xennet_coinst.rc" />
-  </ItemGroup>
-  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
-</Project>
diff --git a/vs2022/xennet_coinst/xennet_coinst.vcxproj.user 
b/vs2022/xennet_coinst/xennet_coinst.vcxproj.user
deleted file mode 100644
index 8b034c4..0000000
--- a/vs2022/xennet_coinst/xennet_coinst.vcxproj.user
+++ /dev/null
@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>
-  <PropertyGroup>
-    <SignMode>TestSign</SignMode>
-    <TestCertificate>..\..\src\xennet.pfx</TestCertificate>
-    
<TimeStampServer>http://timestamp.verisign.com/scripts/timstamp.dll</TimeStampServer>
-  </PropertyGroup>
-</Project>
-- 
2.41.0.windows.3




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.