c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * CDDL HEADER START
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * The contents of this file are subject to the terms of the
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Common Development and Distribution License (the "License").
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * You may not use this file except in compliance with the License.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * See the License for the specific language governing permissions
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * and limitations under the License.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * When distributing Covered Code, include this CDDL HEADER in each
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * If applicable, add the following below this CDDL HEADER, with the
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * fields enclosed by brackets "[]" replaced with your own identifying
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * information: Portions Copyright [yyyy] [name of copyright owner]
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * CDDL HEADER END
b9e93c10c0a2a4bb069d38bb311021a9478c4711Jonathan Haslam * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Use is subject to license terms.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Xen event provider for DTrace
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * NOTE: This provider is PRIVATE. It is intended as a short-term solution and
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * may disappear or be re-implemented at anytime.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * This provider isn't suitable as a general-purpose solution for a number of
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * reasons. First and foremost, we rely on the Xen tracing mechanism and don't
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * have any way to gather data other than that collected by the Xen trace
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * buffers. Further, it does not fit into the DTrace model (see "Interacting
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * with DTrace" below.)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Tracing in Xen
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * --------------
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Xen implements a tracing facility for generating and collecting execution
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * event traces from the hypervisor. When tracing is enabled, compiled in
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * probes record events in contiguous per-CPU trace buffers.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +---------+
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +------+ | |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * | CPUn |----> | BUFFERn |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +------+ | |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +---------+- tbuf.va + (tbuf.size * n)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +---------+
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +------+ | |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * | CPU1 |----> | BUFFER1 |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +------+ | |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +---------+- tbuf.va + tbuf.size
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +------+ | |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * | CPU0 |----> | BUFFER0 |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +------+ | |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +---------+- tbuf.va
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Each CPU buffer consists of a metadata header followed by the trace records.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * The metadata consists of a producer/consumer pair of pointers into the buffer
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * that point to the next record to be written and the next record to be read
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * respectively.
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * A trace record can be in one of two forms, depending on if the TSC is
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * included. The record header indicates whether or not the TSC field is
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * 1. Trace record without TSC:
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * +------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * | HEADER(uint32_t) | DATA FIELDS |
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * +------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * 2. Trace record with TSC:
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * +--------------------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * | HEADER(uint32_t) | TSC(uint64_t) | DATA FIELDS |
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * +--------------------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * HEADER bit field:
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +--------------------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * | C | NDATA | EVENT |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +--------------------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * 31 30 28 27 0
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * EVENT: Event ID.
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * NDATA: Number of populated data fields.
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * C: TSC included.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * DATA FIELDS:
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +--------------------------------------------------------------------------+
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * | D1(uint32_t) | D2(uint32_t) | D3(uint32_t) | . . . | D7(uint32_t) |
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * +--------------------------------------------------------------------------+
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Interacting with DTrace
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * -----------------------
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Every xdt_poll_nsec nano-seconds we poll the trace buffers for data and feed
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * each entry into dtrace_probe() with the corresponding probe ID for the event.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * As a result of this periodic collection implementation probe firings are
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * asynchronous. This is the only sensible way to implement this form of
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * provider, but because of its asynchronous nature asking things like
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * "current CPU" and, more importantly, arbitrary questions about the context
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * surrounding the probe firing are not meaningful. So, consumers should not
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * attempt to infer anything beyond what is supplied via the probe arguments.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq#define XDT_POLL_DEFAULT 100000000 /* default poll interval (ns) */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq#define XDT_POLL_MIN 10000000 /* min poll interval (ns) */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq#define XDT_TBUF_RETRY 50 /* tbuf disable retry count */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * The domid must match IDLE_DOMAIN_ID in xen.hg/xen/include/xen/sched.h
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * in the xVM gate.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/* Macros to extract the domid and cpuid from a HVM trace data field */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden/* Flags for shadow page table events */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_PROBE5(event, arg0, arg1, arg2, arg3, arg4) { \
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden dtrace_probe(id, arg0, arg1, arg2, arg3, arg4); \
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_PROBE4(event, arg0, arg1, arg2, arg3) \
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE5(event, arg0, arg1, arg2, arg3, 0)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_PROBE3(event, arg0, arg1, arg2) \
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE5(event, arg0, arg1, arg2, 0, 0)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/* Probe classes */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/* Probe events */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SCHED_REM_VCPU 19 /* unused */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SCHED_S_TIMER_FN 22 /* unused */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SCHED_T_TIMER_FN 23 /* unused */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SCHED_DOM_TIMER_FN 24 /* unused */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_PV_EMULATE_4GB 30 /* unused (32-bit HV only ) */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_HVM_IO_WRITE 41 /* unused */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_HVM_DR_WRITE 45 /* unused */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SHADOW_EMULATE_UNSHADOW_USER 71
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SHADOW_EMULATE_UNSHADOW_EVTINJ 72
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden#define XDT_SHADOW_EMULATE_UNSHADOW_UNHANDLED 73
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqtypedef struct {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqtypedef struct {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqtypedef struct {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq ulong_t next_wtime; /* time spent waiting to get on cpu */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden ulong_t cur_vcpuid; /* current vcpuid */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqstatic struct {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* per-cpu buffers */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* statistics */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq uint64_t stat_spurious_cpu; /* recs with garbage cpuids */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq uint64_t stat_spurious_switch; /* inconsistent vcpu switches */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq uint64_t stat_unknown_shutdown; /* unknown shutdown code */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq "dropped_recs",
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Tunable variables
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * The following may be tuned by adding a line to /etc/system that
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * includes both the name of the module ("xdt") and the name of the variable.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * For example:
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * set xdt:xdt_tbuf_pages = 40
c7158ae983f5a04c4a998f468ecefba6d23ba721tariquint_t xdt_tbuf_pages = 20; /* pages to alloc per-cpu buf */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * The following may be tuned by adding a line to
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * For example:
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * xdt_poll_nsec = 200000000;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqstatic hrtime_t xdt_poll_nsec; /* trace buffer poll interval */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Another tunable variable: the maximum number of records to process
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * in one scan. If it is 0 (e.g. not set in /etc/system), it will
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * be set to ncpu * (bufsize / max_rec_size).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Having an upper limit avoids a situation where the scan would loop
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * endlessly in case the hypervisor adds records quicker than we
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * can process them. It's better to drop records than to loop, obviously.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Internal variables
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqstatic uint_t xdt_ncpus; /* total number of phys CPUs */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqstatic uint32_t cur_trace_mask; /* current trace mask */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqstatic xdt_schedinfo_t *xdt_cpu_schedinfo; /* per-cpu sched info */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqdtrace_id_t xdt_probemap[XDT_NEVENTS]; /* map of enabled probes */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqdtrace_id_t xdt_prid[XDT_NEVENTS]; /* IDs of registered events */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * These provide context when probes fire. They can be accessed
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * from xdt dtrace probe (as `xdt_curdom, etc). It's ok for these
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * to be global, and not per-cpu, as probes are run strictly in sequence
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * as the trace buffers are
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Lindenuint_t xdt_curdom, xdt_curvcpu, xdt_curpcpu;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* Sched probes */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "sched", "idle-off-cpu", XDT_SCHED_IDLE_OFF_CPU, XDT_SCHED },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "sched", "idle-on-cpu", XDT_SCHED_IDLE_ON_CPU, XDT_SCHED },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "sched", "shutdown-poweroff", XDT_SCHED_SHUTDOWN_POWEROFF,
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "sched", "shutdown-reboot", XDT_SCHED_SHUTDOWN_REBOOT, XDT_SCHED },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "sched", "shutdown-suspend", XDT_SCHED_SHUTDOWN_SUSPEND, XDT_SCHED },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "sched", "shutdown-crash", XDT_SCHED_SHUTDOWN_CRASH, XDT_SCHED },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "sched", "add", XDT_SCHED_ADD_VCPU, XDT_SCHED },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "sched", "runstate-change", XDT_SCHED_RUNSTATE_CHANGE, XDT_SCHED },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "sched", "continue-running", XDT_SCHED_CONTINUE_RUNNING, XDT_SCHED },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* Memory probes */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "mem", "page-grant-map", XDT_MEM_PAGE_GRANT_MAP, XDT_MEM },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "mem", "page-grant-unmap", XDT_MEM_PAGE_GRANT_UNMAP, XDT_MEM },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq { "mem", "page-grant-transfer", XDT_MEM_PAGE_GRANT_TRANSFER, XDT_MEM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "hypercall", XDT_PV_HYPERCALL, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "page-fault", XDT_PV_PAGE_FAULT, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "forced-invalid-op", XDT_PV_FORCED_INVALID_OP, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "emulate-priv-op", XDT_PV_EMULATE_PRIVOP, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "math-state-restore", XDT_PV_MATH_STATE_RESTORE, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "paging-fixup", XDT_PV_PAGING_FIXUP, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "dt-mapping-fault", XDT_PV_DT_MAPPING_FAULT, XDT_PV },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden {"pv", "pte-write-emul", XDT_PV_PTWR_EMULATION, XDT_PV },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* HVM probes */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "pagefault-xen", XDT_HVM_PF_XEN, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "pagefault-inject", XDT_HVM_PF_INJECT, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "exception-inject", XDT_HVM_EXC_INJECT, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "virq-inject", XDT_HVM_VIRQ_INJECT, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "cr-read", XDT_HVM_CR_READ, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "cr-write", XDT_HVM_CR_WRITE, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "msr-read", XDT_HVM_MSR_READ, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "msr-write", XDT_HVM_MSR_WRITE, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "cpuid", XDT_HVM_CPUID, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "intr", XDT_HVM_INTR, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "intr-window", XDT_HVM_INTR_WINDOW, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "nmi", XDT_HVM_NMI, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "smi", XDT_HVM_SMI, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "vmmcall", XDT_HVM_VMMCALL, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "hlt", XDT_HVM_HLT, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "invlpg", XDT_HVM_INVLPG, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "mce", XDT_HVM_MCE, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "pio-read", XDT_HVM_IOPORT_READ, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "pio-write", XDT_HVM_IOPORT_WRITE, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "mmio-read", XDT_HVM_IOMEM_READ, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "mmio-write", XDT_HVM_IOMEM_WRITE, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "clts", XDT_HVM_CLTS, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "hvm", "lmsw", XDT_HVM_LMSW, XDT_HVM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "fault-not-shadow", XDT_SHADOW_NOT_SHADOW, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "fast-propagate", XDT_SHADOW_FAST_PROPAGATE, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "fast-mmio", XDT_SHADOW_FAST_MMIO, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "false-fast-path", XDT_SHADOW_FALSE_FAST_PATH,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "mmio", XDT_SHADOW_MMIO, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "fixup", XDT_SHADOW_FIXUP, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "domf-dying", XDT_SHADOW_DOMF_DYING, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "emulate", XDT_SHADOW_EMULATE, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "emulate-unshadow-user", XDT_SHADOW_EMULATE_UNSHADOW_USER,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_SHADOW_EMULATE_UNSHADOW_EVTINJ, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "emulate-unshadow-unhandled",
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_SHADOW_EMULATE_UNSHADOW_UNHANDLED, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "wrmap-bf", XDT_SHADOW_WRMAP_BF, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "prealloc-unpin", XDT_SHADOW_PREALLOC_UNPIN, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "resync-full", XDT_SHADOW_RESYNC_FULL, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "shadow", "resync-only", XDT_SHADOW_RESYNC_ONLY, XDT_SHADOW },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "pm", "freq-change", XDT_PM_FREQ_CHANGE, XDT_PM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "pm", "idle-entry", XDT_PM_IDLE_ENTRY, XDT_PM },
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden { "pm", "idle-exit", XDT_PM_IDLE_EXIT, XDT_PM },
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee /* Trace buffer related probes */
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee { "trace", "records-lost", XDT_TRC_LOST_RECORDS, XDT_GEN },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqstatic inline uint32_t
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq for (i = 0; i < XDT_NCLASSES; i++)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_classinfo[XDT_PV].trc_mask = TRC_PV;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_classinfo[XDT_SHADOW].trc_mask = TRC_SHADOW;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_classinfo[XDT_PM].trc_mask = TRC_PM;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Assignment order should match that of the names in
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * xdt_stats.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq return (0);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq int nstats = sizeof (xdt_stats) / sizeof (xdt_stats[0]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq if ((xdt_kstats = kstat_create("xdt", 0, "trace_statistics", "misc",
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq while (nstats > 0) {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq return (0);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqxdt_map_trace_buffers(mfn_t mfn, caddr_t va, size_t len)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Ask the HAT to load a throwaway mapping to page zero, then
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * overwrite it with the hypervisor mapping. It gets removed
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * later via hat_unload().
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq xerr = HYPERVISOR_update_va_mapping_otherdomain((ulong_t)va,
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq if (xerr != 0) {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* unmap pages loaded so far */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq return (0);
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail * Xen does not support trace buffer re-sizing. If the buffers
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail * have already been allocated we just use them as is.
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail /* set trace buffer size */
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail tbuf_op.cmd = XEN_SYSCTL_TBUFOP_set_size;
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail /* get trace buffer info */
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail tbuf_op.cmd = XEN_SYSCTL_TBUFOP_get_info;
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail if ((err = xdt_sysctl_tbuf(&tbuf_op)) != 0)
411e7d8f94b93b43156abc905a0ad18cb5f1469cTariq Magdon-Ismail cmn_err(CE_NOTE, "Couldn't allocate trace buffers.");
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq if ((err = xdt_map_trace_buffers(tbuf.start_mfn, tbuf.va, len)) != 0) {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq tbuf.meta = (struct t_buf **)kmem_alloc(tbuf.cnt * sizeof (*tbuf.meta),
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq tbuf.data = (struct t_rec **)kmem_alloc(tbuf.cnt * sizeof (*tbuf.data),
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq sizeof (struct t_buf));
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* throw away stale trace records */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden tbuf_data_size = tbuf.size - sizeof (struct t_buf);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_max_recs = (xdt_ncpus * tbuf_data_size)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden / sizeof (struct t_rec);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq return (0);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Lindenxdt_update_sched_context(uint_t cpuid, uint_t dom, uint_t vcpu)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_schedinfo_t *sp = &xdt_cpu_schedinfo[cpuid];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Lindenxdt_update_domain_context(uint_t dom, uint_t vcpu)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden uint64_t tsc, addr64, rip64, val64, pte64;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * If our current state isn't valid, and if this is not
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * an event that will update our state, skip it.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden tsc = (((uint64_t)rec->u.cycles.cycles_hi) << 32)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Sched probes
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Info on vCPU being de-scheduled
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = prev domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = time spent on pcpu
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Info on next vCPU to be scheduled
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = next domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = time spent waiting to get on cpu
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[2] = time slice
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * vCPU switch
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = prev domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = prev vcpuid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[2] = next domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[3] = next vcpuid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Provide valid context for this probe if there
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_update_domain_context(data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_update_sched_context(cpuid, data[0], data[1]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* prev and next info don't match doms being sched'd */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden sp->prev_domid, sp->prev_vcpuid, sp->prev_ctime);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden sp->next_domid, sp->next_vcpuid, sp->next_wtime,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_update_sched_context(cpuid, data[2], data[3]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_update_domain_context(data[2], data[3]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * vCPU blocked
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = vcpuid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SCHED_BLOCK, data[0], data[1]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Put vCPU to sleep
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = vcpuid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SCHED_SLEEP, data[0], data[1]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Wake up vCPU
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = vcpuid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SCHED_WAKE, data[0], data[1]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * vCPU yielded
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = vcpuid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SCHED_YIELD, data[0], data[1]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Guest shutting down
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = domid
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[1] = initiating vcpu
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[2] = shutdown code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Add vcpu to a guest.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = domid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vcpu
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SCHED_ADD_VCPU, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Scheduling parameters for a guest
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * were modified.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = domid;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Runstate change for a VCPU.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = (domain << 16) | vcpu;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = oldstate;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = newstate;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE4(XDT_SCHED_RUNSTATE_CHANGE, data[0] >> 16,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * VCPU is back on a physical CPU that it previously
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * was also running this VCPU.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = (domain << 16) | vcpu;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SCHED_CONTINUE_RUNNING, data[0] >> 16,
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Mem probes
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Guest mapped page grant
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = target domid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_MEM_PAGE_GRANT_MAP, data[0]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Guest unmapped page grant
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = target domid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_MEM_PAGE_GRANT_UNMAP, data[0]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Page grant is being transferred
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = target domid
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_MEM_PAGE_GRANT_TRANSFER, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Probes for PV domains.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypercall from a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = eax
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PV_HYPERCALL, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypercall from a 64-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = rip(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = eax;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PV_HYPERCALL, rip64, data[2]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Trap in a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = trapnr | (error_code_valid << 15)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * | (error_code << 16);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE4(XDT_PV_TRAP, data[0], data[1] & 0x7fff,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Trap in a 64-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = rip(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = trapnr | (error_code_valid << 15)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * | (error_code << 16);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[1]) << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE4(XDT_PV_TRAP, rip64, data[2] & 0x7fff,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Page fault in a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vaddr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = error code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_PV_PAGE_FAULT, data[0], data[1], data[2]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Page fault in a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = rip(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = vaddr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = vaddr(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = error code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[3]) << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_PV_PAGE_FAULT, rip64, addr64, data[4]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor emulated a forced invalid op (ud2)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * in a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_PV_FORCED_INVALID_OP, data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_PV_FORCED_INVALID_OP | TRC_64_FLAG:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor emulated a forced invalid op (ud2)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * in a 64-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = rip(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_PV_FORCED_INVALID_OP, rip64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor emulated a privileged operation
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * in a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_PV_EMULATE_PRIVOP, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_PV_EMULATE_PRIVOP | TRC_64_FLAG:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor emulated a privileged operation
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * in a 64-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = rip(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_PV_EMULATE_PRIVOP, rip64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden /* unused, 32-bit hypervisor only */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor restores math state after FP DNA trap.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * No arguments.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor fixed up a page fault (e.g. it was
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * a side-effect of hypervisor guest page table
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * bookkeeping, and not propagated to the guest).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vaddr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PV_PAGING_FIXUP, data[0], data[2]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_PV_PAGING_FIXUP | TRC_64_FLAG:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Hypervisor fixed up a page fault (e.g. it was
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * a side-effect of hypervisor guest page table
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * bookkeeping, and not propagated to the guest).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = eip(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = vaddr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = vaddr(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[3]) << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PV_PAGING_FIXUP, rip64, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Descriptor table mapping fault in a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = offset
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PV_DT_MAPPING_FAULT, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_PV_GDT_LDT_MAPPING_FAULT | TRC_64_FLAG:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Descriptor table mapping fault in a 64-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = eip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = eip(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = offset(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = offset(31:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = (((uint64_t)data[3]) << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PV_DT_MAPPING_FAULT, rip64, val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_PV_PTWR_EMULATION_PAE | TRC_64_FLAG:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Should only happen on 32-bit hypervisor; unused.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * PTE write emulation for a 32-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = addr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_PV_PTWR_EMULATION, data[0], data[1], data[2]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_PV_PTWR_EMULATION | TRC_64_FLAG:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * PTE write emulation for a 64-bit PV domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = addr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = addr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[5] = rip(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[3]) << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[5]) << 32) | data[4];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_PV_PTWR_EMULATION, pte64, addr64, rip64);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * HVM probes
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * Return to guest via vmx_launch/vmrun
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Entry into VMEXIT handler from 32-bit HVM domain
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = cpu vendor specific exit code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = guest eip
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_VMEXIT, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Entry into VMEXIT handler from 64-bit HVM domain
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = cpu vendor specific exit code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = guest rip(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = guest rip(32:64)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden rip64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_VMEXIT, data[0], rip64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Pagefault in a guest that is a Xen (e.g. shadow)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * artifact, and is not injected back into the guest.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = error code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = guest VA(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = guest VA(32:64)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_PF_XEN, data[0], addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Same as above, but for a 32-bit HVM domain.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = error code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = guest VA
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_PF_XEN, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * 32-bit Xen only.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Pagefault injected back into a guest (e.g. the shadow
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * code found no mapping).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = error code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = guest VA(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = guest VA(32:64)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_PF_INJECT, data[0], addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Exception injected into an HVM guest.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = trap
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = error code
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_EXC_INJECT, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Interrupt inject into an HVM guest.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = vector
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_HVM_VIRQ_INJECT, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Control register read. Intel VMX only.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = control register #
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = value(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = value(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_CR_READ, data[0], val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * unused (32-bit Xen only)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Control register write. Intel VMX only.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = control register #
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = value(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = value(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_CR_READ, data[0], val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * unused (32-bit Xen only)
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee * data[0] = (domid<<16 + vcpuid)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Debug register write. Not too useful; no values,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * so we ignore this.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = (domid<<16 + vcpuid)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = MSR
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = value(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = value(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = (((uint64_t)data[3]) << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_MSR_READ, data[0], val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = MSR;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = value(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = value(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_MSR_WRITE, data[0], val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = %eax (input)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = %eax
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = %ebx
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = %ecx
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = %edx
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE5(XDT_HVM_CPUID, data[0], data[1], data[2], data[3],
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * VMEXIT because of an interrupt.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * VMEXIT because of an interrupt window (an interrupt
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * can't be delivered immediately to a HVM guest and must
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * be delayed).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = vector
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = source
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = info
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_HVM_INTR_WINDOW, data[0], data[1], data[2]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * VMEXIT because of an NMI.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * VMEXIT because of an SMI
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * VMMCALL insn.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = %eax
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = 1 if VCPU runnable, 0 if not
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = INVLPGA ? 1 : 0
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vaddr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = vaddr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[2]) << 32) | data[1];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_HVM_INVLPG, data[0], addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * unused (32-bit Xen only)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = (domid<<16 + vcpuid)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = addr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = addr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = count
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = size
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(eid, addr64, data[2], data[3]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * CLTS insn (Intel VMX only)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = value(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = value(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = (((uint64_t)data[1]) << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * unused (32-bit Xen only)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Shadow page table probes (mainly used for HVM domains
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * without hardware paging support).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_NOT_SHADOW | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = flags
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_SHADOW_NOT_SHADOW, pte64, data[2], data[3]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_NOT_SHADOW | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_NOT_SHADOW | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = flags
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[2] << 32) | data[3];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_SHADOW_NOT_SHADOW, pte64, addr64, data[4]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FAST_PROPAGATE | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_FAST_PROPAGATE, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FAST_PROPAGATE | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FAST_PROPAGATE | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_FAST_PROPAGATE, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FAST_MMIO | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_FAST_MMIO, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FAST_MMIO | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FAST_MMIO | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_FAST_MMIO, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FALSE_FAST_PATH | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_FALSE_FAST_PATH, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FALSE_FAST_PATH | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_FALSE_FAST_PATH | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_FALSE_FAST_PATH, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = flags
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_SHADOW_FIXUP, pte64, data[2], data[3]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = flags
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[2] << 32) | data[3];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE3(XDT_SHADOW_FIXUP, pte64, addr64, data[4]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_DOMF_DYING | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_DOMF_DYING, data[0]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_DOMF_DYING | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_DOMF_DYING | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = va(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = va(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_DOMF_DYING, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = val(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = val(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = addr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[5] = flags
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[3] << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE5(XDT_SHADOW_EMULATE, pte64, val64, data[4],
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = pte(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = pte(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = val(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = val(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[4] = addr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[5] = addr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[6] = flags
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden pte64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[3] << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[5] << 32) | data[4];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE5(XDT_SHADOW_EMULATE, pte64, val64, data[4],
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_USER | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vaddr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SHADOW_EMULATE_UNSHADOW_USER, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_USER | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_USER | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = vaddr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = vaddr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[3] << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SHADOW_EMULATE_UNSHADOW_USER, val64, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_EVTINJ | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vaddr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SHADOW_EMULATE_UNSHADOW_EVTINJ, data[0],
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_EVTINJ | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_EVTINJ | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = vaddr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = vaddr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[3] << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SHADOW_EMULATE_UNSHADOW_EVTINJ, val64, addr64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_UNHANDLED | SH_GUEST_32:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = vaddr
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SHADOW_EMULATE_UNSHADOW_UNHANDLED, data[0],
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_UNHANDLED | SH_GUEST_PAE:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden case TRC_SHADOW_EMULATE_UNSHADOW_UNHANDLED | SH_GUEST_64:
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[2] = vaddr(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[3] = vaddr(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden addr64 = ((uint64_t)data[3] << 32) | data[2];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_SHADOW_EMULATE_UNSHADOW_UNHANDLED, val64,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_WRMAP_BF, val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_PREALLOC_UNPIN, val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gmfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gmfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_RESYNC_FULL, val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = gmfn(0:31)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = gmfn(32:63)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden val64 = ((uint64_t)data[1] << 32) | data[0];
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_SHADOW_RESYNC_ONLY, val64);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Power management probes.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = old freq
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = new freq
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PM_FREQ_CHANGE, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = C-state
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = time
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PM_IDLE_ENTRY, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[0] = C-state
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * data[1] = time
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE2(XDT_PM_IDLE_EXIT, data[0], data[1]);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_update_sched_context(cpuid, dom, vcpu);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden XDT_PROBE1(XDT_TRC_LOST_RECORDS, cpuid);
349b53dd4e695e3d833b5380540385145b2d3ae8Stuart Maybee rec_size = 4 + (rec->cycles_included ? 8 : 0) + (rec->extra_u32 * 4);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * Scan all CPU buffers for the record with the lowest timestamp so
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * that the probes will fire in order.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Lindenxdt_get_first_rec(uint_t *cpuidp, struct t_rec **recp, uint32_t *consp)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden data = (uintptr_t)tbuf.data[cpuid] + offset;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden ASSERT((caddr_t)rec < tbuf.va + (tbuf.size * (cpuid + 1)));
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * All records that we know about have time cycles included.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * If this record doesn't have them, assume it's a type
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * that we don't handle. Use a 0 time value, which will make
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * it get handled first (it will be thrown away).
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden stamp = (((uint64_t)rec->u.cycles.cycles_hi) << 32)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden nrecs < xdt_max_recs && xdt_get_first_rec(&cpuid, &rec, &cons) > 0;
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_update_domain_context(sp->cur_domid,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden bytes_done = xdt_process_rec(cpuid, rec);
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden * cons and prod are incremented modulo (2 * tbuf_data_size).
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq when.cyt_when = dtrace_gethrtime() + when.cyt_interval;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq if (dtrace_probe_lookup(xdt_id, p->pr_mod, NULL, p->pr_name) != 0)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq xdt_prid[p->evt_id] = dtrace_probe_create(xdt_id, p->pr_mod, NULL,
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/*ARGSUSED*/
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/*ARGSUSED*/
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden /* Always need to trace scheduling, for context */
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden tbuf_op.cmd = XEN_SYSCTL_TBUFOP_set_evt_mask;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/*ARGSUSED*/
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* set the trace mask for this class */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq cmn_err(CE_NOTE, "Couldn't enable hypervisor tracing.");
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/*ARGSUSED*/
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq ASSERT(xdt_probemap[p->evt_id] == xdt_prid[p->evt_id]);
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * We could be here in the slight window between the cyclic firing and
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * a call to dtrace_probe() occurring. We need to be careful if we tear
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * down any shared state.
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden for (i = 0; i < xdt_ncpus; i++)
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_cpu_schedinfo[i].curinfo_valid = 0;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * We will try to disable the trace buffers. If we fail for some
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * reason we will try again, up to a count of XDT_TBUF_RETRY.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * If we still aren't successful we try to set the trace mask
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * to 0 in order to prevent trace records from being written.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq if (err != 0) {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq "Couldn't disable hypervisor tracing.");
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * We don't bother making the hypercall to set
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * the trace mask, since it will be reset when
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * tracing is re-enabled.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq /* other probes are enabled, so add the sub-class mask back */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq{ DTRACE_STABILITY_PRIVATE, DTRACE_STABILITY_PRIVATE, DTRACE_CLASS_PLATFORM },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq{ DTRACE_STABILITY_PRIVATE, DTRACE_STABILITY_PRIVATE, DTRACE_CLASS_PLATFORM },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq{ DTRACE_STABILITY_PRIVATE, DTRACE_STABILITY_PRIVATE, DTRACE_CLASS_UNKNOWN },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq{ DTRACE_STABILITY_PRIVATE, DTRACE_STABILITY_PRIVATE, DTRACE_CLASS_PLATFORM },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq{ DTRACE_STABILITY_PRIVATE, DTRACE_STABILITY_PRIVATE, DTRACE_CLASS_PLATFORM },
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq switch (cmd) {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * We might support proper suspend/resume in the future, so,
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * return DDI_FAILURE for now.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq if (ddi_create_minor_node(devi, "xdt", S_IFCHR, 0, DDI_PSEUDO, 0) ==
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq dtrace_register("xdt", &xdt_attr, DTRACE_PRIV_KERNEL, NULL,
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq val = ddi_getprop(DDI_DEV_T_ANY, devi, DDI_PROP_DONTPASS,
55f5292c612446ce6f93ddd248c0019b5974618bFrank Van Der Linden xdt_cpu_schedinfo = (xdt_schedinfo_t *)kmem_zalloc(xdt_ncpus *
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq switch (cmd) {
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * We might support proper suspend/resume in the future. So
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq * return DDI_FAILURE for now.
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq kmem_free(xdt_cpu_schedinfo, xdt_ncpus * sizeof (xdt_schedinfo_t));
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq xdt_devi = (void *)0;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq/*ARGSUSED*/
c7158ae983f5a04c4a998f468ecefba6d23ba721tariqxdt_info(dev_info_t *devi, ddi_info_cmd_t infocmd, void *arg, void **result)
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq *result = (void *)0;
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq 0, /* devo_refcnt */
c7158ae983f5a04c4a998f468ecefba6d23ba721tariq "Hypervisor event tracing",