aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>2015-05-14 14:59:23 -0300
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>2015-05-14 16:38:46 -0300
commit95b07fbcc702a83b421cb5d0488ba2817d3123c1 (patch)
treee44b1b4e7d6f2610e3e59a23ab36c8e9e0bbc0a1
parent5695d46f5dc0ff2ffbcb0c52b1f6c2ada09c39dc (diff)
downloadglibc-95b07fbcc702a83b421cb5d0488ba2817d3123c1.zip
glibc-95b07fbcc702a83b421cb5d0488ba2817d3123c1.tar.gz
glibc-95b07fbcc702a83b421cb5d0488ba2817d3123c1.tar.bz2
Fix non-portable echo usage in sysdeps/unix/make-syscalls.sh
This patch changes the way make-syscall-sh script uses echo to follow POSIX spec.
-rw-r--r--ChangeLog5
-rw-r--r--sysdeps/unix/make-syscalls.sh23
2 files changed, 19 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index e89c14e..3f3a5b1 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2015-05-14 Jakub Bogusz <qboosh@pld-linux.org>
+ Adhemerval Zanella <adhemerval.zanella@linaro.org>
+
+ * sysdeps/unix/make-syscalls.sh: Remove non-portable echo usage.
+
2015-05-14 Andrew Senkevich <andrew.senkevich@intel.com>
* Makeconfig (rpath-dirs, all-subdirs): Added mathvec folder.
diff --git a/sysdeps/unix/make-syscalls.sh b/sysdeps/unix/make-syscalls.sh
index 910a22c..12f664e 100644
--- a/sysdeps/unix/make-syscalls.sh
+++ b/sysdeps/unix/make-syscalls.sh
@@ -272,28 +272,33 @@ while read file srcfile caller syscall args strong weak; do
vdso_symbol="${vdso_syscall%@*}"
vdso_symver="${vdso_syscall#*@}"
vdso_symver=`echo "$vdso_symver" | sed 's/\./_/g'`
- echo "\
+ cat <<EOF
+
\$(foreach p,\$(sysd-rules-targets),\$(objpfx)\$(patsubst %,\$p,$file).os): \\
\$(..)sysdeps/unix/make-syscalls.sh
\$(make-target-directory)
(echo '#include <dl-vdso.h>'; \\
- echo 'extern void *${strong}_ifunc (void) __asm (\"${strong}\");'; \\
+ echo 'extern void *${strong}_ifunc (void) __asm ("${strong}");'; \\
echo 'void *'; \\
echo '${strong}_ifunc (void)'; \\
echo '{'; \\
echo ' PREPARE_VERSION_KNOWN (symver, ${vdso_symver});'; \\
- echo ' return _dl_vdso_vsym (\"${vdso_symbol}\", &symver);'; \\
+ echo ' return _dl_vdso_vsym ("${vdso_symbol}", &symver);'; \\
echo '}'; \\
- echo 'asm (\".type ${strong}, %gnu_indirect_function\");'; \\"
+ echo 'asm (".type ${strong}, %gnu_indirect_function");'; \\
+EOF
# This is doing "libc_hidden_def (${strong})", but the compiler
# doesn't know that we've defined ${strong} in the same file, so
# we can't do it the normal way.
- echo "\
- echo 'asm (\".globl __GI_${strong}\\n\"'; \\
- echo ' \"__GI_${strong} = ${strong}\");'; \\"
+ cat <<EOF
+ echo 'asm (".globl __GI_${strong}");'; \\
+ echo 'asm ("__GI_${strong} = ${strong}");'; \\
+EOF
emit_weak_aliases
- echo ' ) | $(compile-stdin.c) '"\
-\$(foreach p,\$(patsubst %$file,%,\$(basename \$(@F))),\$(\$(p)CPPFLAGS))"
+ cat <<EOF
+ ) | \$(compile-stdin.c) \
+\$(foreach p,\$(patsubst %$file,%,\$(basename \$(@F))),\$(\$(p)CPPFLAGS))
+EOF
fi
if test $shared_only = t; then