mirror of
https://github.com/reactos/reactos.git
synced 2025-01-05 13:59:25 +00:00
[ADVAPI32] SEH-protext the calls to service control handlers
ScControlService: - SEH-protext the calls to service control handlers. - Return ERROR_EXCEPTION_IN_SERVICE if a service control handler throws an exception. - Return ERROR_SERVICE_CANNOT_ACCEPT_CTRL if no service control handler has been registered for the service.
This commit is contained in:
parent
62a90470f8
commit
db60cd219c
1 changed files with 26 additions and 8 deletions
|
@ -517,7 +517,7 @@ static DWORD
|
||||||
ScControlService(PACTIVE_SERVICE lpService,
|
ScControlService(PACTIVE_SERVICE lpService,
|
||||||
PSCM_CONTROL_PACKET ControlPacket)
|
PSCM_CONTROL_PACKET ControlPacket)
|
||||||
{
|
{
|
||||||
DWORD dwError;
|
DWORD dwError = ERROR_SUCCESS;
|
||||||
|
|
||||||
TRACE("ScControlService(%p %p)\n",
|
TRACE("ScControlService(%p %p)\n",
|
||||||
lpService, ControlPacket);
|
lpService, ControlPacket);
|
||||||
|
@ -529,17 +529,35 @@ ScControlService(PACTIVE_SERVICE lpService,
|
||||||
TRACE("Service: %S\n", (PWSTR)((ULONG_PTR)ControlPacket + ControlPacket->dwServiceNameOffset));
|
TRACE("Service: %S\n", (PWSTR)((ULONG_PTR)ControlPacket + ControlPacket->dwServiceNameOffset));
|
||||||
|
|
||||||
if (lpService->HandlerFunction)
|
if (lpService->HandlerFunction)
|
||||||
|
{
|
||||||
|
_SEH2_TRY
|
||||||
{
|
{
|
||||||
(lpService->HandlerFunction)(ControlPacket->dwControl);
|
(lpService->HandlerFunction)(ControlPacket->dwControl);
|
||||||
dwError = ERROR_SUCCESS;
|
}
|
||||||
|
_SEH2_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
|
||||||
|
{
|
||||||
|
dwError = ERROR_EXCEPTION_IN_SERVICE;
|
||||||
|
}
|
||||||
|
_SEH2_END;
|
||||||
}
|
}
|
||||||
else if (lpService->HandlerFunctionEx)
|
else if (lpService->HandlerFunctionEx)
|
||||||
|
{
|
||||||
|
_SEH2_TRY
|
||||||
{
|
{
|
||||||
/* FIXME: Send correct 2nd and 3rd parameters */
|
/* FIXME: Send correct 2nd and 3rd parameters */
|
||||||
(lpService->HandlerFunctionEx)(ControlPacket->dwControl,
|
(lpService->HandlerFunctionEx)(ControlPacket->dwControl,
|
||||||
0, NULL,
|
0, NULL,
|
||||||
lpService->HandlerContext);
|
lpService->HandlerContext);
|
||||||
dwError = ERROR_SUCCESS;
|
}
|
||||||
|
_SEH2_EXCEPT(EXCEPTION_EXECUTE_HANDLER)
|
||||||
|
{
|
||||||
|
dwError = ERROR_EXCEPTION_IN_SERVICE;
|
||||||
|
}
|
||||||
|
_SEH2_END;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dwError = ERROR_SERVICE_CANNOT_ACCEPT_CTRL;
|
||||||
}
|
}
|
||||||
|
|
||||||
TRACE("ScControlService() done (Error %lu)\n", dwError);
|
TRACE("ScControlService() done (Error %lu)\n", dwError);
|
||||||
|
|
Loading…
Reference in a new issue