[LLVMdev] Win32 COFF Support patch 5 (the final patch in the saga!)

Daniel Dunbar daniel at zuster.org
Fri Jul 30 11:34:17 PDT 2010


On Fri, Jul 30, 2010 at 11:05 AM, Michael Spencer <bigcheesegs at gmail.com> wrote:
> On Fri, Jul 30, 2010 at 1:28 PM, Daniel Dunbar <daniel at zuster.org> wrote:
>> On Mon, Jul 26, 2010 at 7:25 PM, Michael Spencer <bigcheesegs at gmail.com> wrote:
>>> Daniel somehow replied to one of my previous commits on llvm-commits
>>> instead of this thread.
>>>
>>> On Mon, Jul 26, 2010 at 12:41 AM, Daniel Dunbar <daniel at zuster.org> wrote:
>>>> Hi Michael,
>>>>
>>>> Two minor notes:
>>>> --
>>>>> diff --git a/lib/Target/X86/X86AsmBackend.cpp b/lib/Target/X86/X86AsmBackend.cpp
>>>>> index 2cf65c1..02ac2be 100644
>>>>> --- a/lib/Target/X86/X86AsmBackend.cpp
>>>>> +++ b/lib/Target/X86/X86AsmBackend.cpp
>>>>> @@ -14,6 +14,7 @@
>>>>>  #include "llvm/MC/MCAssembler.h"
>>>>>  #include "llvm/MC/MCExpr.h"
>>>>>  #include "llvm/MC/MCObjectWriter.h"
>>>>> +#include "llvm/MC/MCSectionCOFF.h"
>>>>>  #include "llvm/MC/MCSectionELF.h"
>>>>>  #include "llvm/MC/MCSectionMachO.h"
>>>>>  #include "llvm/MC/MachObjectWriter.h"
>>>>> @@ -212,6 +213,24 @@ public:
>>>>>      : ELFX86AsmBackend(T) {}
>>>>>  };
>>>>>
>>>>> +class WindowsX86AsmBackend : public X86AsmBackend {
>>>>> +public:
>>>>> +  WindowsX86AsmBackend(const Target &T)
>>>>> +    : X86AsmBackend(T) {
>>>>> +    HasAbsolutizedSet = true;
>>>>> +    HasScatteredSymbols = true;
>>>>
>>>> These probably should be false for Win32.
>>>
>>> What do they do?
>>
>> You don't really want to know, but:
>> (1) The Darwin tools conspire to allow the linker to reorder code, do
>> dead code stripping, etc. What this means is that any two "atoms" in
>> an assembly file might be moved in the final linked image. Therefore,
>> you can't expect that things like 'A - B' are constants.
>>
>> (2) "Absolutized set" is something where Darwin 'as' will take a
>> directive like '.set foo, A - B', and make foo be the current absolute
>> expression for A - B, ignoring the fact that A and B might move. In
>> practice, this is because the assembler wasn't smart enough to figure
>> out which situations it could reliably compute A - B. This is related
>> to (1).
>>
>> These two things end up impacting relaxation and the assembler
>> backend, which is why they unfortunately get exposed at this level.
>
> I tried setting these to false, but the resulting executable (made
> with link.exe) crashed. I looked at the differences in the object
> file, but couldn't figure out what was causing it. I'm guessing
> there's a bug in the path when these are false.
>
> Now that I know what these flags do, I'll try and figure out exactly
> what the problem is.

If I had to guess, this is probably because the assembler isn't
relaxing something that should be. Scattered symbols will hide this,
because they will force most things to be relaxed, but I think we
probably need a new bit to model the actual semantics in play. I've
paged this stuff out, but I think the semantics the current
implementation isn't modeling is the possible relocation of static
symbols.

If you try your example without the scattered symbols bit, but with
-mc-relax-all, does the resulting binary work?

 - Daniel

> - Michael Spencer
>
>>>>> diff --git a/test/MC/COFF/dg.exp b/test/MC/COFF/dg.exp
>>>>> new file mode 100644
>>>>> index 0000000..7b7bd4e
>>>>> --- /dev/null
>>>>> +++ b/test/MC/COFF/dg.exp
>>>>> @@ -0,0 +1,5 @@
>>>>> +load_lib llvm.exp
>>>>> +
>>>>> +if { [llvm_supports_target X86] } {
>>>>> +  RunLLVMTests [lsort [glob -nocomplain $srcdir/$subdir/*.{ll}]]
>>>>> +}
>>>>
>>>> This should be *.{s}.
>>>
>>> This has to be *.{ll} for now because llvm-mc cannot parse COFF .s files.
>>
>> Oh, right.
>>
>>  - Daniel
>>
>>>
>>>> --
>>>>
>>>> Otherwise looks good to me!
>>>>
>>>>  - Daniel
>>>
>>> - Michael Spencer
>>>
>>
>




More information about the llvm-dev mailing list