xref: /freebsd/contrib/elftoolchain/libdwarf/dwarf_new_expr.3 (revision 2de3b87a120614a3b053be7dd845b72f1e9ce804)
1*2de3b87aSKai Wang.\" Copyright (c) 2011 Kai Wang
2*2de3b87aSKai Wang.\" All rights reserved.
3*2de3b87aSKai Wang.\"
4*2de3b87aSKai Wang.\" Redistribution and use in source and binary forms, with or without
5*2de3b87aSKai Wang.\" modification, are permitted provided that the following conditions
6*2de3b87aSKai Wang.\" are met:
7*2de3b87aSKai Wang.\" 1. Redistributions of source code must retain the above copyright
8*2de3b87aSKai Wang.\"    notice, this list of conditions and the following disclaimer.
9*2de3b87aSKai Wang.\" 2. Redistributions in binary form must reproduce the above copyright
10*2de3b87aSKai Wang.\"    notice, this list of conditions and the following disclaimer in the
11*2de3b87aSKai Wang.\"    documentation and/or other materials provided with the distribution.
12*2de3b87aSKai Wang.\"
13*2de3b87aSKai Wang.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
14*2de3b87aSKai Wang.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15*2de3b87aSKai Wang.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16*2de3b87aSKai Wang.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17*2de3b87aSKai Wang.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18*2de3b87aSKai Wang.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19*2de3b87aSKai Wang.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20*2de3b87aSKai Wang.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21*2de3b87aSKai Wang.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22*2de3b87aSKai Wang.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23*2de3b87aSKai Wang.\" SUCH DAMAGE.
24*2de3b87aSKai Wang.\"
25*2de3b87aSKai Wang.\" $Id: dwarf_new_expr.3 2074 2011-10-27 03:34:33Z jkoshy $
26*2de3b87aSKai Wang.\"
27*2de3b87aSKai Wang.Dd September 8, 2011
28*2de3b87aSKai Wang.Os
29*2de3b87aSKai Wang.Dt DWARF_NEW_EXPR 3
30*2de3b87aSKai Wang.Sh NAME
31*2de3b87aSKai Wang.Nm dwarf_new_expr
32*2de3b87aSKai Wang.Nd create a location expression descriptor
33*2de3b87aSKai Wang.Sh LIBRARY
34*2de3b87aSKai Wang.Lb libdwarf
35*2de3b87aSKai Wang.Sh SYNOPSIS
36*2de3b87aSKai Wang.In libdwarf.h
37*2de3b87aSKai Wang.Ft "Dwarf_P_Expr"
38*2de3b87aSKai Wang.Fo dwarf_new_expr
39*2de3b87aSKai Wang.Fa "Dwarf_P_Debug dbg"
40*2de3b87aSKai Wang.Fa "Dwarf_Error *err"
41*2de3b87aSKai Wang.Fc
42*2de3b87aSKai Wang.Sh DESCRIPTION
43*2de3b87aSKai WangFunction
44*2de3b87aSKai Wang.Fn dwarf_new_expr
45*2de3b87aSKai Wangallocates a DWARF location expression descriptor used to build up a
46*2de3b87aSKai Wanglocation expression stream.
47*2de3b87aSKai Wang.Pp
48*2de3b87aSKai WangThe application can use the functions
49*2de3b87aSKai Wang.Xr dwarf_add_expr_gen 3
50*2de3b87aSKai Wangand
51*2de3b87aSKai Wang.Xr dwarf_add_expr_addr_b 3
52*2de3b87aSKai Wangto add location expression operators to the created descriptor.
53*2de3b87aSKai WangWhen done, the application can call the function
54*2de3b87aSKai Wang.Xr dwarf_expr_into_block 3
55*2de3b87aSKai Wangto retrieve the generated byte stream for the location expression,
56*2de3b87aSKai Wangor call the function
57*2de3b87aSKai Wang.Xr dwarf_add_AT_location_expr 3
58*2de3b87aSKai Wangto create an attribute with the location expression stream as its
59*2de3b87aSKai Wangvalue.
60*2de3b87aSKai Wang.Pp
61*2de3b87aSKai WangArgument
62*2de3b87aSKai Wang.Ar dbg
63*2de3b87aSKai Wangshould reference a DWARF producer instance allocated using
64*2de3b87aSKai Wang.Xr dwarf_producer_init 3
65*2de3b87aSKai Wangor
66*2de3b87aSKai Wang.Xr dwarf_producer_init_b 3 .
67*2de3b87aSKai Wang.Pp
68*2de3b87aSKai WangIf argument
69*2de3b87aSKai Wang.Ar err
70*2de3b87aSKai Wangis not NULL, it will be used to store error information in case
71*2de3b87aSKai Wangof an error.
72*2de3b87aSKai Wang.Sh RETURN VALUES
73*2de3b87aSKai WangOn success, function
74*2de3b87aSKai Wang.Fn dwarf_new_expr
75*2de3b87aSKai Wangreturns the created location expression descriptor.
76*2de3b87aSKai WangIn case of an error, function
77*2de3b87aSKai Wang.Fn dwarf_new_expr
78*2de3b87aSKai Wangreturns
79*2de3b87aSKai Wang.Dv DW_DLV_BADADDR
80*2de3b87aSKai Wangand sets the argument
81*2de3b87aSKai Wang.Ar err .
82*2de3b87aSKai Wang.Sh ERRORS
83*2de3b87aSKai WangFunction
84*2de3b87aSKai Wang.Fn dwarf_new_expr
85*2de3b87aSKai Wangcan fail with:
86*2de3b87aSKai Wang.Bl -tag -width ".Bq Er DW_DLE_ARGUMENT"
87*2de3b87aSKai Wang.It Bq Er DW_DLE_ARGUMENT
88*2de3b87aSKai WangArgument
89*2de3b87aSKai Wang.Ar dbg
90*2de3b87aSKai Wangwas NULL.
91*2de3b87aSKai Wang.It Bq Er DW_DLE_MEMORY
92*2de3b87aSKai WangAn out of memory condition was encountered during the execution of
93*2de3b87aSKai Wangthe function.
94*2de3b87aSKai Wang.El
95*2de3b87aSKai Wang.Sh EXAMPLES
96*2de3b87aSKai WangTo create a location expression descriptor, add location expression
97*2de3b87aSKai Wangoperators to it and to retrieve the generated byte stream,
98*2de3b87aSKai Wanguse:
99*2de3b87aSKai Wang.Bd -literal -offset indent
100*2de3b87aSKai WangDwarf_P_Debug dbg;
101*2de3b87aSKai WangDwarf_Error de;
102*2de3b87aSKai WangDwarf_P_Expr pe;
103*2de3b87aSKai WangDwarf_Addr buf;
104*2de3b87aSKai WangDwarf_Unsigned len;
105*2de3b87aSKai Wang
106*2de3b87aSKai Wang/* ...Assume that `dbg' refers to a DWARF producer instance... */
107*2de3b87aSKai Wang
108*2de3b87aSKai Wangif ((pe = dwarf_new_expr(dbg, &de)) == DW_DLV_BADADDR) {
109*2de3b87aSKai Wang	warnx("dwarf_new_expr failed: %s", dwarf_errmsg(-1));
110*2de3b87aSKai Wang	return;
111*2de3b87aSKai Wang}
112*2de3b87aSKai Wang
113*2de3b87aSKai Wangif (dwarf_add_expr_gen(pe, DW_OP_regx, 55, 0, &de) ==
114*2de3b87aSKai Wang    DW_DLV_NOCOUNT) {
115*2de3b87aSKai Wang	warnx("dwarf_add_expr_gen failed: %s", dwarf_errmsg(-1));
116*2de3b87aSKai Wang	return;
117*2de3b87aSKai Wang}
118*2de3b87aSKai Wang
119*2de3b87aSKai Wangif ((buf = dwarf_expr_into_block(pe, &len, &de)) ==
120*2de3b87aSKai Wang    DW_DLV_BADADDR) {
121*2de3b87aSKai Wang	warnx("dwarf_expr_into_block failed: %s",
122*2de3b87aSKai Wang	    dwarf_errmsg(-1));
123*2de3b87aSKai Wang	return;
124*2de3b87aSKai Wang}
125*2de3b87aSKai Wang.Ed
126*2de3b87aSKai Wang.Sh SEE ALSO
127*2de3b87aSKai Wang.Xr dwarf 3 ,
128*2de3b87aSKai Wang.Xr dwarf_add_AT_location_expr 3 ,
129*2de3b87aSKai Wang.Xr dwarf_add_expr_gen 3 ,
130*2de3b87aSKai Wang.Xr dwarf_add_expr_addr 3 ,
131*2de3b87aSKai Wang.Xr dwarf_add_expr_addr_b 3 ,
132*2de3b87aSKai Wang.Xr dwarf_expr_current_offset 3 ,
133*2de3b87aSKai Wang.Xr dwarf_expr_into_block 3 ,
134*2de3b87aSKai Wang.Xr dwarf_producer_init 3 ,
135*2de3b87aSKai Wang.Xr dwarf_producer_init_b 3
136