dt_parser.h revision 178479
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 (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21/*
22 * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
23 * Use is subject to license terms.
24 */
25
26#ifndef	_DT_PARSER_H
27#define	_DT_PARSER_H
28
29#pragma ident	"%Z%%M%	%I%	%E% SMI"
30
31#include <sys/types.h>
32#include <sys/dtrace.h>
33
34#include <libctf.h>
35#include <stdarg.h>
36#include <stdio.h>
37
38#ifdef	__cplusplus
39extern "C" {
40#endif
41
42#include <dt_errtags.h>
43#include <dt_ident.h>
44#include <dt_decl.h>
45#include <dt_xlator.h>
46#include <dt_list.h>
47
48typedef struct dt_node {
49	ctf_file_t *dn_ctfp;	/* CTF type container for node's type */
50	ctf_id_t dn_type;	/* CTF type reference for node's type */
51	uchar_t dn_kind;	/* node kind (DT_NODE_*, defined below) */
52	uchar_t dn_flags;	/* node flags (DT_NF_*, defined below) */
53	ushort_t dn_op;		/* operator (DT_TOK_*, defined by lex) */
54	int dn_line;		/* line number for error messages */
55	int dn_reg;		/* register allocated by cg */
56	dtrace_attribute_t dn_attr; /* node stability attributes */
57
58	/*
59	 * D compiler nodes, as is the usual style, contain a union of the
60	 * different sub-elements required by the various kinds of nodes.
61	 * These sub-elements are accessed using the macros defined below.
62	 */
63	union {
64		struct {
65			uintmax_t _value;	/* integer value */
66			char *_string;		/* string value */
67		} _const;
68
69		struct {
70			dt_ident_t *_ident;	/* identifier reference */
71			struct dt_node *_links[3]; /* child node pointers */
72		} _nodes;
73
74		struct {
75			struct dt_node *_descs;	/* list of descriptions */
76			struct dt_node *_pred;	/* predicate expression */
77			struct dt_node *_acts;	/* action statement list */
78			dt_idhash_t *_locals;	/* local variable hash */
79			dtrace_attribute_t _attr; /* context attributes */
80		} _clause;
81
82		struct {
83			char *_spec;		/* specifier string (if any) */
84			dtrace_probedesc_t *_desc; /* final probe description */
85		} _pdesc;
86
87		struct {
88			char *_name;		/* string name of member */
89			struct dt_node *_expr;	/* expression node pointer */
90			dt_xlator_t *_xlator;	/* translator reference */
91			uint_t _id;		/* member identifier */
92		} _member;
93
94		struct {
95			dt_xlator_t *_xlator;	/* translator reference */
96			struct dt_node *_xmemb;	/* individual xlator member */
97			struct dt_node *_membs;	/* list of member nodes */
98		} _xlator;
99
100		struct {
101			char *_name;		/* string name of provider */
102			struct dt_provider *_pvp; /* provider references */
103			struct dt_node *_probes;  /* list of probe nodes */
104			int _redecl;		/* provider redeclared */
105		} _provider;
106	} dn_u;
107
108	struct dt_node *dn_list; /* parse tree list link */
109	struct dt_node *dn_link; /* allocation list link */
110} dt_node_t;
111
112#define	dn_value	dn_u._const._value	/* DT_NODE_INT */
113#define	dn_string	dn_u._const._string	/* STRING, IDENT, TYPE */
114#define	dn_ident	dn_u._nodes._ident	/* VAR,SYM,FUN,AGG,INL,PROBE */
115#define	dn_args		dn_u._nodes._links[0]	/* DT_NODE_VAR, FUNC */
116#define	dn_child	dn_u._nodes._links[0]	/* DT_NODE_OP1 */
117#define	dn_left		dn_u._nodes._links[0]	/* DT_NODE_OP2, OP3 */
118#define	dn_right	dn_u._nodes._links[1]	/* DT_NODE_OP2, OP3 */
119#define	dn_expr		dn_u._nodes._links[2]	/* DT_NODE_OP3, DEXPR */
120#define	dn_aggfun	dn_u._nodes._links[0]	/* DT_NODE_AGG */
121#define	dn_aggtup	dn_u._nodes._links[1]	/* DT_NODE_AGG */
122#define	dn_pdescs	dn_u._clause._descs	/* DT_NODE_CLAUSE */
123#define	dn_pred		dn_u._clause._pred	/* DT_NODE_CLAUSE */
124#define	dn_acts		dn_u._clause._acts	/* DT_NODE_CLAUSE */
125#define	dn_locals	dn_u._clause._locals	/* DT_NODE_CLAUSE */
126#define	dn_ctxattr	dn_u._clause._attr	/* DT_NODE_CLAUSE */
127#define	dn_spec		dn_u._pdesc._spec	/* DT_NODE_PDESC */
128#define	dn_desc		dn_u._pdesc._desc	/* DT_NODE_PDESC */
129#define	dn_membname	dn_u._member._name	/* DT_NODE_MEMBER */
130#define	dn_membexpr	dn_u._member._expr	/* DT_NODE_MEMBER */
131#define	dn_membxlator	dn_u._member._xlator	/* DT_NODE_MEMBER */
132#define	dn_membid	dn_u._member._id	/* DT_NODE_MEMBER */
133#define	dn_xlator	dn_u._xlator._xlator	/* DT_NODE_XLATOR */
134#define	dn_xmember	dn_u._xlator._xmemb	/* DT_NODE_XLATOR */
135#define	dn_members	dn_u._xlator._membs	/* DT_NODE_XLATOR */
136#define	dn_provname	dn_u._provider._name	/* DT_NODE_PROVIDER */
137#define	dn_provider	dn_u._provider._pvp	/* DT_NODE_PROVIDER */
138#define	dn_provred	dn_u._provider._redecl	/* DT_NODE_PROVIDER */
139#define	dn_probes	dn_u._provider._probes	/* DT_NODE_PROVIDER */
140
141#define	DT_NODE_FREE	0	/* unused node (waiting to be freed) */
142#define	DT_NODE_INT	1	/* integer value */
143#define	DT_NODE_STRING	2	/* string value */
144#define	DT_NODE_IDENT	3	/* identifier */
145#define	DT_NODE_VAR	4	/* variable reference */
146#define	DT_NODE_SYM	5	/* symbol reference */
147#define	DT_NODE_TYPE	6	/* type reference or formal parameter */
148#define	DT_NODE_FUNC	7	/* function call */
149#define	DT_NODE_OP1	8	/* unary operator */
150#define	DT_NODE_OP2	9	/* binary operator */
151#define	DT_NODE_OP3	10	/* ternary operator */
152#define	DT_NODE_DEXPR	11	/* D expression action */
153#define	DT_NODE_DFUNC	12	/* D function action */
154#define	DT_NODE_AGG	13	/* aggregation */
155#define	DT_NODE_PDESC	14	/* probe description */
156#define	DT_NODE_CLAUSE	15	/* clause definition */
157#define	DT_NODE_INLINE	16	/* inline definition */
158#define	DT_NODE_MEMBER	17	/* member definition */
159#define	DT_NODE_XLATOR	18	/* translator definition */
160#define	DT_NODE_PROBE	19	/* probe definition */
161#define	DT_NODE_PROVIDER 20	/* provider definition */
162#define	DT_NODE_PROG	21	/* program translation unit */
163
164#define	DT_NF_SIGNED	0x01	/* data is a signed quantity (else unsigned) */
165#define	DT_NF_COOKED	0x02	/* data is a known type (else still cooking) */
166#define	DT_NF_REF	0x04	/* pass by reference (array, struct, union) */
167#define	DT_NF_LVALUE	0x08	/* node is an l-value according to ANSI-C */
168#define	DT_NF_WRITABLE	0x10	/* node is writable (can be modified) */
169#define	DT_NF_BITFIELD	0x20	/* node is an integer bitfield */
170#define	DT_NF_USERLAND	0x40	/* data is a userland address */
171
172#define	DT_TYPE_NAMELEN	128	/* reasonable size for ctf_type_name() */
173
174extern int dt_node_is_integer(const dt_node_t *);
175extern int dt_node_is_float(const dt_node_t *);
176extern int dt_node_is_scalar(const dt_node_t *);
177extern int dt_node_is_arith(const dt_node_t *);
178extern int dt_node_is_vfptr(const dt_node_t *);
179extern int dt_node_is_dynamic(const dt_node_t *);
180extern int dt_node_is_stack(const dt_node_t *);
181extern int dt_node_is_symaddr(const dt_node_t *);
182extern int dt_node_is_usymaddr(const dt_node_t *);
183extern int dt_node_is_string(const dt_node_t *);
184extern int dt_node_is_strcompat(const dt_node_t *);
185extern int dt_node_is_pointer(const dt_node_t *);
186extern int dt_node_is_void(const dt_node_t *);
187extern int dt_node_is_ptrcompat(const dt_node_t *, const dt_node_t *,
188	ctf_file_t **, ctf_id_t *);
189extern int dt_node_is_argcompat(const dt_node_t *, const dt_node_t *);
190extern int dt_node_is_posconst(const dt_node_t *);
191extern int dt_node_is_actfunc(const dt_node_t *);
192
193extern dt_node_t *dt_node_int(uintmax_t);
194extern dt_node_t *dt_node_string(char *);
195extern dt_node_t *dt_node_ident(char *);
196extern dt_node_t *dt_node_type(dt_decl_t *);
197extern dt_node_t *dt_node_vatype(void);
198extern dt_node_t *dt_node_decl(void);
199extern dt_node_t *dt_node_func(dt_node_t *, dt_node_t *);
200extern dt_node_t *dt_node_offsetof(dt_decl_t *, char *);
201extern dt_node_t *dt_node_op1(int, dt_node_t *);
202extern dt_node_t *dt_node_op2(int, dt_node_t *, dt_node_t *);
203extern dt_node_t *dt_node_op3(dt_node_t *, dt_node_t *, dt_node_t *);
204extern dt_node_t *dt_node_statement(dt_node_t *);
205extern dt_node_t *dt_node_pdesc_by_name(char *);
206extern dt_node_t *dt_node_pdesc_by_id(uintmax_t);
207extern dt_node_t *dt_node_clause(dt_node_t *, dt_node_t *, dt_node_t *);
208extern dt_node_t *dt_node_inline(dt_node_t *);
209extern dt_node_t *dt_node_member(dt_decl_t *, char *, dt_node_t *);
210extern dt_node_t *dt_node_xlator(dt_decl_t *, dt_decl_t *, char *, dt_node_t *);
211extern dt_node_t *dt_node_probe(char *, int, dt_node_t *, dt_node_t *);
212extern dt_node_t *dt_node_provider(char *, dt_node_t *);
213extern dt_node_t *dt_node_program(dt_node_t *);
214
215extern dt_node_t *dt_node_link(dt_node_t *, dt_node_t *);
216extern dt_node_t *dt_node_cook(dt_node_t *, uint_t);
217
218extern dt_node_t *dt_node_xalloc(dtrace_hdl_t *, int);
219extern void dt_node_free(dt_node_t *);
220
221extern dtrace_attribute_t dt_node_list_cook(dt_node_t **, uint_t);
222extern void dt_node_list_free(dt_node_t **);
223extern void dt_node_link_free(dt_node_t **);
224
225extern void dt_node_attr_assign(dt_node_t *, dtrace_attribute_t);
226extern void dt_node_type_assign(dt_node_t *, ctf_file_t *, ctf_id_t);
227extern void dt_node_type_propagate(const dt_node_t *, dt_node_t *);
228extern const char *dt_node_type_name(const dt_node_t *, char *, size_t);
229extern size_t dt_node_type_size(const dt_node_t *);
230
231extern dt_ident_t *dt_node_resolve(const dt_node_t *, uint_t);
232extern size_t dt_node_sizeof(const dt_node_t *);
233extern void dt_node_promote(dt_node_t *, dt_node_t *, dt_node_t *);
234
235extern void dt_node_diftype(dtrace_hdl_t *,
236    const dt_node_t *, dtrace_diftype_t *);
237extern void dt_node_printr(dt_node_t *, FILE *, int);
238extern const char *dt_node_name(const dt_node_t *, char *, size_t);
239extern int dt_node_root(dt_node_t *);
240
241struct dtrace_typeinfo;	/* see <dtrace.h> */
242struct dt_pcb;		/* see <dt_impl.h> */
243
244#define	IS_CHAR(e) \
245	(((e).cte_format & (CTF_INT_CHAR | CTF_INT_SIGNED)) == \
246	(CTF_INT_CHAR | CTF_INT_SIGNED) && (e).cte_bits == NBBY)
247
248#define	IS_VOID(e) \
249	((e).cte_offset == 0 && (e).cte_bits == 0)
250
251extern int dt_type_lookup(const char *, struct dtrace_typeinfo *);
252extern int dt_type_pointer(struct dtrace_typeinfo *);
253extern const char *dt_type_name(ctf_file_t *, ctf_id_t, char *, size_t);
254
255typedef enum {
256	YYS_CLAUSE,	/* lex/yacc state for finding program clauses */
257	YYS_DEFINE,	/* lex/yacc state for parsing persistent definitions */
258	YYS_EXPR,	/* lex/yacc state for parsing D expressions */
259	YYS_DONE,	/* lex/yacc state for indicating parse tree is done */
260	YYS_CONTROL	/* lex/yacc state for parsing control lines */
261} yystate_t;
262
263extern void dnerror(const dt_node_t *, dt_errtag_t, const char *, ...);
264extern void dnwarn(const dt_node_t *, dt_errtag_t, const char *, ...);
265
266extern void xyerror(dt_errtag_t, const char *, ...);
267extern void xywarn(dt_errtag_t, const char *, ...);
268extern void xyvwarn(dt_errtag_t, const char *, va_list);
269
270extern void yyerror(const char *, ...);
271extern void yywarn(const char *, ...);
272extern void yyvwarn(const char *, va_list);
273
274extern void yylabel(const char *);
275extern void yybegin(yystate_t);
276extern void yyinit(struct dt_pcb *);
277
278extern int yyparse(void);
279extern int yyinput(void);
280
281#ifdef	__cplusplus
282}
283#endif
284
285#endif	/* _DT_PARSER_H */
286