diff options
author | David Majnemer <david.majnemer@gmail.com> | 2014-11-11 08:43:57 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2014-11-11 08:43:57 +0000 |
commit | 2cc4bc77bf11d465faf03b0ae0f5a623f0f73e70 (patch) | |
tree | 1b2f8b1e1f81b4c282266de81b55135ce022e2dc /llvm/lib/MC/WinCOFFStreamer.cpp | |
parent | d158db0f63cece2520e0d70b8bd712001cd78322 (diff) | |
download | bcm5719-llvm-2cc4bc77bf11d465faf03b0ae0f5a623f0f73e70.tar.gz bcm5719-llvm-2cc4bc77bf11d465faf03b0ae0f5a623f0f73e70.zip |
MC, COFF: Use relocations for function references inside the section
Referencing one symbol from another in the same section does not
generally require a relocation. However, the MS linker has a feature
called /INCREMENTAL which enables incremental links. It achieves this
by creating thunks to the actual function and redirecting all
relocations to point to the thunk.
This breaks down with the old scheme if you have a function which
references, say, itself. On x86_64, we would use %rip relative
addressing to reference the start of the function from out current
position. This would lead to miscompiles because other references might
reference the thunk instead, breaking function pointer equality.
This fixes PR21520.
llvm-svn: 221678
Diffstat (limited to 'llvm/lib/MC/WinCOFFStreamer.cpp')
-rw-r--r-- | llvm/lib/MC/WinCOFFStreamer.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/MC/WinCOFFStreamer.cpp b/llvm/lib/MC/WinCOFFStreamer.cpp index 32813a1d263..6a8054d7486 100644 --- a/llvm/lib/MC/WinCOFFStreamer.cpp +++ b/llvm/lib/MC/WinCOFFStreamer.cpp @@ -133,7 +133,7 @@ void MCWinCOFFStreamer::EmitCOFFSymbolStorageClass(int StorageClass) { if (!CurSymbol) FatalError("storage class specified outside of symbol definition"); - if (StorageClass & ~0xff) + if (StorageClass & ~COFF::SSC_Invalid) FatalError(Twine("storage class value '") + itostr(StorageClass) + "' out of range"); |