mirror of
https://github.com/reactos/reactos.git
synced 2025-04-20 04:20:46 +00:00
don't attempt to reference NULL objects in NtIsProcessInJob()
svn path=/trunk/; revision=11019
This commit is contained in:
parent
b50f152bc1
commit
5b552386bc
1 changed files with 37 additions and 34 deletions
|
@ -121,10 +121,12 @@ NtIsProcessInJob(IN HANDLE ProcessHandle,
|
|||
if(NT_SUCCESS(Status))
|
||||
{
|
||||
/* FIXME - make sure the job object doesn't get exchanged or deleted while trying to
|
||||
reference it, e.g. by locking it somehow... */
|
||||
reference it, e.g. by locking it somehow until it is referenced... */
|
||||
|
||||
PEJOB ProcessJob = Process->Job;
|
||||
|
||||
if(ProcessJob != NULL)
|
||||
{
|
||||
/* reference the object without caring about access rights as it does not necessarily
|
||||
have to be accessible from the calling process */
|
||||
Status = ObReferenceObjectByPointer(ProcessJob,
|
||||
|
@ -136,9 +138,9 @@ NtIsProcessInJob(IN HANDLE ProcessHandle,
|
|||
if(JobHandle == NULL)
|
||||
{
|
||||
/* simply test whether the process is assigned to a job */
|
||||
Status = ((Process->Job != NULL) ? STATUS_PROCESS_IN_JOB : STATUS_PROCESS_NOT_IN_JOB);
|
||||
Status = ((ProcessJob != NULL) ? STATUS_PROCESS_IN_JOB : STATUS_PROCESS_NOT_IN_JOB);
|
||||
}
|
||||
else if(ProcessJob != NULL)
|
||||
else /* JobHandle != NULL */
|
||||
{
|
||||
PEJOB JobObject;
|
||||
|
||||
|
@ -155,14 +157,15 @@ NtIsProcessInJob(IN HANDLE ProcessHandle,
|
|||
ObDereferenceObject(JobObject);
|
||||
}
|
||||
}
|
||||
|
||||
ObDereferenceObject(ProcessJob);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
/* the process is not assigned to any job */
|
||||
Status = STATUS_PROCESS_NOT_IN_JOB;
|
||||
}
|
||||
|
||||
ObDereferenceObject(ProcessJob);
|
||||
}
|
||||
ObDereferenceObject(Process);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue