You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
191 lines
9.0 KiB
191 lines
9.0 KiB
commit 0dcbf4c8705309af8c8c1620491c60539901a3b0 |
|
Author: Joseph Myers <joseph@codesourcery.com> |
|
Date: Fri Sep 17 13:12:10 2021 +0000 |
|
|
|
Run conform/ tests using newly built libc |
|
|
|
Although the conform/ header tests are built using the headers of the |
|
glibc under test, the execution tests from conformtest (a few tests of |
|
the values of macros evaluating to string constants) are linked and |
|
run with system libc, not the newly built libc. |
|
|
|
Apart from preventing testing in cross environments, this can be a |
|
problem even for native testing. Specifically, it can be useful to do |
|
native testing when building with a cross compiler that links with a |
|
libc that is not the system libc; for example, on x86_64, you can test |
|
all three ABIs that way if the kernel support is present, even if the |
|
host OS lacks 32-bit or x32 libraries or they are older than the |
|
libraries in the sysroot used by the compiler used to build glibc. |
|
This works for almost all tests, but not for these conformtest tests. |
|
|
|
Arrange for conformtest to link and run test programs similarly to |
|
other tests, with consequent refactoring of various variables in |
|
Makeconfig to allow passing relevant parts of the link-time command |
|
lines down to conformtest. In general, the parts of the link command |
|
involving $@ or $^ are separated out from the parts that should be |
|
passed to conformtest (the variables passed to conformtest still |
|
involve various variables whose names involve $(@F), but those |
|
variables simply won't be defined for the conformtest makefile rules |
|
and I think their presence there is harmless). |
|
|
|
This is also most of the support that would be needed to allow running |
|
those tests of string constants for cross testing when test-wrapper is |
|
defined. That will also need changes to where conformtest.py puts the |
|
test executables, so it puts them in the main object directory |
|
(expected to be shared with a test system in cross testing) rather |
|
than /tmp (not expected to be shared) as at present. |
|
|
|
Tested for x86_64. |
|
|
|
(cherry picked from commit f3eef963902d0f54f68cffc74f79b97f4d6154b7) |
|
|
|
diff --git a/Makeconfig b/Makeconfig |
|
index 68663d984e6a1264..2fa0884b4eee5e53 100644 |
|
--- a/Makeconfig |
|
+++ b/Makeconfig |
|
@@ -412,12 +412,13 @@ link-extra-libs-tests = $(libsupport) |
|
|
|
# Command for linking PIE programs with the C library. |
|
ifndef +link-pie |
|
-+link-pie-before-libc = $(if $($(@F)-no-pie),$(no-pie-ldflag),-pie) \ |
|
- -Wl,-O1 -nostdlib -nostartfiles -o $@ \ |
|
++link-pie-before-inputs = $(if $($(@F)-no-pie),$(no-pie-ldflag),-pie) \ |
|
+ -Wl,-O1 -nostdlib -nostartfiles \ |
|
$(sysdep-LDFLAGS) $(LDFLAGS) $(LDFLAGS-$(@F)) \ |
|
$(combreloc-LDFLAGS) $(relro-LDFLAGS) $(hashstyle-LDFLAGS) \ |
|
$(firstword $(CRT-$(@F)) $(csu-objpfx)S$(start-installed-name)) \ |
|
- $(+preinit) $(+prectorS) \ |
|
+ $(+preinit) $(+prectorS) |
|
++link-pie-before-libc = -o $@ $(+link-pie-before-inputs) \ |
|
$(filter-out $(addprefix $(csu-objpfx),start.o \ |
|
S$(start-installed-name))\ |
|
$(+preinit) $(link-extra-libs) \ |
|
@@ -442,11 +443,12 @@ endef |
|
endif |
|
# Command for statically linking programs with the C library. |
|
ifndef +link-static |
|
-+link-static-before-libc = -nostdlib -nostartfiles -static -o $@ \ |
|
++link-static-before-inputs = -nostdlib -nostartfiles -static \ |
|
$(if $($(@F)-no-pie),$(no-pie-ldflag),$(default-pie-ldflag)) \ |
|
$(sysdep-LDFLAGS) $(LDFLAGS) $(LDFLAGS-$(@F)) \ |
|
$(firstword $(CRT-$(@F)) $(csu-objpfx)$(real-static-start-installed-name)) \ |
|
- $(+preinit) $(+prectorT) \ |
|
+ $(+preinit) $(+prectorT) |
|
++link-static-before-libc = -o $@ $(+link-static-before-inputs) \ |
|
$(filter-out $(addprefix $(csu-objpfx),start.o \ |
|
$(start-installed-name))\ |
|
$(+preinit) $(link-extra-libs-static) \ |
|
@@ -473,13 +475,16 @@ endif |
|
ifeq (yes,$(build-pie-default)) |
|
+link = $(+link-pie) |
|
+link-tests = $(+link-pie-tests) |
|
++link-tests-before-inputs = $(+link-pie-before-inputs) $(rtld-tests-LDFLAGS) |
|
++link-tests-after-inputs = $(link-libc-tests) $(+link-pie-after-libc) |
|
+link-printers-tests = $(+link-pie-printers-tests) |
|
else # not build-pie-default |
|
-+link-before-libc = -nostdlib -nostartfiles -o $@ \ |
|
++link-before-inputs = -nostdlib -nostartfiles \ |
|
$(sysdep-LDFLAGS) $(LDFLAGS) $(LDFLAGS-$(@F)) \ |
|
$(combreloc-LDFLAGS) $(relro-LDFLAGS) $(hashstyle-LDFLAGS) \ |
|
$(firstword $(CRT-$(@F)) $(csu-objpfx)$(start-installed-name)) \ |
|
- $(+preinit) $(+prector) \ |
|
+ $(+preinit) $(+prector) |
|
++link-before-libc = -o $@ $(+link-before-inputs) \ |
|
$(filter-out $(addprefix $(csu-objpfx),start.o \ |
|
$(start-installed-name))\ |
|
$(+preinit) $(link-extra-libs) \ |
|
@@ -491,6 +496,8 @@ $(CC) $(link-libc-rpath-link) $(+link-before-libc) $(rtld-LDFLAGS) \ |
|
$(link-extra-flags) $(link-libc) $(+link-after-libc) |
|
$(call after-link,$@) |
|
endef |
|
++link-tests-before-inputs = $(+link-before-inputs) $(rtld-tests-LDFLAGS) |
|
++link-tests-after-inputs = $(link-libc-tests) $(+link-after-libc) |
|
define +link-tests |
|
$(CC) $(+link-before-libc) $(rtld-tests-LDFLAGS) $(link-libc-tests) \ |
|
$(+link-after-libc) |
|
@@ -505,6 +512,8 @@ endif # build-pie-default |
|
else # build-static |
|
+link = $(+link-static) |
|
+link-tests = $(+link-static-tests) |
|
++link-tests-before-inputs = $(+link-static-before-inputs) |
|
++link-tests-after-inputs = $(link-libc-static-tests) $(+link-static-after-libc) |
|
+link-printers-tests = $(+link-static-tests) |
|
endif # build-shared |
|
endif # +link |
|
diff --git a/conform/Makefile b/conform/Makefile |
|
index c64a83a905b991cc..296db818f0a72253 100644 |
|
--- a/conform/Makefile |
|
+++ b/conform/Makefile |
|
@@ -176,6 +176,9 @@ $(conformtest-header-tests): $(objpfx)%/conform.out: \ |
|
(set -e; std_hdr=$*; std=$${std_hdr%%/*}; hdr=$${std_hdr#*/}; \ |
|
mkdir -p $(@D); \ |
|
$(PYTHON) $< --cc='$(CC)' --flags='$(conformtest-cc-flags)' \ |
|
+ --ldflags='$(+link-tests-before-inputs)' \ |
|
+ --libs='$(+link-tests-after-inputs)' \ |
|
+ --run-program-prefix='$(run-program-prefix)' \ |
|
--standard=$$std --header=$$hdr $(conformtest-xfail) \ |
|
$(conformtest-cross) \ |
|
> $@ 2>&1); \ |
|
diff --git a/conform/conformtest.py b/conform/conformtest.py |
|
index f0405b71869831f9..4898e16c9fb96503 100644 |
|
--- a/conform/conformtest.py |
|
+++ b/conform/conformtest.py |
|
@@ -381,12 +381,16 @@ class MacroStrTest(object): |
|
class HeaderTests(object): |
|
"""The set of tests run for a header.""" |
|
|
|
- def __init__(self, header, standard, cc, flags, cross, xfail): |
|
+ def __init__(self, header, standard, cc, flags, ldflags, libs, |
|
+ run_program_prefix, cross, xfail): |
|
"""Initialize a HeaderTests object.""" |
|
self.header = header |
|
self.standard = standard |
|
self.cc = cc |
|
self.flags = flags |
|
+ self.ldflags = ldflags |
|
+ self.libs = libs |
|
+ self.run_program_prefix = run_program_prefix |
|
self.cross = cross |
|
self.xfail_str = xfail |
|
self.cflags_namespace = ('%s -fno-builtin %s -D_ISOMAC' |
|
@@ -590,7 +594,8 @@ class HeaderTests(object): |
|
exe_file = os.path.join(self.temp_dir, 'test') |
|
with open(c_file, 'w') as c_file_out: |
|
c_file_out.write('#include <%s>\n%s' % (self.header, text)) |
|
- cmd = ('%s %s %s -o %s' % (self.cc, self.cflags, c_file, exe_file)) |
|
+ cmd = ('%s %s %s %s %s -o %s' % (self.cc, self.cflags, self.ldflags, |
|
+ c_file, self.libs, exe_file)) |
|
try: |
|
subprocess.check_call(cmd, shell=True) |
|
except subprocess.CalledProcessError: |
|
@@ -600,7 +605,9 @@ class HeaderTests(object): |
|
self.note_skip(name) |
|
return |
|
try: |
|
- subprocess.check_call(exe_file, shell=True) |
|
+ subprocess.check_call('%s %s' % (self.run_program_prefix, |
|
+ exe_file), |
|
+ shell=True) |
|
except subprocess.CalledProcessError: |
|
self.note_error(name, self.group_xfail) |
|
return |
|
@@ -719,12 +726,19 @@ def main(): |
|
help='C compiler to use') |
|
parser.add_argument('--flags', metavar='CFLAGS', |
|
help='Compiler flags to use with CC') |
|
+ parser.add_argument('--ldflags', metavar='LDFLAGS', |
|
+ help='Compiler arguments for linking before inputs') |
|
+ parser.add_argument('--libs', metavar='LIBS', |
|
+ help='Compiler arguments for linking after inputs') |
|
+ parser.add_argument('--run-program-prefix', metavar='RUN-PROGRAM-PREFIX', |
|
+ help='Wrapper for running newly built program') |
|
parser.add_argument('--cross', action='store_true', |
|
help='Do not run compiled test programs') |
|
parser.add_argument('--xfail', metavar='COND', |
|
help='Name of condition for XFAILs') |
|
args = parser.parse_args() |
|
tests = HeaderTests(args.header, args.standard, args.cc, args.flags, |
|
+ args.ldflags, args.libs, args.run_program_prefix, |
|
args.cross, args.xfail) |
|
tests.run() |
|
|
|
|