forked from Minki/linux
96a8fae0fe
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>
31 lines
713 B
Bash
31 lines
713 B
Bash
#!/bin/sh
|
|
|
|
in="$1"
|
|
out="$2"
|
|
my_abis=`echo "($3)" | tr ',' '|'`
|
|
prefix="$4"
|
|
offset="$5"
|
|
|
|
fileguard=_ASM_ARM_`basename "$out" | sed \
|
|
-e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/' \
|
|
-e 's/[^A-Z0-9_]/_/g' -e 's/__/_/g'`
|
|
if echo $out | grep -q uapi; then
|
|
fileguard="_UAPI$fileguard"
|
|
fi
|
|
grep -E "^[0-9A-Fa-fXx]+[[:space:]]+${my_abis}" "$in" | sort -n | (
|
|
echo "#ifndef ${fileguard}"
|
|
echo "#define ${fileguard} 1"
|
|
echo ""
|
|
|
|
while read nr abi name entry ; do
|
|
if [ -z "$offset" ]; then
|
|
echo "#define __NR_${prefix}${name} $nr"
|
|
else
|
|
echo "#define __NR_${prefix}${name} ($offset + $nr)"
|
|
fi
|
|
done
|
|
|
|
echo ""
|
|
echo "#endif /* ${fileguard} */"
|
|
) > "$out"
|