diff options
| author | Michael Forney <forney@google.com> | 2018-02-07 01:41:17 -0500 |
|---|---|---|
| committer | Masahiro Yamada <yamada.masahiro@socionext.com> | 2018-03-25 13:01:18 -0400 |
| commit | 1fe7d2bb24d7db6175e0b0a31d8fe03dc6ffb16e (patch) | |
| tree | 1d1acfa6039c3f4a51ea7032656d09f58bf14654 /scripts | |
| parent | ae0c553c24c009596c3a3e903433824fe050c547 (diff) | |
kbuild: Improve portability of some sed invocations
* Use BREs where EREs aren't necessary.
* Pass -E instead of -r to use EREs. This will be standardized in the
next POSIX revision[0]. GNU sed supports this since 4.2 (May 2009),
and busybox since 1.22.0 (Jan 2014).
* Use the [:space:] character class instead of ` \t` in bracket
expressions. In bracket expressions, POSIX says that <backslash> loses
its special meaning, so a conforming implementation cannot expand \t
to <tab>[1].
* In BREs, use interval expressions (\{n,m\}) instead of non-standard
features like \+ and \?.
* Use a loop instead of -s flag.
There are still plenty of other cases of non-standard sed invocations
(use of ERE features in BREs, in-place editing), but this fixes some
core ones.
[0] http://austingroupbugs.net/view.php?id=528
[1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap09.html#tag_09_03_05
Signed-off-by: Michael Forney <forney@google.com>
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/Kbuild.include | 2 | ||||
| -rw-r--r-- | scripts/Makefile.build | 2 | ||||
| -rwxr-xr-x | scripts/adjust_autoksyms.sh | 4 | ||||
| -rwxr-xr-x | scripts/gen_initramfs_list.sh | 2 | ||||
| -rwxr-xr-x | scripts/headers_install.sh | 10 |
5 files changed, 11 insertions, 9 deletions
diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include index 065324a8046f..34cbd81024b0 100644 --- a/scripts/Kbuild.include +++ b/scripts/Kbuild.include | |||
| @@ -368,7 +368,7 @@ ksym_dep_filter = \ | |||
| 368 | $(CPP) $(call flags_nodeps,a_flags) -D__KSYM_DEPS__ $< ;; \ | 368 | $(CPP) $(call flags_nodeps,a_flags) -D__KSYM_DEPS__ $< ;; \ |
| 369 | boot*|build*|cpp_its_S|*cpp_lds_S|dtc|host*|vdso*) : ;; \ | 369 | boot*|build*|cpp_its_S|*cpp_lds_S|dtc|host*|vdso*) : ;; \ |
| 370 | *) echo "Don't know how to preprocess $(1)" >&2; false ;; \ | 370 | *) echo "Don't know how to preprocess $(1)" >&2; false ;; \ |
| 371 | esac | tr ";" "\n" | sed -rn 's/^.*=== __KSYM_(.*) ===.*$$/KSYM_\1/p' | 371 | esac | tr ";" "\n" | sed -n 's/^.*=== __KSYM_\(.*\) ===.*$$/KSYM_\1/p' |
| 372 | 372 | ||
| 373 | cmd_and_fixdep = \ | 373 | cmd_and_fixdep = \ |
| 374 | $(echo-cmd) $(cmd_$(1)); \ | 374 | $(echo-cmd) $(cmd_$(1)); \ |
diff --git a/scripts/Makefile.build b/scripts/Makefile.build index 4f2b25d43ec9..fff770983960 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build | |||
| @@ -314,7 +314,7 @@ endef | |||
| 314 | 314 | ||
| 315 | # List module undefined symbols (or empty line if not enabled) | 315 | # List module undefined symbols (or empty line if not enabled) |
| 316 | ifdef CONFIG_TRIM_UNUSED_KSYMS | 316 | ifdef CONFIG_TRIM_UNUSED_KSYMS |
| 317 | cmd_undef_syms = $(NM) $@ | sed -n 's/^ \+U //p' | xargs echo | 317 | cmd_undef_syms = $(NM) $@ | sed -n 's/^ *U //p' | xargs echo |
| 318 | else | 318 | else |
| 319 | cmd_undef_syms = echo | 319 | cmd_undef_syms = echo |
| 320 | endif | 320 | endif |
diff --git a/scripts/adjust_autoksyms.sh b/scripts/adjust_autoksyms.sh index 513da1a4a2da..a162258ab606 100755 --- a/scripts/adjust_autoksyms.sh +++ b/scripts/adjust_autoksyms.sh | |||
| @@ -60,7 +60,9 @@ cat > "$new_ksyms_file" << EOT | |||
| 60 | 60 | ||
| 61 | EOT | 61 | EOT |
| 62 | [ "$(ls -A "$MODVERDIR")" ] && | 62 | [ "$(ls -A "$MODVERDIR")" ] && |
| 63 | sed -ns -e '3{s/ /\n/g;/^$/!p;}' "$MODVERDIR"/*.mod | sort -u | | 63 | for mod in "$MODVERDIR"/*.mod; do |
| 64 | sed -n -e '3{s/ /\n/g;/^$/!p;}' "$mod" | ||
| 65 | done | sort -u | | ||
| 64 | while read sym; do | 66 | while read sym; do |
| 65 | if [ -n "$CONFIG_HAVE_UNDERSCORE_SYMBOL_PREFIX" ]; then | 67 | if [ -n "$CONFIG_HAVE_UNDERSCORE_SYMBOL_PREFIX" ]; then |
| 66 | sym="${sym#_}" | 68 | sym="${sym#_}" |
diff --git a/scripts/gen_initramfs_list.sh b/scripts/gen_initramfs_list.sh index 86a3c0e5cfbc..10e528b3a08f 100755 --- a/scripts/gen_initramfs_list.sh +++ b/scripts/gen_initramfs_list.sh | |||
| @@ -194,7 +194,7 @@ input_file() { | |||
| 194 | source="$1" | 194 | source="$1" |
| 195 | if [ -f "$1" ]; then | 195 | if [ -f "$1" ]; then |
| 196 | ${dep_list}header "$1" | 196 | ${dep_list}header "$1" |
| 197 | is_cpio="$(echo "$1" | sed 's/^.*\.cpio\(\..*\)\?/cpio/')" | 197 | is_cpio="$(echo "$1" | sed 's/^.*\.cpio\(\..*\)\{0,1\}/cpio/')" |
| 198 | if [ $2 -eq 0 -a ${is_cpio} = "cpio" ]; then | 198 | if [ $2 -eq 0 -a ${is_cpio} = "cpio" ]; then |
| 199 | cpio_file=$1 | 199 | cpio_file=$1 |
| 200 | echo "$1" | grep -q '^.*\.cpio\..*' && is_cpio_compressed="compressed" | 200 | echo "$1" | grep -q '^.*\.cpio\..*' && is_cpio_compressed="compressed" |
diff --git a/scripts/headers_install.sh b/scripts/headers_install.sh index a18bca720995..593f8879c641 100755 --- a/scripts/headers_install.sh +++ b/scripts/headers_install.sh | |||
| @@ -31,13 +31,13 @@ trap 'rm -f "$OUTDIR/$FILE" "$OUTDIR/$FILE.sed"' EXIT | |||
| 31 | for i in "$@" | 31 | for i in "$@" |
| 32 | do | 32 | do |
| 33 | FILE="$(basename "$i")" | 33 | FILE="$(basename "$i")" |
| 34 | sed -r \ | 34 | sed -E \ |
| 35 | -e 's/([ \t(])(__user|__force|__iomem)[ \t]/\1/g' \ | 35 | -e 's/([[:space:](])(__user|__force|__iomem)[[:space:]]/\1/g' \ |
| 36 | -e 's/__attribute_const__([ \t]|$)/\1/g' \ | 36 | -e 's/__attribute_const__([[:space:]]|$)/\1/g' \ |
| 37 | -e 's@^#include <linux/compiler(|_types).h>@@' \ | 37 | -e 's@^#include <linux/compiler(|_types).h>@@' \ |
| 38 | -e 's/(^|[^a-zA-Z0-9])__packed([^a-zA-Z0-9_]|$)/\1__attribute__((packed))\2/g' \ | 38 | -e 's/(^|[^a-zA-Z0-9])__packed([^a-zA-Z0-9_]|$)/\1__attribute__((packed))\2/g' \ |
| 39 | -e 's/(^|[ \t(])(inline|asm|volatile)([ \t(]|$)/\1__\2__\3/g' \ | 39 | -e 's/(^|[[:space:](])(inline|asm|volatile)([[:space:](]|$)/\1__\2__\3/g' \ |
| 40 | -e 's@#(ifndef|define|endif[ \t]*/[*])[ \t]*_UAPI@#\1 @' \ | 40 | -e 's@#(ifndef|define|endif[[:space:]]*/[*])[[:space:]]*_UAPI@#\1 @' \ |
| 41 | "$SRCDIR/$i" > "$OUTDIR/$FILE.sed" || exit 1 | 41 | "$SRCDIR/$i" > "$OUTDIR/$FILE.sed" || exit 1 |
| 42 | scripts/unifdef -U__KERNEL__ -D__EXPORTED_HEADERS__ "$OUTDIR/$FILE.sed" \ | 42 | scripts/unifdef -U__KERNEL__ -D__EXPORTED_HEADERS__ "$OUTDIR/$FILE.sed" \ |
| 43 | > "$OUTDIR/$FILE" | 43 | > "$OUTDIR/$FILE" |
