[lld] r344264 - [COFF] Set proper pointer size alignment for LocalImportChunk

Martin Storsjo via llvm-commits llvm-commits at lists.llvm.org
Thu Oct 11 10:45:51 PDT 2018


Author: mstorsjo
Date: Thu Oct 11 10:45:51 2018
New Revision: 344264

URL: http://llvm.org/viewvc/llvm-project?rev=344264&view=rev
Log:
[COFF] Set proper pointer size alignment for LocalImportChunk

When these are accessed with load/store instructions on ARM64,
it becomes strictly necessary to have them properly aligned.

This fixes PR39228.

Differential Revision: https://reviews.llvm.org/D53128

Added:
    lld/trunk/test/COFF/arm64-localimport-align.s
Modified:
    lld/trunk/COFF/Chunks.h

Modified: lld/trunk/COFF/Chunks.h
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/COFF/Chunks.h?rev=344264&r1=344263&r2=344264&view=diff
==============================================================================
--- lld/trunk/COFF/Chunks.h (original)
+++ lld/trunk/COFF/Chunks.h Thu Oct 11 10:45:51 2018
@@ -368,7 +368,9 @@ public:
 // See comments for DefinedLocalImport class.
 class LocalImportChunk : public Chunk {
 public:
-  explicit LocalImportChunk(Defined *S) : Sym(S) {}
+  explicit LocalImportChunk(Defined *S) : Sym(S) {
+    Alignment = Config->is64() ? 8 : 4;
+  }
   size_t getSize() const override;
   void getBaserels(std::vector<Baserel> *Res) override;
   void writeTo(uint8_t *Buf) const override;

Added: lld/trunk/test/COFF/arm64-localimport-align.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/COFF/arm64-localimport-align.s?rev=344264&view=auto
==============================================================================
--- lld/trunk/test/COFF/arm64-localimport-align.s (added)
+++ lld/trunk/test/COFF/arm64-localimport-align.s Thu Oct 11 10:45:51 2018
@@ -0,0 +1,24 @@
+// REQUIRES: aarch64
+// RUN: llvm-mc -filetype=obj -triple=aarch64-windows %s -o %t.obj
+// RUN: lld-link -entry:main -subsystem:console %t.obj -out:%t.exe
+// Don't check the output, just make sure it links fine and doesn't
+// error out due to a misaligned load.
+    .text
+    .globl main
+    .globl myfunc
+main:
+    adrp x8, __imp_myfunc
+    ldr  x0, [x8, :lo12:__imp_myfunc]
+    br   x0
+    ret
+myfunc:
+    ret
+
+    .section .rdata, "dr"
+    // Start the .rdata section with a 4 byte chunk, to expose the alignment
+    // of the next chunk in the section.
+mydata:
+    .byte 42
+    // The synthesized LocalImportChunk gets stored here in the .rdata
+    // section, but needs to get proper 8 byte alignment since it is a
+    // pointer, just like regular LookupChunks in the IAT.




More information about the llvm-commits mailing list