<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
p.msonormal0, li.msonormal0, div.msonormal0
        {mso-style-name:msonormal;
        mso-margin-top-alt:auto;
        margin-right:0cm;
        mso-margin-bottom-alt:auto;
        margin-left:0cm;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.EmailStyle18
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-IN" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Hello Dwarf experts.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I am currently working trying to encode dwarf of binaries with having bi-endian variables marked with DW_AT_endianity attribute.<o:p></o:p></p>
<p class="MsoNormal">The location calculation for some  variable depends on other variable with different endianity, also the value of this other variable is known at runtime.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">At the moment I am using location list to calculate the correct location of first variable and list of dwarf operators to reverse the endianity of variable “__gbloffset__” in below case (I only needed lower 32 bits on 64 bit machine).<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">0x000001e5: DW_TAG_base_type<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:36.0pt"> DW_AT_byte_size  (0x04)<o:p></o:p></p>
<p class="MsoNormal" style="text-indent:36.0pt">  DW_AT_encoding  (DW_ATE_signed)<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_name      ("int")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_endianity (DW_END_big)<o:p></o:p></p>
<p class="MsoNormal">…<o:p></o:p></p>
<p class="MsoNormal">0x00000057:   DW_TAG_variable<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_name      ("__gbloffset__")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_type      (0x000001e5 "int")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_external  (true)<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_decl_file ("…")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_decl_line (8)<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_location  (DW_OP_addr 0) // pre linkage<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_linkage_name      ("_gblsection__")<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">0x00000170:   DW_TAG_variable<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_name      ("VAR1")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_type      (0x0000010b "fixed.dec.display.72")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_decl_file ("…")<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_decl_line (10)<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_location  (DW_OP_addr 0x0, DW_OP_call4 0x57, DW_OP_deref_size, 4,<o:p></o:p></p>
<p class="MsoNormal"><span style="color:#FFC000">DW_OP_dup, DW_OP_constu 0xff, DW_OP_lit0, DW_OP_shl, DW_OP_and, DW_OP_lit24, DW_OP_shl, DW_OP_swap, DW_OP_dup, DW_OP_constu 0xff, DW_OP_lit8, DW_OP_shl, DW_OP_and, DW_OP_lit8, DW_OP_shl, DW_OP_swap, DW_OP_dup,
 DW_OP_constu 0xff, DW_OP_lit16, DW_OP_shl, DW_OP_and, DW_OP_lit8, DW_OP_shr, DW_OP_swap, DW_OP_constu 0xff, DW_OP_lit24, DW_OP_shl, DW_OP_and, DW_OP_lit24, DW_OP_shr, DW_OP_swap, DW_OP_or, DW_OP_or, DW_OP_or</span>, DW_OP_plus)<o:p></o:p></p>
<p class="MsoNormal">                DW_AT_linkage_name      ("VAR1")<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">In above snippet of dwarf dump, I am using yellow highlighted list of operators to swap the bytes.<o:p></o:p></p>
<p class="MsoNormal">I think there should be a support for DW_OP_byte_swap simple operator to accomplice this simple task. Does this idea looks like it can be useful? Is there any specific reason why dwarf spec does not have it or I am missing something subtle.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I hope I conveyed the idea properly, apologies in advanced as English is not my first language.
<o:p></o:p></p>
<p class="MsoNormal"><b><span lang="EN-US" style="color:#2F5597;mso-fareast-language:FR-BE"><o:p> </o:p></span></b></p>
<p class="MsoNormal"><b><span lang="EN-US" style="color:#2F5597;mso-fareast-language:FR-BE">Thanks and regards,<o:p></o:p></span></b></p>
<p class="MsoNormal"><b><span lang="EN-US" style="color:#2F5597;mso-fareast-language:FR-BE"><o:p> </o:p></span></b></p>
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Chirag Patel</span></b><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE"><o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Software Engineer | Raincode Labs India
<o:p></o:p></span></p>
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Tel</span></b><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">: (+91) 080 41159811<o:p></o:p></span></p>
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Mob</span></b><span lang="EN-US" style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">: (+91) 9049336744<o:p></o:p></span></p>
<p class="MsoNormal"><a href="http://www.raincodelabs.com/"><span lang="EN-US" style="font-size:12.0pt;color:#0563C1;mso-fareast-language:FR-BE">www.raincodelabs.com</span></a><u><span lang="EN-US" style="font-size:12.0pt;color:blue;mso-fareast-language:FR-BE"><o:p></o:p></span></u></p>
<p class="MsoNormal"><a href="https://in.linkedin.com/in/chirag-patel-"><span style="font-size:10.0pt;color:#0563C1;mso-fareast-language:FR-BE;text-decoration:none"><img border="0" width="180" height="60" style="width:1.875in;height:.625in" id="Picture_x0020_1" src="cid:image001.png@01D58D92.1A9A9E60" alt="linkedin-button"></span></a><span style="font-size:10.0pt;color:#2F5597;mso-fareast-language:FR-BE"><o:p></o:p></span></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>