diff options
author | Russell King <rmk+kernel@armlinux.org.uk> | 2016-10-18 19:57:01 +0100 |
---|---|---|
committer | Russell King <rmk+kernel@armlinux.org.uk> | 2016-10-18 21:34:06 +0100 |
commit | 96a8fae0fe094b6a26a3ec88b2f097418f269cfe (patch) | |
tree | 611c87ac99ac3ee4407d4d37b6c77d5274e3c2e1 /arch/arm/tools/syscalltbl.sh | |
parent | 4e2648db9c5f7b2281551694597102612f54460d (diff) | |
download | lwn-96a8fae0fe094b6a26a3ec88b2f097418f269cfe.tar.gz lwn-96a8fae0fe094b6a26a3ec88b2f097418f269cfe.zip |
ARM: convert to generated system call tables
Convert ARM to use a similar mechanism to x86 to generate the unistd.h
system call numbers and the various kernel system call tables. This
means that rather than having to edit three places (asm/unistd.h for
the total number of system calls, uapi/asm/unistd.h for the system call
numbers, and arch/arm/kernel/calls.S for the call table) we have only
one place to edit, making the process much more simple.
The scripts have knowledge of the table padding requirements, so there's
no need to worry about __NR_syscalls not fitting within the immediate
constant field of ALU instructions anymore.
Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
Diffstat (limited to 'arch/arm/tools/syscalltbl.sh')
-rw-r--r-- | arch/arm/tools/syscalltbl.sh | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/arch/arm/tools/syscalltbl.sh b/arch/arm/tools/syscalltbl.sh new file mode 100644 index 000000000000..5ca834545ed3 --- /dev/null +++ b/arch/arm/tools/syscalltbl.sh @@ -0,0 +1,21 @@ +#!/bin/sh +in="$1" +out="$2" +my_abis=`echo "($3)" | tr ',' '|'` + +grep -E "^[0-9A-Fa-fXx]+[[:space:]]+${my_abis}" "$in" | sort -n | ( + while read nr abi name entry compat; do + if [ "$abi" = "eabi" -a -n "$compat" ]; then + echo "$in: error: a compat entry for an EABI syscall ($name) makes no sense" >&2 + exit 1 + fi + + if [ -n "$entry" ]; then + if [ -z "$compat" ]; then + echo "NATIVE($nr, $entry)" + else + echo "COMPAT($nr, $entry, $compat)" + fi + fi + done +) > "$out" |