dc7077f89a
The __SYSCALL macro's arguments are system call number, system call entry name and number of arguments for the system call. Argument- nargs in __SYSCALL(nr, entry, nargs) is neither calculated nor used anywhere. So it would be better to keep the implementaion as __SYSCALL(nr, entry). This will unifies the implementation with some other architetures too. Signed-off-by: Firoz Khan <firoz.khan@linaro.org> Signed-off-by: Paul Burton <paul.burton@mips.com> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: James Hogan <jhogan@kernel.org> Cc: linux-mips@vger.kernel.org Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Philippe Ombredanne <pombredanne@nexb.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Kate Stewart <kstewart@linuxfoundation.org> Cc: y2038@lists.linaro.org Cc: linux-kernel@vger.kernel.org Cc: linux-arch@vger.kernel.org Cc: arnd@arndb.de Cc: deepa.kernel@gmail.com Cc: marcin.juszkiewicz@linaro.org
37 lines
694 B
Bash
37 lines
694 B
Bash
#!/bin/sh
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
in="$1"
|
|
out="$2"
|
|
my_abis=`echo "($3)" | tr ',' '|'`
|
|
my_abi="$4"
|
|
offset="$5"
|
|
|
|
emit() {
|
|
t_nxt="$1"
|
|
t_nr="$2"
|
|
t_entry="$3"
|
|
|
|
while [ $t_nxt -lt $t_nr ]; do
|
|
printf "__SYSCALL(%s,sys_ni_syscall)\n" "${t_nxt}"
|
|
t_nxt=$((t_nxt+1))
|
|
done
|
|
printf "__SYSCALL(%s,%s)\n" "${t_nxt}" "${t_entry}"
|
|
}
|
|
|
|
grep -E "^[0-9A-Fa-fXx]+[[:space:]]+${my_abis}" "$in" | sort -n | (
|
|
nxt=0
|
|
if [ -z "$offset" ]; then
|
|
offset=0
|
|
fi
|
|
|
|
while read nr abi name entry compat ; do
|
|
if [ "$my_abi" = "64_o32" ] && [ ! -z "$compat" ]; then
|
|
emit $((nxt+offset)) $((nr+offset)) $compat
|
|
else
|
|
emit $((nxt+offset)) $((nr+offset)) $entry
|
|
fi
|
|
nxt=$((nr+1))
|
|
done
|
|
) > "$out"
|