【操作系统】实验四 增加Linux系统调用

简介: 【操作系统】实验四 增加Linux系统调用

😘欢迎关注:👍点赞🙌收藏✍️留言

🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要,有问题可在评论区提出,感谢支持!!!

实验四

实验内容

  1. 实验名称:增加Linux系统调用
  2. 实验任务:

学习如何产生一个系统调用以及怎样同过往内核中增加一个新函数从而在内核空间中实现对用户空间的读/写。
部分A
添加一个新的内核系统调用,具体完成某个你希望实现的功能。
部分B
重新编译内核,使你的系统调用可用。
部分C
编写一个用户态的程序,验证你增加的系统调用。

实验过程

部分A: 添加新的内核系统调用

在最新版本的 Linux 内核源代码中,系统调用入口表通常不再在 entry_64.S文件中。系统调用入口表的位置在不同的内核版本中可能会有所变化。通常,它会在 arch/x86/entry/syscalls/syscall_64.tbl 文件中定义。

新下载一个内核源代码,然后解压再进行下面步骤:

  1. 打开终端并进入内核源代码目录。根据内核版本,可能会有所不同:
    cd /usr/src/linux-6.0.1 # 根据你的内核版本进入相应的目录
  2. 查找系统调用入口表的位置。可以使用以下命令找到它:

find . -name syscalls.h

这将在整个内核源代码目录中搜索 syscalls.h文件,如图所示。

vim ./arch/x86/include/asm/syscalls.h

图1 找到的syscalls.h 文件

打开找到的 syscalls.h 文件,在里面声明自己的系统调用函数,如图2所示。

图2打开syscalls.h文件

  1. 添加asmlinkage long sys_helloworld(void);声明,如图3所示。

    图3 添加声明
  2. 添加系统调用id:文件为 syscall_64.tbl它包含系统调用号和系统调用函数之间的映射,如图4所示。
vim ./arch/x86/entry/syscalls/syscall_64.tbl

图4 添加系统调用

在文件中找到一个空的系统调用入口,通常为sys_ni_syscall

使用命令 /sys_ni_syscall 搜索,找到以后回车,然后 点击 i 即可修改

修改内容,如图5所示。:

图5 添加系统调用入口

这表示将系统调用号 156映射到名为 sys_my_call 的系统调用函数。

  1. 保存文件并退出编辑器。
:wq

编写新的系统调用函数,先打开sys.c文件,如图6所示。

图6 打开sys.c文件

6. 在内核源代码目录中,打开文件 kernel/sys.c 以编辑,如图7所示。

图7 执行 vim kernel/sys.c命令

7. 在文件末尾添加你的新系统调用函数 sys_my_call的定义。例如,你可以添加一个简单的示例系统调用,如图8所示。

asmlinkage long sys_helloworld(void) {
printk(“hello world”);
return 1; 
}

图8 添加系统调用

注意:这里函数定义部分有些教程中使用的是 asmlinkage helloworld(void)在高版本的内核中很可能会出现以下报错:

arch/x86/entry/syscall_64.o:(.rodata+0xa78):undefined reference to '__x64_sys_helloworld'

在我的版本下使用如下函数形式,如图9所示。

SYSCALL_DEFINE0(helloworld) {
Printk(“hello world!\n”);
return 0; 
}

图9 添加系统调用

8. 保存文件并退出编辑器。

:wq

部分B: 重新编译和安装内核

  1. 在终端中编译内核:
  2. 在此之前需要 make clean 清理一下旧文件
  3. 重新配置.config文件 make menuconfig

make menuconfig 时将general setup -> localversion 修改成新的名称,如 “wikiKernel”

  1. 然后make -j8 编译内核 (时间较长)
    编译成功,没有报错信息,如图10所示。

图10 编译内核完毕

  1. 安装内核
    编译成功,没有报错信息,如图11所示。

图11 执行sudo make modules_install命令安装内核成功

图12 执行sudo make install命令

图13 reboot重启机器

部分C编写一个用户态的程序

验证系统调用,如图14、15所示。

新建hello.c文件,编写程序如下:

#include <stdio.h>
#include<linux/kernel.h>
#include<sys/syscall.h>
#include<unistd.h>
 
int main()
{
       long int a = syscall(156);
       printf("System call sys_helloworld return %ld\n", a);
       return 0;
}

图14 验证系统调用的代码

编译:

Gcc -o a hello.c

运行:

./a.out

图15 执行命令,验证系统调用添加成功

实验小结

在本次实验中,我成功地增加了Linux系统调用,并通过重新编译内核和编写用户态程序的方式实现了对用户空间的读/写功能。在实验过程中,我遇到了以下一些问题和挑战:

存在问题:

  1. 在添加新的系统调用时,需要深入理解Linux内核的机制和源代码,对于初学者来说有一定的难度。
  2. 在重新编译内核时,需要安装并配置相应的编译工具和环境,对于操作系统的了解和熟练掌握程度有一定要求。
  3. 在编写用户态程序时,需要熟悉Linux的系统调用接口,以及如何与内核交互,需要进行比较深入的学习和理解。

注意事项:

  1. 在整个实验过程中,要特别注意安全性原则,避免操作系统内核被破坏或者数据被篡改。
  2. 在修改和编译内核时,务必备份原有的内核文件,以防止操作失误导致系统无法启动。
  3. 在进行用户态程序开发时,需要考虑异常情况的处理和错误信息的输出,确保程序的健壮性和可靠性。

有待提高的能力:

  1. 理解并掌握操作系统的内核机制和体系结构,提高对内核源代码的理解和阅读能力。
  2. 熟悉Linux系统调用的接口和使用方法,能够灵活地进行系统调用操作。
  3. 学会使用编译工具和环境,能够独立完成内核的编译和安装过程。
  4. 提高代码的编写能力和调试技巧,加强对程序异常情况的处理能力。
  5. 培养独立思考和解决实际问题的能力,寻找并探索更多的实践机会,不断提高自己的技术水平和能力。

相关文章
|
16天前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
43 1
|
9天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
39 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
18天前
|
安全 Linux 数据安全/隐私保护
深入Linux操作系统:文件系统和权限管理
在数字世界的海洋中,操作系统是连接用户与硬件的桥梁,而Linux作为其中的佼佼者,其文件系统和权限管理则是这座桥梁上不可或缺的结构。本文将带你探索Linux的文件系统结构,理解文件权限的重要性,并通过实际案例揭示如何有效地管理和控制这些权限。我们将一起航行在Linux的命令行海洋中,解锁文件系统的奥秘,并学习如何保护你的数据免受不必要的访问。
|
19天前
|
搜索推荐 Linux
深入理解Linux操作系统的启动过程
本文旨在揭示Linux操作系统从开机到完全启动的神秘面纱,通过逐步解析BIOS、引导加载程序、内核初始化等关键步骤,帮助读者建立对Linux启动流程的清晰认识。我们将探讨如何自定义和优化这一过程,以实现更高效、更稳定的系统运行。
|
16天前
|
存储 缓存 网络协议
Linux操作系统的内核优化与性能调优####
本文深入探讨了Linux操作系统内核的优化策略与性能调优方法,旨在为系统管理员和高级用户提供一套实用的指南。通过分析内核参数调整、文件系统选择、内存管理及网络配置等关键方面,本文揭示了如何有效提升Linux系统的稳定性和运行效率。不同于常规摘要仅概述内容的做法,本摘要直接指出文章的核心价值——提供具体可行的优化措施,助力读者实现系统性能的飞跃。 ####
|
17天前
|
缓存 监控 网络协议
Linux操作系统的内核优化与实践####
本文旨在探讨Linux操作系统内核的优化策略与实际应用案例,深入分析内核参数调优、编译选项配置及实时性能监控的方法。通过具体实例讲解如何根据不同应用场景调整内核设置,以提升系统性能和稳定性,为系统管理员和技术爱好者提供实用的优化指南。 ####
|
19天前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
1月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
95 8