[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL v4 29/32] scripts: add a script to generate syscall_nr.h
From: |
Laurent Vivier |
Subject: |
[PULL v4 29/32] scripts: add a script to generate syscall_nr.h |
Date: |
Fri, 20 Mar 2020 16:24:05 +0100 |
This script is needed for targets based on asm-generic syscall numbers
generation
Signed-off-by: Laurent Vivier <address@hidden>
Reviewed-by: Alistair Francis <address@hidden>
Reviewed-by: Taylor Simpson <address@hidden>
Reviewed-by: Richard Henderson <address@hidden>
Message-Id: <address@hidden>
[lv: added file in MAINTAINERS]
---
MAINTAINERS | 1 +
scripts/gensyscalls.sh | 102 +++++++++++++++++++++++++++++++++++++++++
2 files changed, 103 insertions(+)
create mode 100755 scripts/gensyscalls.sh
diff --git a/MAINTAINERS b/MAINTAINERS
index 958e05b27f15..45d48992b13c 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -2450,6 +2450,7 @@ F: default-configs/*-linux-user.mak
F: scripts/qemu-binfmt-conf.sh
F: scripts/update-syscalltbl.sh
F: scripts/update-mips-syscall-args.sh
+F: scripts/gensyscalls.sh
Tiny Code Generator (TCG)
-------------------------
diff --git a/scripts/gensyscalls.sh b/scripts/gensyscalls.sh
new file mode 100755
index 000000000000..b7b8456f6312
--- /dev/null
+++ b/scripts/gensyscalls.sh
@@ -0,0 +1,102 @@
+#!/bin/sh
+#
+# Update syscall_nr.h files from linux headers asm-generic/unistd.h
+#
+# This code is licensed under the GPL version 2 or later. See
+# the COPYING file in the top-level directory.
+#
+
+linux="$1"
+output="$2"
+
+TMP=$(mktemp -d)
+
+if [ "$linux" = "" ] ; then
+ echo "Needs path to linux source tree" 1>&2
+ exit 1
+fi
+
+if [ "$output" = "" ] ; then
+ output="$PWD"
+fi
+
+upper()
+{
+ echo "$1" | tr "[:lower:]" "[:upper:]" | tr "[:punct:]" "_"
+}
+
+qemu_arch()
+{
+ case "$1" in
+ arm64)
+ echo "aarch64"
+ ;;
+ *)
+ echo "$1"
+ ;;
+ esac
+}
+
+read_includes()
+{
+ arch=$1
+ bits=$2
+
+ cpp -P -nostdinc -fdirectives-only \
+ -D_UAPI_ASM_$(upper ${arch})_BITSPERLONG_H \
+ -D__BITS_PER_LONG=${bits} \
+ -I${linux}/arch/${arch}/include/uapi/ \
+ -I${linux}/include/uapi \
+ -I${TMP} \
+ "${linux}/arch/${arch}/include/uapi/asm/unistd.h"
+}
+
+filter_defines()
+{
+ grep -e "#define __NR_" -e "#define __NR3264"
+}
+
+rename_defines()
+{
+ sed "s/ __NR_/ TARGET_NR_/g;s/(__NR_/(TARGET_NR_/g"
+}
+
+evaluate_values()
+{
+ sed "s/#define TARGET_NR_/QEMU TARGET_NR_/" | \
+ cpp -P -nostdinc | \
+ sed "s/^QEMU /#define /"
+}
+
+generate_syscall_nr()
+{
+ arch=$1
+ bits=$2
+ file="$3"
+ guard="$(upper LINUX_USER_$(qemu_arch $arch)_$(basename "$file"))"
+
+ (echo "/*"
+ echo " * This file contains the system call numbers."
+ echo " * Do not modify."
+ echo " * This file is generated by scripts/gensyscalls.sh"
+ echo " */"
+ echo "#ifndef ${guard}"
+ echo "#define ${guard}"
+ echo
+ read_includes $arch $bits | filter_defines | rename_defines | \
+ evaluate_values | sort -n -k 3
+ echo
+ echo "#endif /* ${guard} */"
+ echo) > "$file"
+}
+
+mkdir "$TMP/asm"
+> "$TMP/asm/bitsperlong.h"
+
+generate_syscall_nr arm64 64 "$output/linux-user/aarch64/syscall_nr.h"
+generate_syscall_nr nios2 32 "$output/linux-user/nios2/syscall_nr.h"
+generate_syscall_nr openrisc 32 "$output/linux-user/openrisc/syscall_nr.h"
+
+generate_syscall_nr riscv 32 "$output/linux-user/riscv/syscall32_nr.h"
+generate_syscall_nr riscv 64 "$output/linux-user/riscv/syscall64_nr.h"
+rm -fr "$TMP"
--
2.25.1
- [PULL v4 11/32] linux-user, m68k: add syscall table generation support, (continued)
- [PULL v4 11/32] linux-user, m68k: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 15/32] linux-user, arm: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 22/32] linux-user, x86_64: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 25/32] linux-user, scripts: add a script to update syscall.tbl, Laurent Vivier, 2020/03/20
- [PULL v4 26/32] linux-user: update syscall.tbl from linux 0bf999f9c5e7, Laurent Vivier, 2020/03/20
- [PULL v4 14/32] linux-user, microblaze: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 19/32] linux-user, sparc, sparc64: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 21/32] linux-user, i386: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 27/32] linux-user,mips: move content of mips_syscall_args, Laurent Vivier, 2020/03/20
- [PULL v4 23/32] linux-user, mips: add syscall table generation support, Laurent Vivier, 2020/03/20
- [PULL v4 29/32] scripts: add a script to generate syscall_nr.h,
Laurent Vivier <=
- [PULL v4 32/32] linux-user, openrisc: sync syscall numbers with kernel v5.5, Laurent Vivier, 2020/03/20
- [PULL v4 31/32] linux-user, nios2: sync syscall numbers with kernel v5.5, Laurent Vivier, 2020/03/20
- [PULL v4 28/32] linux-user,mips: update syscall-args-o32.c.inc, Laurent Vivier, 2020/03/20
- [PULL v4 30/32] linux-user, aarch64: sync syscall numbers with kernel v5.5, Laurent Vivier, 2020/03/20
- [PULL v4 24/32] linux-user, mips64: add syscall table generation support, Laurent Vivier, 2020/03/20
- Re: [PULL v4 00/32] Linux user for 5.0 patches, Peter Maydell, 2020/03/21