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

时间:2023-02-05 15:49:42

刘柳 + 原创作品转载请注明出处 + 《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();
}

综合展示

实验过程用动态图展示。

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

2分析system_call的流程

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

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

经典的伪代码流程

采集于老师的课件
动静结合学内核之 linux 系统调用浅析
动静结合学内核之 linux 系统调用浅析
动静结合学内核之 linux 系统调用浅析

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

系统调用过程分析

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

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

小结

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

参考要求

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