diff options
author | Masahiro Yamada <masahiroy@kernel.org> | 2021-07-05 08:06:54 +0200 |
---|---|---|
committer | Masahiro Yamada <masahiroy@kernel.org> | 2021-07-08 21:00:39 +0200 |
commit | c6a3a81d19b834e3aed819027f022c5938fca2ec (patch) | |
tree | f44a9b2ced0e0d8d9ca894cad174dbb807ee3ec2 /scripts | |
parent | sparc: syscalls: use pattern rules to generate syscall headers (diff) | |
download | linux-c6a3a81d19b834e3aed819027f022c5938fca2ec.tar.xz linux-c6a3a81d19b834e3aed819027f022c5938fca2ec.zip |
scripts: check duplicated syscall number in syscall table
Currently, syscall{hdr,tbl}.sh sorts the entire syscall table, but you
can assume it is already sorted by the syscall number.
The generated syscall table does not work if the same syscall number
appears twice. Check it in the script.
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/syscallhdr.sh | 2 | ||||
-rwxr-xr-x | scripts/syscalltbl.sh | 7 |
2 files changed, 7 insertions, 2 deletions
diff --git a/scripts/syscallhdr.sh b/scripts/syscallhdr.sh index 848ac2735115..22e34cd46b9b 100755 --- a/scripts/syscallhdr.sh +++ b/scripts/syscallhdr.sh @@ -69,7 +69,7 @@ guard=_UAPI_ASM_$(basename "$outfile" | sed -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/' \ -e 's/[^A-Z0-9_]/_/g' -e 's/__/_/g') -grep -E "^[0-9A-Fa-fXx]+[[:space:]]+$abis" "$infile" | sort -n | { +grep -E "^[0-9A-Fa-fXx]+[[:space:]]+$abis" "$infile" | { echo "#ifndef $guard" echo "#define $guard" echo diff --git a/scripts/syscalltbl.sh b/scripts/syscalltbl.sh index aa6ab156301c..6abe143889ef 100755 --- a/scripts/syscalltbl.sh +++ b/scripts/syscalltbl.sh @@ -52,10 +52,15 @@ outfile="$2" nxt=0 -grep -E "^[0-9]+[[:space:]]+$abis" "$infile" | sort -n | { +grep -E "^[0-9]+[[:space:]]+$abis" "$infile" | { while read nr abi name native compat ; do + if [ $nxt -gt $nr ]; then + echo "error: $infile: syscall table is not sorted or duplicates the same syscall number" >&2 + exit 1 + fi + while [ $nxt -lt $nr ]; do echo "__SYSCALL($nxt, sys_ni_syscall)" nxt=$((nxt + 1)) |