zoukankan      html  css  js  c++  java
  • 2018-2019-1 20189215 《Linux内核原理与分析》第六周作业

    《庖丁解牛》第五章书本知识总结

    1. system_call并不是一个普通的函数,只是一段汇编代码的起点,且内部没有严格遵守函数调用堆栈机制。
    2. 通过set_system_trap_gate函数绑定了中断向量0x80system_call中断服务程序入口之后,一旦执行0x80,CPU就直接跳转到system_call这个位置来执行。即系统调用的工作机制在start_kernel里初始化之后,CPU一旦执行到int 0x80指令就会立即跳转到system_call的位置。
    3. 代码中的sys_call_table是一个系统调用的表,EAX寄存器传递的系统调用号,使用者在调用它时会根据EAX寄存器值来调用对应的系统调用内核处理函数。

    实验:分析system_call中断处理过程

    1. 添加命令mkdir
    2. 使用课本第三章的步骤,制作rootfs.img(因为内核版本不一样,make rootfs有一些不同),并启动内核
    3. 设置断点sys_mkdir
    4. 启动系统执行mkdir指令
    5. 三步s跳转到另一个宏定义
    6. 运行到sys_call
    7. 执行结束
    8. 重新mkdir创建失败

    一些补充

    1. 流程图
      system_call位于kernel/entry_32.S中,是一段特殊的汇编代码,执行流程如下:
    2. linux内核编译过程中,无法进去编译好的内核,错误提示如下:

      推测是某些模块编译出错,因为修改了delayout = 10,也无法进入。之后换一个新版本的内核,重新进行。

    更新:内核编译成功

    附图如下(虚拟机本来的内核版本是4.15.0):

    遇到的问题:

    1. 提醒大家安装模块的命令是sudo make modules_installmodulesinstall之间是有下划线的!!希望没人跟我一样犯这种错误。。。
    2. 编译结束进入新内核,提示“虚拟机已禁用CPU”。
      解决:使用记事本打开虚拟机的.vmx文件,添加下列一行即可。
      cpuid.1.eax = "0000:0000:0000:0001:0000:0110:1010:0101"
    3. 进入新内核提示out of memory and no killable processes
      解决:内存不足,给虚拟机分配多一点内存即可解决。
    4. gcc编译c文件,提示syscall没有定义
      解决:使用gcc4.8版本进行编译,问题解决。安装低版本gcc工具请参考:https://www.linuxidc.com/Linux/2017-03/142299.htm

    参考资料

    《庖丁解牛Linux》

  • 相关阅读:
    韦到头打印链表
    字符串替换
    二维数组中的查找
    字符串加解密
    简单密码破解
    vue中store模块化
    使用requests抓取网页内容
    PyQt中的一些小问题
    微信公众号之Token验证
    编译BOOST中的PYTHON模块
  • 原文地址:https://www.cnblogs.com/jsjliyang/p/9979433.html
Copyright © 2011-2022 走看看