mirror of
https://github.com/reactos/reactos.git
synced 2024-12-26 00:54:40 +00:00
[NTOS:LPC] Fix input parameter for ProbeAndCaptureUnicodeString (#5815)
Addendum to commit b3c55b9e6
(PR #4399).
Passing &CapturedObjectName as pointer to be probed and captured would
fail if e.g. PreviousMode == UserMode, since that pointer is always in
kernel space. Instead, pass the original user-mode pointer.
Bug caught by Timo Kreuzer ;)
This commit is contained in:
parent
5b54477d47
commit
501c2bdd63
1 changed files with 4 additions and 3 deletions
|
@ -83,8 +83,9 @@ LpcpCreatePort(OUT PHANDLE PortHandle,
|
|||
}
|
||||
else
|
||||
{
|
||||
if (ObjectAttributes->ObjectName)
|
||||
CapturedObjectName = *(ObjectAttributes->ObjectName);
|
||||
ObjectName = ObjectAttributes->ObjectName;
|
||||
if (ObjectName)
|
||||
CapturedObjectName = *ObjectName;
|
||||
}
|
||||
|
||||
/* Normalize the buffer pointer in case we don't have
|
||||
|
@ -96,7 +97,7 @@ LpcpCreatePort(OUT PHANDLE PortHandle,
|
|||
/* Capture the port name for DPRINT only - ObCreateObject does its
|
||||
* own capture. As it is used only for debugging, ignore any failure;
|
||||
* the string is zeroed out in such case. */
|
||||
ProbeAndCaptureUnicodeString(&CapturedPortName, PreviousMode, &CapturedObjectName);
|
||||
ProbeAndCaptureUnicodeString(&CapturedPortName, PreviousMode, ObjectName);
|
||||
LPCTRACE(LPC_CREATE_DEBUG, "Name: %wZ\n", &CapturedPortName);
|
||||
ReleaseCapturedUnicodeString(&CapturedPortName, PreviousMode);
|
||||
#endif
|
||||
|
|
Loading…
Reference in a new issue