summaryrefslogtreecommitdiff
path: root/proc
diff options
context:
space:
mode:
Diffstat (limited to 'proc')
-rw-r--r--proc/info.c22
1 files changed, 11 insertions, 11 deletions
diff --git a/proc/info.c b/proc/info.c
index 7fe056c4..abb3e78f 100644
--- a/proc/info.c
+++ b/proc/info.c
@@ -342,7 +342,7 @@ S_proc_getprocenv (struct proc *callerp,
kern_return_t
S_proc_getprocinfo (struct proc *callerp,
pid_t pid,
- int flags,
+ int *flags,
int **piarray,
u_int *piarraylen,
char **waits, mach_msg_type_number_t *waits_len)
@@ -370,11 +370,11 @@ S_proc_getprocinfo (struct proc *callerp,
task = p->p_task;
msgport = p->p_deadmsg ? MACH_PORT_NULL : p->p_msgport;
- if (flags & (PI_FETCH_THREAD_SCHED | PI_FETCH_THREAD_BASIC
+ if (*flags & (PI_FETCH_THREAD_SCHED | PI_FETCH_THREAD_BASIC
| PI_FETCH_THREAD_WAITS))
- flags |= PI_FETCH_THREADS;
+ *flags |= PI_FETCH_THREADS;
- if (flags & PI_FETCH_THREADS)
+ if (*flags & PI_FETCH_THREADS)
{
err = task_threads (p->p_task, &thds, &nthreads);
if (err == MACH_SEND_INVALID_DEST)
@@ -422,7 +422,7 @@ S_proc_getprocinfo (struct proc *callerp,
potential calls to P's msgport, which can block. */
mutex_unlock (&global_lock);
- if (flags & PI_FETCH_TASKINFO)
+ if (*flags & PI_FETCH_TASKINFO)
{
tkcount = TASK_BASIC_INFO_COUNT;
err = task_info (task, TASK_BASIC_INFO, (int *)&pi->taskinfo, &tkcount);
@@ -433,7 +433,7 @@ S_proc_getprocinfo (struct proc *callerp,
for (i = 0; i < nthreads; i++)
{
pi->threadinfos[i].died = 0;
- if (flags & PI_FETCH_THREAD_BASIC)
+ if (*flags & PI_FETCH_THREAD_BASIC)
{
thcount = THREAD_BASIC_INFO_COUNT;
err = thread_info (thds[i], THREAD_BASIC_INFO,
@@ -448,7 +448,7 @@ S_proc_getprocinfo (struct proc *callerp,
break;
}
- if (flags & PI_FETCH_THREAD_SCHED)
+ if (*flags & PI_FETCH_THREAD_SCHED)
{
thcount = THREAD_SCHED_INFO_COUNT;
if (!err)
@@ -464,11 +464,11 @@ S_proc_getprocinfo (struct proc *callerp,
break;
}
- if (flags & PI_FETCH_THREAD_WAITS)
+ if (*flags & PI_FETCH_THREAD_WAITS)
{
/* See what thread I is waiting on. */
if (msgport == MACH_PORT_NULL)
- flags &= ~PI_FETCH_THREAD_WAITS; /* Can't return much... */
+ *flags &= ~PI_FETCH_THREAD_WAITS; /* Can't return much... */
else
{
string_t desc;
@@ -496,7 +496,7 @@ S_proc_getprocinfo (struct proc *callerp,
(vm_address_t *)&new_waits, new_len,1);
if (err)
/* Just don't return any more waits information. */
- flags &= ~PI_FETCH_THREAD_WAITS;
+ *flags &= ~PI_FETCH_THREAD_WAITS;
else
{
if (waits_used > 0)
@@ -523,7 +523,7 @@ S_proc_getprocinfo (struct proc *callerp,
mach_port_deallocate (mach_task_self (), thds[i]);
}
- if (flags & PI_FETCH_THREADS)
+ if (*flags & PI_FETCH_THREADS)
{
vm_deallocate (mach_task_self (),
(vm_address_t)thds, nthreads * sizeof (thread_t));