[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:
Eric Kohl 2018-05-02 23:24:26 +02:00
parent 62a90470f8
commit db60cd219c

View file

@ -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);