静态增加系统调用
暂时只适合4.6以下的内核
核心思路
通过增加系统调用号和系统调用函数来新增系统调用
修改文件
- 向量文件
修改 arch/x86/entry/syscalls/syscall_64.tbl
,增加一条向量条目,格式如下:
<syscall no> <abi> <name> <entry>
比如 0 common read sys_read
name | comments |
---|---|
syscall no |
系统调用号,最好顺序使用。 |
abi |
使用何种应用程序二进制接口,可以取值 common 通用的、64 64位机器使用、x32 32位机器使用。 |
name |
暴露给用户层的系统调用函数名。 |
entry |
内核层的系统调用实现函数名。 |
然后在内核编译时会先在生成文件 include/generated/asm-offsets.h
中依据向量文件生成宏 __NR_syscall_max
,它代表系统调用号最大值,这会影响 arch/x86/entry/syscall_64.c
里的系统调用表 sys_call_table[]
的大小,这个表会在依据向量文件生成文件 arch/x86/include/generated/asm/syscalls_64.h
中使用 __SYSCALL_64()
来设置系统调用表的最终内容。
比如 __SYSCALL_64(0, sys_read, )
- 弱符号别名声明
在 kernel/sys_ni.c
中添加需要声明的系统调用。比如 cond_syscall(sys_read)
。
类似 gcc 的 __attribute__((weak, alias("sys_ni_syscall")))
,大概意思是,如果向量文件中的系统调用没有定义,则使用默认的 sys_ni_syscall()
链接。