Add an optional alias list to SYSCALLS.TXT
This patch adds an optional alias list to SYSCALLS.TXT. It is used to
create aliases for a syscall. For x86-64, lseek64 is an alias for lseek.
Change-Id: Icb11fd2bb461ea4f5f0a26bfc585471d7d7cc468
Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Signed-off-by: Pavel Chupin <pavel.v.chupin@intel.com>
diff --git a/libc/tools/bionic_utils.py b/libc/tools/bionic_utils.py
index a00080d..0ca2178 100644
--- a/libc/tools/bionic_utils.py
+++ b/libc/tools/bionic_utils.py
@@ -49,7 +49,7 @@
""" parse a syscall spec line.
line processing, format is
- return type func_name[:syscall_name[:socketcall_id]] ( [paramlist] ) architecture_list
+ return type func_name[|alias_list][:syscall_name[:socketcall_id]] ( [paramlist] ) architecture_list
"""
pos_lparen = line.find('(')
E = self.E
@@ -93,6 +93,17 @@
socketcall_id = int(syscall_func[pos_colon2+1:])
syscall_func = syscall_func[:pos_colon]
+ alias_delim = syscall_func.find('|')
+ if alias_delim > 0:
+ alias_list = syscall_func[alias_delim+1:].strip()
+ syscall_func = syscall_func[:alias_delim]
+ alias_delim = syscall_name.find('|')
+ if alias_delim > 0:
+ syscall_name = syscall_name[:alias_delim]
+ syscall_aliases = string.split(alias_list, ',')
+ else:
+ syscall_aliases = []
+
if pos_rparen > pos_lparen+1:
syscall_params = line[pos_lparen+1:pos_rparen].split(',')
params = string.join(syscall_params,',')
@@ -103,6 +114,7 @@
t = {
"name" : syscall_name,
"func" : syscall_func,
+ "aliases" : syscall_aliases,
"params" : syscall_params,
"decl" : "%-15s %s (%s);" % (return_type, syscall_func, params),
"socketcall_id" : socketcall_id
diff --git a/libc/tools/gensyscalls.py b/libc/tools/gensyscalls.py
index a3c8450..386a8db 100755
--- a/libc/tools/gensyscalls.py
+++ b/libc/tools/gensyscalls.py
@@ -37,6 +37,10 @@
ENTRY(%(fname)s)
"""
+function_alias = """
+ .globl _C_LABEL(%(alias)s)
+ .equ _C_LABEL(%(alias)s), _C_LABEL(%(fname)s)
+"""
#
# x86 assembler templates for each syscall stub
@@ -210,7 +214,7 @@
self.other_files = []
self.syscalls = []
- def x86_64_genstub(self, fname, numparams, idname):
+ def x86_64_genstub(self, fname, numparams, idname, aliases):
t = { "fname" : fname, "idname" : idname }
result = syscall_stub_header % t
@@ -219,6 +223,10 @@
result += " movq %rcx, %r10\n"
result += x86_64_call % t
+ for alias in aliases:
+ t = { "fname" : fname, "alias" : alias }
+ result += function_alias % t
+
return result
def x86_genstub(self, fname, numparams, idname):
@@ -301,6 +309,7 @@
for t in self.syscalls:
syscall_func = t["func"]
+ syscall_aliases = t["aliases"]
syscall_params = t["params"]
syscall_name = t["name"]
__NR_name = make__NR_name(t["name"])
@@ -324,7 +333,7 @@
if t.has_key("x86_64"):
num_regs = count_generic_param_registers64(syscall_params)
- t["asm-x86_64"] = self.x86_64_genstub(syscall_func, num_regs, __NR_name)
+ t["asm-x86_64"] = self.x86_64_genstub(syscall_func, num_regs, __NR_name, syscall_aliases)
# Scan a Linux kernel asm/unistd.h file containing __NR_* constants
# and write out equivalent SYS_* constants for glibc source compatibility.