psinfo.d revision 305748
1/*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License").  You may not use this file except in compliance
7 * with the License.
8 *
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
13 *
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
19 *
20 * CDDL HEADER END
21 *
22 * Portions Copyright 2006 John Birrell jb@freebsd.org
23 *
24 * $FreeBSD: stable/10/cddl/lib/libdtrace/psinfo.d 305748 2016-09-12 17:05:42Z gnn $
25 */
26/*
27 * Copyright 2004 Sun Microsystems, Inc.  All rights reserved.
28 * Use is subject to license terms.
29 */
30
31typedef struct psinfo {
32	int	pr_nlwp;	/* number of threads */
33	pid_t	pr_pid;		/* unique process id */
34	pid_t	pr_ppid;	/* process id of parent */
35	pid_t	pr_pgid;	/* pid of process group leader */
36	pid_t	pr_sid;		/* session id */
37	uid_t	pr_uid;		/* real user id */
38	uid_t	pr_euid;	/* effective user id */
39	gid_t	pr_gid;		/* real group id */
40	gid_t	pr_egid;	/* effective group id */
41	uintptr_t
42		pr_addr;	/* address of process */
43	string	pr_psargs;	/* process arguments */
44	u_int	pr_arglen;	/* process argument length */
45	u_int	pr_jailid;	/* jail id */
46} psinfo_t;
47
48#pragma D binding "1.0" translator
49translator psinfo_t < struct proc *T > {
50	pr_nlwp = T->p_numthreads;
51	pr_pid = T->p_pid;
52	pr_ppid = (T->p_pptr == 0) ? 0 : T->p_pptr->p_pid;
53	pr_pgid = (T->p_leader == 0) ? 0 : T->p_leader->p_pid;
54	pr_sid = (T->p_pgrp == 0) ? 0 : ((T->p_pgrp->pg_session == 0) ? 0 : T->p_pgrp->pg_session->s_sid);
55	pr_uid = T->p_ucred->cr_ruid;
56	pr_euid = T->p_ucred->cr_uid;
57	pr_gid = T->p_ucred->cr_rgid;
58	pr_egid = T->p_ucred->cr_groups[0];
59	pr_addr = 0;
60	pr_psargs = (T->p_args == 0) ? "" :
61	    memstr(T->p_args->ar_args, ' ', T->p_args->ar_length);
62	pr_arglen = T->p_args->ar_length;
63	pr_jailid = T->p_ucred->cr_prison->pr_id;
64};
65
66typedef struct lwpsinfo {
67	id_t	pr_lwpid;	/* thread ID. */
68	int	pr_flag;	/* thread flags. */
69	int	pr_pri;		/* thread priority. */
70	char	pr_state;	/* numeric lwp state */
71	char	pr_sname;	/* printable character for pr_state */
72	short	pr_syscall;	/* system call number (if in syscall) */
73	uintptr_t
74		pr_addr;	/* internal address of lwp */
75	uintptr_t
76		pr_wchan;	/* sleep address */
77} lwpsinfo_t;
78
79#pragma D binding "1.0" translator
80translator lwpsinfo_t < struct thread *T > {
81	pr_lwpid = T->td_tid;
82	pr_pri = T->td_priority;
83	pr_flag = T->td_flags;
84	pr_state = 0; /* XXX */
85	pr_sname = '?'; /* XXX */
86	pr_syscall = 0; /* XXX */
87	pr_addr = (uintptr_t)T;
88	pr_wchan = (uintptr_t)T->td_wchan;
89};
90
91inline psinfo_t *curpsinfo = xlate <psinfo_t *> (curthread->td_proc);
92#pragma D attributes Stable/Stable/Common curpsinfo
93#pragma D binding "1.0" curpsinfo
94
95inline lwpsinfo_t *curlwpsinfo = xlate <lwpsinfo_t *> (curthread);
96#pragma D attributes Stable/Stable/Common curlwpsinfo
97#pragma D binding "1.0" curlwpsinfo
98
99