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