qga: vss-win32: Use NULL as an invalid pointer for OpenEvent and CreateEvent
OpenEvent and CreateEvent WinAPI return NULL when failed to open/create events handles, instead of INVALID_HANDLE_VALUE (although their return types are HANDLE). This replaces INVALID_HANDLE_VALUE related to event handles with NULL. Signed-off-by: Tomoki Sekiyama <tomoki.sekiyama@hds.com> Reviewed-by: Gal Hammer <ghammer@redhat.com> Reviewed-by: Yan Vugenfirer <yvugenfi@redhat.com> Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
This commit is contained in:
parent
105a060188
commit
4c1b8f1e83
|
@ -342,18 +342,18 @@ STDMETHODIMP CQGAVssProvider::CommitSnapshots(VSS_ID SnapshotSetId)
|
||||||
HANDLE hEventFrozen, hEventThaw, hEventTimeout;
|
HANDLE hEventFrozen, hEventThaw, hEventTimeout;
|
||||||
|
|
||||||
hEventFrozen = OpenEvent(EVENT_ALL_ACCESS, FALSE, EVENT_NAME_FROZEN);
|
hEventFrozen = OpenEvent(EVENT_ALL_ACCESS, FALSE, EVENT_NAME_FROZEN);
|
||||||
if (hEventFrozen == INVALID_HANDLE_VALUE) {
|
if (!hEventFrozen) {
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
hEventThaw = OpenEvent(EVENT_ALL_ACCESS, FALSE, EVENT_NAME_THAW);
|
hEventThaw = OpenEvent(EVENT_ALL_ACCESS, FALSE, EVENT_NAME_THAW);
|
||||||
if (hEventThaw == INVALID_HANDLE_VALUE) {
|
if (!hEventThaw) {
|
||||||
CloseHandle(hEventFrozen);
|
CloseHandle(hEventFrozen);
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
}
|
}
|
||||||
|
|
||||||
hEventTimeout = OpenEvent(EVENT_ALL_ACCESS, FALSE, EVENT_NAME_TIMEOUT);
|
hEventTimeout = OpenEvent(EVENT_ALL_ACCESS, FALSE, EVENT_NAME_TIMEOUT);
|
||||||
if (hEventTimeout == INVALID_HANDLE_VALUE) {
|
if (!hEventTimeout) {
|
||||||
CloseHandle(hEventFrozen);
|
CloseHandle(hEventFrozen);
|
||||||
CloseHandle(hEventThaw);
|
CloseHandle(hEventThaw);
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
|
|
|
@ -50,10 +50,6 @@ static struct QGAVSSContext {
|
||||||
|
|
||||||
STDAPI requester_init(void)
|
STDAPI requester_init(void)
|
||||||
{
|
{
|
||||||
vss_ctx.hEventFrozen = INVALID_HANDLE_VALUE;
|
|
||||||
vss_ctx.hEventThaw = INVALID_HANDLE_VALUE;
|
|
||||||
vss_ctx.hEventTimeout = INVALID_HANDLE_VALUE;
|
|
||||||
|
|
||||||
COMInitializer initializer; /* to call CoInitializeSecurity */
|
COMInitializer initializer; /* to call CoInitializeSecurity */
|
||||||
HRESULT hr = CoInitializeSecurity(
|
HRESULT hr = CoInitializeSecurity(
|
||||||
NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_PKT_PRIVACY,
|
NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_PKT_PRIVACY,
|
||||||
|
@ -94,17 +90,17 @@ STDAPI requester_init(void)
|
||||||
|
|
||||||
static void requester_cleanup(void)
|
static void requester_cleanup(void)
|
||||||
{
|
{
|
||||||
if (vss_ctx.hEventFrozen != INVALID_HANDLE_VALUE) {
|
if (vss_ctx.hEventFrozen) {
|
||||||
CloseHandle(vss_ctx.hEventFrozen);
|
CloseHandle(vss_ctx.hEventFrozen);
|
||||||
vss_ctx.hEventFrozen = INVALID_HANDLE_VALUE;
|
vss_ctx.hEventFrozen = NULL;
|
||||||
}
|
}
|
||||||
if (vss_ctx.hEventThaw != INVALID_HANDLE_VALUE) {
|
if (vss_ctx.hEventThaw) {
|
||||||
CloseHandle(vss_ctx.hEventThaw);
|
CloseHandle(vss_ctx.hEventThaw);
|
||||||
vss_ctx.hEventThaw = INVALID_HANDLE_VALUE;
|
vss_ctx.hEventThaw = NULL;
|
||||||
}
|
}
|
||||||
if (vss_ctx.hEventTimeout != INVALID_HANDLE_VALUE) {
|
if (vss_ctx.hEventTimeout) {
|
||||||
CloseHandle(vss_ctx.hEventTimeout);
|
CloseHandle(vss_ctx.hEventTimeout);
|
||||||
vss_ctx.hEventTimeout = INVALID_HANDLE_VALUE;
|
vss_ctx.hEventTimeout = NULL;
|
||||||
}
|
}
|
||||||
if (vss_ctx.pAsyncSnapshot) {
|
if (vss_ctx.pAsyncSnapshot) {
|
||||||
vss_ctx.pAsyncSnapshot->Release();
|
vss_ctx.pAsyncSnapshot->Release();
|
||||||
|
@ -374,19 +370,19 @@ void requester_freeze(int *num_vols, ErrorSet *errset)
|
||||||
sa.bInheritHandle = FALSE;
|
sa.bInheritHandle = FALSE;
|
||||||
|
|
||||||
vss_ctx.hEventFrozen = CreateEvent(&sa, TRUE, FALSE, EVENT_NAME_FROZEN);
|
vss_ctx.hEventFrozen = CreateEvent(&sa, TRUE, FALSE, EVENT_NAME_FROZEN);
|
||||||
if (vss_ctx.hEventFrozen == INVALID_HANDLE_VALUE) {
|
if (!vss_ctx.hEventFrozen) {
|
||||||
err_set(errset, GetLastError(), "failed to create event %s",
|
err_set(errset, GetLastError(), "failed to create event %s",
|
||||||
EVENT_NAME_FROZEN);
|
EVENT_NAME_FROZEN);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
vss_ctx.hEventThaw = CreateEvent(&sa, TRUE, FALSE, EVENT_NAME_THAW);
|
vss_ctx.hEventThaw = CreateEvent(&sa, TRUE, FALSE, EVENT_NAME_THAW);
|
||||||
if (vss_ctx.hEventThaw == INVALID_HANDLE_VALUE) {
|
if (!vss_ctx.hEventThaw) {
|
||||||
err_set(errset, GetLastError(), "failed to create event %s",
|
err_set(errset, GetLastError(), "failed to create event %s",
|
||||||
EVENT_NAME_THAW);
|
EVENT_NAME_THAW);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
vss_ctx.hEventTimeout = CreateEvent(&sa, TRUE, FALSE, EVENT_NAME_TIMEOUT);
|
vss_ctx.hEventTimeout = CreateEvent(&sa, TRUE, FALSE, EVENT_NAME_TIMEOUT);
|
||||||
if (vss_ctx.hEventTimeout == INVALID_HANDLE_VALUE) {
|
if (!vss_ctx.hEventTimeout) {
|
||||||
err_set(errset, GetLastError(), "failed to create event %s",
|
err_set(errset, GetLastError(), "failed to create event %s",
|
||||||
EVENT_NAME_TIMEOUT);
|
EVENT_NAME_TIMEOUT);
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -443,7 +439,7 @@ void requester_thaw(int *num_vols, ErrorSet *errset)
|
||||||
{
|
{
|
||||||
COMPointer<IVssAsync> pAsync;
|
COMPointer<IVssAsync> pAsync;
|
||||||
|
|
||||||
if (vss_ctx.hEventThaw == INVALID_HANDLE_VALUE) {
|
if (!vss_ctx.hEventThaw) {
|
||||||
/*
|
/*
|
||||||
* In this case, DoSnapshotSet is aborted or not started,
|
* In this case, DoSnapshotSet is aborted or not started,
|
||||||
* and no volumes must be frozen. We return without an error.
|
* and no volumes must be frozen. We return without an error.
|
||||||
|
|
Loading…
Reference in New Issue