lto-18 test
authorAlan Modra <amodra@gmail.com>
Wed, 9 Sep 2020 02:46:23 +0000 (12:16 +0930)
committerAlan Modra <amodra@gmail.com>
Wed, 9 Sep 2020 03:06:59 +0000 (12:36 +0930)
Demonstrates a reason to use IR symbols when deciding an --as-needed
library should be loaded.

* testsuite/ld-plugin/lto-18a.c,
* testsuite/ld-plugin/lto-18b.c,
* testsuite/ld-plugin/lto-18c.c,
* testsuite/ld-plugin/lto-18d.c,
* testsuite/ld-plugin/lto-18.out: New test.
* testsuite/ld-plugin/lto.exp: Run it.

ld/ChangeLog
ld/testsuite/ld-plugin/lto-18.out [new file with mode: 0644]
ld/testsuite/ld-plugin/lto-18a.c [new file with mode: 0644]
ld/testsuite/ld-plugin/lto-18b.c [new file with mode: 0644]
ld/testsuite/ld-plugin/lto-18c.c [new file with mode: 0644]
ld/testsuite/ld-plugin/lto-18d.c [new file with mode: 0644]
ld/testsuite/ld-plugin/lto.exp

index 1f804793107269da2db658aab7ec26056b401c4a..27df4a0e9dd44309daeb49e92629c1f4c91b8374 100644 (file)
@@ -1,3 +1,12 @@
+2020-09-09  Alan Modra  <amodra@gmail.com>
+
+       * testsuite/ld-plugin/lto-18a.c,
+       * testsuite/ld-plugin/lto-18b.c,
+       * testsuite/ld-plugin/lto-18c.c,
+       * testsuite/ld-plugin/lto-18d.c,
+       * testsuite/ld-plugin/lto-18.out: New test.
+       * testsuite/ld-plugin/lto.exp: Run it.
+
 2020-09-08  Jozef Lawrynowicz  <jozef.l@mittosystems.com>
 
        * testsuite/ld-msp430-elf/msp430-elf.exp: Run new tests.
diff --git a/ld/testsuite/ld-plugin/lto-18.out b/ld/testsuite/ld-plugin/lto-18.out
new file mode 100644 (file)
index 0000000..d00491f
--- /dev/null
@@ -0,0 +1 @@
+1
diff --git a/ld/testsuite/ld-plugin/lto-18a.c b/ld/testsuite/ld-plugin/lto-18a.c
new file mode 100644 (file)
index 0000000..477386a
--- /dev/null
@@ -0,0 +1,22 @@
+#include <stdio.h>
+
+extern int select ();
+extern int f1 (int);
+extern int f2 (int);
+
+int main (void)
+{
+  switch (select ())
+    {
+    case 1:
+      printf ("%d\n", f1 (3));
+      break;
+    case 2:
+      printf ("%d\n", f2 (4));
+      break;
+    default:
+      printf ("%d\n", f2 (0));
+      break;
+    }
+  return 0;
+}
diff --git a/ld/testsuite/ld-plugin/lto-18b.c b/ld/testsuite/ld-plugin/lto-18b.c
new file mode 100644 (file)
index 0000000..0ae3a20
--- /dev/null
@@ -0,0 +1,10 @@
+int select (void) { return 1; }
+
+extern int f2 (int);
+
+int f1 (int x)
+{
+  if (x > 0)
+    return x * f2 (x - 1);
+  return 1;
+}
diff --git a/ld/testsuite/ld-plugin/lto-18c.c b/ld/testsuite/ld-plugin/lto-18c.c
new file mode 100644 (file)
index 0000000..90cc81b
--- /dev/null
@@ -0,0 +1,10 @@
+int select (void) { return 2; }
+
+extern int f1 (int);
+
+int f2 (int x)
+{
+  if (x > 0)
+    return x * f1 (x - 1);
+  return 1;
+}
diff --git a/ld/testsuite/ld-plugin/lto-18d.c b/ld/testsuite/ld-plugin/lto-18d.c
new file mode 100644 (file)
index 0000000..cfb27cf
--- /dev/null
@@ -0,0 +1 @@
+int select (void) { return 0; }
index 684d1db314ad8bfe8e4256e5c3cff9221a7c716c..0479e3e40354e9f531257ad1b26e994892f78f15 100644 (file)
@@ -404,6 +404,15 @@ set lto_link_elf_tests [list \
    "-shared -Wl,--exclude-libs,ALL tmpdir/pr25618a.o tmpdir/pr25618.a" \
    "-fpic" \
    {dummy.c} {{readelf {--dyn-syms --wide} pr25618.d}} "pr25618.so" "c++"] \
+  [list {liblto-18b.so} \
+   {-shared} {-O2 -fpic} \
+   {lto-18b.c} {} {liblto-18b.so}] \
+  [list {liblto-18c.so} \
+   {-shared} {-O2 -fpic} \
+   {lto-18c.c} {} {liblto-18c.so}] \
+  [list {lto-18d.o} \
+   {} {-flto -O2} \
+   {lto-18d.c} {} {}] \
 ]
 
 # PR 14918 checks that libgcc is not spuriously included in a shared link of
@@ -412,11 +421,11 @@ set lto_link_elf_tests [list \
 # __aeabi_unwind_cpp_pr0@@GCC_3.5 which is provided by libgcc_s.so.1, so the
 # test fails.  Hence this code to skip the test.
 if { ! [istarget "arm*-*-*"] } {
-    set lto_link_elf_tests [concat $lto_link_elf_tests [list \
+    lappend lto_link_elf_tests [list \
   [list "PR ld/14918" \
    "-flto" "-flto" \
    {pr14918.c} {{"readelf" {-d --wide} "pr14918.d"}} "pr14918.exe" "c"] \
-  ]]
+  ]
 }
 
 # PR 12982 checks that an executable stack is not created by default
@@ -424,11 +433,11 @@ if { ! [istarget "arm*-*-*"] } {
 # executable stack for syscall restarts and signal returns, so we
 # skip this test for that target.
 if { ! [istarget "hppa*-*-*"] } {
-    set lto_link_elf_tests [concat $lto_link_elf_tests [list \
+    lappend lto_link_elf_tests [list \
   [list "PR ld/12982" \
    "-O2 -flto -fuse-linker-plugin" "-O2 -flto" \
    {pr12982.c} {{"readelf" {-l --wide} "pr12982.d"}} "pr12982.exe"] \
-  ]]
+  ]
 }
 
 # Check final symbols in executables.
@@ -569,6 +578,14 @@ set lto_run_elf_shared_tests [list \
   [list {pr22220b} \
    {-flto -fuse-linker-plugin -Wl,--no-as-needed tmpdir/pr22220lib.so tmpdir/pr22220main.o} {} \
    {dummy.c} {pr22220b.exe} {pass.out} {} {c++}] \
+  [list {lto-18 (1)} \
+   {-flto -fuse-linker-plugin} {} \
+   {lto-18a.c} {lto-18-1.exe} {lto-18.out} {-flto -O2} {c} {} \
+   {tmpdir/lto-18d.o -Wl,--as-needed,-R,tmpdir -Ltmpdir -llto-18b -llto-18c}] \
+  [list {lto-18 (2)} \
+   {-flto -fuse-linker-plugin} {} \
+   {lto-18a.c} {lto-18-2.exe} {lto-18.out} {-flto -O2} {c} {} \
+   {-Wl,--as-needed,-R,tmpdir -Ltmpdir -llto-18b -llto-18c tmpdir/lto-18d.o}] \
 ]
 
 # LTO run-time tests for ELF