* commit '4501a00be35f2fc851795ac8b15b8956eab69c27': Add an optional alias list to SYSCALLS.TXT
This commit is contained in:
commit
f662660ca3
@ -2,7 +2,7 @@
|
|||||||
#
|
#
|
||||||
# Each non-blank, non-comment line has the following format:
|
# Each non-blank, non-comment line has the following format:
|
||||||
#
|
#
|
||||||
# return_type func_name[:syscall_name[:socketcall_id]]([parameter_list]) arch_list
|
# return_type func_name[|alias_list][:syscall_name[:socketcall_id]]([parameter_list]) arch_list
|
||||||
#
|
#
|
||||||
# where:
|
# where:
|
||||||
# arch_list ::= "all" | "custom" | arch+
|
# arch_list ::= "all" | "custom" | arch+
|
||||||
@ -13,6 +13,8 @@
|
|||||||
# the exported function name (example: the exit syscall is implemented by the _exit()
|
# the exported function name (example: the exit syscall is implemented by the _exit()
|
||||||
# function, which is not the same as the standard C exit() function which calls it)
|
# function, which is not the same as the standard C exit() function which calls it)
|
||||||
#
|
#
|
||||||
|
# - alias_list is optional comma separated list of function aliases.
|
||||||
|
#
|
||||||
# - The call_id parameter, given that func_name and syscall_name have
|
# - The call_id parameter, given that func_name and syscall_name have
|
||||||
# been provided, allows the user to specify dispatch style syscalls.
|
# been provided, allows the user to specify dispatch style syscalls.
|
||||||
# For example, socket() syscall on i386 actually becomes:
|
# For example, socket() syscall on i386 actually becomes:
|
||||||
@ -109,7 +111,8 @@ int __open:open(const char*, int, mode_t) all
|
|||||||
int __openat:openat(int, const char*, int, mode_t) all
|
int __openat:openat(int, const char*, int, mode_t) all
|
||||||
int close(int) all
|
int close(int) all
|
||||||
int creat(const char*, mode_t) custom
|
int creat(const char*, mode_t) custom
|
||||||
off_t lseek(int, off_t, int) all
|
off_t lseek(int, off_t, int) arm,x86,mips
|
||||||
|
off_t lseek|lseek64(int, off_t, int) x86_64
|
||||||
int __llseek:_llseek(int, unsigned long, unsigned long, off64_t*, int) arm,x86,mips
|
int __llseek:_llseek(int, unsigned long, unsigned long, off64_t*, int) arm,x86,mips
|
||||||
pid_t getpid() all
|
pid_t getpid() all
|
||||||
void* mmap(void*, size_t, int, int, int, long) x86_64
|
void* mmap(void*, size_t, int, int, int, long) x86_64
|
||||||
|
@ -15,3 +15,6 @@ ENTRY(lseek)
|
|||||||
1:
|
1:
|
||||||
ret
|
ret
|
||||||
END(lseek)
|
END(lseek)
|
||||||
|
|
||||||
|
.globl _C_LABEL(lseek64)
|
||||||
|
.equ _C_LABEL(lseek64), _C_LABEL(lseek)
|
||||||
|
@ -49,7 +49,7 @@ class SysCallsTxtParser:
|
|||||||
""" parse a syscall spec line.
|
""" parse a syscall spec line.
|
||||||
|
|
||||||
line processing, format is
|
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('(')
|
pos_lparen = line.find('(')
|
||||||
E = self.E
|
E = self.E
|
||||||
@ -93,6 +93,17 @@ class SysCallsTxtParser:
|
|||||||
socketcall_id = int(syscall_func[pos_colon2+1:])
|
socketcall_id = int(syscall_func[pos_colon2+1:])
|
||||||
syscall_func = syscall_func[:pos_colon]
|
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:
|
if pos_rparen > pos_lparen+1:
|
||||||
syscall_params = line[pos_lparen+1:pos_rparen].split(',')
|
syscall_params = line[pos_lparen+1:pos_rparen].split(',')
|
||||||
params = string.join(syscall_params,',')
|
params = string.join(syscall_params,',')
|
||||||
@ -103,6 +114,7 @@ class SysCallsTxtParser:
|
|||||||
t = {
|
t = {
|
||||||
"name" : syscall_name,
|
"name" : syscall_name,
|
||||||
"func" : syscall_func,
|
"func" : syscall_func,
|
||||||
|
"aliases" : syscall_aliases,
|
||||||
"params" : syscall_params,
|
"params" : syscall_params,
|
||||||
"decl" : "%-15s %s (%s);" % (return_type, syscall_func, params),
|
"decl" : "%-15s %s (%s);" % (return_type, syscall_func, params),
|
||||||
"socketcall_id" : socketcall_id
|
"socketcall_id" : socketcall_id
|
||||||
|
@ -37,6 +37,10 @@ syscall_stub_header = """/* autogenerated by gensyscalls.py */
|
|||||||
ENTRY(%(fname)s)
|
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
|
# x86 assembler templates for each syscall stub
|
||||||
@ -210,7 +214,7 @@ class State:
|
|||||||
self.other_files = []
|
self.other_files = []
|
||||||
self.syscalls = []
|
self.syscalls = []
|
||||||
|
|
||||||
def x86_64_genstub(self, fname, numparams, idname):
|
def x86_64_genstub(self, fname, numparams, idname, aliases):
|
||||||
t = { "fname" : fname, "idname" : idname }
|
t = { "fname" : fname, "idname" : idname }
|
||||||
|
|
||||||
result = syscall_stub_header % t
|
result = syscall_stub_header % t
|
||||||
@ -219,6 +223,10 @@ class State:
|
|||||||
result += " movq %rcx, %r10\n"
|
result += " movq %rcx, %r10\n"
|
||||||
|
|
||||||
result += x86_64_call % t
|
result += x86_64_call % t
|
||||||
|
for alias in aliases:
|
||||||
|
t = { "fname" : fname, "alias" : alias }
|
||||||
|
result += function_alias % t
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def x86_genstub(self, fname, numparams, idname):
|
def x86_genstub(self, fname, numparams, idname):
|
||||||
@ -301,6 +309,7 @@ class State:
|
|||||||
|
|
||||||
for t in self.syscalls:
|
for t in self.syscalls:
|
||||||
syscall_func = t["func"]
|
syscall_func = t["func"]
|
||||||
|
syscall_aliases = t["aliases"]
|
||||||
syscall_params = t["params"]
|
syscall_params = t["params"]
|
||||||
syscall_name = t["name"]
|
syscall_name = t["name"]
|
||||||
__NR_name = make__NR_name(t["name"])
|
__NR_name = make__NR_name(t["name"])
|
||||||
@ -324,7 +333,7 @@ class State:
|
|||||||
|
|
||||||
if t.has_key("x86_64"):
|
if t.has_key("x86_64"):
|
||||||
num_regs = count_generic_param_registers64(syscall_params)
|
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
|
# Scan a Linux kernel asm/unistd.h file containing __NR_* constants
|
||||||
# and write out equivalent SYS_* constants for glibc source compatibility.
|
# and write out equivalent SYS_* constants for glibc source compatibility.
|
||||||
|
Loading…
Reference in New Issue
Block a user