linux 内核系统调用服务例程的源代码在哪里?

Where is source code for linux kernel syscall service routines?

我对系统调用(高级)工作流程的理解是:

  1. 用户调用 libc 包装器
  2. wrapper 将系统调用编号和参数放在正确的位置、寄存器或堆栈
  3. wrapper 执行 syscall 或 int 0x80 指令
  4. 内核中断处理程序调用 sys_xxx() 服务例程

如果是这样,那么内核源码中应该有一堆sys_xxx()函数。例如,对于 read(),在内核 2.6 代码中,我发现 sys_read. However, in kernel 5.4 code, I did not find such service routine code, the only sys_read 就像是 libc 包装器的替代品。所以我很困惑..

一个相关的问题 - 内核将实现放在 sys_xxx() 中的原因是内核 space 也可以调用这些函数,对吗?

内核确实定义了一个名为 sys_read 的函数,它的行为与您所说的一样。通过搜索很难找到它,因为它是通过使用 token concatenation. See fs/read_write.c line 595:

的辅助宏定义的
SYSCALL_DEFINE3(read, unsigned int, fd, char __user *, buf, size_t, count)
{
    return ksys_read(fd, buf, count);
}

这具有以下效果:

  • 正在声明一个名为 sys_read 的函数到 __se_sys_read

  • 定义 __se_sys_read,它显然对任何 32 位参数进行符号扩展,然后调用 __do_sys_read

  • 定义 __do_sys_read 其主体如图所示(即调用 ksys_read 执行实际工作)。

您可以在 include/linux/syscalls.h line 206.

查看 SYSCALL_DEFINEx 宏的定义