b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# CDDL HEADER START
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# The contents of this file are subject to the terms of the
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# Common Development and Distribution License (the "License").
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# You may not use this file except in compliance with the License.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# or http://www.opensolaris.org/os/licensing.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# See the License for the specific language governing permissions
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# and limitations under the License.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# When distributing Covered Code, include this CDDL HEADER in each
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# If applicable, add the following below this CDDL HEADER, with the
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# fields enclosed by brackets "[]" replaced with your own identifying
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# information: Portions Copyright [yyyy] [name of copyright owner]
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# CDDL HEADER END
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# Copyright (c) 2012, Joyent, Inc. All rights reserved.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrillppriv -s A=basic,dtrace_proc,dtrace_user $$
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# When we have dtrace_proc (but lack dtrace_kernel), we expect to be able to
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# read certain curpsinfo/curlwpsinfo/curcpu fields even though they require
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# reading in-kernel state. However, there are other fields in these translated
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# structures that we know we shouldn't be able to read, as they require reading
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# in-kernel state that we cannot read with only dtrace_proc. Finally, there
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# are a few fields that we may or may not be able to read depending on the
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# specifics of context. This test therefore asserts that we can read what we
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# think we should be able to, that we can't read what we think we shouldn't be
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# able to, and (for purposes of completeness) that we are indifferent about
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill# what we cannot assert one way or the other.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill/usr/sbin/dtrace -q -Cs /dev/stdin <<EOF
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#define CANREAD(what, field) \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill BEGIN { errmsg = "can't read field from what"; printf("field: "); \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill trace(what->field); printf("\n"); }
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#define CANTREAD(what, field) \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill BEGIN { errmsg = ""; trace(what->field); \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill printf("\nable to successfully read field from what!"); exit(1); }
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#define MIGHTREAD(what, field) \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill BEGIN { errmsg = ""; printf("field: "); trace(what->field); printf("\n"); }
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#define CANREADVAR(vname) \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill BEGIN { errmsg = "can't read vname"; printf("vname: "); \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill trace(vname); printf("\n"); }
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#define CANTREADVAR(vname) \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill BEGIN { errmsg = ""; trace(vname); \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill printf("\nable to successfully read vname!"); exit(1); }
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill#define MIGHTREADVAR(vname) \
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill BEGIN { errmsg = ""; printf("vname: "); trace(vname); printf("\n"); }
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_pid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_nlwp)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_ppid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_uid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_euid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_gid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_egid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_addr)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_start)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_fname)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_psargs)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_argc)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_argv)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_envp)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curpsinfo, pr_dmodel)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill/*
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill * If our p_pgidp points to the same pid structure as our p_pidp, we will
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill * be able to read pr_pgid -- but we won't if not.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill */
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillMIGHTREAD(curpsinfo, pr_pgid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curpsinfo, pr_sid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curpsinfo, pr_ttydev)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curpsinfo, pr_projid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curpsinfo, pr_zoneid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curpsinfo, pr_contract)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_flag)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_lwpid)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_addr)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_wchan)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_stype)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_state)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_sname)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_syscall)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_pri)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_onpro)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_bindpro)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curlwpsinfo, pr_bindpset)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curlwpsinfo, pr_clname)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curlwpsinfo, pr_lgrp)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREAD(curcpu, cpu_id)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curcpu, cpu_pset)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curcpu, cpu_chip)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curcpu, cpu_lgrp)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREAD(curcpu, cpu_info)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill/*
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill * We cannot assert one thing or another about the variable "root": for those
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill * with only dtrace_proc, it will be readable in the global but not readable in
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill * the non-global.
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill */
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillMIGHTREADVAR(root)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANREADVAR(cpu)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREADVAR(pset)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREADVAR(cwd)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREADVAR(chip)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillCANTREADVAR(lgrp)
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillBEGIN
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill{
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill exit(0);
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill}
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan CantrillERROR
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill/errmsg != ""/
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill{
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill printf("fatal error: %s", errmsg);
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill exit(1);
b0f673c4626e4cb1db7785287eaeed2731dfefe8Bryan Cantrill}