[lld] d2f7f77 - [lld][ELF][test] Add additional --symbol-ordering-file testing

James Henderson via llvm-commits llvm-commits at lists.llvm.org
Tue Nov 10 02:29:41 PST 2020


Author: James Henderson
Date: 2020-11-10T10:28:47Z
New Revision: d2f7f775cac5df24bafa158c3cc7a86c2593f03c

URL: https://github.com/llvm/llvm-project/commit/d2f7f775cac5df24bafa158c3cc7a86c2593f03c
DIFF: https://github.com/llvm/llvm-project/commit/d2f7f775cac5df24bafa158c3cc7a86c2593f03c.diff

LOG: [lld][ELF][test] Add additional --symbol-ordering-file testing

This covers a few cases that aren't otherwise tested:
1) Non-ascii symbol names are ordered.
2) Comments, whitespace and blank lines are trimmed.
3) Missing order files result in an error.

Reviewed by: MaskRay, grimar

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

Added: 
    

Modified: 
    lld/test/ELF/symbol-ordering-file.s

Removed: 
    


################################################################################
diff  --git a/lld/test/ELF/symbol-ordering-file.s b/lld/test/ELF/symbol-ordering-file.s
index 73d45a794d31..f6776cdb6f67 100644
--- a/lld/test/ELF/symbol-ordering-file.s
+++ b/lld/test/ELF/symbol-ordering-file.s
@@ -4,31 +4,53 @@
 # RUN: llvm-objdump -s %t.out| FileCheck %s --check-prefix=BEFORE
 
 # BEFORE:      Contents of section .foo:
-# BEFORE-NEXT:  11223344 5566
+# BEFORE-NEXT:  11223344 556677
 # BEFORE:      Contents of section .init:
 # BEFORE-NEXT:  1122
 
 # RUN: echo "_foo4  " > %t_order.txt
 # RUN: echo "  _foo3" >> %t_order.txt
+# RUN: echo "_nönascii" >> %t_order.txt
 # RUN: echo "_foo5" >> %t_order.txt
-# RUN: echo "_foo2" >> %t_order.txt
+# RUN: echo -e " _foo2 \t\v\r\f" >> %t_order.txt
+# RUN: echo "# a comment" >> %t_order.txt
 # RUN: echo " " >> %t_order.txt
 # RUN: echo "_foo4" >> %t_order.txt
 # RUN: echo "_bar1" >> %t_order.txt
+# RUN: echo "" >> %t_order.txt
 # RUN: echo "_foo1" >> %t_order.txt
 # RUN: echo "_init2" >> %t_order.txt
 # RUN: echo "_init1" >> %t_order.txt
 
-# RUN: ld.lld --symbol-ordering-file %t_order.txt %t.o -o %t2.out
-# RUN: llvm-objdump -s %t2.out| FileCheck %s --check-prefix=AFTER
+## Show that both --symbol-ordering-file and --symbol-ordering-file= work.
+## Also show that lines beginning with '#', whitespace and empty lines, are ignored.
+## Also show that "first one wins" when there are duplicate symbols in the order
+## file (a warning will be emitted).
+# RUN: ld.lld --symbol-ordering-file %t_order.txt %t.o -o %t2.out 2>&1 | \
+# RUN:   FileCheck %s --check-prefix=WARN --implicit-check-not=warning:
+# RUN: llvm-objdump -s %t2.out | FileCheck %s --check-prefix=AFTER
 # RUN: ld.lld --symbol-ordering-file=%t_order.txt %t.o -o %t2.out
-# RUN: llvm-objdump -s %t2.out| FileCheck %s --check-prefix=AFTER
+# RUN: llvm-objdump -s %t2.out | FileCheck %s --check-prefix=AFTER
+
+# WARN: warning: {{.*}}.txt: duplicate ordered symbol
 
 # AFTER:      Contents of section .foo:
-# AFTER-NEXT:  44335566 2211
+# AFTER-NEXT:  44337755 662211
 # AFTER:      Contents of section .init:
 # AFTER-NEXT:  1122
 
+## Show that a nonexistent symbol ordering file causes an error.
+# RUN: not ld.lld --symbol-ordering-file=%t.nonexistent %t.o -o %t3.out 2>&1 | \
+# RUN:   FileCheck %s --check-prefix=ERR -DFILE=%t.nonexistent
+
+# ERR: error: cannot open [[FILE]]: {{[Nn]}}o such file or directory
+
+## Show that an empty ordering file can be handled (symbols remain in their
+## normal order).
+# RUN: touch %t.empty
+# RUN: ld.lld --symbol-ordering-file=%t.empty %t.o -o %t4.out
+# RUN: llvm-objdump -s %t4.out | FileCheck %s --check-prefix=BEFORE
+
 .section .foo,"ax", at progbits,unique,1
 _foo1:
  .byte 0x11
@@ -51,6 +73,10 @@ _foo5:
 _bar1:
  .byte 0x66
 
+.section .foo,"ax", at progbits,unique,6
+"_nönascii":
+.byte 0x77
+
 .section .init,"ax", at progbits,unique,1
 _init1:
  .byte 0x11
@@ -58,3 +84,8 @@ _init1:
 .section .init,"ax", at progbits,unique,2
 _init2:
  .byte 0x22
+
+.text
+.global _start
+_start:
+    nop


        


More information about the llvm-commits mailing list