freebsd-skq/cddl/lib/libdtrace/sched.d
Mark Johnston 7e518a6648 - Use an explicit "depends_on module kernel" guard in DTrace libraries that
reference types defined in the kernel. Otherwise dtrace(1) expects to find
  CTF definitions for all referenced types, which is not very reasonable
  when it is being used in a build environment. This was previously worked
  around by adding "-x nolibs" to dtrace -h or -G invocations, but as of
  r283025, dtrace(1) actually handles dependencies properly, so this is no
  longer necessary.
- Remove "pragma ident" directives from DTrace libraries, as they're being
  phased out upstream as well.

Submitted by:	Krister Johansen <Krister.Johansen@isilon.com> [1]
MFC after:	1 week
Sponsored by:	EMC / Isilon Storage Division
2015-08-07 19:56:22 +00:00

85 lines
2.7 KiB
D

/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*
* Portions Copyright 2006-2008 John Birrell jb@freebsd.org
*
* $FreeBSD$
*/
/*
* Copyright 2006 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#pragma D depends_on module kernel
#pragma D depends_on provider sched
struct cpuinfo {
processorid_t cpu_id; /* CPU identifier */
psetid_t cpu_pset; /* processor set identifier */
chipid_t cpu_chip; /* chip identifier */
lgrp_id_t cpu_lgrp; /* locality group identifer */
processor_info_t cpu_info; /* CPU information */
};
typedef struct cpuinfo cpuinfo_t;
translator cpuinfo_t < cpu_t *C > {
cpu_id = C->cpu_id;
cpu_pset = C->cpu_part->cp_id;
cpu_chip = C->cpu_physid->cpu_chipid;
cpu_lgrp = C->cpu_lpl->lpl_lgrpid;
cpu_info = (processor_info_t)C->cpu_type_info;
};
translator cpuinfo_t < disp_t *D > {
cpu_id = D->disp_cpu == NULL ? -1 :
xlate <cpuinfo_t> (D->disp_cpu).cpu_id;
cpu_pset = D->disp_cpu == NULL ? -1 :
xlate <cpuinfo_t> (D->disp_cpu).cpu_pset;
cpu_chip = D->disp_cpu == NULL ? -1 :
xlate <cpuinfo_t> (D->disp_cpu).cpu_chip;
cpu_lgrp = D->disp_cpu == NULL ? -1 :
xlate <cpuinfo_t> (D->disp_cpu).cpu_lgrp;
cpu_info = D->disp_cpu == NULL ?
*((processor_info_t *)dtrace`dtrace_zero) :
(processor_info_t)xlate <cpuinfo_t> (D->disp_cpu).cpu_info;
};
inline cpuinfo_t *curcpu = xlate <cpuinfo_t *> (curthread->t_cpu);
#pragma D attributes Stable/Stable/Common curcpu
#pragma D binding "1.0" curcpu
inline processorid_t cpu = curcpu->cpu_id;
#pragma D attributes Stable/Stable/Common cpu
#pragma D binding "1.0" cpu
inline psetid_t pset = curcpu->cpu_pset;
#pragma D attributes Stable/Stable/Common pset
#pragma D binding "1.0" pset
inline chipid_t chip = curcpu->cpu_chip;
#pragma D attributes Stable/Stable/Common chip
#pragma D binding "1.0" chip
inline lgrp_id_t lgrp = curcpu->cpu_lgrp;
#pragma D attributes Stable/Stable/Common lgrp
#pragma D binding "1.0" lgrp