动静结合学内核之 linux 系统调用浅析

刘柳 + 原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000

直入主题

实验过程1-增加新的菜单

  • update the menu //git cone
  • Uhange main.c //注册菜单函数
  • Add the chmodC ,chmodASM //菜单函数的实现
  • Make rootfs //激动人心的时刻,进入menuos调用我们新函数

chmodASM代码

讲述调用chmod系统调用的嵌入式汇编代码。

    int chmodASM ()
    {
      long rc ;
      char * file_name = "/ etc / passwd " ;
      unsigned short mode =0444;
      asm (
      " int $0x80"
      : "=a" ( rc )
      : "0" ( SYS_chmod ), "b" (( long ) file_name ), "c" (( long ) mode )
          );
      if ( ( unsigned long ) rc >=( unsigned long )-123 )//123 是最小的错误码
      { errno = - rc ;   rc =-1 ;
      }
      if ( rc == -1)
      fprintf ( stderr , " chmode failed,errno =%d\n" , errno );
      else
      printf ( " chmod ok\n" );
      return 0;
}

代码展示 chmodC

讲述调用chmod系统调用c代码。

int chmodC ()
{
  long rc ;
  char * file_name = "/ etc / passwd " ;
  unsigned short mode =0444;
  rc = chmod ( file_name , mode ); //

  if ( ( unsigned long ) rc >=( unsigned long )-123 )
  {
  errno = - rc ;
  rc =-1;

  }
  if ( rc == -1)
  fprintf ( stderr , " chmode failed,errno =%d\n" , errno );
  else
  printf ( " chmod ok\n" );
  return 0;
}

主函数main

int main()
{

  PrintMenuOS();
  SetPrompt("MenuOS>>");
  MenuConfig("version","MenuOS V1.0(Based on Linux 3.18.6)",NULL);
  MenuConfig("quit","Quit from MenuOS",Quit);
  MenuConfig("time","Show System Time",Time);
  MenuConfig("time-asm","Show System Time(asm)",TimeAsm);

  MenuConfig("chmod","chmod demo",chmodC);//new
  MenuConfig("chmod-asm","chmod demo",chmodASM);//new
  ExecuteMenu();
}

综合展示

实验过程用动态图展示。

技术分享

2分析system_call的流程

system_call位置在entry_32.s中,老师的伪代码框架 很棒,不过这里给上 我自己绘制了一个小时的流程图。
iret之前的进程调度时机,就是schedule函数的调用过程在这个流程图里面,很清晰的说明了。

技术分享

经典的伪代码流程

采集于老师的课件
技术分享
技术分享
技术分享

小节,就是 从system_call 到iret的整个流程,
不要被细节困扰。

系统调用过程分析

系统调用过程和一般的中断处理流程 一起分析,这里来一个经典的图吧(来自 ULK)。
这里,仅从返回过程来说,
可以看到无论是中断返回(ret_from_intr) ,还是系统调用返回,都使用了 work_pending 和resume_userspace

技术分享

小结

本内容耗时12小时,本来想尝试gdb 跟踪,但是由于工具限制,不能逐代码跟踪,于是使用流程图分析。
关键点:在流程图中确定iret前的schdule时机。
系统调用,某种意义上,是一种特殊的中断。从他的初始化/出发/返回,我们都能找到共性 ,本文仅对返回过程做了初步分析。

参考要求

题目自拟,内容围绕系统调用system_call的处理过程进行;
博客内容中需要仔细分析system_call对应的汇编代码的工作过程,特别注意系统调用返回iret之前的进程调度时机等。
总结部分需要阐明自己对“系统调用处理过程”的理解,进一步推广到一般的中断处理过程。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。