api: adapter: cleanup wintrust shim if install fails
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
This commit is contained in:
parent
47c8eda1d5
commit
98cf23c410
@ -1195,7 +1195,7 @@ SelectDriver(
|
|||||||
if (!SetupCopyOEMInfW(InfPath, NULL, SPOST_NONE, 0, InfStorePath, MAX_PATH, NULL, NULL))
|
if (!SetupCopyOEMInfW(InfPath, NULL, SPOST_NONE, 0, InfStorePath, MAX_PATH, NULL, NULL))
|
||||||
{
|
{
|
||||||
LastError = LOG_LAST_ERROR(L"Could not install driver %s to store", InfPath);
|
LastError = LOG_LAST_ERROR(L"Could not install driver %s to store", InfPath);
|
||||||
goto cleanupDelete;
|
goto cleanupWintrustChangedKey;
|
||||||
}
|
}
|
||||||
_Analysis_assume_nullterminated_(InfStorePath);
|
_Analysis_assume_nullterminated_(InfStorePath);
|
||||||
|
|
||||||
@ -1207,29 +1207,29 @@ SelectDriver(
|
|||||||
{
|
{
|
||||||
LOG(WINTUN_LOG_ERR, L"Inf path too long: %s", InfStorePath);
|
LOG(WINTUN_LOG_ERR, L"Inf path too long: %s", InfStorePath);
|
||||||
LastError = ERROR_INVALID_PARAMETER;
|
LastError = ERROR_INVALID_PARAMETER;
|
||||||
goto cleanupDelete;
|
goto cleanupWintrustChangedKey;
|
||||||
}
|
}
|
||||||
if (!SetupDiSetDeviceInstallParamsW(DevInfo, DevInfoData, DevInstallParams))
|
if (!SetupDiSetDeviceInstallParamsW(DevInfo, DevInfoData, DevInstallParams))
|
||||||
{
|
{
|
||||||
LastError = LOG_LAST_ERROR(L"Failed to set adapter %u device installation parameters", DevInfoData->DevInst);
|
LastError = LOG_LAST_ERROR(L"Failed to set adapter %u device installation parameters", DevInfoData->DevInst);
|
||||||
goto cleanupDelete;
|
goto cleanupWintrustChangedKey;
|
||||||
}
|
}
|
||||||
if (!SetupDiBuildDriverInfoList(DevInfo, DevInfoData, SPDIT_COMPATDRIVER))
|
if (!SetupDiBuildDriverInfoList(DevInfo, DevInfoData, SPDIT_COMPATDRIVER))
|
||||||
{
|
{
|
||||||
LastError = LOG_LAST_ERROR(L"Failed rebuilding adapter %u driver info list", DevInfoData->DevInst);
|
LastError = LOG_LAST_ERROR(L"Failed rebuilding adapter %u driver info list", DevInfoData->DevInst);
|
||||||
goto cleanupDelete;
|
goto cleanupWintrustChangedKey;
|
||||||
}
|
}
|
||||||
DestroyDriverInfoListOnCleanup = TRUE;
|
DestroyDriverInfoListOnCleanup = TRUE;
|
||||||
SP_DRVINFO_DATA_W DrvInfoData = { .cbSize = sizeof(SP_DRVINFO_DATA_W) };
|
SP_DRVINFO_DATA_W DrvInfoData = { .cbSize = sizeof(SP_DRVINFO_DATA_W) };
|
||||||
if (!SetupDiEnumDriverInfoW(DevInfo, DevInfoData, SPDIT_COMPATDRIVER, 0, &DrvInfoData))
|
if (!SetupDiEnumDriverInfoW(DevInfo, DevInfoData, SPDIT_COMPATDRIVER, 0, &DrvInfoData))
|
||||||
{
|
{
|
||||||
LastError = LOG_LAST_ERROR(L"Failed to get adapter %u driver", DevInfoData->DevInst);
|
LastError = LOG_LAST_ERROR(L"Failed to get adapter %u driver", DevInfoData->DevInst);
|
||||||
goto cleanupDelete;
|
goto cleanupWintrustChangedKey;
|
||||||
}
|
}
|
||||||
if (!SetupDiSetSelectedDriverW(DevInfo, DevInfoData, &DrvInfoData))
|
if (!SetupDiSetSelectedDriverW(DevInfo, DevInfoData, &DrvInfoData))
|
||||||
{
|
{
|
||||||
LastError = LOG_LAST_ERROR(L"Failed to set adapter %u driver", DevInfoData->DevInst);
|
LastError = LOG_LAST_ERROR(L"Failed to set adapter %u driver", DevInfoData->DevInst);
|
||||||
goto cleanupDelete;
|
goto cleanupWintrustChangedKey;
|
||||||
}
|
}
|
||||||
LastError = ERROR_SUCCESS;
|
LastError = ERROR_SUCCESS;
|
||||||
DestroyDriverInfoListOnCleanup = FALSE;
|
DestroyDriverInfoListOnCleanup = FALSE;
|
||||||
|
Loading…
Reference in New Issue
Block a user