xref: /xnu-8019.80.24/bsd/sys/sdt_impl.h (revision a325d9c4a84054e40bbe985afedcb50ab80993ea)
1*a325d9c4SApple OSS Distributions /*
2*a325d9c4SApple OSS Distributions  * CDDL HEADER START
3*a325d9c4SApple OSS Distributions  *
4*a325d9c4SApple OSS Distributions  * The contents of this file are subject to the terms of the
5*a325d9c4SApple OSS Distributions  * Common Development and Distribution License, Version 1.0 only
6*a325d9c4SApple OSS Distributions  * (the "License").  You may not use this file except in compliance
7*a325d9c4SApple OSS Distributions  * with the License.
8*a325d9c4SApple OSS Distributions  *
9*a325d9c4SApple OSS Distributions  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*a325d9c4SApple OSS Distributions  * or http://www.opensolaris.org/os/licensing.
11*a325d9c4SApple OSS Distributions  * See the License for the specific language governing permissions
12*a325d9c4SApple OSS Distributions  * and limitations under the License.
13*a325d9c4SApple OSS Distributions  *
14*a325d9c4SApple OSS Distributions  * When distributing Covered Code, include this CDDL HEADER in each
15*a325d9c4SApple OSS Distributions  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*a325d9c4SApple OSS Distributions  * If applicable, add the following below this CDDL HEADER, with the
17*a325d9c4SApple OSS Distributions  * fields enclosed by brackets "[]" replaced with your own identifying
18*a325d9c4SApple OSS Distributions  * information: Portions Copyright [yyyy] [name of copyright owner]
19*a325d9c4SApple OSS Distributions  *
20*a325d9c4SApple OSS Distributions  * CDDL HEADER END
21*a325d9c4SApple OSS Distributions  */
22*a325d9c4SApple OSS Distributions /*
23*a325d9c4SApple OSS Distributions  * Copyright 2004 Sun Microsystems, Inc.  All rights reserved.
24*a325d9c4SApple OSS Distributions  * Use is subject to license terms.
25*a325d9c4SApple OSS Distributions  */
26*a325d9c4SApple OSS Distributions 
27*a325d9c4SApple OSS Distributions #ifndef _SDT_IMPL_H
28*a325d9c4SApple OSS Distributions #define _SDT_IMPL_H
29*a325d9c4SApple OSS Distributions 
30*a325d9c4SApple OSS Distributions #ifdef  __cplusplus
31*a325d9c4SApple OSS Distributions extern "C" {
32*a325d9c4SApple OSS Distributions #endif
33*a325d9c4SApple OSS Distributions 
34*a325d9c4SApple OSS Distributions extern const char *sdt_prefix;
35*a325d9c4SApple OSS Distributions 
36*a325d9c4SApple OSS Distributions typedef struct sdt_probedesc {
37*a325d9c4SApple OSS Distributions 	char                    *sdpd_name;     /* name of this probe */
38*a325d9c4SApple OSS Distributions 	int                     sdpd_namelen;
39*a325d9c4SApple OSS Distributions 	char                    *sdpd_func;     /* APPLE NOTE: function name */
40*a325d9c4SApple OSS Distributions 	const char              *sdpd_prov;     /* APPLE NOTE: provider name */
41*a325d9c4SApple OSS Distributions 	unsigned long           sdpd_offset;    /* offset of call in text */
42*a325d9c4SApple OSS Distributions 	struct sdt_probedesc    *sdpd_next;     /* next static probe */
43*a325d9c4SApple OSS Distributions } sdt_probedesc_t;
44*a325d9c4SApple OSS Distributions 
45*a325d9c4SApple OSS Distributions #ifdef  __cplusplus
46*a325d9c4SApple OSS Distributions }
47*a325d9c4SApple OSS Distributions #endif
48*a325d9c4SApple OSS Distributions 
49*a325d9c4SApple OSS Distributions #ifdef  __cplusplus
50*a325d9c4SApple OSS Distributions extern "C" {
51*a325d9c4SApple OSS Distributions #endif
52*a325d9c4SApple OSS Distributions 
53*a325d9c4SApple OSS Distributions #include <sys/dtrace.h>
54*a325d9c4SApple OSS Distributions 
55*a325d9c4SApple OSS Distributions struct module {
56*a325d9c4SApple OSS Distributions 	int sdt_nprobes;
57*a325d9c4SApple OSS Distributions 	sdt_probedesc_t *sdt_probes;
58*a325d9c4SApple OSS Distributions };
59*a325d9c4SApple OSS Distributions 
60*a325d9c4SApple OSS Distributions extern int sdt_invop(uintptr_t, uintptr_t *, uintptr_t);
61*a325d9c4SApple OSS Distributions extern uint64_t sdt_getarg(void *, dtrace_id_t, void *, int, int);
62*a325d9c4SApple OSS Distributions 
63*a325d9c4SApple OSS Distributions void sdt_provide_module(void *, struct modctl *);
64*a325d9c4SApple OSS Distributions void sdt_early_init(void);
65*a325d9c4SApple OSS Distributions void sdt_load_machsect(struct modctl *ctl);
66*a325d9c4SApple OSS Distributions void sdt_init(void);
67*a325d9c4SApple OSS Distributions 
68*a325d9c4SApple OSS Distributions extern int          sdt_probetab_size;
69*a325d9c4SApple OSS Distributions extern int          sdt_probetab_mask;
70*a325d9c4SApple OSS Distributions #define SDT_ADDR2NDX(addr)  ((((uintptr_t)(addr)) >> 4) & sdt_probetab_mask)
71*a325d9c4SApple OSS Distributions 
72*a325d9c4SApple OSS Distributions 
73*a325d9c4SApple OSS Distributions #if defined(__x86_64__)
74*a325d9c4SApple OSS Distributions typedef uint8_t sdt_instr_t;
75*a325d9c4SApple OSS Distributions #elif defined(__arm__)
76*a325d9c4SApple OSS Distributions typedef uint16_t sdt_instr_t;
77*a325d9c4SApple OSS Distributions #elif defined(__arm64__)
78*a325d9c4SApple OSS Distributions typedef uint32_t sdt_instr_t;
79*a325d9c4SApple OSS Distributions #else
80*a325d9c4SApple OSS Distributions #error Unknown implementation
81*a325d9c4SApple OSS Distributions #endif
82*a325d9c4SApple OSS Distributions 
83*a325d9c4SApple OSS Distributions typedef struct sdt_provider {
84*a325d9c4SApple OSS Distributions 	const char                      *sdtp_name;     /* name of provider */
85*a325d9c4SApple OSS Distributions 	const char                      *sdtp_prefix;   /* prefix for probe names */
86*a325d9c4SApple OSS Distributions 	dtrace_pattr_t          *sdtp_attr;     /* stability attributes */
87*a325d9c4SApple OSS Distributions 	dtrace_provider_id_t    sdtp_id;        /* provider ID */
88*a325d9c4SApple OSS Distributions } sdt_provider_t;
89*a325d9c4SApple OSS Distributions 
90*a325d9c4SApple OSS Distributions extern sdt_provider_t sdt_providers[];          /* array of providers */
91*a325d9c4SApple OSS Distributions 
92*a325d9c4SApple OSS Distributions typedef struct sdt_probe {
93*a325d9c4SApple OSS Distributions 	sdt_provider_t  *sdp_provider;          /* provider */
94*a325d9c4SApple OSS Distributions 	char            *sdp_name;              /* name of probe */
95*a325d9c4SApple OSS Distributions 	int             sdp_namelen;            /* length of allocated name */
96*a325d9c4SApple OSS Distributions 	dtrace_id_t     sdp_id;                 /* probe ID */
97*a325d9c4SApple OSS Distributions 	struct modctl   *sdp_ctl;               /* modctl for module */
98*a325d9c4SApple OSS Distributions 	int             sdp_loadcnt;            /* load count for module */
99*a325d9c4SApple OSS Distributions 	int             sdp_primary;            /* non-zero if primary mod */
100*a325d9c4SApple OSS Distributions 	sdt_instr_t     *sdp_patchpoint;        /* patch point */
101*a325d9c4SApple OSS Distributions 	sdt_instr_t     sdp_patchval;           /* instruction to patch */
102*a325d9c4SApple OSS Distributions 	sdt_instr_t     sdp_savedval;           /* saved instruction value */
103*a325d9c4SApple OSS Distributions 	struct sdt_probe *sdp_next;             /* next probe */
104*a325d9c4SApple OSS Distributions 	struct sdt_probe *sdp_hashnext;         /* next on hash */
105*a325d9c4SApple OSS Distributions } sdt_probe_t;
106*a325d9c4SApple OSS Distributions 
107*a325d9c4SApple OSS Distributions typedef struct sdt_argdesc {
108*a325d9c4SApple OSS Distributions 	const char *sda_provider;               /* provider for arg */
109*a325d9c4SApple OSS Distributions 	const char *sda_name;                   /* name of probe */
110*a325d9c4SApple OSS Distributions 	const int sda_ndx;                      /* argument index */
111*a325d9c4SApple OSS Distributions 	const int sda_mapping;                  /* mapping of argument */
112*a325d9c4SApple OSS Distributions 	const char *sda_native;                 /* native type of argument */
113*a325d9c4SApple OSS Distributions 	const char *sda_xlate;                  /* translated type of arg */
114*a325d9c4SApple OSS Distributions } sdt_argdesc_t;
115*a325d9c4SApple OSS Distributions 
116*a325d9c4SApple OSS Distributions extern void sdt_getargdesc(void *, dtrace_id_t, void *, dtrace_argdesc_t *);
117*a325d9c4SApple OSS Distributions 
118*a325d9c4SApple OSS Distributions #ifdef  __cplusplus
119*a325d9c4SApple OSS Distributions }
120*a325d9c4SApple OSS Distributions #endif
121*a325d9c4SApple OSS Distributions 
122*a325d9c4SApple OSS Distributions #endif  /* _SDT_IMPL_H */
123