<div dir="ltr"><div><div>And you want this for only SOME bits of code, and that's why you need to have the IR report what sections are "sensitive"? <br><br></div><div>It would be fairly easy if the code you want to check is a normal functions, just store the start address of the function, and the length should be doable too at machine code level, but not IR level. If you want to check only the middle of the function, it's a bit harder. <br><br></div><div>How are you dealing with the fact that code gets relocated during loading?<br></div><div><br></div>[I'm always curious as to how these type of designs cope with someone modifying the checksumming code itself, but that's another problem - or is this one of these things where the checksum is stored in special hardwareprotected memory?].<br><br>--<br></div>Mats<br></div><div class="gmail_extra"><br><div class="gmail_quote">On 22 February 2016 at 14:45, Wehrli Johan <span dir="ltr"><<a href="mailto:johan.wehrli@heig-vd.ch" target="_blank">johan.wehrli@heig-vd.ch</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div>I will try to explain better what I do.</div><div><br></div><div>The main goal behind this is to verify that a part of code is not modified by someone else (it is an integrity check).</div><div><br></div><div>To do this, I create in IR a function who take 2 parameters, a begin and an end value.</div><div><br></div><div>This function perform an hash over the code area (from begin to end) and return it.</div><div><br></div><div>At first, I don’t know the addresses and the hash value so I put random value (it is an integer 64 bits).</div><div><br></div><div>The function look like<b> uint32_t isModified(uint64_t* begin, uint64_t* end). </b></div><div><br></div><div>Once the compilation is over, I need to update the begin address, end address and the hash value.</div><div><br></div><div>When I say the compilation is over, I mean the clang driver has finished all of his action (compiling, linking, etc.).</div><div><br></div><div>Greetings,</div><div><br></div><div>Johan</div><div><div class="h5"><div><br></div><br><div><blockquote type="cite"><div>On 22 Feb 2016, at 15:04, mats petersson <<a href="mailto:mats@planetcatfish.com" target="_blank">mats@planetcatfish.com</a>> wrote:</div><br><div><div dir="ltr"><div><div><div>What kind of constant: type, value and how is it created?<br><br></div>You can make public symbols that you can extract in a linker script to a special section.<br><br></div>Or perhaps you want some metadata that a special late state (machine instr) pass is extracting and adding. <br><br></div><div>The "best" solution really depends on what you are trying to achieve overall and what kind of data you are working with.<br></div><div><br>--<br></div>Mats<br></div><div class="gmail_extra"><br><div class="gmail_quote">On 22 February 2016 at 13:04, Wehrli Johan via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi,<br>
<br>
I want to know if it is possible to pass information from IR to the final binary (like a constant value)?<br>
<br>
I have a module pass in IR who make some transformation and, once the compilation is finished, I need to apply a post-processing.<br>
<br>
The post-processing need information from the IR part.<br>
<br>
Greetings,<br>
<br>
Johan<br>
<br>
<br>
<br>_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
<br></blockquote></div><br></div>
</div></blockquote></div><br></div></div></div></blockquote></div><br></div>