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