<html 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=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:Helvetica;
        panose-1:2 11 5 4 2 2 2 2 2 4;}
@font-face
        {font-family:Wingdings;
        panose-1:5 0 0 0 0 0 0 0 0 0;}
@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:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
p
        {mso-style-priority:99;
        margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style></head><body lang=EN-US link=blue vlink="#954F72"><div class=WordSection1><p>Hi Richard,</p><p><o:p> </o:p></p><p>Thanks for the reply, I completely forgot that most people were probably on holidays <span style='font-family:Wingdings'>J</span></p><p><o:p> </o:p></p><p>I’ll try the irc channel as well.</p><p><o:p> </o:p></p><p>Cheers,</p><p>Tamar</p><p><o:p> </o:p></p><p><o:p> </o:p></p><div style='mso-element:para-border-div;border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in'><p style='border:none;padding:0in'><br><b>From: </b>Richard Eisenberg<br><b>Sent: </b>Friday, August 14, 2015 04:46<br><b>To: </b>lonetiger@gmail.com<br><b>Cc: </b>GHC<br><b>Subject: </b>Re: Linker questions</p></div><p class=MsoNormal><span style='font-family:"Times New Roman",serif'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-family:"Times New Roman",serif'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>Hi Tamar,</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p></o:p></span></p><div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p> </o:p></span></p></div><div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>I haven't a clue about any of this. But I didn't want your detailed email to go without any response. Perhaps agitate a bit on #ghc at freenode to get some attention? Also, be aware that many people are on holiday right now, and so responses may be slower than at other times.<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p> </o:p></span></p></div><div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>Sorry I can't be more helpful, but I definitely appreciate your looking into this!<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>Richard<o:p></o:p></span></p></div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p> </o:p></span></p><div><div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>On Aug 11, 2015, at 3:43 PM, <a href="mailto:lonetiger@gmail.com">lonetiger@gmail.com</a> wrote:<o:p></o:p></span></p></div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><br><br><o:p></o:p></span></p><blockquote style='margin-top:5.0pt;margin-bottom:5.0pt'><div><div><p class=MsoNormal>Hi *,<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>I had a few questions about the linker I was hoping someone can help me with,<o:p></o:p></p></div><div><p class=MsoNormal>I'm pretty new to it so any insights would be appreciated.<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>1) Has to do with checkProddableBlock and #10672 and #10563<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>static void checkProddableBlock (ObjectCode *oc, void *addr, size_t size )<o:p></o:p></p></div><div><p class=MsoNormal>{<o:p></o:p></p></div><div><p class=MsoNormal>   ProddableBlock* pb;<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>   for (pb = oc->proddables; pb != NULL; pb = pb->next) {<o:p></o:p></p></div><div><p class=MsoNormal>      char* s = (char*)(pb->start);<o:p></o:p></p></div><div><p class=MsoNormal>      char* e = s + pb->size;<o:p></o:p></p></div><div><p class=MsoNormal>      char* a = (char*)addr;<o:p></o:p></p></div><div><p class=MsoNormal>      if (a >= s && (a+size) <= e) return;<o:p></o:p></p></div><div><p class=MsoNormal>   }<o:p></o:p></p></div><div><p class=MsoNormal>   barf("checkProddableBlock: invalid fixup in runtime linker: %p", addr);<o:p></o:p></p></div><div><p class=MsoNormal>}<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>From what I have found, these errors seem to happen because oc->proddables is initially NULL,<o:p></o:p></p></div><div><p class=MsoNormal>the for loop is skipped. From what I can tell, this function is checking if there's a "proddable"<o:p></o:p></p></div><div><p class=MsoNormal>that fits within the supplied address and size. So if there is no proddables to begin with, should this<o:p></o:p></p></div><div><p class=MsoNormal>check just not be skipped and the callee of this call not use this ObjectCode instead of erroring out?<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>2) The second question is about static int ocGetNames_PEi386 ( ObjectCode* oc )<o:p></o:p></p></div><div><p class=MsoNormal>I am getting a test failure because it is claiming that .eh_frame section is misaligned.<o:p></o:p></p></div><div><p class=MsoNormal>This comes from this code:<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>  if (kind != SECTIONKIND_OTHER && end >= start) {<o:p></o:p></p></div><div><p class=MsoNormal>           if ((((size_t)(start)) % 4) != 0) {<o:p></o:p></p></div><div><p class=MsoNormal>               errorBelch("Misaligned section %s: %p", (char*)secname, start);<o:p></o:p></p></div><div><p class=MsoNormal>               stgFree(secname);<o:p></o:p></p></div><div><p class=MsoNormal>               return 0;<o:p></o:p></p></div><div><p class=MsoNormal>           }<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>Where start is defined as:<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>start = ((UChar*)(oc->image)) + sectab_i->PointerToRawData;<o:p></o:p></p></div><div><p class=MsoNormal>and  oc->image is a memory location received by allocateImageAndTrampolines.<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>In the case of my test failure it is because the .eh_frame section seems to begin at 0x30F<o:p></o:p></p></div><div><p class=MsoNormal>since oc->image will always be 4 aligned (so it doesn't really matter in the check) it gives that error because PointerToRawData isn't aligned by 4.<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>So my question is would it not be better just to check the alignment flag in the PE section header instead of checking the load address (which is always going to aligned to 4?) and The file pointer to<o:p></o:p></p></div><div><p class=MsoNormal>the first page of the section within the COFF file to determine the alignment? Like objdump and dumpbin do?<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>e.g.<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>9 .eh_frame     00000038  00000000  00000000  0000030f  2**2<o:p></o:p></p></div><div><p class=MsoNormal>                  CONTENTS, ALLOC, LOAD, RELOC, READONLY, DATA<o:p></o:p></p></div><p>                 </p><div><p class=MsoNormal>Is the output from objdump which correctly determines the alignment from the section. From what I understand from the PE specification<o:p></o:p></p></div><div><p class=MsoNormal>the on disk address doesn't have to be aligned by 4:<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>"For object files, the value *should* be aligned on a 4-byte boundary for best performance."<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>I'm wondering if we are incorrectly erroring out here, instead of using the section and making sure we pad it to the alignment boundary.<o:p></o:p></p></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><p class=MsoNormal>Regards,<o:p></o:p></p></div><div><p class=MsoNormal>Tamar<o:p></o:p></p></div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica",sans-serif'>_______________________________________________<br>ghc-devs mailing list<br><a href="mailto:ghc-devs@haskell.org"><span style='color:#954F72'>ghc-devs@haskell.org</span></a><br><a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs"><span style='color:#954F72'>http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs</span></a><o:p></o:p></span></p></div></blockquote></div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p> </o:p></span></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p></div></body></html>