[ros-diffs] [weiden] 13421: only attach to the process to be
queried when necessary
weiden at svn.reactos.com
weiden at svn.reactos.com
Sat Feb 5 11:31:40 CET 2005
only attach to the process to be queried when necessary
Modified: trunk/reactos/ntoskrnl/ke/spinlock.c
Modified: trunk/reactos/ntoskrnl/ps/process.c
_____
Modified: trunk/reactos/ntoskrnl/ke/spinlock.c
--- trunk/reactos/ntoskrnl/ke/spinlock.c 2005-02-05 10:19:49 UTC
(rev 13420)
+++ trunk/reactos/ntoskrnl/ke/spinlock.c 2005-02-05 10:31:37 UTC
(rev 13421)
@@ -195,9 +195,7 @@
:
: "r" (SpinLock));
#else
- while (0 != *(volatile PKSPIN_LOCK)SpinLock)
- {
- }
+ while (0 != *(volatile KSPIN_LOCK*)SpinLock);
#endif
#else
DbgPrint("Spinning on spinlock %x current value %x\n", SpinLock,
i);
_____
Modified: trunk/reactos/ntoskrnl/ps/process.c
--- trunk/reactos/ntoskrnl/ps/process.c 2005-02-05 10:19:49 UTC (rev
13420)
+++ trunk/reactos/ntoskrnl/ps/process.c 2005-02-05 10:31:37 UTC (rev
13421)
@@ -1613,11 +1613,15 @@
{
PRTL_USER_PROCESS_PARAMETERS ProcParams = NULL;
UNICODE_STRING LocalDest;
+ BOOLEAN Attached;
ULONG ImagePathLen = 0;
PUNICODE_STRING DstPath =
(PUNICODE_STRING)ProcessInformation;
/* we need to attach to the process to make sure we're in the
right context! */
- KeAttachProcess(&Process->Pcb);
+ Attached = Process != PsGetCurrentProcess();
+
+ if(Attached)
+ KeAttachProcess(&Process->Pcb);
_SEH_TRY
{
@@ -1677,7 +1681,8 @@
_SEH_END;
/* detach from the process */
- KeDetachProcess();
+ if(Attached)
+ KeDetachProcess();
/* only copy the string back to the caller if we were
able to
copy it into the temporary buffer! */
@@ -1715,7 +1720,8 @@
}
/* don't forget to detach from the process!!! */
- KeDetachProcess();
+ if(Attached)
+ KeDetachProcess();
}
else
{
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://www.reactos.org/pipermail/ros-diffs/attachments/20050205/c41cd4e8/attachment.html
More information about the Ros-diffs
mailing list