summaryrefslogtreecommitdiff
path: root/process.c
diff options
context:
space:
mode:
authorJeremie Koenig <jk@jk.fr.eu.org>2010-08-17 22:20:32 +0000
committerJeremie Koenig <jk@jk.fr.eu.org>2010-08-30 14:14:49 +0200
commit85feec46e7d8884a9a34276c7cad8133c5fbb02e (patch)
treef13066e7725f2360e172440583f7d79f11ee3487 /process.c
parent931c02a6bd8197b0b6334622795984463c05200b (diff)
Fetch process information and reject the non-existing ones
* process.c, process.h (process_make_node): Make static, include a procinfo structure into the node information. (process_lookup_pid): New function, replaces process_make_node as the outer interface, returns an error for non-existing processes. * proclist.c (proclist_lookup): Convert to the new interface.
Diffstat (limited to 'process.c')
-rw-r--r--process.c34
1 files changed, 31 insertions, 3 deletions
diff --git a/process.c b/process.c
index 90ea511b..612ed493 100644
--- a/process.c
+++ b/process.c
@@ -7,6 +7,7 @@
struct process_node {
process_t procserv;
pid_t pid;
+ struct procinfo info;
};
@@ -57,8 +58,8 @@ process_argz_make_node (void *dir_hook, void *entry_hook)
}
-struct node *
-process_make_node (process_t procserv, pid_t pid)
+static struct node *
+process_make_node (process_t procserv, pid_t pid, const struct procinfo *info)
{
static const struct procfs_dir_entry entries[] = {
{ "cmdline", process_argz_make_node, proc_getprocargs, },
@@ -73,7 +74,34 @@ process_make_node (process_t procserv, pid_t pid)
pn->procserv = procserv;
pn->pid = pid;
+ memcpy (&pn->info, info, sizeof pn->info);
- return procfs_dir_make_node (entries, pn, free);
+ return procfs_dir_make_node (entries, pn, process_cleanup);
}
+error_t
+process_lookup_pid (process_t procserv, pid_t pid, struct node **np)
+{
+ procinfo_t info;
+ size_t info_sz;
+ data_t tw;
+ size_t tw_sz;
+ int flags;
+ error_t err;
+
+ tw_sz = info_sz = 0, flags = 0;
+ err = proc_getprocinfo (procserv, pid, &flags, &info, &info_sz, &tw, &tw_sz);
+ if (err == ESRCH)
+ return ENOENT;
+ if (err)
+ return EIO;
+
+ assert (info_sz * sizeof *info >= sizeof (struct procinfo));
+ *np = process_make_node (procserv, pid, (struct procinfo *) info);
+ vm_deallocate (mach_task_self (), (vm_address_t) info, info_sz);
+
+ if (! *np)
+ return ENOMEM;
+
+ return 0;
+}