mirror of
https://github.com/rui314/mold.git
synced 2024-10-04 16:48:04 +03:00
bb5a596bc5
We unset `LANG`, but it looks like `LC_ALL` takes precedence over `LANG`, so we should set `LC_ALL` to `C`. Reported at https://github.com/rui314/mold/pull/385
37 lines
683 B
Bash
Executable File
37 lines
683 B
Bash
Executable File
#!/bin/bash
|
|
export LC_ALL=C
|
|
set -e
|
|
CC="${CC:-cc}"
|
|
CXX="${CXX:-c++}"
|
|
testname=$(basename "$0" .sh)
|
|
echo -n "Testing $testname ... "
|
|
cd "$(dirname "$0")"/../..
|
|
mold="$(pwd)/mold"
|
|
t=out/test/elf/$testname
|
|
mkdir -p $t
|
|
|
|
cat <<EOF | $CC -o $t/a.o -c -xc -
|
|
#include <stdio.h>
|
|
|
|
__attribute__((aligned(512)))
|
|
char hello[] = "Hello";
|
|
|
|
__attribute__((aligned(512)))
|
|
char world[] = "world";
|
|
|
|
int main() {
|
|
printf("%s %s\n", hello, world);
|
|
}
|
|
EOF
|
|
|
|
$CC -B. -static -Wl,--filler,0xfe -o $t/exe1 $t/a.o
|
|
sed -i -e 's/--filler 0xfe/--filler 0x00/' $t/exe1
|
|
hexdump -C $t/exe1 > $t/txt1
|
|
|
|
$CC -B. -static -Wl,--filler,0x00 -o $t/exe2 $t/a.o
|
|
hexdump -C $t/exe2 > $t/txt2
|
|
|
|
diff -q $t/txt1 $t/txt2
|
|
|
|
echo OK
|