Blame SOURCES/ltrace-0.7.91-aarch64.patch

2e4be5
diff --git a/README b/README
2e4be5
index 414bdfb..a04b767 100644
2e4be5
--- a/README
2e4be5
+++ b/README
2e4be5
@@ -24,6 +24,7 @@ The following targets are currently (at least somewhat) supported.
2e4be5
 Some of them may be more or less broken in reality, it is not feasible
2e4be5
 to test each release comprehensively on each target.
2e4be5
 
2e4be5
+	aarch64-*-linux-gnu
2e4be5
 	armv6l-*-linux-gnueabi
2e4be5
 	armv7l-*-linux-gnueabihf
2e4be5
 	i[4567]86-*-linux-gnu
2e4be5
@@ -81,7 +82,7 @@ quick one-liner), it is advisable to send an e-mail beforehand.
2e4be5
 
2e4be5
 
2e4be5
 -------------------------------------------------------------------------------
2e4be5
-Copyright (C) 2012,2013 Petr Machata <pmachata@redhat.com>
2e4be5
+Copyright (C) 2012-2014 Petr Machata <pmachata@redhat.com>
2e4be5
 Copyright (C) 1997-2009 Juan Cespedes <cespedes@debian.org>
2e4be5
 This file is part of ltrace.
2e4be5
 
2e4be5
diff --git a/configure.ac b/configure.ac
2e4be5
index c6e6bf0..0e9a124 100644
2e4be5
--- a/configure.ac
2e4be5
+++ b/configure.ac
2e4be5
@@ -1,6 +1,6 @@
2e4be5
 # -*- Autoconf -*-
2e4be5
 # This file is part of ltrace.
2e4be5
-# Copyright (C) 2010,2012,2013 Petr Machata, Red Hat Inc.
2e4be5
+# Copyright (C) 2010,2012,2013,2014 Petr Machata, Red Hat Inc.
2e4be5
 # Copyright (C) 2010,2011 Joe Damato
2e4be5
 # Copyright (C) 2010 Marc Kleine-Budde
2e4be5
 # Copyright (C) 2010 Zachary T Welch
2e4be5
@@ -399,6 +399,7 @@ AC_CONFIG_FILES([
2e4be5
 	Makefile
2e4be5
 	sysdeps/Makefile
2e4be5
 	sysdeps/linux-gnu/Makefile
2e4be5
+	sysdeps/linux-gnu/aarch64/Makefile
2e4be5
 	sysdeps/linux-gnu/alpha/Makefile
2e4be5
 	sysdeps/linux-gnu/arm/Makefile
2e4be5
 	sysdeps/linux-gnu/cris/Makefile
2e4be5
diff --git a/etc/libc.so.conf b/etc/libc.so.conf
2e4be5
index 669c50a..48b3b01 100644
2e4be5
--- a/etc/libc.so.conf
2e4be5
+++ b/etc/libc.so.conf
2e4be5
@@ -1,5 +1,12 @@
2e4be5
 # See ltrace.conf(5) for description of syntax of this file.
2e4be5
 
2e4be5
+# XXX ltrace misses long double and long long support
2e4be5
+typedef ldouble = double;
2e4be5
+typedef llong = long;
2e4be5
+typedef ullong = ulong;
2e4be5
+
2e4be5
+void __libc_start_main(hide(void*), hide(int), array(string, arg2));
2e4be5
+
2e4be5
 # arpa/inet.h
2e4be5
 typedef in_addr = struct(hex(uint));
2e4be5
 int inet_aton(string, +in_addr*);
2e4be5
@@ -233,9 +240,22 @@ void setbuffer(file,addr,ulong);
2e4be5
 void setlinebuf(file);
2e4be5
 int rename(string,string);
2e4be5
 
2e4be5
+# xlocale.h
2e4be5
+typedef locale_t = void*;
2e4be5
+locale_t newlocale(hex(int), string, locale_t);
2e4be5
+
2e4be5
 # stdlib.h
2e4be5
-long __strtol_internal(string,addr,int);
2e4be5
-ulong __strtoul_internal(string,addr,int);
2e4be5
+long __strtol_internal(string, +string*, int);
2e4be5
+ulong __strtoul_internal(string, +string*, int);
2e4be5
+
2e4be5
+double strtod(string, +string*);
2e4be5
+float strtof(string, +string*);
2e4be5
+ldouble strtold(string, +string*);
2e4be5
+
2e4be5
+double strtod_l(string, +string*, locale_t);
2e4be5
+float strtof_l(string, +string*, locale_t);
2e4be5
+ldouble strtold_l(string, +string*, locale_t);
2e4be5
+
2e4be5
 int atexit(addr);
2e4be5
 addr bsearch(string, addr, ulong, ulong, addr);
2e4be5
 addr calloc(ulong, ulong);
2e4be5
@@ -343,6 +363,10 @@ addr gmtime(addr);
2e4be5
 addr localtime(addr);
2e4be5
 ulong strftime(+string2,ulong,string,addr);
2e4be5
 long time(addr);
2e4be5
+# XXX in fact (time_t, long), which may be (llong, long) on 32-bit
2e4be5
+# arches.  We don't have llong as of this writing.
2e4be5
+typedef timespec = struct(long, long);
2e4be5
+int nanosleep(timespec*, timespec*);
2e4be5
 
2e4be5
 # unistd.h
2e4be5
 void _exit(int);
2e4be5
diff --git a/etc/syscalls.conf b/etc/syscalls.conf
2e4be5
index 562f4e7..09d347d 100644
2e4be5
--- a/etc/syscalls.conf
2e4be5
+++ b/etc/syscalls.conf
2e4be5
@@ -1,6 +1,10 @@
2e4be5
 # syscall.conf -- system call prototypes
2e4be5
 # See ltrace.conf(5) for description of syntax of this file.
2e4be5
 
2e4be5
+# Special value used to indicate the *at functions should use the
2e4be5
+# current working directory.
2e4be5
+typedef at_dirfd_t = enum[int](AT_FDCWD=-100);
2e4be5
+
2e4be5
 addr brk(addr);
2e4be5
 int close(int);
2e4be5
 int execve(string,addr,addr);
2e4be5
@@ -14,7 +18,7 @@ int getpid();
2e4be5
 addr mmap(addr,ulong,int,int,int,long);
2e4be5
 
2e4be5
 int munmap(addr,ulong);
2e4be5
-int open(string,int,octal);
2e4be5
+int open(string, hex(uint), oct(uint));
2e4be5
 int personality(uint);
2e4be5
 long read(int,+string0,ulong);
2e4be5
 int stat(string,addr);
2e4be5
@@ -113,3 +117,30 @@ ulong writev(int,addr,int);
2e4be5
 int mprotect(addr,int,int);
2e4be5
 int access(string,octal);
2e4be5
 int getdents(uint, void *, uint);
2e4be5
+
2e4be5
+int openat(at_dirfd_t, string, hex(uint), oct(uint));
2e4be5
+int mknodat(at_dirfd_t, string, oct(uint), ushort)
2e4be5
+int mkdirat(at_dirfd_t, string, oct(uint));
2e4be5
+int unlinkat(at_dirfd_t, string, hex(uint));
2e4be5
+int symlinkat(string, at_dirfd_t, string);
2e4be5
+int linkat(at_dirfd_t, string, at_dirfd_t, string, hex(uint));
2e4be5
+int renameat(at_dirfd_t, string, at_dirfd_t, string);
2e4be5
+int faccessat(at_dirfd_t, string, oct(uint), hex(uint));
2e4be5
+int fchmodat(at_dirfd_t, string, oct(uint), hex(uint));
2e4be5
+int fchownat(at_dirfd_t, string, int, int, hex(uint));
2e4be5
+int readlinkat(at_dirfd_t, string, +string[arg4], ulong);
2e4be5
+int fstatat(at_dirfd_t, string, addr, hex(uint));
2e4be5
+int utimensat(at_dirfd_t, string, addr, hex(uint));
2e4be5
+int futimens(int, addr);
2e4be5
+int futimesat(at_dirfd_t, string, addr);
2e4be5
+addr shmat(int, addr, hex(uint));
2e4be5
+int shmdt(addr);
2e4be5
+
2e4be5
+typedef fid_type = enum(FILEID_ROOT=0, FILEID_INO32_GEN=1, FILEID_INO32_GEN_PARENT=2, FILEID_BTRFS_WITHOUT_PARENT=0x4d, FILEID_BTRFS_WITH_PARENT=0x4e, FILEID_BTRFS_WITH_PARENT_ROOT=0x4f, FILEID_UDF_WITHOUT_PARENT=0x51, FILEID_UDF_WITH_PARENT=0x52, FILEID_NILFS_WITHOUT_PARENT=0x61, FILEID_NILFS_WITH_PARENT=0x62);
2e4be5
+typedef file_handle = struct(uint, fid_type, array(hex(char), elt1)*);
2e4be5
+int name_to_handle_at(at_dirfd_t, string, file_handle, int*, hex(uint));
2e4be5
+int open_by_handle_at(at_dirfd_t, file_handle, hex(uint));
2e4be5
+
2e4be5
+int newfstatat(at_dirfd_t, string, addr, hex(uint));
2e4be5
+int creat(string, oct(int));
2e4be5
+int ustat(ushort, addr);
2e4be5
diff --git a/sysdeps/linux-gnu/Makefile.am b/sysdeps/linux-gnu/Makefile.am
2e4be5
index ecee577..ec26162 100644
2e4be5
--- a/sysdeps/linux-gnu/Makefile.am
2e4be5
+++ b/sysdeps/linux-gnu/Makefile.am
2e4be5
@@ -1,4 +1,5 @@
2e4be5
 # This file is part of ltrace.
2e4be5
+# Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
 # Copyright (C) 2010,2012 Marc Kleine-Budde, Pengutronix
2e4be5
 #
2e4be5
 # This program is free software; you can redistribute it and/or
2e4be5
@@ -16,7 +17,8 @@
2e4be5
 # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
 # 02110-1301 USA
2e4be5
 
2e4be5
-DIST_SUBDIRS = alpha arm cris ia64 m68k metag mips ppc s390 sparc x86
2e4be5
+DIST_SUBDIRS = aarch64 alpha arm cris ia64 m68k metag mips ppc s390	\
2e4be5
+	       sparc x86
2e4be5
 
2e4be5
 SUBDIRS = \
2e4be5
 	$(HOST_CPU)
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/Makefile.am b/sysdeps/linux-gnu/aarch64/Makefile.am
2e4be5
new file mode 100644
2e4be5
index 0000000..0af4e6e
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/Makefile.am
2e4be5
@@ -0,0 +1,25 @@
2e4be5
+# This file is part of ltrace.
2e4be5
+# Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+#
2e4be5
+# This program is free software; you can redistribute it and/or
2e4be5
+# modify it under the terms of the GNU General Public License as
2e4be5
+# published by the Free Software Foundation; either version 2 of the
2e4be5
+# License, or (at your option) any later version.
2e4be5
+#
2e4be5
+# This program is distributed in the hope that it will be useful, but
2e4be5
+# WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+# General Public License for more details.
2e4be5
+#
2e4be5
+# You should have received a copy of the GNU General Public License
2e4be5
+# along with this program; if not, write to the Free Software
2e4be5
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+# 02110-1301 USA
2e4be5
+
2e4be5
+noinst_LTLIBRARIES = ../libcpu.la
2e4be5
+
2e4be5
+___libcpu_la_SOURCES = fetch.c plt.c regs.c trace.c
2e4be5
+
2e4be5
+noinst_HEADERS = arch.h ptrace.h signalent.h syscallent.h
2e4be5
+
2e4be5
+MAINTAINERCLEANFILES = Makefile.in
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/arch.h b/sysdeps/linux-gnu/aarch64/arch.h
2e4be5
new file mode 100644
2e4be5
index 0000000..4137613
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/arch.h
2e4be5
@@ -0,0 +1,37 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+#ifndef LTRACE_AARCH64_ARCH_H
2e4be5
+#define LTRACE_AARCH64_ARCH_H
2e4be5
+
2e4be5
+/* | 31                 21 | 20       5 | 4       0 | *
2e4be5
+ * | 1 1 0 1 0 1 0 0 0 0 1 |    imm16   | 0 0 0 0 0 | */
2e4be5
+#define BREAKPOINT_VALUE { 0xd4, 0x20, 0, 0 }
2e4be5
+#define BREAKPOINT_LENGTH 4
2e4be5
+#define DECR_PC_AFTER_BREAK 0
2e4be5
+
2e4be5
+#define LT_ELFCLASS	ELFCLASS64
2e4be5
+#define LT_ELF_MACHINE	EM_AARCH64
2e4be5
+
2e4be5
+#define ARCH_HAVE_FETCH_ARG
2e4be5
+#define ARCH_ENDIAN_BIG
2e4be5
+#define ARCH_HAVE_SIZEOF
2e4be5
+#define ARCH_HAVE_ALIGNOF
2e4be5
+
2e4be5
+#endif /* LTRACE_AARCH64_ARCH_H */
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/fetch.c b/sysdeps/linux-gnu/aarch64/fetch.c
2e4be5
new file mode 100644
2e4be5
index 0000000..8779f03
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/fetch.c
2e4be5
@@ -0,0 +1,365 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+#include <sys/ptrace.h>
2e4be5
+#include <asm/ptrace.h>
2e4be5
+#include <stdlib.h>
2e4be5
+#include <string.h>
2e4be5
+
2e4be5
+#include "fetch.h"
2e4be5
+#include "proc.h"
2e4be5
+#include "type.h"
2e4be5
+#include "value.h"
2e4be5
+
2e4be5
+int aarch64_read_gregs(struct process *proc, struct user_pt_regs *regs);
2e4be5
+int aarch64_read_fregs(struct process *proc, struct user_fpsimd_state *regs);
2e4be5
+
2e4be5
+
2e4be5
+struct fetch_context
2e4be5
+{
2e4be5
+	struct user_pt_regs gregs;
2e4be5
+	struct user_fpsimd_state fpregs;
2e4be5
+	arch_addr_t nsaa;
2e4be5
+	unsigned ngrn;
2e4be5
+	unsigned nsrn;
2e4be5
+	arch_addr_t x8;
2e4be5
+};
2e4be5
+
2e4be5
+static int
2e4be5
+context_init(struct fetch_context *context, struct process *proc)
2e4be5
+{
2e4be5
+	if (aarch64_read_gregs(proc, &context->gregs) < 0
2e4be5
+	    || aarch64_read_fregs(proc, &context->fpregs) < 0)
2e4be5
+		return -1;
2e4be5
+
2e4be5
+	context->ngrn = 0;
2e4be5
+	context->nsrn = 0;
2e4be5
+	/* XXX double cast */
2e4be5
+	context->nsaa = (arch_addr_t) (uintptr_t) context->gregs.sp;
2e4be5
+	context->x8 = 0;
2e4be5
+
2e4be5
+	return 0;
2e4be5
+}
2e4be5
+
2e4be5
+struct fetch_context *
2e4be5
+arch_fetch_arg_clone(struct process *proc, struct fetch_context *context)
2e4be5
+{
2e4be5
+	struct fetch_context *ret = malloc(sizeof(*ret));
2e4be5
+	if (ret == NULL)
2e4be5
+		return NULL;
2e4be5
+	return memcpy(ret, context, sizeof(*ret));
2e4be5
+}
2e4be5
+
2e4be5
+static void
2e4be5
+fetch_next_gpr(struct fetch_context *context, unsigned char *buf)
2e4be5
+{
2e4be5
+	uint64_t u = context->gregs.regs[context->ngrn++];
2e4be5
+	memcpy(buf, &u, 8);
2e4be5
+}
2e4be5
+
2e4be5
+static int
2e4be5
+fetch_gpr(struct fetch_context *context, struct value *value, size_t sz)
2e4be5
+{
2e4be5
+	if (sz < 8)
2e4be5
+		sz = 8;
2e4be5
+
2e4be5
+	unsigned char *buf = value_reserve(value, sz);
2e4be5
+	if (buf == NULL)
2e4be5
+		return -1;
2e4be5
+
2e4be5
+	size_t i;
2e4be5
+	for (i = 0; i < sz; i += 8)
2e4be5
+		fetch_next_gpr(context, buf + i);
2e4be5
+
2e4be5
+	return 0;
2e4be5
+}
2e4be5
+
2e4be5
+static void
2e4be5
+fetch_next_sse(struct fetch_context *context, unsigned char *buf, size_t sz)
2e4be5
+{
2e4be5
+	__int128 u = context->fpregs.vregs[context->nsrn++];
2e4be5
+	memcpy(buf, &u, sz);
2e4be5
+}
2e4be5
+
2e4be5
+static int
2e4be5
+fetch_sse(struct fetch_context *context, struct value *value, size_t sz)
2e4be5
+{
2e4be5
+	unsigned char *buf = value_reserve(value, sz);
2e4be5
+	if (buf == NULL)
2e4be5
+		return -1;
2e4be5
+
2e4be5
+	fetch_next_sse(context, buf, sz);
2e4be5
+	return 0;
2e4be5
+}
2e4be5
+
2e4be5
+static int
2e4be5
+fetch_hfa(struct fetch_context *context,
2e4be5
+	  struct value *value, struct arg_type_info *hfa_t, size_t count)
2e4be5
+{
2e4be5
+	size_t sz = type_sizeof(value->inferior, hfa_t);
2e4be5
+	unsigned char *buf = value_reserve(value, sz * count);
2e4be5
+	if (buf == NULL)
2e4be5
+		return -1;
2e4be5
+
2e4be5
+	size_t i;
2e4be5
+	for (i = 0; i < count; ++i) {
2e4be5
+		fetch_next_sse(context, buf, sz);
2e4be5
+		buf += sz;
2e4be5
+	}
2e4be5
+	return 0;
2e4be5
+}
2e4be5
+
2e4be5
+static int
2e4be5
+fetch_stack(struct fetch_context *context, struct value *value,
2e4be5
+	    size_t align, size_t sz)
2e4be5
+{
2e4be5
+	if (align < 8)
2e4be5
+		align = 8;
2e4be5
+	size_t amount = ((sz + align - 1) / align) * align;
2e4be5
+
2e4be5
+	/* XXX double casts */
2e4be5
+	uintptr_t sp = (uintptr_t) context->nsaa;
2e4be5
+	sp = ((sp + align - 1) / align) * align;
2e4be5
+
2e4be5
+	value_in_inferior(value, (arch_addr_t) sp);
2e4be5
+
2e4be5
+	sp += amount;
2e4be5
+	context->nsaa = (arch_addr_t) sp;
2e4be5
+
2e4be5
+	return 0;
2e4be5
+}
2e4be5
+
2e4be5
+enum convert_method {
2e4be5
+	CVT_ERR = -1,
2e4be5
+	CVT_NOP = 0,
2e4be5
+	CVT_BYREF,
2e4be5
+};
2e4be5
+
2e4be5
+enum fetch_method {
2e4be5
+	FETCH_NOP,
2e4be5
+	FETCH_STACK,
2e4be5
+	FETCH_GPR,
2e4be5
+	FETCH_SSE,
2e4be5
+	FETCH_HFA,
2e4be5
+};
2e4be5
+
2e4be5
+struct fetch_script {
2e4be5
+	enum convert_method c;
2e4be5
+	enum fetch_method f;
2e4be5
+	size_t sz;
2e4be5
+	struct arg_type_info *hfa_t;
2e4be5
+	size_t count;
2e4be5
+};
2e4be5
+
2e4be5
+static struct fetch_script
2e4be5
+pass_arg(struct fetch_context const *context,
2e4be5
+	 struct process *proc, struct arg_type_info *info)
2e4be5
+{
2e4be5
+	enum fetch_method cvt = CVT_NOP;
2e4be5
+
2e4be5
+	size_t sz = type_sizeof(proc, info);
2e4be5
+	if (sz == (size_t) -1)
2e4be5
+		return (struct fetch_script) { CVT_ERR, FETCH_NOP, sz };
2e4be5
+
2e4be5
+	switch (info->type) {
2e4be5
+	case ARGTYPE_VOID:
2e4be5
+		return (struct fetch_script) { cvt, FETCH_NOP, sz };
2e4be5
+
2e4be5
+	case ARGTYPE_STRUCT:
2e4be5
+	case ARGTYPE_ARRAY:;
2e4be5
+		size_t count;
2e4be5
+		struct arg_type_info *hfa_t = type_get_hfa_type(info, &count);
2e4be5
+		if (hfa_t != NULL && count <= 4) {
2e4be5
+			if (context->nsrn + count <= 8)
2e4be5
+				return (struct fetch_script)
2e4be5
+					{ cvt, FETCH_HFA, sz, hfa_t, count };
2e4be5
+			return (struct fetch_script)
2e4be5
+				{ cvt, FETCH_STACK, sz, hfa_t, count };
2e4be5
+		}
2e4be5
+
2e4be5
+		if (sz <= 16) {
2e4be5
+			size_t count = sz / 8;
2e4be5
+			if (context->ngrn + count <= 8)
2e4be5
+				return (struct fetch_script)
2e4be5
+					{ cvt, FETCH_GPR, sz };
2e4be5
+		}
2e4be5
+
2e4be5
+		cvt = CVT_BYREF;
2e4be5
+		sz = 8;
2e4be5
+		/* Fall through.  */
2e4be5
+
2e4be5
+	case ARGTYPE_POINTER:
2e4be5
+	case ARGTYPE_INT:
2e4be5
+	case ARGTYPE_UINT:
2e4be5
+	case ARGTYPE_LONG:
2e4be5
+	case ARGTYPE_ULONG:
2e4be5
+	case ARGTYPE_CHAR:
2e4be5
+	case ARGTYPE_SHORT:
2e4be5
+	case ARGTYPE_USHORT:
2e4be5
+		if (context->ngrn < 8 && sz <= 8)
2e4be5
+			return (struct fetch_script) { cvt, FETCH_GPR, sz };
2e4be5
+		/* We don't support types wider than 8 bytes as of
2e4be5
+		 * now.  */
2e4be5
+		assert(sz <= 8);
2e4be5
+
2e4be5
+		return (struct fetch_script) { cvt, FETCH_STACK, sz };
2e4be5
+
2e4be5
+	case ARGTYPE_FLOAT:
2e4be5
+	case ARGTYPE_DOUBLE:
2e4be5
+		if (context->nsrn < 8) {
2e4be5
+			/* ltrace doesn't support float128.  */
2e4be5
+			assert(sz <= 8);
2e4be5
+			return (struct fetch_script) { cvt, FETCH_SSE, sz };
2e4be5
+		}
2e4be5
+
2e4be5
+		return (struct fetch_script) { cvt, FETCH_STACK, sz };
2e4be5
+	}
2e4be5
+
2e4be5
+	assert(! "Failed to allocate argument.");
2e4be5
+	abort();
2e4be5
+}
2e4be5
+
2e4be5
+static int
2e4be5
+convert_arg(struct value *value, struct fetch_script how)
2e4be5
+{
2e4be5
+	switch (how.c) {
2e4be5
+	case CVT_NOP:
2e4be5
+		return 0;
2e4be5
+	case CVT_BYREF:
2e4be5
+		return value_pass_by_reference(value);
2e4be5
+	case CVT_ERR:
2e4be5
+		return -1;
2e4be5
+	}
2e4be5
+
2e4be5
+	assert(! "Don't know how to convert argument.");
2e4be5
+	abort();
2e4be5
+}
2e4be5
+
2e4be5
+static int
2e4be5
+fetch_arg(struct fetch_context *context,
2e4be5
+	  struct process *proc, struct arg_type_info *info,
2e4be5
+	  struct value *value, struct fetch_script how)
2e4be5
+{
2e4be5
+	if (convert_arg(value, how) < 0)
2e4be5
+		return -1;
2e4be5
+
2e4be5
+	switch (how.f) {
2e4be5
+	case FETCH_NOP:
2e4be5
+		return 0;
2e4be5
+
2e4be5
+	case FETCH_STACK:
2e4be5
+		if (how.hfa_t != NULL && how.count != 0 && how.count <= 8)
2e4be5
+			context->nsrn = 8;
2e4be5
+		return fetch_stack(context, value,
2e4be5
+				   type_alignof(proc, info), how.sz);
2e4be5
+
2e4be5
+	case FETCH_GPR:
2e4be5
+		return fetch_gpr(context, value, how.sz);
2e4be5
+
2e4be5
+	case FETCH_SSE:
2e4be5
+		return fetch_sse(context, value, how.sz);
2e4be5
+
2e4be5
+	case FETCH_HFA:
2e4be5
+		return fetch_hfa(context, value, how.hfa_t, how.count);
2e4be5
+	}
2e4be5
+
2e4be5
+	assert(! "Don't know how to fetch argument.");
2e4be5
+	abort();
2e4be5
+}
2e4be5
+
2e4be5
+struct fetch_context *
2e4be5
+arch_fetch_arg_init(enum tof type, struct process *proc,
2e4be5
+		    struct arg_type_info *ret_info)
2e4be5
+{
2e4be5
+	struct fetch_context *context = malloc(sizeof *context);
2e4be5
+	if (context == NULL || context_init(context, proc) < 0) {
2e4be5
+	fail:
2e4be5
+		free(context);
2e4be5
+		return NULL;
2e4be5
+	}
2e4be5
+
2e4be5
+	/* There's a provision in ARMv8 parameter passing convention
2e4be5
+	 * for returning types that, if passed as first argument to a
2e4be5
+	 * function, would be passed on stack.  For those types, x8
2e4be5
+	 * contains an address where the return argument should be
2e4be5
+	 * placed.  The callee doesn't need to preserve the value of
2e4be5
+	 * x8, so we need to fetch it now.
2e4be5
+	 *
2e4be5
+	 * To my knowledge, there are currently no types where this
2e4be5
+	 * holds, but the code is here, utterly untested.  */
2e4be5
+
2e4be5
+	struct fetch_script how = pass_arg(context, proc, ret_info);
2e4be5
+	if (how.c == CVT_ERR)
2e4be5
+		goto fail;
2e4be5
+	if (how.c == CVT_NOP && how.f == FETCH_STACK) {
2e4be5
+		/* XXX double cast.  */
2e4be5
+		context->x8 = (arch_addr_t) (uintptr_t) context->gregs.regs[8];
2e4be5
+		/* See the comment above about the assert.  */
2e4be5
+		assert(! "Unexpected: first argument passed on stack.");
2e4be5
+		abort();
2e4be5
+	}
2e4be5
+
2e4be5
+	return context;
2e4be5
+}
2e4be5
+
2e4be5
+int
2e4be5
+arch_fetch_arg_next(struct fetch_context *context, enum tof type,
2e4be5
+		    struct process *proc, struct arg_type_info *info,
2e4be5
+		    struct value *value)
2e4be5
+{
2e4be5
+	return fetch_arg(context, proc, info, value,
2e4be5
+			 pass_arg(context, proc, info));
2e4be5
+}
2e4be5
+
2e4be5
+int
2e4be5
+arch_fetch_retval(struct fetch_context *context, enum tof type,
2e4be5
+		  struct process *proc, struct arg_type_info *info,
2e4be5
+		  struct value *value)
2e4be5
+{
2e4be5
+	if (context->x8 != 0) {
2e4be5
+		value_in_inferior(value, context->x8);
2e4be5
+		return 0;
2e4be5
+	}
2e4be5
+
2e4be5
+	if (context_init(context, proc) < 0)
2e4be5
+		return -1;
2e4be5
+
2e4be5
+	return fetch_arg(context, proc, info, value,
2e4be5
+			 pass_arg(context, proc, info));
2e4be5
+}
2e4be5
+
2e4be5
+void
2e4be5
+arch_fetch_arg_done(struct fetch_context *context)
2e4be5
+{
2e4be5
+	if (context != NULL)
2e4be5
+		free(context);
2e4be5
+}
2e4be5
+
2e4be5
+size_t
2e4be5
+arch_type_sizeof(struct process *proc, struct arg_type_info *arg)
2e4be5
+{
2e4be5
+	return (size_t) -2;
2e4be5
+}
2e4be5
+
2e4be5
+size_t
2e4be5
+arch_type_alignof(struct process *proc, struct arg_type_info *arg)
2e4be5
+{
2e4be5
+	return (size_t) -2;
2e4be5
+}
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/plt.c b/sysdeps/linux-gnu/aarch64/plt.c
2e4be5
new file mode 100644
2e4be5
index 0000000..29dc4c9
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/plt.c
2e4be5
@@ -0,0 +1,38 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+#include <gelf.h>
2e4be5
+
2e4be5
+#include "backend.h"
2e4be5
+#include "proc.h"
2e4be5
+#include "library.h"
2e4be5
+#include "ltrace-elf.h"
2e4be5
+
2e4be5
+arch_addr_t
2e4be5
+sym2addr(struct process *proc, struct library_symbol *sym)
2e4be5
+{
2e4be5
+	return sym->enter_addr;
2e4be5
+}
2e4be5
+
2e4be5
+GElf_Addr
2e4be5
+arch_plt_sym_val(struct ltelf *lte, size_t ndx, GElf_Rela *rela)
2e4be5
+{
2e4be5
+	return lte->plt_addr + 32 + ndx * 16;
2e4be5
+}
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/ptrace.h b/sysdeps/linux-gnu/aarch64/ptrace.h
2e4be5
new file mode 100644
2e4be5
index 0000000..283c314
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/ptrace.h
2e4be5
@@ -0,0 +1,22 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+#include <sys/ptrace.h>
2e4be5
+#include <asm/ptrace.h>
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/regs.c b/sysdeps/linux-gnu/aarch64/regs.c
2e4be5
new file mode 100644
2e4be5
index 0000000..06eb72b
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/regs.c
2e4be5
@@ -0,0 +1,130 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+#include <sys/ptrace.h>
2e4be5
+#include <asm/ptrace.h>
2e4be5
+#include <linux/uio.h>
2e4be5
+#include <assert.h>
2e4be5
+#include <stdlib.h>
2e4be5
+
2e4be5
+#include "backend.h"
2e4be5
+#include "proc.h"
2e4be5
+
2e4be5
+#define PC_OFF (32 * 4)
2e4be5
+
2e4be5
+int
2e4be5
+aarch64_read_gregs(struct process *proc, struct user_pt_regs *regs)
2e4be5
+{
2e4be5
+	*regs = (struct user_pt_regs) {};
2e4be5
+	struct iovec iovec;
2e4be5
+	iovec.iov_base = regs;
2e4be5
+	iovec.iov_len = sizeof *regs;
2e4be5
+	return ptrace(PTRACE_GETREGSET, proc->pid, NT_PRSTATUS, &iovec) < 0
2e4be5
+		? -1 : 0;
2e4be5
+}
2e4be5
+
2e4be5
+int
2e4be5
+aarch64_write_gregs(struct process *proc, struct user_pt_regs *regs)
2e4be5
+{
2e4be5
+	struct iovec iovec;
2e4be5
+	iovec.iov_base = regs;
2e4be5
+	iovec.iov_len = sizeof *regs;
2e4be5
+	return ptrace(PTRACE_SETREGSET, proc->pid, NT_PRSTATUS, &iovec) < 0
2e4be5
+		? -1 : 0;
2e4be5
+}
2e4be5
+
2e4be5
+int
2e4be5
+aarch64_read_fregs(struct process *proc, struct user_fpsimd_state *regs)
2e4be5
+{
2e4be5
+	*regs = (struct user_fpsimd_state) {};
2e4be5
+	struct iovec iovec;
2e4be5
+	iovec.iov_base = regs;
2e4be5
+	iovec.iov_len = sizeof *regs;
2e4be5
+	return ptrace(PTRACE_GETREGSET, proc->pid, NT_FPREGSET, &iovec) < 0
2e4be5
+		? -1 : 0;
2e4be5
+}
2e4be5
+
2e4be5
+arch_addr_t
2e4be5
+get_instruction_pointer(struct process *proc)
2e4be5
+{
2e4be5
+	struct user_pt_regs regs;
2e4be5
+	if (aarch64_read_gregs(proc, &regs) < 0) {
2e4be5
+		fprintf(stderr, "get_instruction_pointer: "
2e4be5
+			"Couldn't read registers of %d.\n", proc->pid);
2e4be5
+		return 0;
2e4be5
+	}
2e4be5
+
2e4be5
+	/* 
2e4be5
+	char buf[128];
2e4be5
+	sprintf(buf, "cat /proc/%d/maps", proc->pid);
2e4be5
+	system(buf);
2e4be5
+	*/
2e4be5
+
2e4be5
+	/* XXX double cast */
2e4be5
+	return (arch_addr_t) (uintptr_t) regs.pc;
2e4be5
+}
2e4be5
+
2e4be5
+void
2e4be5
+set_instruction_pointer(struct process *proc, arch_addr_t addr)
2e4be5
+{
2e4be5
+	struct user_pt_regs regs;
2e4be5
+	if (aarch64_read_gregs(proc, &regs) < 0) {
2e4be5
+		fprintf(stderr, "get_instruction_pointer: "
2e4be5
+			"Couldn't read registers of %d.\n", proc->pid);
2e4be5
+		return;
2e4be5
+	}
2e4be5
+
2e4be5
+	/* XXX double cast */
2e4be5
+	regs.pc = (uint64_t) (uintptr_t) addr;
2e4be5
+
2e4be5
+	if (aarch64_write_gregs(proc, &regs) < 0) {
2e4be5
+		fprintf(stderr, "get_instruction_pointer: "
2e4be5
+			"Couldn't write registers of %d.\n", proc->pid);
2e4be5
+		return;
2e4be5
+	}
2e4be5
+}
2e4be5
+
2e4be5
+arch_addr_t
2e4be5
+get_stack_pointer(struct process *proc)
2e4be5
+{
2e4be5
+	struct user_pt_regs regs;
2e4be5
+	if (aarch64_read_gregs(proc, &regs) < 0) {
2e4be5
+		fprintf(stderr, "get_stack_pointer: "
2e4be5
+			"Couldn't read registers of %d.\n", proc->pid);
2e4be5
+		return 0;
2e4be5
+	}
2e4be5
+
2e4be5
+	/* XXX double cast */
2e4be5
+	return (arch_addr_t) (uintptr_t) regs.sp;
2e4be5
+}
2e4be5
+
2e4be5
+arch_addr_t
2e4be5
+get_return_addr(struct process *proc, arch_addr_t stack_pointer)
2e4be5
+{
2e4be5
+	struct user_pt_regs regs;
2e4be5
+	if (aarch64_read_gregs(proc, &regs) < 0) {
2e4be5
+		fprintf(stderr, "get_return_addr: "
2e4be5
+			"Couldn't read registers of %d.\n", proc->pid);
2e4be5
+		return 0;
2e4be5
+	}
2e4be5
+
2e4be5
+	/* XXX double cast */
2e4be5
+	return (arch_addr_t) (uintptr_t) regs.regs[30];
2e4be5
+}
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/signalent.h b/sysdeps/linux-gnu/aarch64/signalent.h
2e4be5
new file mode 100644
2e4be5
index 0000000..bf56ebc
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/signalent.h
2e4be5
@@ -0,0 +1,52 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2006 Ian Wienand
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+	"SIG_0",			/* 0 */
2e4be5
+	"SIGHUP",			/* 1 */
2e4be5
+	"SIGINT",			/* 2 */
2e4be5
+	"SIGQUIT",			/* 3 */
2e4be5
+	"SIGILL",			/* 4 */
2e4be5
+	"SIGTRAP",			/* 5 */
2e4be5
+	"SIGABRT",			/* 6 */
2e4be5
+	"SIGBUS",			/* 7 */
2e4be5
+	"SIGFPE",			/* 8 */
2e4be5
+	"SIGKILL",			/* 9 */
2e4be5
+	"SIGUSR1",			/* 10 */
2e4be5
+	"SIGSEGV",			/* 11 */
2e4be5
+	"SIGUSR2",			/* 12 */
2e4be5
+	"SIGPIPE",			/* 13 */
2e4be5
+	"SIGALRM",			/* 14 */
2e4be5
+	"SIGTERM",			/* 15 */
2e4be5
+	"SIGSTKFLT",			/* 16 */
2e4be5
+	"SIGCHLD",			/* 17 */
2e4be5
+	"SIGCONT",			/* 18 */
2e4be5
+	"SIGSTOP",			/* 19 */
2e4be5
+	"SIGTSTP",			/* 20 */
2e4be5
+	"SIGTTIN",			/* 21 */
2e4be5
+	"SIGTTOU",			/* 22 */
2e4be5
+	"SIGURG",			/* 23 */
2e4be5
+	"SIGXCPU",			/* 24 */
2e4be5
+	"SIGXFSZ",			/* 25 */
2e4be5
+	"SIGVTALRM",			/* 26 */
2e4be5
+	"SIGPROF",			/* 27 */
2e4be5
+	"SIGWINCH",			/* 28 */
2e4be5
+	"SIGIO",			/* 29 */
2e4be5
+	"SIGPWR",			/* 30 */
2e4be5
+	"SIGSYS",			/* 31 */
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/syscallent.h b/sysdeps/linux-gnu/aarch64/syscallent.h
2e4be5
new file mode 100644
2e4be5
index 0000000..aca8191
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/syscallent.h
2e4be5
@@ -0,0 +1,1100 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+	"io_setup",                        /* 0 */
2e4be5
+	"io_destroy",                      /* 1 */
2e4be5
+	"io_submit",                       /* 2 */
2e4be5
+	"io_cancel",                       /* 3 */
2e4be5
+	"io_getevents",                    /* 4 */
2e4be5
+	"setxattr",                        /* 5 */
2e4be5
+	"lsetxattr",                       /* 6 */
2e4be5
+	"fsetxattr",                       /* 7 */
2e4be5
+	"getxattr",                        /* 8 */
2e4be5
+	"lgetxattr",                       /* 9 */
2e4be5
+	"fgetxattr",                       /* 10 */
2e4be5
+	"listxattr",                       /* 11 */
2e4be5
+	"llistxattr",                      /* 12 */
2e4be5
+	"flistxattr",                      /* 13 */
2e4be5
+	"removexattr",                     /* 14 */
2e4be5
+	"lremovexattr",                    /* 15 */
2e4be5
+	"fremovexattr",                    /* 16 */
2e4be5
+	"getcwd",                          /* 17 */
2e4be5
+	"lookup_dcookie",                  /* 18 */
2e4be5
+	"eventfd2",                        /* 19 */
2e4be5
+	"epoll_create1",                   /* 20 */
2e4be5
+	"epoll_ctl",                       /* 21 */
2e4be5
+	"epoll_pwait",                     /* 22 */
2e4be5
+	"dup",                             /* 23 */
2e4be5
+	"dup3",                            /* 24 */
2e4be5
+	"fcntl",                           /* 25 */
2e4be5
+	"inotify_init1",                   /* 26 */
2e4be5
+	"inotify_add_watch",               /* 27 */
2e4be5
+	"inotify_rm_watch",                /* 28 */
2e4be5
+	"ioctl",                           /* 29 */
2e4be5
+	"ioprio_set",                      /* 30 */
2e4be5
+	"ioprio_get",                      /* 31 */
2e4be5
+	"flock",                           /* 32 */
2e4be5
+	"mknodat",                         /* 33 */
2e4be5
+	"mkdirat",                         /* 34 */
2e4be5
+	"unlinkat",                        /* 35 */
2e4be5
+	"symlinkat",                       /* 36 */
2e4be5
+	"linkat",                          /* 37 */
2e4be5
+	"renameat",                        /* 38 */
2e4be5
+	"umount2",                         /* 39 */
2e4be5
+	"mount",                           /* 40 */
2e4be5
+	"pivot_root",                      /* 41 */
2e4be5
+	"nfsservctl",                      /* 42 */
2e4be5
+	"statfs",                          /* 43 */
2e4be5
+	"fstatfs",                         /* 44 */
2e4be5
+	"truncate",                        /* 45 */
2e4be5
+	"ftruncate",                       /* 46 */
2e4be5
+	"fallocate",                       /* 47 */
2e4be5
+	"faccessat",                       /* 48 */
2e4be5
+	"chdir",                           /* 49 */
2e4be5
+	"fchdir",                          /* 50 */
2e4be5
+	"chroot",                          /* 51 */
2e4be5
+	"fchmod",                          /* 52 */
2e4be5
+	"fchmodat",                        /* 53 */
2e4be5
+	"fchownat",                        /* 54 */
2e4be5
+	"fchown",                          /* 55 */
2e4be5
+	"openat",                          /* 56 */
2e4be5
+	"close",                           /* 57 */
2e4be5
+	"vhangup",                         /* 58 */
2e4be5
+	"pipe2",                           /* 59 */
2e4be5
+	"quotactl",                        /* 60 */
2e4be5
+	"getdents64",                      /* 61 */
2e4be5
+	"lseek",                           /* 62 */
2e4be5
+	"read",                            /* 63 */
2e4be5
+	"write",                           /* 64 */
2e4be5
+	"readv",                           /* 65 */
2e4be5
+	"writev",                          /* 66 */
2e4be5
+	"pread64",                         /* 67 */
2e4be5
+	"pwrite64",                        /* 68 */
2e4be5
+	"preadv",                          /* 69 */
2e4be5
+	"pwritev",                         /* 70 */
2e4be5
+	"sendfile",                        /* 71 */
2e4be5
+	"pselect6",                        /* 72 */
2e4be5
+	"ppoll",                           /* 73 */
2e4be5
+	"signalfd4",                       /* 74 */
2e4be5
+	"vmsplice",                        /* 75 */
2e4be5
+	"splice",                          /* 76 */
2e4be5
+	"tee",                             /* 77 */
2e4be5
+	"readlinkat",                      /* 78 */
2e4be5
+	"fstatat",                         /* 79 */
2e4be5
+	"fstat",                           /* 80 */
2e4be5
+	"sync",                            /* 81 */
2e4be5
+	"fsync",                           /* 82 */
2e4be5
+	"fdatasync",                       /* 83 */
2e4be5
+	"sync_file_range",                 /* 84 */
2e4be5
+	"timerfd_create",                  /* 85 */
2e4be5
+	"timerfd_settime",                 /* 86 */
2e4be5
+	"timerfd_gettime",                 /* 87 */
2e4be5
+	"utimensat",                       /* 88 */
2e4be5
+	"acct",                            /* 89 */
2e4be5
+	"capget",                          /* 90 */
2e4be5
+	"capset",                          /* 91 */
2e4be5
+	"personality",                     /* 92 */
2e4be5
+	"exit",                            /* 93 */
2e4be5
+	"exit_group",                      /* 94 */
2e4be5
+	"waitid",                          /* 95 */
2e4be5
+	"set_tid_address",                 /* 96 */
2e4be5
+	"unshare",                         /* 97 */
2e4be5
+	"futex",                           /* 98 */
2e4be5
+	"set_robust_list",                 /* 99 */
2e4be5
+	"get_robust_list",                 /* 100 */
2e4be5
+	"nanosleep",                       /* 101 */
2e4be5
+	"getitimer",                       /* 102 */
2e4be5
+	"setitimer",                       /* 103 */
2e4be5
+	"kexec_load",                      /* 104 */
2e4be5
+	"init_module",                     /* 105 */
2e4be5
+	"delete_module",                   /* 106 */
2e4be5
+	"timer_create",                    /* 107 */
2e4be5
+	"timer_gettime",                   /* 108 */
2e4be5
+	"timer_getoverrun",                /* 109 */
2e4be5
+	"timer_settime",                   /* 110 */
2e4be5
+	"timer_delete",                    /* 111 */
2e4be5
+	"clock_settime",                   /* 112 */
2e4be5
+	"clock_gettime",                   /* 113 */
2e4be5
+	"clock_getres",                    /* 114 */
2e4be5
+	"clock_nanosleep",                 /* 115 */
2e4be5
+	"syslog",                          /* 116 */
2e4be5
+	"ptrace",                          /* 117 */
2e4be5
+	"sched_setparam",                  /* 118 */
2e4be5
+	"sched_setscheduler",              /* 119 */
2e4be5
+	"sched_getscheduler",              /* 120 */
2e4be5
+	"sched_getparam",                  /* 121 */
2e4be5
+	"sched_setaffinity",               /* 122 */
2e4be5
+	"sched_getaffinity",               /* 123 */
2e4be5
+	"sched_yield",                     /* 124 */
2e4be5
+	"sched_get_priority_max",          /* 125 */
2e4be5
+	"sched_get_priority_min",          /* 126 */
2e4be5
+	"sched_rr_get_interval",           /* 127 */
2e4be5
+	"restart_syscall",                 /* 128 */
2e4be5
+	"kill",                            /* 129 */
2e4be5
+	"tkill",                           /* 130 */
2e4be5
+	"tgkill",                          /* 131 */
2e4be5
+	"sigaltstack",                     /* 132 */
2e4be5
+	"rt_sigsuspend",                   /* 133 */
2e4be5
+	"rt_sigaction",                    /* 134 */
2e4be5
+	"rt_sigprocmask",                  /* 135 */
2e4be5
+	"rt_sigpending",                   /* 136 */
2e4be5
+	"rt_sigtimedwait",                 /* 137 */
2e4be5
+	"rt_sigqueueinfo",                 /* 138 */
2e4be5
+	"rt_sigreturn",                    /* 139 */
2e4be5
+	"setpriority",                     /* 140 */
2e4be5
+	"getpriority",                     /* 141 */
2e4be5
+	"reboot",                          /* 142 */
2e4be5
+	"setregid",                        /* 143 */
2e4be5
+	"setgid",                          /* 144 */
2e4be5
+	"setreuid",                        /* 145 */
2e4be5
+	"setuid",                          /* 146 */
2e4be5
+	"setresuid",                       /* 147 */
2e4be5
+	"getresuid",                       /* 148 */
2e4be5
+	"setresgid",                       /* 149 */
2e4be5
+	"getresgid",                       /* 150 */
2e4be5
+	"setfsuid",                        /* 151 */
2e4be5
+	"setfsgid",                        /* 152 */
2e4be5
+	"times",                           /* 153 */
2e4be5
+	"setpgid",                         /* 154 */
2e4be5
+	"getpgid",                         /* 155 */
2e4be5
+	"getsid",                          /* 156 */
2e4be5
+	"setsid",                          /* 157 */
2e4be5
+	"getgroups",                       /* 158 */
2e4be5
+	"setgroups",                       /* 159 */
2e4be5
+	"uname",                           /* 160 */
2e4be5
+	"sethostname",                     /* 161 */
2e4be5
+	"setdomainname",                   /* 162 */
2e4be5
+	"getrlimit",                       /* 163 */
2e4be5
+	"setrlimit",                       /* 164 */
2e4be5
+	"getrusage",                       /* 165 */
2e4be5
+	"umask",                           /* 166 */
2e4be5
+	"prctl",                           /* 167 */
2e4be5
+	"getcpu",                          /* 168 */
2e4be5
+	"gettimeofday",                    /* 169 */
2e4be5
+	"settimeofday",                    /* 170 */
2e4be5
+	"adjtimex",                        /* 171 */
2e4be5
+	"getpid",                          /* 172 */
2e4be5
+	"getppid",                         /* 173 */
2e4be5
+	"getuid",                          /* 174 */
2e4be5
+	"geteuid",                         /* 175 */
2e4be5
+	"getgid",                          /* 176 */
2e4be5
+	"getegid",                         /* 177 */
2e4be5
+	"gettid",                          /* 178 */
2e4be5
+	"sysinfo",                         /* 179 */
2e4be5
+	"mq_open",                         /* 180 */
2e4be5
+	"mq_unlink",                       /* 181 */
2e4be5
+	"mq_timedsend",                    /* 182 */
2e4be5
+	"mq_timedreceive",                 /* 183 */
2e4be5
+	"mq_notify",                       /* 184 */
2e4be5
+	"mq_getsetattr",                   /* 185 */
2e4be5
+	"msgget",                          /* 186 */
2e4be5
+	"msgctl",                          /* 187 */
2e4be5
+	"msgrcv",                          /* 188 */
2e4be5
+	"msgsnd",                          /* 189 */
2e4be5
+	"semget",                          /* 190 */
2e4be5
+	"semctl",                          /* 191 */
2e4be5
+	"semtimedop",                      /* 192 */
2e4be5
+	"semop",                           /* 193 */
2e4be5
+	"shmget",                          /* 194 */
2e4be5
+	"shmctl",                          /* 195 */
2e4be5
+	"shmat",                           /* 196 */
2e4be5
+	"shmdt",                           /* 197 */
2e4be5
+	"socket",                          /* 198 */
2e4be5
+	"socketpair",                      /* 199 */
2e4be5
+	"bind",                            /* 200 */
2e4be5
+	"listen",                          /* 201 */
2e4be5
+	"accept",                          /* 202 */
2e4be5
+	"connect",                         /* 203 */
2e4be5
+	"getsockname",                     /* 204 */
2e4be5
+	"getpeername",                     /* 205 */
2e4be5
+	"sendto",                          /* 206 */
2e4be5
+	"recvfrom",                        /* 207 */
2e4be5
+	"setsockopt",                      /* 208 */
2e4be5
+	"getsockopt",                      /* 209 */
2e4be5
+	"shutdown",                        /* 210 */
2e4be5
+	"sendmsg",                         /* 211 */
2e4be5
+	"recvmsg",                         /* 212 */
2e4be5
+	"readahead",                       /* 213 */
2e4be5
+	"brk",                             /* 214 */
2e4be5
+	"munmap",                          /* 215 */
2e4be5
+	"mremap",                          /* 216 */
2e4be5
+	"add_key",                         /* 217 */
2e4be5
+	"request_key",                     /* 218 */
2e4be5
+	"keyctl",                          /* 219 */
2e4be5
+	"clone",                           /* 220 */
2e4be5
+	"execve",                          /* 221 */
2e4be5
+	"mmap",                            /* 222 */
2e4be5
+	"fadvise64",                       /* 223 */
2e4be5
+	"swapon",                          /* 224 */
2e4be5
+	"swapoff",                         /* 225 */
2e4be5
+	"mprotect",                        /* 226 */
2e4be5
+	"msync",                           /* 227 */
2e4be5
+	"mlock",                           /* 228 */
2e4be5
+	"munlock",                         /* 229 */
2e4be5
+	"mlockall",                        /* 230 */
2e4be5
+	"munlockall",                      /* 231 */
2e4be5
+	"mincore",                         /* 232 */
2e4be5
+	"madvise",                         /* 233 */
2e4be5
+	"remap_file_pages",                /* 234 */
2e4be5
+	"mbind",                           /* 235 */
2e4be5
+	"get_mempolicy",                   /* 236 */
2e4be5
+	"set_mempolicy",                   /* 237 */
2e4be5
+	"migrate_pages",                   /* 238 */
2e4be5
+	"move_pages",                      /* 239 */
2e4be5
+	"rt_tgsigqueueinfo",               /* 240 */
2e4be5
+	"perf_event_open",                 /* 241 */
2e4be5
+	"accept4",                         /* 242 */
2e4be5
+	"recvmmsg",                        /* 243 */
2e4be5
+	"arch_specific_syscall",           /* 244 */
2e4be5
+	"245",                             /* 245 */
2e4be5
+	"246",                             /* 246 */
2e4be5
+	"247",                             /* 247 */
2e4be5
+	"248",                             /* 248 */
2e4be5
+	"249",                             /* 249 */
2e4be5
+	"250",                             /* 250 */
2e4be5
+	"251",                             /* 251 */
2e4be5
+	"252",                             /* 252 */
2e4be5
+	"253",                             /* 253 */
2e4be5
+	"254",                             /* 254 */
2e4be5
+	"255",                             /* 255 */
2e4be5
+	"256",                             /* 256 */
2e4be5
+	"257",                             /* 257 */
2e4be5
+	"258",                             /* 258 */
2e4be5
+	"259",                             /* 259 */
2e4be5
+	"wait4",                           /* 260 */
2e4be5
+	"prlimit64",                       /* 261 */
2e4be5
+	"fanotify_init",                   /* 262 */
2e4be5
+	"fanotify_mark",                   /* 263 */
2e4be5
+	"name_to_handle_at",               /* 264 */
2e4be5
+	"open_by_handle_at",               /* 265 */
2e4be5
+	"clock_adjtime",                   /* 266 */
2e4be5
+	"syncfs",                          /* 267 */
2e4be5
+	"setns",                           /* 268 */
2e4be5
+	"sendmmsg",                        /* 269 */
2e4be5
+	"process_vm_readv",                /* 270 */
2e4be5
+	"process_vm_writev",               /* 271 */
2e4be5
+	"kcmp",                            /* 272 */
2e4be5
+	"finit_module",                    /* 273 */
2e4be5
+	"syscalls",                        /* 274 */
2e4be5
+	"275",                             /* 275 */
2e4be5
+	"276",                             /* 276 */
2e4be5
+	"277",                             /* 277 */
2e4be5
+	"278",                             /* 278 */
2e4be5
+	"279",                             /* 279 */
2e4be5
+	"280",                             /* 280 */
2e4be5
+	"281",                             /* 281 */
2e4be5
+	"282",                             /* 282 */
2e4be5
+	"283",                             /* 283 */
2e4be5
+	"284",                             /* 284 */
2e4be5
+	"285",                             /* 285 */
2e4be5
+	"286",                             /* 286 */
2e4be5
+	"287",                             /* 287 */
2e4be5
+	"288",                             /* 288 */
2e4be5
+	"289",                             /* 289 */
2e4be5
+	"290",                             /* 290 */
2e4be5
+	"291",                             /* 291 */
2e4be5
+	"292",                             /* 292 */
2e4be5
+	"293",                             /* 293 */
2e4be5
+	"294",                             /* 294 */
2e4be5
+	"295",                             /* 295 */
2e4be5
+	"296",                             /* 296 */
2e4be5
+	"297",                             /* 297 */
2e4be5
+	"298",                             /* 298 */
2e4be5
+	"299",                             /* 299 */
2e4be5
+	"300",                             /* 300 */
2e4be5
+	"301",                             /* 301 */
2e4be5
+	"302",                             /* 302 */
2e4be5
+	"303",                             /* 303 */
2e4be5
+	"304",                             /* 304 */
2e4be5
+	"305",                             /* 305 */
2e4be5
+	"306",                             /* 306 */
2e4be5
+	"307",                             /* 307 */
2e4be5
+	"308",                             /* 308 */
2e4be5
+	"309",                             /* 309 */
2e4be5
+	"310",                             /* 310 */
2e4be5
+	"311",                             /* 311 */
2e4be5
+	"312",                             /* 312 */
2e4be5
+	"313",                             /* 313 */
2e4be5
+	"314",                             /* 314 */
2e4be5
+	"315",                             /* 315 */
2e4be5
+	"316",                             /* 316 */
2e4be5
+	"317",                             /* 317 */
2e4be5
+	"318",                             /* 318 */
2e4be5
+	"319",                             /* 319 */
2e4be5
+	"320",                             /* 320 */
2e4be5
+	"321",                             /* 321 */
2e4be5
+	"322",                             /* 322 */
2e4be5
+	"323",                             /* 323 */
2e4be5
+	"324",                             /* 324 */
2e4be5
+	"325",                             /* 325 */
2e4be5
+	"326",                             /* 326 */
2e4be5
+	"327",                             /* 327 */
2e4be5
+	"328",                             /* 328 */
2e4be5
+	"329",                             /* 329 */
2e4be5
+	"330",                             /* 330 */
2e4be5
+	"331",                             /* 331 */
2e4be5
+	"332",                             /* 332 */
2e4be5
+	"333",                             /* 333 */
2e4be5
+	"334",                             /* 334 */
2e4be5
+	"335",                             /* 335 */
2e4be5
+	"336",                             /* 336 */
2e4be5
+	"337",                             /* 337 */
2e4be5
+	"338",                             /* 338 */
2e4be5
+	"339",                             /* 339 */
2e4be5
+	"340",                             /* 340 */
2e4be5
+	"341",                             /* 341 */
2e4be5
+	"342",                             /* 342 */
2e4be5
+	"343",                             /* 343 */
2e4be5
+	"344",                             /* 344 */
2e4be5
+	"345",                             /* 345 */
2e4be5
+	"346",                             /* 346 */
2e4be5
+	"347",                             /* 347 */
2e4be5
+	"348",                             /* 348 */
2e4be5
+	"349",                             /* 349 */
2e4be5
+	"350",                             /* 350 */
2e4be5
+	"351",                             /* 351 */
2e4be5
+	"352",                             /* 352 */
2e4be5
+	"353",                             /* 353 */
2e4be5
+	"354",                             /* 354 */
2e4be5
+	"355",                             /* 355 */
2e4be5
+	"356",                             /* 356 */
2e4be5
+	"357",                             /* 357 */
2e4be5
+	"358",                             /* 358 */
2e4be5
+	"359",                             /* 359 */
2e4be5
+	"360",                             /* 360 */
2e4be5
+	"361",                             /* 361 */
2e4be5
+	"362",                             /* 362 */
2e4be5
+	"363",                             /* 363 */
2e4be5
+	"364",                             /* 364 */
2e4be5
+	"365",                             /* 365 */
2e4be5
+	"366",                             /* 366 */
2e4be5
+	"367",                             /* 367 */
2e4be5
+	"368",                             /* 368 */
2e4be5
+	"369",                             /* 369 */
2e4be5
+	"370",                             /* 370 */
2e4be5
+	"371",                             /* 371 */
2e4be5
+	"372",                             /* 372 */
2e4be5
+	"373",                             /* 373 */
2e4be5
+	"374",                             /* 374 */
2e4be5
+	"375",                             /* 375 */
2e4be5
+	"376",                             /* 376 */
2e4be5
+	"377",                             /* 377 */
2e4be5
+	"378",                             /* 378 */
2e4be5
+	"379",                             /* 379 */
2e4be5
+	"380",                             /* 380 */
2e4be5
+	"381",                             /* 381 */
2e4be5
+	"382",                             /* 382 */
2e4be5
+	"383",                             /* 383 */
2e4be5
+	"384",                             /* 384 */
2e4be5
+	"385",                             /* 385 */
2e4be5
+	"386",                             /* 386 */
2e4be5
+	"387",                             /* 387 */
2e4be5
+	"388",                             /* 388 */
2e4be5
+	"389",                             /* 389 */
2e4be5
+	"390",                             /* 390 */
2e4be5
+	"391",                             /* 391 */
2e4be5
+	"392",                             /* 392 */
2e4be5
+	"393",                             /* 393 */
2e4be5
+	"394",                             /* 394 */
2e4be5
+	"395",                             /* 395 */
2e4be5
+	"396",                             /* 396 */
2e4be5
+	"397",                             /* 397 */
2e4be5
+	"398",                             /* 398 */
2e4be5
+	"399",                             /* 399 */
2e4be5
+	"400",                             /* 400 */
2e4be5
+	"401",                             /* 401 */
2e4be5
+	"402",                             /* 402 */
2e4be5
+	"403",                             /* 403 */
2e4be5
+	"404",                             /* 404 */
2e4be5
+	"405",                             /* 405 */
2e4be5
+	"406",                             /* 406 */
2e4be5
+	"407",                             /* 407 */
2e4be5
+	"408",                             /* 408 */
2e4be5
+	"409",                             /* 409 */
2e4be5
+	"410",                             /* 410 */
2e4be5
+	"411",                             /* 411 */
2e4be5
+	"412",                             /* 412 */
2e4be5
+	"413",                             /* 413 */
2e4be5
+	"414",                             /* 414 */
2e4be5
+	"415",                             /* 415 */
2e4be5
+	"416",                             /* 416 */
2e4be5
+	"417",                             /* 417 */
2e4be5
+	"418",                             /* 418 */
2e4be5
+	"419",                             /* 419 */
2e4be5
+	"420",                             /* 420 */
2e4be5
+	"421",                             /* 421 */
2e4be5
+	"422",                             /* 422 */
2e4be5
+	"423",                             /* 423 */
2e4be5
+	"424",                             /* 424 */
2e4be5
+	"425",                             /* 425 */
2e4be5
+	"426",                             /* 426 */
2e4be5
+	"427",                             /* 427 */
2e4be5
+	"428",                             /* 428 */
2e4be5
+	"429",                             /* 429 */
2e4be5
+	"430",                             /* 430 */
2e4be5
+	"431",                             /* 431 */
2e4be5
+	"432",                             /* 432 */
2e4be5
+	"433",                             /* 433 */
2e4be5
+	"434",                             /* 434 */
2e4be5
+	"435",                             /* 435 */
2e4be5
+	"436",                             /* 436 */
2e4be5
+	"437",                             /* 437 */
2e4be5
+	"438",                             /* 438 */
2e4be5
+	"439",                             /* 439 */
2e4be5
+	"440",                             /* 440 */
2e4be5
+	"441",                             /* 441 */
2e4be5
+	"442",                             /* 442 */
2e4be5
+	"443",                             /* 443 */
2e4be5
+	"444",                             /* 444 */
2e4be5
+	"445",                             /* 445 */
2e4be5
+	"446",                             /* 446 */
2e4be5
+	"447",                             /* 447 */
2e4be5
+	"448",                             /* 448 */
2e4be5
+	"449",                             /* 449 */
2e4be5
+	"450",                             /* 450 */
2e4be5
+	"451",                             /* 451 */
2e4be5
+	"452",                             /* 452 */
2e4be5
+	"453",                             /* 453 */
2e4be5
+	"454",                             /* 454 */
2e4be5
+	"455",                             /* 455 */
2e4be5
+	"456",                             /* 456 */
2e4be5
+	"457",                             /* 457 */
2e4be5
+	"458",                             /* 458 */
2e4be5
+	"459",                             /* 459 */
2e4be5
+	"460",                             /* 460 */
2e4be5
+	"461",                             /* 461 */
2e4be5
+	"462",                             /* 462 */
2e4be5
+	"463",                             /* 463 */
2e4be5
+	"464",                             /* 464 */
2e4be5
+	"465",                             /* 465 */
2e4be5
+	"466",                             /* 466 */
2e4be5
+	"467",                             /* 467 */
2e4be5
+	"468",                             /* 468 */
2e4be5
+	"469",                             /* 469 */
2e4be5
+	"470",                             /* 470 */
2e4be5
+	"471",                             /* 471 */
2e4be5
+	"472",                             /* 472 */
2e4be5
+	"473",                             /* 473 */
2e4be5
+	"474",                             /* 474 */
2e4be5
+	"475",                             /* 475 */
2e4be5
+	"476",                             /* 476 */
2e4be5
+	"477",                             /* 477 */
2e4be5
+	"478",                             /* 478 */
2e4be5
+	"479",                             /* 479 */
2e4be5
+	"480",                             /* 480 */
2e4be5
+	"481",                             /* 481 */
2e4be5
+	"482",                             /* 482 */
2e4be5
+	"483",                             /* 483 */
2e4be5
+	"484",                             /* 484 */
2e4be5
+	"485",                             /* 485 */
2e4be5
+	"486",                             /* 486 */
2e4be5
+	"487",                             /* 487 */
2e4be5
+	"488",                             /* 488 */
2e4be5
+	"489",                             /* 489 */
2e4be5
+	"490",                             /* 490 */
2e4be5
+	"491",                             /* 491 */
2e4be5
+	"492",                             /* 492 */
2e4be5
+	"493",                             /* 493 */
2e4be5
+	"494",                             /* 494 */
2e4be5
+	"495",                             /* 495 */
2e4be5
+	"496",                             /* 496 */
2e4be5
+	"497",                             /* 497 */
2e4be5
+	"498",                             /* 498 */
2e4be5
+	"499",                             /* 499 */
2e4be5
+	"500",                             /* 500 */
2e4be5
+	"501",                             /* 501 */
2e4be5
+	"502",                             /* 502 */
2e4be5
+	"503",                             /* 503 */
2e4be5
+	"504",                             /* 504 */
2e4be5
+	"505",                             /* 505 */
2e4be5
+	"506",                             /* 506 */
2e4be5
+	"507",                             /* 507 */
2e4be5
+	"508",                             /* 508 */
2e4be5
+	"509",                             /* 509 */
2e4be5
+	"510",                             /* 510 */
2e4be5
+	"511",                             /* 511 */
2e4be5
+	"512",                             /* 512 */
2e4be5
+	"513",                             /* 513 */
2e4be5
+	"514",                             /* 514 */
2e4be5
+	"515",                             /* 515 */
2e4be5
+	"516",                             /* 516 */
2e4be5
+	"517",                             /* 517 */
2e4be5
+	"518",                             /* 518 */
2e4be5
+	"519",                             /* 519 */
2e4be5
+	"520",                             /* 520 */
2e4be5
+	"521",                             /* 521 */
2e4be5
+	"522",                             /* 522 */
2e4be5
+	"523",                             /* 523 */
2e4be5
+	"524",                             /* 524 */
2e4be5
+	"525",                             /* 525 */
2e4be5
+	"526",                             /* 526 */
2e4be5
+	"527",                             /* 527 */
2e4be5
+	"528",                             /* 528 */
2e4be5
+	"529",                             /* 529 */
2e4be5
+	"530",                             /* 530 */
2e4be5
+	"531",                             /* 531 */
2e4be5
+	"532",                             /* 532 */
2e4be5
+	"533",                             /* 533 */
2e4be5
+	"534",                             /* 534 */
2e4be5
+	"535",                             /* 535 */
2e4be5
+	"536",                             /* 536 */
2e4be5
+	"537",                             /* 537 */
2e4be5
+	"538",                             /* 538 */
2e4be5
+	"539",                             /* 539 */
2e4be5
+	"540",                             /* 540 */
2e4be5
+	"541",                             /* 541 */
2e4be5
+	"542",                             /* 542 */
2e4be5
+	"543",                             /* 543 */
2e4be5
+	"544",                             /* 544 */
2e4be5
+	"545",                             /* 545 */
2e4be5
+	"546",                             /* 546 */
2e4be5
+	"547",                             /* 547 */
2e4be5
+	"548",                             /* 548 */
2e4be5
+	"549",                             /* 549 */
2e4be5
+	"550",                             /* 550 */
2e4be5
+	"551",                             /* 551 */
2e4be5
+	"552",                             /* 552 */
2e4be5
+	"553",                             /* 553 */
2e4be5
+	"554",                             /* 554 */
2e4be5
+	"555",                             /* 555 */
2e4be5
+	"556",                             /* 556 */
2e4be5
+	"557",                             /* 557 */
2e4be5
+	"558",                             /* 558 */
2e4be5
+	"559",                             /* 559 */
2e4be5
+	"560",                             /* 560 */
2e4be5
+	"561",                             /* 561 */
2e4be5
+	"562",                             /* 562 */
2e4be5
+	"563",                             /* 563 */
2e4be5
+	"564",                             /* 564 */
2e4be5
+	"565",                             /* 565 */
2e4be5
+	"566",                             /* 566 */
2e4be5
+	"567",                             /* 567 */
2e4be5
+	"568",                             /* 568 */
2e4be5
+	"569",                             /* 569 */
2e4be5
+	"570",                             /* 570 */
2e4be5
+	"571",                             /* 571 */
2e4be5
+	"572",                             /* 572 */
2e4be5
+	"573",                             /* 573 */
2e4be5
+	"574",                             /* 574 */
2e4be5
+	"575",                             /* 575 */
2e4be5
+	"576",                             /* 576 */
2e4be5
+	"577",                             /* 577 */
2e4be5
+	"578",                             /* 578 */
2e4be5
+	"579",                             /* 579 */
2e4be5
+	"580",                             /* 580 */
2e4be5
+	"581",                             /* 581 */
2e4be5
+	"582",                             /* 582 */
2e4be5
+	"583",                             /* 583 */
2e4be5
+	"584",                             /* 584 */
2e4be5
+	"585",                             /* 585 */
2e4be5
+	"586",                             /* 586 */
2e4be5
+	"587",                             /* 587 */
2e4be5
+	"588",                             /* 588 */
2e4be5
+	"589",                             /* 589 */
2e4be5
+	"590",                             /* 590 */
2e4be5
+	"591",                             /* 591 */
2e4be5
+	"592",                             /* 592 */
2e4be5
+	"593",                             /* 593 */
2e4be5
+	"594",                             /* 594 */
2e4be5
+	"595",                             /* 595 */
2e4be5
+	"596",                             /* 596 */
2e4be5
+	"597",                             /* 597 */
2e4be5
+	"598",                             /* 598 */
2e4be5
+	"599",                             /* 599 */
2e4be5
+	"600",                             /* 600 */
2e4be5
+	"601",                             /* 601 */
2e4be5
+	"602",                             /* 602 */
2e4be5
+	"603",                             /* 603 */
2e4be5
+	"604",                             /* 604 */
2e4be5
+	"605",                             /* 605 */
2e4be5
+	"606",                             /* 606 */
2e4be5
+	"607",                             /* 607 */
2e4be5
+	"608",                             /* 608 */
2e4be5
+	"609",                             /* 609 */
2e4be5
+	"610",                             /* 610 */
2e4be5
+	"611",                             /* 611 */
2e4be5
+	"612",                             /* 612 */
2e4be5
+	"613",                             /* 613 */
2e4be5
+	"614",                             /* 614 */
2e4be5
+	"615",                             /* 615 */
2e4be5
+	"616",                             /* 616 */
2e4be5
+	"617",                             /* 617 */
2e4be5
+	"618",                             /* 618 */
2e4be5
+	"619",                             /* 619 */
2e4be5
+	"620",                             /* 620 */
2e4be5
+	"621",                             /* 621 */
2e4be5
+	"622",                             /* 622 */
2e4be5
+	"623",                             /* 623 */
2e4be5
+	"624",                             /* 624 */
2e4be5
+	"625",                             /* 625 */
2e4be5
+	"626",                             /* 626 */
2e4be5
+	"627",                             /* 627 */
2e4be5
+	"628",                             /* 628 */
2e4be5
+	"629",                             /* 629 */
2e4be5
+	"630",                             /* 630 */
2e4be5
+	"631",                             /* 631 */
2e4be5
+	"632",                             /* 632 */
2e4be5
+	"633",                             /* 633 */
2e4be5
+	"634",                             /* 634 */
2e4be5
+	"635",                             /* 635 */
2e4be5
+	"636",                             /* 636 */
2e4be5
+	"637",                             /* 637 */
2e4be5
+	"638",                             /* 638 */
2e4be5
+	"639",                             /* 639 */
2e4be5
+	"640",                             /* 640 */
2e4be5
+	"641",                             /* 641 */
2e4be5
+	"642",                             /* 642 */
2e4be5
+	"643",                             /* 643 */
2e4be5
+	"644",                             /* 644 */
2e4be5
+	"645",                             /* 645 */
2e4be5
+	"646",                             /* 646 */
2e4be5
+	"647",                             /* 647 */
2e4be5
+	"648",                             /* 648 */
2e4be5
+	"649",                             /* 649 */
2e4be5
+	"650",                             /* 650 */
2e4be5
+	"651",                             /* 651 */
2e4be5
+	"652",                             /* 652 */
2e4be5
+	"653",                             /* 653 */
2e4be5
+	"654",                             /* 654 */
2e4be5
+	"655",                             /* 655 */
2e4be5
+	"656",                             /* 656 */
2e4be5
+	"657",                             /* 657 */
2e4be5
+	"658",                             /* 658 */
2e4be5
+	"659",                             /* 659 */
2e4be5
+	"660",                             /* 660 */
2e4be5
+	"661",                             /* 661 */
2e4be5
+	"662",                             /* 662 */
2e4be5
+	"663",                             /* 663 */
2e4be5
+	"664",                             /* 664 */
2e4be5
+	"665",                             /* 665 */
2e4be5
+	"666",                             /* 666 */
2e4be5
+	"667",                             /* 667 */
2e4be5
+	"668",                             /* 668 */
2e4be5
+	"669",                             /* 669 */
2e4be5
+	"670",                             /* 670 */
2e4be5
+	"671",                             /* 671 */
2e4be5
+	"672",                             /* 672 */
2e4be5
+	"673",                             /* 673 */
2e4be5
+	"674",                             /* 674 */
2e4be5
+	"675",                             /* 675 */
2e4be5
+	"676",                             /* 676 */
2e4be5
+	"677",                             /* 677 */
2e4be5
+	"678",                             /* 678 */
2e4be5
+	"679",                             /* 679 */
2e4be5
+	"680",                             /* 680 */
2e4be5
+	"681",                             /* 681 */
2e4be5
+	"682",                             /* 682 */
2e4be5
+	"683",                             /* 683 */
2e4be5
+	"684",                             /* 684 */
2e4be5
+	"685",                             /* 685 */
2e4be5
+	"686",                             /* 686 */
2e4be5
+	"687",                             /* 687 */
2e4be5
+	"688",                             /* 688 */
2e4be5
+	"689",                             /* 689 */
2e4be5
+	"690",                             /* 690 */
2e4be5
+	"691",                             /* 691 */
2e4be5
+	"692",                             /* 692 */
2e4be5
+	"693",                             /* 693 */
2e4be5
+	"694",                             /* 694 */
2e4be5
+	"695",                             /* 695 */
2e4be5
+	"696",                             /* 696 */
2e4be5
+	"697",                             /* 697 */
2e4be5
+	"698",                             /* 698 */
2e4be5
+	"699",                             /* 699 */
2e4be5
+	"700",                             /* 700 */
2e4be5
+	"701",                             /* 701 */
2e4be5
+	"702",                             /* 702 */
2e4be5
+	"703",                             /* 703 */
2e4be5
+	"704",                             /* 704 */
2e4be5
+	"705",                             /* 705 */
2e4be5
+	"706",                             /* 706 */
2e4be5
+	"707",                             /* 707 */
2e4be5
+	"708",                             /* 708 */
2e4be5
+	"709",                             /* 709 */
2e4be5
+	"710",                             /* 710 */
2e4be5
+	"711",                             /* 711 */
2e4be5
+	"712",                             /* 712 */
2e4be5
+	"713",                             /* 713 */
2e4be5
+	"714",                             /* 714 */
2e4be5
+	"715",                             /* 715 */
2e4be5
+	"716",                             /* 716 */
2e4be5
+	"717",                             /* 717 */
2e4be5
+	"718",                             /* 718 */
2e4be5
+	"719",                             /* 719 */
2e4be5
+	"720",                             /* 720 */
2e4be5
+	"721",                             /* 721 */
2e4be5
+	"722",                             /* 722 */
2e4be5
+	"723",                             /* 723 */
2e4be5
+	"724",                             /* 724 */
2e4be5
+	"725",                             /* 725 */
2e4be5
+	"726",                             /* 726 */
2e4be5
+	"727",                             /* 727 */
2e4be5
+	"728",                             /* 728 */
2e4be5
+	"729",                             /* 729 */
2e4be5
+	"730",                             /* 730 */
2e4be5
+	"731",                             /* 731 */
2e4be5
+	"732",                             /* 732 */
2e4be5
+	"733",                             /* 733 */
2e4be5
+	"734",                             /* 734 */
2e4be5
+	"735",                             /* 735 */
2e4be5
+	"736",                             /* 736 */
2e4be5
+	"737",                             /* 737 */
2e4be5
+	"738",                             /* 738 */
2e4be5
+	"739",                             /* 739 */
2e4be5
+	"740",                             /* 740 */
2e4be5
+	"741",                             /* 741 */
2e4be5
+	"742",                             /* 742 */
2e4be5
+	"743",                             /* 743 */
2e4be5
+	"744",                             /* 744 */
2e4be5
+	"745",                             /* 745 */
2e4be5
+	"746",                             /* 746 */
2e4be5
+	"747",                             /* 747 */
2e4be5
+	"748",                             /* 748 */
2e4be5
+	"749",                             /* 749 */
2e4be5
+	"750",                             /* 750 */
2e4be5
+	"751",                             /* 751 */
2e4be5
+	"752",                             /* 752 */
2e4be5
+	"753",                             /* 753 */
2e4be5
+	"754",                             /* 754 */
2e4be5
+	"755",                             /* 755 */
2e4be5
+	"756",                             /* 756 */
2e4be5
+	"757",                             /* 757 */
2e4be5
+	"758",                             /* 758 */
2e4be5
+	"759",                             /* 759 */
2e4be5
+	"760",                             /* 760 */
2e4be5
+	"761",                             /* 761 */
2e4be5
+	"762",                             /* 762 */
2e4be5
+	"763",                             /* 763 */
2e4be5
+	"764",                             /* 764 */
2e4be5
+	"765",                             /* 765 */
2e4be5
+	"766",                             /* 766 */
2e4be5
+	"767",                             /* 767 */
2e4be5
+	"768",                             /* 768 */
2e4be5
+	"769",                             /* 769 */
2e4be5
+	"770",                             /* 770 */
2e4be5
+	"771",                             /* 771 */
2e4be5
+	"772",                             /* 772 */
2e4be5
+	"773",                             /* 773 */
2e4be5
+	"774",                             /* 774 */
2e4be5
+	"775",                             /* 775 */
2e4be5
+	"776",                             /* 776 */
2e4be5
+	"777",                             /* 777 */
2e4be5
+	"778",                             /* 778 */
2e4be5
+	"779",                             /* 779 */
2e4be5
+	"780",                             /* 780 */
2e4be5
+	"781",                             /* 781 */
2e4be5
+	"782",                             /* 782 */
2e4be5
+	"783",                             /* 783 */
2e4be5
+	"784",                             /* 784 */
2e4be5
+	"785",                             /* 785 */
2e4be5
+	"786",                             /* 786 */
2e4be5
+	"787",                             /* 787 */
2e4be5
+	"788",                             /* 788 */
2e4be5
+	"789",                             /* 789 */
2e4be5
+	"790",                             /* 790 */
2e4be5
+	"791",                             /* 791 */
2e4be5
+	"792",                             /* 792 */
2e4be5
+	"793",                             /* 793 */
2e4be5
+	"794",                             /* 794 */
2e4be5
+	"795",                             /* 795 */
2e4be5
+	"796",                             /* 796 */
2e4be5
+	"797",                             /* 797 */
2e4be5
+	"798",                             /* 798 */
2e4be5
+	"799",                             /* 799 */
2e4be5
+	"800",                             /* 800 */
2e4be5
+	"801",                             /* 801 */
2e4be5
+	"802",                             /* 802 */
2e4be5
+	"803",                             /* 803 */
2e4be5
+	"804",                             /* 804 */
2e4be5
+	"805",                             /* 805 */
2e4be5
+	"806",                             /* 806 */
2e4be5
+	"807",                             /* 807 */
2e4be5
+	"808",                             /* 808 */
2e4be5
+	"809",                             /* 809 */
2e4be5
+	"810",                             /* 810 */
2e4be5
+	"811",                             /* 811 */
2e4be5
+	"812",                             /* 812 */
2e4be5
+	"813",                             /* 813 */
2e4be5
+	"814",                             /* 814 */
2e4be5
+	"815",                             /* 815 */
2e4be5
+	"816",                             /* 816 */
2e4be5
+	"817",                             /* 817 */
2e4be5
+	"818",                             /* 818 */
2e4be5
+	"819",                             /* 819 */
2e4be5
+	"820",                             /* 820 */
2e4be5
+	"821",                             /* 821 */
2e4be5
+	"822",                             /* 822 */
2e4be5
+	"823",                             /* 823 */
2e4be5
+	"824",                             /* 824 */
2e4be5
+	"825",                             /* 825 */
2e4be5
+	"826",                             /* 826 */
2e4be5
+	"827",                             /* 827 */
2e4be5
+	"828",                             /* 828 */
2e4be5
+	"829",                             /* 829 */
2e4be5
+	"830",                             /* 830 */
2e4be5
+	"831",                             /* 831 */
2e4be5
+	"832",                             /* 832 */
2e4be5
+	"833",                             /* 833 */
2e4be5
+	"834",                             /* 834 */
2e4be5
+	"835",                             /* 835 */
2e4be5
+	"836",                             /* 836 */
2e4be5
+	"837",                             /* 837 */
2e4be5
+	"838",                             /* 838 */
2e4be5
+	"839",                             /* 839 */
2e4be5
+	"840",                             /* 840 */
2e4be5
+	"841",                             /* 841 */
2e4be5
+	"842",                             /* 842 */
2e4be5
+	"843",                             /* 843 */
2e4be5
+	"844",                             /* 844 */
2e4be5
+	"845",                             /* 845 */
2e4be5
+	"846",                             /* 846 */
2e4be5
+	"847",                             /* 847 */
2e4be5
+	"848",                             /* 848 */
2e4be5
+	"849",                             /* 849 */
2e4be5
+	"850",                             /* 850 */
2e4be5
+	"851",                             /* 851 */
2e4be5
+	"852",                             /* 852 */
2e4be5
+	"853",                             /* 853 */
2e4be5
+	"854",                             /* 854 */
2e4be5
+	"855",                             /* 855 */
2e4be5
+	"856",                             /* 856 */
2e4be5
+	"857",                             /* 857 */
2e4be5
+	"858",                             /* 858 */
2e4be5
+	"859",                             /* 859 */
2e4be5
+	"860",                             /* 860 */
2e4be5
+	"861",                             /* 861 */
2e4be5
+	"862",                             /* 862 */
2e4be5
+	"863",                             /* 863 */
2e4be5
+	"864",                             /* 864 */
2e4be5
+	"865",                             /* 865 */
2e4be5
+	"866",                             /* 866 */
2e4be5
+	"867",                             /* 867 */
2e4be5
+	"868",                             /* 868 */
2e4be5
+	"869",                             /* 869 */
2e4be5
+	"870",                             /* 870 */
2e4be5
+	"871",                             /* 871 */
2e4be5
+	"872",                             /* 872 */
2e4be5
+	"873",                             /* 873 */
2e4be5
+	"874",                             /* 874 */
2e4be5
+	"875",                             /* 875 */
2e4be5
+	"876",                             /* 876 */
2e4be5
+	"877",                             /* 877 */
2e4be5
+	"878",                             /* 878 */
2e4be5
+	"879",                             /* 879 */
2e4be5
+	"880",                             /* 880 */
2e4be5
+	"881",                             /* 881 */
2e4be5
+	"882",                             /* 882 */
2e4be5
+	"883",                             /* 883 */
2e4be5
+	"884",                             /* 884 */
2e4be5
+	"885",                             /* 885 */
2e4be5
+	"886",                             /* 886 */
2e4be5
+	"887",                             /* 887 */
2e4be5
+	"888",                             /* 888 */
2e4be5
+	"889",                             /* 889 */
2e4be5
+	"890",                             /* 890 */
2e4be5
+	"891",                             /* 891 */
2e4be5
+	"892",                             /* 892 */
2e4be5
+	"893",                             /* 893 */
2e4be5
+	"894",                             /* 894 */
2e4be5
+	"895",                             /* 895 */
2e4be5
+	"896",                             /* 896 */
2e4be5
+	"897",                             /* 897 */
2e4be5
+	"898",                             /* 898 */
2e4be5
+	"899",                             /* 899 */
2e4be5
+	"900",                             /* 900 */
2e4be5
+	"901",                             /* 901 */
2e4be5
+	"902",                             /* 902 */
2e4be5
+	"903",                             /* 903 */
2e4be5
+	"904",                             /* 904 */
2e4be5
+	"905",                             /* 905 */
2e4be5
+	"906",                             /* 906 */
2e4be5
+	"907",                             /* 907 */
2e4be5
+	"908",                             /* 908 */
2e4be5
+	"909",                             /* 909 */
2e4be5
+	"910",                             /* 910 */
2e4be5
+	"911",                             /* 911 */
2e4be5
+	"912",                             /* 912 */
2e4be5
+	"913",                             /* 913 */
2e4be5
+	"914",                             /* 914 */
2e4be5
+	"915",                             /* 915 */
2e4be5
+	"916",                             /* 916 */
2e4be5
+	"917",                             /* 917 */
2e4be5
+	"918",                             /* 918 */
2e4be5
+	"919",                             /* 919 */
2e4be5
+	"920",                             /* 920 */
2e4be5
+	"921",                             /* 921 */
2e4be5
+	"922",                             /* 922 */
2e4be5
+	"923",                             /* 923 */
2e4be5
+	"924",                             /* 924 */
2e4be5
+	"925",                             /* 925 */
2e4be5
+	"926",                             /* 926 */
2e4be5
+	"927",                             /* 927 */
2e4be5
+	"928",                             /* 928 */
2e4be5
+	"929",                             /* 929 */
2e4be5
+	"930",                             /* 930 */
2e4be5
+	"931",                             /* 931 */
2e4be5
+	"932",                             /* 932 */
2e4be5
+	"933",                             /* 933 */
2e4be5
+	"934",                             /* 934 */
2e4be5
+	"935",                             /* 935 */
2e4be5
+	"936",                             /* 936 */
2e4be5
+	"937",                             /* 937 */
2e4be5
+	"938",                             /* 938 */
2e4be5
+	"939",                             /* 939 */
2e4be5
+	"940",                             /* 940 */
2e4be5
+	"941",                             /* 941 */
2e4be5
+	"942",                             /* 942 */
2e4be5
+	"943",                             /* 943 */
2e4be5
+	"944",                             /* 944 */
2e4be5
+	"945",                             /* 945 */
2e4be5
+	"946",                             /* 946 */
2e4be5
+	"947",                             /* 947 */
2e4be5
+	"948",                             /* 948 */
2e4be5
+	"949",                             /* 949 */
2e4be5
+	"950",                             /* 950 */
2e4be5
+	"951",                             /* 951 */
2e4be5
+	"952",                             /* 952 */
2e4be5
+	"953",                             /* 953 */
2e4be5
+	"954",                             /* 954 */
2e4be5
+	"955",                             /* 955 */
2e4be5
+	"956",                             /* 956 */
2e4be5
+	"957",                             /* 957 */
2e4be5
+	"958",                             /* 958 */
2e4be5
+	"959",                             /* 959 */
2e4be5
+	"960",                             /* 960 */
2e4be5
+	"961",                             /* 961 */
2e4be5
+	"962",                             /* 962 */
2e4be5
+	"963",                             /* 963 */
2e4be5
+	"964",                             /* 964 */
2e4be5
+	"965",                             /* 965 */
2e4be5
+	"966",                             /* 966 */
2e4be5
+	"967",                             /* 967 */
2e4be5
+	"968",                             /* 968 */
2e4be5
+	"969",                             /* 969 */
2e4be5
+	"970",                             /* 970 */
2e4be5
+	"971",                             /* 971 */
2e4be5
+	"972",                             /* 972 */
2e4be5
+	"973",                             /* 973 */
2e4be5
+	"974",                             /* 974 */
2e4be5
+	"975",                             /* 975 */
2e4be5
+	"976",                             /* 976 */
2e4be5
+	"977",                             /* 977 */
2e4be5
+	"978",                             /* 978 */
2e4be5
+	"979",                             /* 979 */
2e4be5
+	"980",                             /* 980 */
2e4be5
+	"981",                             /* 981 */
2e4be5
+	"982",                             /* 982 */
2e4be5
+	"983",                             /* 983 */
2e4be5
+	"984",                             /* 984 */
2e4be5
+	"985",                             /* 985 */
2e4be5
+	"986",                             /* 986 */
2e4be5
+	"987",                             /* 987 */
2e4be5
+	"988",                             /* 988 */
2e4be5
+	"989",                             /* 989 */
2e4be5
+	"990",                             /* 990 */
2e4be5
+	"991",                             /* 991 */
2e4be5
+	"992",                             /* 992 */
2e4be5
+	"993",                             /* 993 */
2e4be5
+	"994",                             /* 994 */
2e4be5
+	"995",                             /* 995 */
2e4be5
+	"996",                             /* 996 */
2e4be5
+	"997",                             /* 997 */
2e4be5
+	"998",                             /* 998 */
2e4be5
+	"999",                             /* 999 */
2e4be5
+	"1000",                            /* 1000 */
2e4be5
+	"1001",                            /* 1001 */
2e4be5
+	"1002",                            /* 1002 */
2e4be5
+	"1003",                            /* 1003 */
2e4be5
+	"1004",                            /* 1004 */
2e4be5
+	"1005",                            /* 1005 */
2e4be5
+	"1006",                            /* 1006 */
2e4be5
+	"1007",                            /* 1007 */
2e4be5
+	"1008",                            /* 1008 */
2e4be5
+	"1009",                            /* 1009 */
2e4be5
+	"1010",                            /* 1010 */
2e4be5
+	"1011",                            /* 1011 */
2e4be5
+	"1012",                            /* 1012 */
2e4be5
+	"1013",                            /* 1013 */
2e4be5
+	"1014",                            /* 1014 */
2e4be5
+	"1015",                            /* 1015 */
2e4be5
+	"1016",                            /* 1016 */
2e4be5
+	"1017",                            /* 1017 */
2e4be5
+	"1018",                            /* 1018 */
2e4be5
+	"1019",                            /* 1019 */
2e4be5
+	"1020",                            /* 1020 */
2e4be5
+	"1021",                            /* 1021 */
2e4be5
+	"1022",                            /* 1022 */
2e4be5
+	"1023",                            /* 1023 */
2e4be5
+	"open",                            /* 1024 */
2e4be5
+	"link",                            /* 1025 */
2e4be5
+	"unlink",                          /* 1026 */
2e4be5
+	"mknod",                           /* 1027 */
2e4be5
+	"chmod",                           /* 1028 */
2e4be5
+	"chown",                           /* 1029 */
2e4be5
+	"mkdir",                           /* 1030 */
2e4be5
+	"rmdir",                           /* 1031 */
2e4be5
+	"lchown",                          /* 1032 */
2e4be5
+	"access",                          /* 1033 */
2e4be5
+	"rename",                          /* 1034 */
2e4be5
+	"readlink",                        /* 1035 */
2e4be5
+	"symlink",                         /* 1036 */
2e4be5
+	"utimes",                          /* 1037 */
2e4be5
+	"stat",                            /* 1038 */
2e4be5
+	"lstat",                           /* 1039 */
2e4be5
+	"pipe",                            /* 1040 */
2e4be5
+	"dup2",                            /* 1041 */
2e4be5
+	"epoll_create",                    /* 1042 */
2e4be5
+	"inotify_init",                    /* 1043 */
2e4be5
+	"eventfd",                         /* 1044 */
2e4be5
+	"signalfd",                        /* 1045 */
2e4be5
+	"sendfile",                        /* 1046 */
2e4be5
+	"ftruncate",                       /* 1047 */
2e4be5
+	"truncate",                        /* 1048 */
2e4be5
+	"stat",                            /* 1049 */
2e4be5
+	"lstat",                           /* 1050 */
2e4be5
+	"fstat",                           /* 1051 */
2e4be5
+	"fcntl",                           /* 1052 */
2e4be5
+	"fadvise64",                       /* 1053 */
2e4be5
+	"newfstatat",                      /* 1054 */
2e4be5
+	"fstatfs",                         /* 1055 */
2e4be5
+	"statfs",                          /* 1056 */
2e4be5
+	"lseek",                           /* 1057 */
2e4be5
+	"mmap",                            /* 1058 */
2e4be5
+	"alarm",                           /* 1059 */
2e4be5
+	"getpgrp",                         /* 1060 */
2e4be5
+	"pause",                           /* 1061 */
2e4be5
+	"time",                            /* 1062 */
2e4be5
+	"utime",                           /* 1063 */
2e4be5
+	"creat",                           /* 1064 */
2e4be5
+	"getdents",                        /* 1065 */
2e4be5
+	"futimesat",                       /* 1066 */
2e4be5
+	"select",                          /* 1067 */
2e4be5
+	"poll",                            /* 1068 */
2e4be5
+	"epoll_wait",                      /* 1069 */
2e4be5
+	"ustat",                           /* 1070 */
2e4be5
+	"vfork",                           /* 1071 */
2e4be5
+	"oldwait4",                        /* 1072 */
2e4be5
+	"recv",                            /* 1073 */
2e4be5
+	"send",                            /* 1074 */
2e4be5
+	"bdflush",                         /* 1075 */
2e4be5
+	"umount",                          /* 1076 */
2e4be5
+	"uselib",                          /* 1077 */
2e4be5
+	"_sysctl",                         /* 1078 */
2e4be5
+	"fork",                            /* 1079 */
2e4be5
diff --git a/sysdeps/linux-gnu/aarch64/trace.c b/sysdeps/linux-gnu/aarch64/trace.c
2e4be5
new file mode 100644
2e4be5
index 0000000..5544b51
2e4be5
--- /dev/null
2e4be5
+++ b/sysdeps/linux-gnu/aarch64/trace.c
2e4be5
@@ -0,0 +1,83 @@
2e4be5
+/*
2e4be5
+ * This file is part of ltrace.
2e4be5
+ * Copyright (C) 2014 Petr Machata, Red Hat, Inc.
2e4be5
+ *
2e4be5
+ * This program is free software; you can redistribute it and/or
2e4be5
+ * modify it under the terms of the GNU General Public License as
2e4be5
+ * published by the Free Software Foundation; either version 2 of the
2e4be5
+ * License, or (at your option) any later version.
2e4be5
+ *
2e4be5
+ * This program is distributed in the hope that it will be useful, but
2e4be5
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+ * General Public License for more details.
2e4be5
+ *
2e4be5
+ * You should have received a copy of the GNU General Public License
2e4be5
+ * along with this program; if not, write to the Free Software
2e4be5
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+ * 02110-1301 USA
2e4be5
+ */
2e4be5
+
2e4be5
+#include <sys/ptrace.h>
2e4be5
+#include <sys/types.h>
2e4be5
+#include <sys/wait.h>
2e4be5
+#include <asm/ptrace.h>
2e4be5
+#include <string.h>
2e4be5
+#include <errno.h>
2e4be5
+
2e4be5
+#include "backend.h"
2e4be5
+#include "proc.h"
2e4be5
+
2e4be5
+void
2e4be5
+get_arch_dep(struct process *proc)
2e4be5
+{
2e4be5
+}
2e4be5
+
2e4be5
+int aarch64_read_gregs(struct process *proc, struct user_pt_regs *regs);
2e4be5
+
2e4be5
+/* The syscall instruction is:
2e4be5
+ * | 31                   21 | 20    5 | 4       0 |
2e4be5
+ * | 1 1 0 1 0 1 0 0 | 0 0 0 |  imm16  | 0 0 0 0 1 | */
2e4be5
+#define SVC_MASK  0xffe0001f
2e4be5
+#define SVC_VALUE 0xd4000001
2e4be5
+
2e4be5
+int
2e4be5
+syscall_p(struct process *proc, int status, int *sysnum)
2e4be5
+{
2e4be5
+	if (WIFSTOPPED(status)
2e4be5
+	    && WSTOPSIG(status) == (SIGTRAP | proc->tracesysgood)) {
2e4be5
+
2e4be5
+		struct user_pt_regs regs;
2e4be5
+		if (aarch64_read_gregs(proc, &regs) < 0) {
2e4be5
+			fprintf(stderr, "syscall_p: "
2e4be5
+				"Couldn't read registers of %d.\n", proc->pid);
2e4be5
+			return -1;
2e4be5
+		}
2e4be5
+
2e4be5
+		errno = 0;
2e4be5
+		unsigned long insn = (unsigned long) ptrace(PTRACE_PEEKTEXT,
2e4be5
+							    proc->pid,
2e4be5
+							    regs.pc - 4, 0);
2e4be5
+		if (insn == -1UL && errno != 0) {
2e4be5
+			fprintf(stderr, "syscall_p: "
2e4be5
+				"Couldn't peek into %d: %s\n", proc->pid,
2e4be5
+				strerror(errno));
2e4be5
+			return -1;
2e4be5
+		}
2e4be5
+
2e4be5
+		insn &= 0xffffffffUL;
2e4be5
+		if ((insn & SVC_MASK) == SVC_VALUE) {
2e4be5
+			*sysnum = regs.regs[8];
2e4be5
+
2e4be5
+			size_t d1 = proc->callstack_depth - 1;
2e4be5
+			if (proc->callstack_depth > 0
2e4be5
+			    && proc->callstack[d1].is_syscall
2e4be5
+			    && proc->callstack[d1].c_un.syscall == *sysnum)
2e4be5
+				return 2;
2e4be5
+
2e4be5
+			return 1;
2e4be5
+		}
2e4be5
+	}
2e4be5
+
2e4be5
+	return 0;
2e4be5
+}
2e4be5
diff --git a/testsuite/ltrace.main/system_call_params.exp b/testsuite/ltrace.main/system_call_params.exp
2e4be5
index 787e342..2ccf840 100644
2e4be5
--- a/testsuite/ltrace.main/system_call_params.exp
2e4be5
+++ b/testsuite/ltrace.main/system_call_params.exp
2e4be5
@@ -1,5 +1,5 @@
2e4be5
 # This file is part of ltrace.
2e4be5
-# Copyright (C) 2013 Petr Machata, Red Hat Inc.
2e4be5
+# Copyright (C) 2013, 2014 Petr Machata, Red Hat Inc.
2e4be5
 #
2e4be5
 # This program is free software; you can redistribute it and/or
2e4be5
 # modify it under the terms of the GNU General Public License as
2e4be5
@@ -17,11 +17,25 @@
2e4be5
 # 02110-1301 USA
2e4be5
 
2e4be5
 set bin [ltraceCompile {} [ltraceSource c {
2e4be5
+    #define _GNU_SOURCE
2e4be5
     #include <sys/types.h>
2e4be5
     #include <sys/stat.h>
2e4be5
     #include <fcntl.h>
2e4be5
+    #include <unistd.h>
2e4be5
+    #include <sys/syscall.h>   /* For SYS_xxx definitions */
2e4be5
+
2e4be5
+    #ifndef SYS_open
2e4be5
+    # if defined(__aarch64__)
2e4be5
+    #  /* Linux doesn't actually implement SYS_open on AArch64, but for merely
2e4be5
+    #   * recording the syscall, it's fine.  */
2e4be5
+    #  define SYS_open 1024
2e4be5
+    # else
2e4be5
+    #  error SYS_open not available.
2e4be5
+    # endif
2e4be5
+    #endif
2e4be5
+
2e4be5
     int main(void) {
2e4be5
-	open("/some/path", O_RDONLY);
2e4be5
+	syscall(SYS_open, "/some/path", O_RDONLY);
2e4be5
 	write(1, "something", 10);
2e4be5
 	mount("source", "target", "filesystemtype", 0, 0);
2e4be5
     }
2e4be5
diff --git a/testsuite/ltrace.main/system_calls.c b/testsuite/ltrace.main/system_calls.c
2e4be5
deleted file mode 100644
2e4be5
index 7be3d04..0000000
2e4be5
--- a/testsuite/ltrace.main/system_calls.c
2e4be5
+++ /dev/null
2e4be5
@@ -1,68 +0,0 @@
2e4be5
-/* Ltrace Test : system_calls.c.
2e4be5
-   Objectives  : Verify that Ltrace can trace all the system calls in
2e4be5
-   execution.
2e4be5
-
2e4be5
-   You can add new system calls in it and add its verification in 
2e4be5
-   system_calls correspondingly.
2e4be5
-
2e4be5
-   This file was written by Yao Qi <qiyao@cn.ibm.com>. */
2e4be5
-
2e4be5
-#include <stdio.h>
2e4be5
-#include <unistd.h>
2e4be5
-#include <sys/syscall.h>
2e4be5
-#include <sys/stat.h>
2e4be5
-#include <errno.h>
2e4be5
-
2e4be5
-void exit (int);
2e4be5
-
2e4be5
-#define	BUF_SIZE	100
2e4be5
-
2e4be5
-int 
2e4be5
-main ()
2e4be5
-{
2e4be5
-  FILE* fp;
2e4be5
-  char s[]="system_calls";
2e4be5
-  char buffer[BUF_SIZE];
2e4be5
-  struct stat state;
2e4be5
-  
2e4be5
-  /*  SYS_open.  */
2e4be5
-  fp = fopen ("system_calls.tmp", "w");
2e4be5
-  if (fp == NULL)
2e4be5
-    {
2e4be5
-      printf("Can not create system_calls.tmp\n");
2e4be5
-      exit (0);
2e4be5
-    }
2e4be5
-  /*  SYS_write.  */
2e4be5
-  fwrite(s, sizeof(s), 1, fp);
2e4be5
-  /*  SYS_lseek.  */
2e4be5
-  fseek (fp, 0, SEEK_CUR);
2e4be5
-  /*  SYS_read.  */
2e4be5
-  fread(buffer, sizeof(s), 1, fp);
2e4be5
-  /*  SYS_close.  */
2e4be5
-  fclose(fp);
2e4be5
-
2e4be5
-  /*  SYS_getcwd.  */
2e4be5
-  getcwd (buffer, BUF_SIZE);
2e4be5
-  /*  SYS_chdir.  */
2e4be5
-  chdir (".");
2e4be5
-  /*  SYS_symlink.  */
2e4be5
-  symlink ("system_calls.tmp", "system_calls.link");
2e4be5
-  /*  SYS_unlink.  */
2e4be5
-  remove("system_calls.link");
2e4be5
-  /*  SYS_rename.  */
2e4be5
-  rename ("system_calls.tmp", "system_calls.tmp1");
2e4be5
-  /*  SYS_stat.  */
2e4be5
-  stat ("system_calls.tmp", &state);
2e4be5
-  /*  SYS_access.  */
2e4be5
-  access ("system_calls.tmp", R_OK);
2e4be5
-  remove("system_calls.tmp1");
2e4be5
-  
2e4be5
-  /*  SYS_mkdir.  */
2e4be5
-  mkdir ("system_call_mkdir", 0777);
2e4be5
-  /*  SYS_rmdir.  */
2e4be5
-  rmdir ("system_call_mkdir");
2e4be5
-  
2e4be5
-  return 0;
2e4be5
-}
2e4be5
-
2e4be5
-
2e4be5
diff --git a/testsuite/ltrace.main/system_calls.exp b/testsuite/ltrace.main/system_calls.exp
2e4be5
index a74fa04..f60e319 100644
2e4be5
--- a/testsuite/ltrace.main/system_calls.exp
2e4be5
+++ b/testsuite/ltrace.main/system_calls.exp
2e4be5
@@ -1,67 +1,146 @@
2e4be5
-# This file was written by Yao Qi <qiyao@cn.ibm.com>.
2e4be5
+# This file is part of ltrace.
2e4be5
+# Copyright (C) 2014 Petr Machata, Red Hat Inc.
2e4be5
+# Copyright (C) 2006 Yao Qi <qiyao@cn.ibm.com>, IBM Corporation
2e4be5
+#
2e4be5
+# This program is free software; you can redistribute it and/or
2e4be5
+# modify it under the terms of the GNU General Public License as
2e4be5
+# published by the Free Software Foundation; either version 2 of the
2e4be5
+# License, or (at your option) any later version.
2e4be5
+#
2e4be5
+# This program is distributed in the hope that it will be useful, but
2e4be5
+# WITHOUT ANY WARRANTY; without even the implied warranty of
2e4be5
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
2e4be5
+# General Public License for more details.
2e4be5
+#
2e4be5
+# You should have received a copy of the GNU General Public License
2e4be5
+# along with this program; if not, write to the Free Software
2e4be5
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
2e4be5
+# 02110-1301 USA
2e4be5
 
2e4be5
-set testfile "system_calls"
2e4be5
-set srcfile ${testfile}.c
2e4be5
-set binfile ${testfile}
2e4be5
+# Objectives: Verify that Ltrace can trace all the system calls in
2e4be5
+# execution.  Note that this test is necessarily noisy.  Dynamic
2e4be5
+# linker adds a bunch of system calls of its own.
2e4be5
 
2e4be5
+set empty [ltraceCompile {} [ltraceSource c {
2e4be5
+    int main (void) { return 0; }
2e4be5
+}]]
2e4be5
 
2e4be5
-verbose "compiling source file now....."
2e4be5
-# Build the shared libraries this test case needs.
2e4be5
-if  { [ ltrace_compile "${srcdir}/${subdir}/${testfile}.c" "${objdir}/${subdir}/${binfile}" executable {debug} ] != "" } {
2e4be5
-     send_user "Testcase compile failed, so all tests in this file will automatically fail.\n"
2e4be5
+set bin [ltraceCompile {} [ltraceSource c {
2e4be5
+    #include <stdio.h>
2e4be5
+    #include <unistd.h>
2e4be5
+    #include <sys/syscall.h>
2e4be5
+    #include <sys/stat.h>
2e4be5
+    #include <errno.h>
2e4be5
+    #include <stdlib.h>
2e4be5
+
2e4be5
+    int
2e4be5
+    main ()
2e4be5
+    {
2e4be5
+      FILE* fp;
2e4be5
+      char s[]="system_calls";
2e4be5
+      char buffer[1024];
2e4be5
+      struct stat state;
2e4be5
+
2e4be5
+      fp = fopen ("system_calls.tmp", "w");
2e4be5
+      if (fp == NULL)
2e4be5
+	{
2e4be5
+	  printf("Can not create system_calls.tmp\n");
2e4be5
+	  exit (0);
2e4be5
+	}
2e4be5
+      fwrite(s, sizeof(s), 1, fp);
2e4be5
+      fseek (fp, 0, SEEK_CUR);
2e4be5
+      fread(buffer, sizeof(s), 1, fp);
2e4be5
+      fclose(fp);
2e4be5
+
2e4be5
+      getcwd (buffer, sizeof buffer);
2e4be5
+      chdir (".");
2e4be5
+      symlink ("system_calls.tmp", "system_calls.link");
2e4be5
+      remove("system_calls.link");
2e4be5
+      rename ("system_calls.tmp", "system_calls.tmp1");
2e4be5
+      stat ("system_calls.tmp", &state);
2e4be5
+      access ("system_calls.tmp", R_OK);
2e4be5
+      remove("system_calls.tmp1");
2e4be5
+
2e4be5
+      mkdir ("system_call_mkdir", 0777);
2e4be5
+      rmdir ("system_call_mkdir");
2e4be5
+
2e4be5
+      return 0;
2e4be5
+    }
2e4be5
+}]]
2e4be5
+
2e4be5
+proc Calls {logfile} {
2e4be5
+    set fp [open $logfile]
2e4be5
+    set ret {}
2e4be5
+
2e4be5
+    while {[gets $fp line] >= 0} {
2e4be5
+	if [regexp -- {^[a-zA-Z0-9]*@SYS} $line] {
2e4be5
+	    set call [lindex [split $line @] 0]
2e4be5
+	    dict incr ret $call
2e4be5
+	}
2e4be5
+    }
2e4be5
+
2e4be5
+    close $fp
2e4be5
+    return $ret
2e4be5
+}
2e4be5
+
2e4be5
+proc GetDefault {d key def} {
2e4be5
+    if {[dict exists $d $key]} {
2e4be5
+	return [dict get $d $key]
2e4be5
+    } else {
2e4be5
+	return $def
2e4be5
+    }
2e4be5
 }
2e4be5
 
2e4be5
-# set options for ltrace.
2e4be5
-ltrace_options "-S"
2e4be5
+proc Diff {d1 d2} {
2e4be5
+    set keys [lsort -unique [concat [dict keys $d1] [dict keys $d2]]]
2e4be5
+    set ret {}
2e4be5
+    foreach key $keys {
2e4be5
+	set n1 [GetDefault $d1 $key 0]
2e4be5
+	set n2 [GetDefault $d2 $key 0]
2e4be5
+	set sum [expr $n1 - $n2]
2e4be5
+	if {[expr $sum != 0]} {
2e4be5
+		dict set ret $key $sum
2e4be5
+	}
2e4be5
+    }
2e4be5
+    return $ret
2e4be5
+}
2e4be5
+
2e4be5
+proc Match {d patterns} {
2e4be5
+    foreach line $patterns {
2e4be5
+	set pattern [lindex $line 0]
2e4be5
+	set op [lindex $line 1]
2e4be5
+	set expect [lindex $line 2]
2e4be5
 
2e4be5
-#Run PUT for ltarce.
2e4be5
-set exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile]
2e4be5
+	set count 0
2e4be5
+	foreach key [dict keys $d] {
2e4be5
+	    if [regexp -- $pattern $key] {
2e4be5
+		incr count [dict get $d $key]
2e4be5
+	    }
2e4be5
+	}
2e4be5
 
2e4be5
-#check the output of this program.
2e4be5
-verbose "ltrace runtest output: $exec_output\n"
2e4be5
+	set msgMain "$pattern was recorded $count times"
2e4be5
 
2e4be5
-if [regexp {ELF from incompatible architecture} $exec_output] {
2e4be5
-	fail "32-bit ltrace can not perform on 64-bit PUTs and rebuild ltrace in 64 bit mode!"
2e4be5
-        return
2e4be5
-} elseif [ regexp {Couldn't get .hash data} $exec_output ] {
2e4be5
-	fail "Couldn't get .hash data!"
2e4be5
-	return
2e4be5
+	if {[eval expr $count $op $expect]} {
2e4be5
+	    pass $msgMain
2e4be5
+	} else {
2e4be5
+	    fail "$msgMain, expected $op $expect"
2e4be5
+	}
2e4be5
+    }
2e4be5
 }
2e4be5
 
2e4be5
+Match [Diff [Calls [ltraceRun -L -S -- $bin]] \
2e4be5
+	   [Calls [ltraceRun -L -S -- $empty]]] {
2e4be5
+    { {^write$} == 1 }
2e4be5
+    { {^unlink(at)?$} >= 2 }
2e4be5
+    { {^open(at)?$} == 1 }
2e4be5
+    { {^(new|f)?stat(64)?$} == 1 }
2e4be5
+    { {^close$} == 1 }
2e4be5
+    { {^getcwd$} == 1 }
2e4be5
+    { {^chdir$} == 1 }
2e4be5
+    { {^symlink(at)?$} == 1 }
2e4be5
+    { {^f?access(at)?$} == 1 }
2e4be5
+    { {^rename(at)?$} == 1 }
2e4be5
+    { {^mkdir(at)?$} == 1 }
2e4be5
+}
2e4be5
 
2e4be5
-set pattern "^munmap@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 2
2e4be5
-set pattern "^write@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^unlink@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-
2e4be5
-set pattern "^brk@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^open@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^(new)?fstat(64)?@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 egrep
2e4be5
-set pattern "^(old_)?mmap2?@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 egrep
2e4be5
-set pattern "^close@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-
2e4be5
-set pattern "^getcwd@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^chdir@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^symlink@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^unlink@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^(new)?stat(64)?@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1 egrep
2e4be5
-set pattern "^access@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^rename@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^mkdir@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
-set pattern "^rmdir@SYS"
2e4be5
-ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 1
2e4be5
+ltraceDone
2e4be5
diff --git a/testsuite/ltrace.minor/trace-clone.c b/testsuite/ltrace.minor/trace-clone.c
2e4be5
index db1936d..ded930c 100644
2e4be5
--- a/testsuite/ltrace.minor/trace-clone.c
2e4be5
+++ b/testsuite/ltrace.minor/trace-clone.c
2e4be5
@@ -8,6 +8,7 @@
2e4be5
 #include <sys/types.h>
2e4be5
 #include <stdlib.h>
2e4be5
 #include <sched.h>
2e4be5
+#include <unistd.h>
2e4be5
 
2e4be5
 int child ()
2e4be5
 {
2e4be5
@@ -22,7 +23,8 @@ typedef int (* myfunc)();
2e4be5
 int main ()
2e4be5
 {
2e4be5
   pid_t pid;
2e4be5
-  static char stack[STACK_SIZE];
2e4be5
+  static __attribute__ ((aligned (16))) char stack[STACK_SIZE];
2e4be5
+
2e4be5
 #ifdef __ia64__
2e4be5
   pid = __clone2((myfunc)&child, stack, STACK_SIZE, CLONE_FS, NULL);
2e4be5
 #else