]> CyberLeo.Net >> Repos - FreeBSD/releng/10.2.git/blob - cddl/contrib/opensolaris/lib/libdtrace/common/dt_decl.h
- Copy stable/10@285827 to releng/10.2 in preparation for 10.2-RC1
[FreeBSD/releng/10.2.git] / cddl / contrib / opensolaris / lib / libdtrace / common / dt_decl.h
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 /*
27  * Copyright (c) 2013 by Delphix. All rights reserved.
28  * Copyright (c) 2013 Joyent, Inc. All rights reserved.
29  */
30
31 #ifndef _DT_DECL_H
32 #define _DT_DECL_H
33
34 #include <sys/types.h>
35 #include <libctf.h>
36 #include <dtrace.h>
37 #include <stdio.h>
38
39 #ifdef  __cplusplus
40 extern "C" {
41 #endif
42
43 struct dt_node;                         /* forward declaration of dt_node_t */
44
45 typedef struct dt_decl {
46         ushort_t dd_kind;               /* declaration kind (CTF_K_* kind) */
47         ushort_t dd_attr;               /* attributes (DT_DA_* flags) */
48         ctf_file_t *dd_ctfp;            /* CTF container for decl's type */
49         ctf_id_t dd_type;               /* CTF identifier for decl's type */
50         char *dd_name;                  /* string name of this decl (or NULL) */
51         struct dt_node *dd_node;        /* node for array size or parm list */
52         struct dt_decl *dd_next;        /* next declaration in list */
53 } dt_decl_t;
54
55 #define DT_DA_SIGNED    0x0001          /* signed integer value */
56 #define DT_DA_UNSIGNED  0x0002          /* unsigned integer value */
57 #define DT_DA_SHORT     0x0004          /* short integer value */
58 #define DT_DA_LONG      0x0008          /* long integer or double */
59 #define DT_DA_LONGLONG  0x0010          /* long long integer value */
60 #define DT_DA_CONST     0x0020          /* qualify type as const */
61 #define DT_DA_RESTRICT  0x0040          /* qualify type as restrict */
62 #define DT_DA_VOLATILE  0x0080          /* qualify type as volatile */
63 #define DT_DA_PAREN     0x0100          /* parenthesis tag */
64 #define DT_DA_USER      0x0200          /* user-land type specifier */
65
66 typedef enum dt_dclass {
67         DT_DC_DEFAULT,                  /* no storage class specified */
68         DT_DC_AUTO,                     /* automatic storage */
69         DT_DC_REGISTER,                 /* register storage */
70         DT_DC_STATIC,                   /* static storage */
71         DT_DC_EXTERN,                   /* extern storage */
72         DT_DC_TYPEDEF,                  /* type definition */
73         DT_DC_SELF,                     /* thread-local storage */
74         DT_DC_THIS                      /* clause-local storage */
75 } dt_dclass_t;
76
77 typedef struct dt_scope {
78         dt_decl_t *ds_decl;             /* pointer to top of decl stack */
79         struct dt_scope *ds_next;       /* pointer to next scope */
80         char *ds_ident;                 /* identifier for this scope (if any) */
81         ctf_file_t *ds_ctfp;            /* CTF container for this scope */
82         ctf_id_t ds_type;               /* CTF id of enclosing type */
83         dt_dclass_t ds_class;           /* declaration class for this scope */
84         int ds_enumval;                 /* most recent enumerator value */
85 } dt_scope_t;
86
87 extern dt_decl_t *dt_decl_alloc(ushort_t, char *);
88 extern void dt_decl_free(dt_decl_t *);
89 extern void dt_decl_reset(void);
90 extern dt_decl_t *dt_decl_push(dt_decl_t *);
91 extern dt_decl_t *dt_decl_pop(void);
92 extern dt_decl_t *dt_decl_pop_param(char **);
93 extern dt_decl_t *dt_decl_top(void);
94
95 extern dt_decl_t *dt_decl_ident(char *);
96 extern void dt_decl_class(dt_dclass_t);
97
98 #define DT_DP_VARARGS   0x1             /* permit varargs in prototype */
99 #define DT_DP_DYNAMIC   0x2             /* permit dynamic type in prototype */
100 #define DT_DP_VOID      0x4             /* permit void type in prototype */
101 #define DT_DP_ANON      0x8             /* permit anonymous parameters */
102
103 extern int dt_decl_prototype(struct dt_node *, struct dt_node *,
104     const char *, uint_t);
105
106 extern dt_decl_t *dt_decl_spec(ushort_t, char *);
107 extern dt_decl_t *dt_decl_attr(ushort_t);
108 extern dt_decl_t *dt_decl_array(struct dt_node *);
109 extern dt_decl_t *dt_decl_func(dt_decl_t *, struct dt_node *);
110 extern dt_decl_t *dt_decl_ptr(void);
111
112 extern dt_decl_t *dt_decl_sou(uint_t, char *);
113 extern void dt_decl_member(struct dt_node *);
114
115 extern dt_decl_t *dt_decl_enum(char *);
116 extern void dt_decl_enumerator(char *, struct dt_node *);
117
118 extern int dt_decl_type(dt_decl_t *, dtrace_typeinfo_t *);
119
120 extern void dt_scope_create(dt_scope_t *);
121 extern void dt_scope_destroy(dt_scope_t *);
122 extern void dt_scope_push(ctf_file_t *, ctf_id_t);
123 extern dt_decl_t *dt_scope_pop(void);
124
125 #ifdef  __cplusplus
126 }
127 #endif
128
129 #endif  /* _DT_DECL_H */