mirror of
https://github.com/reactos/reactos.git
synced 2024-12-28 18:15:11 +00:00
Open named pipe to SCM
svn path=/trunk/; revision=2310
This commit is contained in:
parent
f611cbbe42
commit
75ebd197fa
4 changed files with 354 additions and 176 deletions
|
@ -1,4 +1,4 @@
|
||||||
# $Id: makefile,v 1.19 2001/08/21 20:13:05 chorns Exp $
|
# $Id: makefile,v 1.20 2001/10/21 19:06:42 chorns Exp $
|
||||||
|
|
||||||
PATH_TO_TOP = ../..
|
PATH_TO_TOP = ../..
|
||||||
|
|
||||||
|
@ -8,6 +8,8 @@ TARGET_NAME = advapi32
|
||||||
|
|
||||||
TARGET_SDKLIBS = ntdll.a kernel32.a
|
TARGET_SDKLIBS = ntdll.a kernel32.a
|
||||||
|
|
||||||
|
# TARGET_CFLAGS = -DUNICODE
|
||||||
|
|
||||||
TARGET_BASE = 0x77dc0000
|
TARGET_BASE = 0x77dc0000
|
||||||
|
|
||||||
MISC_OBJECTS=\
|
MISC_OBJECTS=\
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: scm.c,v 1.7 2001/06/25 14:19:56 ekohl Exp $
|
/* $Id: scm.c,v 1.8 2001/10/21 19:06:42 chorns Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS system libraries
|
* PROJECT: ReactOS system libraries
|
||||||
|
@ -100,18 +100,18 @@ SC_HANDLE
|
||||||
STDCALL
|
STDCALL
|
||||||
CreateServiceA(
|
CreateServiceA(
|
||||||
SC_HANDLE hSCManager,
|
SC_HANDLE hSCManager,
|
||||||
LPCTSTR lpServiceName,
|
LPCSTR lpServiceName,
|
||||||
LPCTSTR lpDisplayName,
|
LPCSTR lpDisplayName,
|
||||||
DWORD dwDesiredAccess,
|
DWORD dwDesiredAccess,
|
||||||
DWORD dwServiceType,
|
DWORD dwServiceType,
|
||||||
DWORD dwStartType,
|
DWORD dwStartType,
|
||||||
DWORD dwErrorControl,
|
DWORD dwErrorControl,
|
||||||
LPCTSTR lpBinaryPathName,
|
LPCSTR lpBinaryPathName,
|
||||||
LPCTSTR lpLoadOrderGroup,
|
LPCSTR lpLoadOrderGroup,
|
||||||
LPDWORD lpdwTagId,
|
LPDWORD lpdwTagId,
|
||||||
LPCTSTR lpDependencies,
|
LPCSTR lpDependencies,
|
||||||
LPCTSTR lpServiceStartName,
|
LPCSTR lpServiceStartName,
|
||||||
LPCTSTR lpPassword
|
LPCSTR lpPassword
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
||||||
|
@ -410,33 +410,110 @@ SC_HANDLE STDCALL OpenSCManagerW(LPCWSTR lpMachineName,
|
||||||
LPCWSTR lpDatabaseName,
|
LPCWSTR lpDatabaseName,
|
||||||
DWORD dwDesiredAccess)
|
DWORD dwDesiredAccess)
|
||||||
{
|
{
|
||||||
HANDLE h;
|
HANDLE hPipe;
|
||||||
|
DWORD dwMode;
|
||||||
|
BOOL fSuccess;
|
||||||
|
LPWSTR lpszPipeName = L"\\\\.\\pipe\\Ntsvcs";
|
||||||
|
|
||||||
if (lpMachineName == NULL ||
|
if (lpMachineName == NULL || wcslen(lpMachineName) == 0)
|
||||||
wcslen(lpMachineName) == 0)
|
|
||||||
{
|
{
|
||||||
if (lpDatabaseName != NULL &&
|
if (lpDatabaseName != NULL && wcscmp(lpDatabaseName, SERVICES_ACTIVE_DATABASEW) != 0)
|
||||||
wcscmp(lpDatabaseName, SERVICES_ACTIVE_DATABASEW) != 0)
|
|
||||||
{
|
{
|
||||||
return(NULL);
|
return(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
h = CreateFileW(L"\\\\.\\pipe\\ntsrvctrl",
|
// Try to open a named pipe; wait for it, if necessary
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
hPipe = CreateFileW(
|
||||||
|
lpszPipeName, // pipe name
|
||||||
dwDesiredAccess,
|
dwDesiredAccess,
|
||||||
0,
|
0, // no sharing
|
||||||
NULL,
|
NULL, // no security attributes
|
||||||
OPEN_EXISTING,
|
OPEN_EXISTING, // opens existing pipe
|
||||||
0,
|
0, // default attributes
|
||||||
NULL);
|
NULL); // no template file
|
||||||
if (h == INVALID_HANDLE_VALUE)
|
|
||||||
|
// Break if the pipe handle is valid
|
||||||
|
|
||||||
|
if (hPipe != INVALID_HANDLE_VALUE)
|
||||||
|
break;
|
||||||
|
|
||||||
|
// Exit if an error other than ERROR_PIPE_BUSY occurs
|
||||||
|
|
||||||
|
if (GetLastError() != ERROR_PIPE_BUSY)
|
||||||
{
|
{
|
||||||
return(NULL);
|
return(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
return(h);
|
// All pipe instances are busy, so wait for 20 seconds
|
||||||
|
|
||||||
|
if (!WaitNamedPipeW(lpszPipeName, 20000))
|
||||||
|
{
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// The pipe connected; change to message-read mode
|
||||||
|
|
||||||
|
dwMode = PIPE_READMODE_MESSAGE;
|
||||||
|
fSuccess = SetNamedPipeHandleState(
|
||||||
|
hPipe, // pipe handle
|
||||||
|
&dwMode, // new pipe mode
|
||||||
|
NULL, // don't set maximum bytes
|
||||||
|
NULL); // don't set maximum time
|
||||||
|
if (!fSuccess)
|
||||||
|
{
|
||||||
|
CloseHandle(hPipe);
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
#if 0
|
||||||
|
// Send a message to the pipe server
|
||||||
|
|
||||||
|
lpvMessage = (argc > 1) ? argv[1] : "default message";
|
||||||
|
|
||||||
|
fSuccess = WriteFile(
|
||||||
|
hPipe, // pipe handle
|
||||||
|
lpvMessage, // message
|
||||||
|
strlen(lpvMessage) + 1, // message length
|
||||||
|
&cbWritten, // bytes written
|
||||||
|
NULL); // not overlapped
|
||||||
|
if (!fSuccess)
|
||||||
|
{
|
||||||
|
CloseHandle(hPipe);
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
// Read from the pipe
|
||||||
|
|
||||||
|
fSuccess = ReadFile(
|
||||||
|
hPipe, // pipe handle
|
||||||
|
chBuf, // buffer to receive reply
|
||||||
|
512, // size of buffer
|
||||||
|
&cbRead, // number of bytes read
|
||||||
|
NULL); // not overlapped
|
||||||
|
|
||||||
|
if (! fSuccess && GetLastError() != ERROR_MORE_DATA)
|
||||||
|
break;
|
||||||
|
|
||||||
|
// Reply from the pipe is written to STDOUT.
|
||||||
|
|
||||||
|
if (!WriteFile(GetStdHandle(STD_OUTPUT_HANDLE),
|
||||||
|
chBuf, cbRead, &cbWritten, NULL))
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
} while (!fSuccess); // repeat loop if ERROR_MORE_DATA
|
||||||
|
//CloseHandle(hPipe);
|
||||||
|
#endif
|
||||||
|
return(hPipe);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
/* FIXME: Connect to remote SCM */
|
||||||
return(NULL);
|
return(NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: sctrl.c,v 1.2 2001/06/25 14:19:56 ekohl Exp $
|
/* $Id: sctrl.c,v 1.3 2001/10/21 19:06:42 chorns Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS system libraries
|
* PROJECT: ReactOS system libraries
|
||||||
|
@ -20,6 +20,9 @@
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
DWORD ThreadId;
|
DWORD ThreadId;
|
||||||
|
UNICODE_STRING ServiceName;
|
||||||
|
SERVICE_STATUS ServiceStatus;
|
||||||
|
LPHANDLER_FUNCTION Handler;
|
||||||
} ACTIVE_SERVICE, *PACTIVE_SERVICE;
|
} ACTIVE_SERVICE, *PACTIVE_SERVICE;
|
||||||
|
|
||||||
/* GLOBALS *******************************************************************/
|
/* GLOBALS *******************************************************************/
|
||||||
|
@ -30,6 +33,39 @@ static PHANDLE ActiveServicesThreadHandles;
|
||||||
|
|
||||||
/* FUNCTIONS *****************************************************************/
|
/* FUNCTIONS *****************************************************************/
|
||||||
|
|
||||||
|
PACTIVE_SERVICE
|
||||||
|
ScLookupServiceByThreadId(
|
||||||
|
DWORD ThreadId)
|
||||||
|
{
|
||||||
|
DWORD i;
|
||||||
|
|
||||||
|
for (i = 0; i < ActiveServiceCount; i++)
|
||||||
|
{
|
||||||
|
if (ActiveServices[i].ThreadId == ThreadId)
|
||||||
|
{
|
||||||
|
return &ActiveServices[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
DWORD
|
||||||
|
WINAPI
|
||||||
|
ScServiceMainStub(
|
||||||
|
LPVOID Context)
|
||||||
|
{
|
||||||
|
LPSERVICE_MAIN_FUNCTION lpServiceProc = (LPSERVICE_MAIN_FUNCTION)Context;
|
||||||
|
|
||||||
|
/* FIXME: Send argc and argv (from command line) as arguments */
|
||||||
|
|
||||||
|
(lpServiceProc)(0, NULL);
|
||||||
|
|
||||||
|
return ERROR_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**********************************************************************
|
/**********************************************************************
|
||||||
* RegisterServiceCtrlHandlerA
|
* RegisterServiceCtrlHandlerA
|
||||||
*/
|
*/
|
||||||
|
@ -43,12 +79,16 @@ SERVICE_STATUS_HANDLE STDCALL RegisterServiceCtrlHandlerA(
|
||||||
SERVICE_STATUS_HANDLE SHandle;
|
SERVICE_STATUS_HANDLE SHandle;
|
||||||
|
|
||||||
RtlInitAnsiString(&ServiceNameA, (LPSTR)lpServiceName);
|
RtlInitAnsiString(&ServiceNameA, (LPSTR)lpServiceName);
|
||||||
RtlAnsiStringToUnicodeString(&ServiceNameU, &ServiceNameA, TRUE);
|
if (!NT_SUCCESS(RtlAnsiStringToUnicodeString(&ServiceNameU, &ServiceNameA, TRUE)))
|
||||||
|
{
|
||||||
|
SetLastError(ERROR_OUTOFMEMORY);
|
||||||
|
return (SERVICE_STATUS_HANDLE)0;
|
||||||
|
}
|
||||||
|
|
||||||
SHandle = RegisterServiceCtrlHandlerW(ServiceNameU.Buffer,
|
SHandle = RegisterServiceCtrlHandlerW(ServiceNameU.Buffer,
|
||||||
lpHandlerProc);
|
lpHandlerProc);
|
||||||
|
|
||||||
RtlFreeHeap(RtlGetProcessHeap(), 0, ServiceNameU.Buffer);
|
RtlFreeUnicodeString(&ServiceNameU);
|
||||||
|
|
||||||
return(SHandle);
|
return(SHandle);
|
||||||
}
|
}
|
||||||
|
@ -61,8 +101,15 @@ SERVICE_STATUS_HANDLE STDCALL RegisterServiceCtrlHandlerW(
|
||||||
LPCWSTR lpServiceName,
|
LPCWSTR lpServiceName,
|
||||||
LPHANDLER_FUNCTION lpHandlerProc)
|
LPHANDLER_FUNCTION lpHandlerProc)
|
||||||
{
|
{
|
||||||
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
PACTIVE_SERVICE Service;
|
||||||
return 0;
|
|
||||||
|
/* FIXME: Locate active service entry from name */
|
||||||
|
|
||||||
|
Service = &ActiveServices[0];
|
||||||
|
|
||||||
|
Service->Handler = lpHandlerProc;
|
||||||
|
|
||||||
|
return (SERVICE_STATUS_HANDLE)Service->ThreadId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -102,13 +149,25 @@ BOOL
|
||||||
STDCALL
|
STDCALL
|
||||||
SetServiceStatus(
|
SetServiceStatus(
|
||||||
SERVICE_STATUS_HANDLE hServiceStatus,
|
SERVICE_STATUS_HANDLE hServiceStatus,
|
||||||
LPSERVICE_STATUS lpServiceStatus
|
LPSERVICE_STATUS lpServiceStatus)
|
||||||
)
|
|
||||||
{
|
{
|
||||||
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
PACTIVE_SERVICE Service;
|
||||||
|
|
||||||
|
Service = ScLookupServiceByThreadId((DWORD)hServiceStatus);
|
||||||
|
if (!Service)
|
||||||
|
{
|
||||||
|
SetLastError(ERROR_INVALID_HANDLE);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RtlCopyMemory(
|
||||||
|
&Service->ServiceStatus,
|
||||||
|
lpServiceStatus,
|
||||||
|
sizeof(SERVICE_STATUS));
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
/**********************************************************************
|
/**********************************************************************
|
||||||
* StartServiceCtrlDispatcherA
|
* StartServiceCtrlDispatcherA
|
||||||
*/
|
*/
|
||||||
|
@ -118,7 +177,7 @@ BOOL STDCALL StartServiceCtrlDispatcherA(
|
||||||
LPSERVICE_TABLE_ENTRYW ServiceStartTableW;
|
LPSERVICE_TABLE_ENTRYW ServiceStartTableW;
|
||||||
ANSI_STRING ServiceNameA;
|
ANSI_STRING ServiceNameA;
|
||||||
UNICODE_STRING ServiceNameW;
|
UNICODE_STRING ServiceNameW;
|
||||||
ULONG i;
|
ULONG i, j;
|
||||||
ULONG Count;
|
ULONG Count;
|
||||||
BOOL b;
|
BOOL b;
|
||||||
|
|
||||||
|
@ -129,16 +188,31 @@ BOOL STDCALL StartServiceCtrlDispatcherA(
|
||||||
}
|
}
|
||||||
Count = i;
|
Count = i;
|
||||||
|
|
||||||
ServiceStartTableW = RtlAllocateHeap(RtlGetProcessHeap(),
|
ServiceStartTableW = RtlAllocateHeap(
|
||||||
|
RtlGetProcessHeap(),
|
||||||
HEAP_ZERO_MEMORY,
|
HEAP_ZERO_MEMORY,
|
||||||
sizeof(SERVICE_TABLE_ENTRYW) * Count);
|
sizeof(SERVICE_TABLE_ENTRYW) * Count);
|
||||||
for (i = 0; i < Count; i++)
|
for (i = 0; i < Count; i++)
|
||||||
{
|
{
|
||||||
RtlInitAnsiString(&ServiceNameA,
|
RtlInitAnsiString(
|
||||||
lpServiceStartTable[i].lpServiceName);
|
|
||||||
RtlAnsiStringToUnicodeString(&ServiceNameW,
|
|
||||||
&ServiceNameA,
|
&ServiceNameA,
|
||||||
TRUE);
|
lpServiceStartTable[i].lpServiceName);
|
||||||
|
if (!NT_SUCCESS(RtlAnsiStringToUnicodeString(
|
||||||
|
&ServiceNameW,
|
||||||
|
&ServiceNameA,
|
||||||
|
TRUE)))
|
||||||
|
{
|
||||||
|
for (j = 0; j < i; j++)
|
||||||
|
{
|
||||||
|
RtlInitUnicodeString(
|
||||||
|
&ServiceNameW,
|
||||||
|
ServiceStartTableW[j].lpServiceName);
|
||||||
|
RtlFreeUnicodeString(&ServiceNameW);
|
||||||
|
}
|
||||||
|
RtlFreeHeap(RtlGetProcessHeap(), 0, ServiceStartTableW);
|
||||||
|
SetLastError(ERROR_OUTOFMEMORY);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
ServiceStartTableW[i].lpServiceName = ServiceNameW.Buffer;
|
ServiceStartTableW[i].lpServiceName = ServiceNameW.Buffer;
|
||||||
ServiceStartTableW[i].lpServiceProc =
|
ServiceStartTableW[i].lpServiceProc =
|
||||||
lpServiceStartTable[i].lpServiceProc;
|
lpServiceStartTable[i].lpServiceProc;
|
||||||
|
@ -148,15 +222,12 @@ BOOL STDCALL StartServiceCtrlDispatcherA(
|
||||||
|
|
||||||
for (i = 0; i < Count; i++)
|
for (i = 0; i < Count; i++)
|
||||||
{
|
{
|
||||||
RtlFreeHeap(RtlGetProcessHeap(),
|
RtlFreeHeap(RtlGetProcessHeap(), 0, ServiceStartTableW[i].lpServiceName);
|
||||||
0,
|
|
||||||
ServiceStartTableW[i].lpServiceName);
|
|
||||||
}
|
}
|
||||||
RtlFreeHeap(RtlGetProcessHeap(),
|
|
||||||
0,
|
|
||||||
ServiceStartTableW);
|
|
||||||
|
|
||||||
return(b);
|
RtlFreeHeap(RtlGetProcessHeap(), 0, ServiceStartTableW);
|
||||||
|
|
||||||
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -178,25 +249,43 @@ BOOL STDCALL StartServiceCtrlDispatcherW(
|
||||||
}
|
}
|
||||||
|
|
||||||
ActiveServiceCount = i;
|
ActiveServiceCount = i;
|
||||||
ActiveServices = RtlAllocateHeap(GetProcessHeap(),
|
ActiveServices = RtlAllocateHeap(
|
||||||
|
RtlGetProcessHeap(),
|
||||||
HEAP_ZERO_MEMORY,
|
HEAP_ZERO_MEMORY,
|
||||||
ActiveServiceCount *
|
ActiveServiceCount *
|
||||||
sizeof(ACTIVE_SERVICE));
|
sizeof(ACTIVE_SERVICE));
|
||||||
ActiveServicesThreadHandles = RtlAllocateHeap(GetProcessHeap(),
|
if (!ActiveServices)
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
ActiveServicesThreadHandles = RtlAllocateHeap(
|
||||||
|
RtlGetProcessHeap(),
|
||||||
HEAP_ZERO_MEMORY,
|
HEAP_ZERO_MEMORY,
|
||||||
(ActiveServiceCount + 1) *
|
(ActiveServiceCount + 1) *
|
||||||
sizeof(HANDLE));
|
sizeof(HANDLE));
|
||||||
|
if (!ActiveServicesThreadHandles)
|
||||||
|
{
|
||||||
|
RtlFreeHeap(RtlGetProcessHeap(), 0, ActiveServices);
|
||||||
|
ActiveServices = NULL;
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i<ActiveServiceCount; i++)
|
for (i = 0; i<ActiveServiceCount; i++)
|
||||||
{
|
{
|
||||||
h = CreateThread(NULL,
|
h = CreateThread(
|
||||||
0,
|
|
||||||
(LPTHREAD_START_ROUTINE)lpServiceStartTable[i].lpServiceProc,
|
|
||||||
NULL,
|
NULL,
|
||||||
|
0,
|
||||||
|
ScServiceMainStub,
|
||||||
|
lpServiceStartTable[i].lpServiceProc,
|
||||||
0,
|
0,
|
||||||
&Tid);
|
&Tid);
|
||||||
if (h == INVALID_HANDLE_VALUE)
|
if (h == INVALID_HANDLE_VALUE)
|
||||||
{
|
{
|
||||||
|
RtlFreeHeap(RtlGetProcessHeap(), 0, ActiveServicesThreadHandles);
|
||||||
|
ActiveServicesThreadHandles = NULL;
|
||||||
|
RtlFreeHeap(RtlGetProcessHeap(), 0, ActiveServices);
|
||||||
|
ActiveServices = NULL;
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
}
|
}
|
||||||
ActiveServicesThreadHandles[i + 1] = h;
|
ActiveServicesThreadHandles[i + 1] = h;
|
||||||
|
@ -205,7 +294,8 @@ BOOL STDCALL StartServiceCtrlDispatcherW(
|
||||||
|
|
||||||
while (ActiveServiceCount > 0)
|
while (ActiveServiceCount > 0)
|
||||||
{
|
{
|
||||||
r = WaitForMultipleObjects(ActiveServiceCount + 1,
|
r = WaitForMultipleObjects(
|
||||||
|
ActiveServiceCount + 1,
|
||||||
ActiveServicesThreadHandles,
|
ActiveServicesThreadHandles,
|
||||||
FALSE,
|
FALSE,
|
||||||
INFINITE);
|
INFINITE);
|
||||||
|
@ -213,15 +303,15 @@ BOOL STDCALL StartServiceCtrlDispatcherW(
|
||||||
{
|
{
|
||||||
/* Received message from the scm */
|
/* Received message from the scm */
|
||||||
}
|
}
|
||||||
else if (r > WAIT_OBJECT_0 &&
|
else if (r > WAIT_OBJECT_0 && r < (WAIT_OBJECT_0 + ActiveServiceCount))
|
||||||
r < (WAIT_OBJECT_0 + ActiveServiceCount))
|
|
||||||
{
|
{
|
||||||
/* A service died */
|
/* A service died */
|
||||||
|
|
||||||
ActiveServiceCount--;
|
ActiveServiceCount--;
|
||||||
ActiveServicesThreadHandles[r - WAIT_OBJECT_0 - 1] =
|
ActiveServicesThreadHandles[r - WAIT_OBJECT_0 - 1] =
|
||||||
ActiveServicesThreadHandles[ActiveServiceCount + 1];
|
ActiveServicesThreadHandles[ActiveServiceCount + 1];
|
||||||
memcpy(&ActiveServices[r - WAIT_OBJECT_0 - 2],
|
RtlCopyMemory(
|
||||||
|
&ActiveServices[r - WAIT_OBJECT_0 - 2],
|
||||||
&ActiveServices[ActiveServiceCount],
|
&ActiveServices[ActiveServiceCount],
|
||||||
sizeof(ACTIVE_SERVICE));
|
sizeof(ACTIVE_SERVICE));
|
||||||
}
|
}
|
||||||
|
@ -230,7 +320,7 @@ BOOL STDCALL StartServiceCtrlDispatcherW(
|
||||||
/* Bail */
|
/* Bail */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return(TRUE);
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $Id: npipe.c,v 1.7 2001/10/20 15:28:03 ekohl Exp $
|
/* $Id: npipe.c,v 1.8 2001/10/21 19:06:42 chorns Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS system libraries
|
* PROJECT: ReactOS system libraries
|
||||||
|
@ -346,23 +346,27 @@ SetNamedPipeHandleState(HANDLE hNamedPipe,
|
||||||
IO_STATUS_BLOCK Iosb;
|
IO_STATUS_BLOCK Iosb;
|
||||||
NTSTATUS Status;
|
NTSTATUS Status;
|
||||||
|
|
||||||
#if 0
|
|
||||||
Status = NtFsControlFile(hNamedPipe,
|
Status = NtFsControlFile(hNamedPipe,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
&Iosb,
|
&Iosb,
|
||||||
FSCTL_GET_STATE,
|
FSCTL_PIPE_GET_STATE,
|
||||||
NULL,
|
NULL,
|
||||||
0,
|
0,
|
||||||
&GetState,
|
&GetState,
|
||||||
sizeof(GetState));
|
sizeof(NPFS_GET_STATE));
|
||||||
|
if (Status == STATUS_PENDING)
|
||||||
|
{
|
||||||
|
Status = NtWaitForSingleObject(hNamedPipe,
|
||||||
|
FALSE,
|
||||||
|
NULL);
|
||||||
if (!NT_SUCCESS(Status))
|
if (!NT_SUCCESS(Status))
|
||||||
{
|
{
|
||||||
SetLastErrorByStatus(Status);
|
SetLastErrorByStatus(Status);
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
}
|
}
|
||||||
#endif
|
}
|
||||||
|
|
||||||
if (lpMode != NULL)
|
if (lpMode != NULL)
|
||||||
{
|
{
|
||||||
|
@ -411,23 +415,28 @@ SetNamedPipeHandleState(HANDLE hNamedPipe,
|
||||||
SetState.Timeout = GetState.Timeout;
|
SetState.Timeout = GetState.Timeout;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
|
||||||
Status = NtFsControlFile(hNamedPipe,
|
Status = NtFsControlFile(hNamedPipe,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
&Iosb,
|
&Iosb,
|
||||||
FSCTL_SET_STATE,
|
FSCTL_PIPE_SET_STATE,
|
||||||
&SetState,
|
&SetState,
|
||||||
sizeof(SetState),
|
sizeof(NPFS_SET_STATE),
|
||||||
NULL,
|
NULL,
|
||||||
0);
|
0);
|
||||||
|
if (Status == STATUS_PENDING)
|
||||||
|
{
|
||||||
|
Status = NtWaitForSingleObject(hNamedPipe,
|
||||||
|
FALSE,
|
||||||
|
NULL);
|
||||||
if (!NT_SUCCESS(Status))
|
if (!NT_SUCCESS(Status))
|
||||||
{
|
{
|
||||||
SetLastErrorByStatus(Status);
|
SetLastErrorByStatus(Status);
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
}
|
}
|
||||||
#endif
|
}
|
||||||
|
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue