<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:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
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:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.EmailStyle18
        {mso-style-type:personal;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
span.EmailStyle19
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
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-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Hello Chirag,<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Regarding a byte-swap operation, it seems that you have a reasonable use-case on a bi-endian machine.  Feel free to request a new operator on the “public comments” page at
<a href="http://dwarfstd.org/Comment.php">http://dwarfstd.org/Comment.php</a> <o:p>
</o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Note that a byte-swap operator would swap all bytes in the top-of-stack value, which on your 64-bit machine would of course be a 64-bit value.  As you want a 32-bit swapped value, you would still need to do a shift afterward, but even so,
 “DW_OP_byte_swap DW_OP_const1u 32 DW_OP_shr” would be considerably shorter than what you have to do now. 
<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Of course a new operator would be introduced in a new DWARF revision, which is likely to be years away.  In the meantime let me suggest a shorter expression for doing the byte-swap operation.  The book “Hacker’s Delight” shows a straightforward
 32-bit byte swap with masks no wider than 16 bits, as follows:<o:p></o:p></p>
<p class="MsoNormal">               x = (x << 24) | ((x & 0xff00) << 8) | ((x >> 8) & 0xff00) | (x >> 24);<o:p></o:p></p>
<p class="MsoNormal">Your 64-bit machine will of course use 64-bit values on the expression stack, so to keep the result “32-bit clean” we want to do one additional mask:<o:p></o:p></p>
<p class="MsoNormal">               x = ((x & 0xff) << 24) | ((x & 0xff00) << 8) | ((x >> 8) & 0xff00) | (x >> 24);<o:p></o:p></p>
<p class="MsoNormal">Translating this into a DWARF expression, I get the following:<o:p></o:p></p>
<p class="MsoNormal">               DW_OP_dup, DW_OP_const1u 0xff, DW_OP_and, DW_OP_lit24, DW_OP_shl, DW_OP_swap, DW_OP_dup, DW_OP_const2u 0xff00, DW_OP_and, DW_OP_lit8, DW_OP_shl, DW_OP_swap, DW_OP_dup, DW_OP_lit8, DW_OP_shr, DW_OP_const2u 0xff00, DW_OP_and,
 DW_OP_swap, DW_OP_lit24, DW_OP_shr, DW_OP_or, DW_OP_or, DW_OP_or<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I hope this is helpful to you.<o:p></o:p></p>
<p class="MsoNormal">--paulr<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b>From:</b> Dwarf-Discuss <dwarf-discuss-bounces@lists.dwarfstd.org>
<b>On Behalf Of </b>Chirag Patel via Dwarf-Discuss<br>
<b>Sent:</b> Monday, October 28, 2019 12:47 AM<br>
<b>To:</b> dwarf-discuss@lists.dwarfstd.org<br>
<b>Subject:</b> [Dwarf-Discuss] dwarf stack operator for byte swap.<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><span lang="EN-IN">Hello Dwarf experts.<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">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></span></p>
<p class="MsoNormal"><span lang="EN-IN">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></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">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></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">0x000001e5: DW_TAG_base_type<o:p></o:p></span></p>
<p class="MsoNormal" style="text-indent:.5in"><span lang="EN-IN"> DW_AT_byte_size  (0x04)<o:p></o:p></span></p>
<p class="MsoNormal" style="text-indent:.5in"><span lang="EN-IN">  DW_AT_encoding  (DW_ATE_signed)<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_name      ("int")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_endianity (DW_END_big)<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">…<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">0x00000057:   DW_TAG_variable<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_name      ("__gbloffset__")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_type      (0x000001e5 "int")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_external  (true)<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_decl_file ("…")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_decl_line (8)<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_location  (DW_OP_addr 0) // pre linkage<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_linkage_name      ("_gblsection__")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">0x00000170:   DW_TAG_variable<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_name      ("VAR1")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_type      (0x0000010b "fixed.dec.display.72")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_decl_file ("…")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_decl_line (10)<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_location  (DW_OP_addr 0x0, DW_OP_call4 0x57, DW_OP_deref_size, 4,<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN" 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><span lang="EN-IN">, DW_OP_plus)<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">                DW_AT_linkage_name      ("VAR1")<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">In above snippet of dwarf dump, I am using yellow highlighted list of operators to swap the bytes.<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">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></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN">I hope I conveyed the idea properly, apologies in advanced as English is not my first language.
<o:p></o:p></span></p>
<p class="MsoNormal"><b><span style="color:#2F5597;mso-fareast-language:FR-BE"><o:p> </o:p></span></b></p>
<p class="MsoNormal"><b><span style="color:#2F5597;mso-fareast-language:FR-BE">Thanks and regards,<o:p></o:p></span></b></p>
<p class="MsoNormal"><b><span style="color:#2F5597;mso-fareast-language:FR-BE"><o:p> </o:p></span></b></p>
<p class="MsoNormal"><b><span style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Chirag Patel</span></b><span style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE"><o:p></o:p></span></p>
<p class="MsoNormal"><span 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 style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Tel</span></b><span 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 style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">Mob</span></b><span style="font-size:12.0pt;color:#2F5597;mso-fareast-language:FR-BE">: (+91) 9049336744<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN"><a href="http://www.raincodelabs.com/"><span lang="EN-US" style="font-size:12.0pt;mso-fareast-language:FR-BE">www.raincodelabs.com</span></a></span><u><span style="font-size:12.0pt;color:blue;mso-fareast-language:FR-BE"><o:p></o:p></span></u></p>
<p class="MsoNormal"><span lang="EN-IN"><a href="https://in.linkedin.com/in/chirag-patel-"><span style="font-size:10.0pt;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:image002.png@01D58D72.7BC5DAD0" alt="linkedin-button"></span></a></span><span lang="EN-IN" style="font-size:10.0pt;color:#2F5597;mso-fareast-language:FR-BE"><o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-IN"><o:p> </o:p></span></p>
</div>
</body>
</html>