Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

103 lines
3.2 KiB

Can we provide (in the NSP timeframe) a generic URI-based IPC mechanism for
NT5 (and, in future releases, NT4 & Win9x)? More importantly, can this
mechanism be leveraged by UL?
The goal here is to totally separate the "listening" and "dispatching"
functionality. We'll provide a general IPC mechanism that everyone can
use. It just so happens that three of the customers will be a) the listener,
b) the worker processes, and c) the WAS.
Consider a completely stateless IPC mechanism based on only three APIs:
ULONG
RegisterUri(
OUT PHANDLE UriHandle,
IN HANDLE ParentUri OPTIONAL,
IN PWSTR pUri,
IN ULONG Flags
);
ULONG
SendMessage(
IN HANDLE UriHandle,
IN PWSTR pSourceSuffix OPTIONAL,
IN PWSTR pTargetUri,
IN PVOID pData,
IN ULONG DataLength,
OUT PULONG pBytesSent OPTIONAL,
IN LPOVERLAPPED pOverlapped OPTIONAL
);
typedef struct _MESSAGE
{
ULONG SourceUriLength;
ULONG TargetUriLength;
ULONG DataLength;
ULONG Reserved;
// WCHAR SourceUri[SourceUriLength];
// WCHAR TargetUri[TargetUriLength];
// UCHAR Alignment[varies];
// UCHAR Data[DataLength];
} MESSAGE, *PMESSAGE;
ULONG
ReceiveMessage(
IN HANDLE UriHandle,
OUT PMESSAGE pMessageBuffer,
IN ULONG MessageBufferLength,
OUT PULONG pBytesReceived OPTIONAL,
IN LPOVERLAPPED pOverlapped OPTIONAL
);
A request/response API can be built on top of these three primitives:
1. Process 1: Creates new GUID -> GUID1
2. Process 1: Registers "ipc:/GUID1" -> REG1
3. Process 2: Registers "http://foo" -> REG2
4. Process 2: Posts ReceiveMessage( REG2 )
5. Process 1: Creates request ID (another GUID?) -> RID1
6. Process 1: SendMessage(
REG1,
"RID1",
"http://foo/bar/xyz.htm",
{request_blob}
);
7. Process 1: Posts ReceiveMessage( REG1 )
8. Process 2: ReceiveMessage() completes with
SourceUri = "ipc:/GUID1/RID1"
TargetUri = "http://foo/bar/xyz.htm"
Data = {request_blob}
9. Process 2: SendMessage(
REG2,
"bar/xyz.htm", <- URI "stem"
"ipc:/GUID1/RID1", <- old source URI
{response_blob}
);
10. Process 1: ReceiveMessage() completes with
SourceUri = "http://foo/bar/xyz.htm"
TargetUri = "ipc:/GUID1/RID1"
Data = {response_blob}
08/23/1999 I don't think this totally stateless idea is going to work.
Well, it *could* work, but it places way to much burden on the
client & server writers to properly manage concepts like
keep-alive and dead peer detection. I'm now thinking we should
go to more of a handle-based mechanism with a sockets-like
flavor.