Date: Fri, 13 Apr 2001 18:32:18 -0700 From: Dima Dorfman <dima@unixfreak.org> To: Evan S <kaworu@sektor7.ath.cx> Cc: freebsd-hackers@freebsd.org Subject: Re: question on kvm_getprocs Message-ID: <20010414013218.93BED3E25@bazooka.unixfreak.org> In-Reply-To: <Pine.GSO.4.10.10104132113550.17812-100000@wintermute.sekt7>; from kaworu@sektor7.ath.cx on "Fri, 13 Apr 2001 21:17:13 -0400 (EDT)"
index | next in thread | previous in thread | raw e-mail
Evan S <kaworu@sektor7.ath.cx> writes:
> if ((kinfo = malloc(nentries * sizeof(*kinfo))) == NULL)
> err(1, NULL);
> for (i = nentries; --i >= 0; ++proc_list) {
> (&kinfo[i])->ki_p = proc_list;
> if (KI_PROC(&kinfo[i])->p_prison)
> {
> printf("Jailed Process\n");
> printf("%s\n",
>
> KI_PROC(&kinfo[i])->p_prison->pr_host);
> }
> }
>
> KI_PROC is just a macro that is
> #define KI_PROC(ki) (&(ki)->ki_p->kp_proc)
>
> [teqnix](~/work/c/getprocs)%gcc -g -lkvm getprocs.c -o getprocs
> getprocs.c: In function `main':
> getprocs.c:87: dereferencing pointer to incomplete type
pr_host is a member of struct prison, which is a kernel structure.
It's under #ifdef _KERNEL, which is why you don't have a definition
for it. I'm not quite sure where you're getting your process list
from, but I think that p_prison is a kernel pointer in your context.
Obviously, trying to follow that from the userland won't do what you
want. :-)
Then again, I could be wrong. If you want, take the definition of
struct prison from /usr/include/sys/jail.h and paste it into your
code. That will get rid of the warning. If your program seg faults
when you try to run it, you'll know I was right.
Regards,
Dima Dorfman
dima@unixfreak.org
To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-hackers" in the body of the message
help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20010414013218.93BED3E25>
