正文描述:《西电Linux内核分析大作业.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、Linux内核作业一、程序设计思路题H屮说明要使用系统调用,所以首先要先下载编译Linux内核,并在内核中加入相关的系统调用声明,序号等等的。进程是通过list_head双向链表连接起来的,所以根据一个进程就可以得到其他的进程描述符。耍获得第一个进程,我们选择了init进程。要把进程以树的形式输出,所以要用到深度优先遍历。在进程描述符屮,通过children可以获得这个进程的子进程。根据优先遍历的方法,进行递归的打印输出,就可以牛成一棵进程树。打印过程屮,缩进采用层级的打印空格实现。二、程序内容程序屮首先要在一些表屮进行声明。主要的程序在sys.c屮实现。主要有两个函数构成
2、,一个系统调用函数,一个用于递归调用的函数。在系统调用函数屮,会调用这个递归调用函数。三、问题及解决办法1.不了解进程描述符structtask_struct{〃这个是进程的运行时状态,J代表不可运行,0代表可运行,>0代表已停止。volatilelongstate;/*fl昭s是进程当前的状态标志,具体的如:0x00000002表示进程正在被创建;0x00000004表示进程正准备退出;0x00000040表不此进程被fork出,但是并没有执行exec;0x00000400表示此进稈由于其他进稈发送相关信号而被杀死。*/unsignedintflags;〃表不此进程的运行
3、优先级unsignedintrt_priority;structlist^headtasks;〃该结构体记录了进稈内存使用的相关情况structmm_struct*mm;/*进程的一些状态参数*/intexit_state;intexit_code,exit_signal;〃进程号pid_tpid;〃进程组号pid_ttgid;//real_parent是该进稈的“亲生父亲”,不管其是否被“寄养”。structtask_struct*real_parent;//parent是该进稈现在的父进程,有可能是“继父”structtask_struct*parent;〃这里chil
4、dren指的是该进程孩了的链表,可以得到所有孩了的进程描述符structlist_headchildren;//sibling该进程兄弟的链表,也就是其父亲的所有孩了的链表structlist_headsibling;〃这个是主线程的进程描述符structtask_struct*group_leader;〃这个是该进程所有线程的链表。structlist_headthread_group;〃该进稈•使用卬u时间的信息,utime是在用户态下执行的时间,stime是在内核态下执行的时间cputime_tutimezstime;//卜•面的是启动的时间,只是时间基准不一样str
5、ucttimespecstart_time;structtimespecreal_start_time;//comm是保存该进程名字的字符数组,长度最长为15,因为TASK_COMM_LEN为16charcomm[TASK_COMM_LEN];/*文件系统信息计数*/intlinkcount,totallinkcount;/*该进稈在特定CPU下的状态structthread_structthread;/*文件系统相关信息结构体*/structfs_struct*fs;/*打开的文件相关信息结构体*/structfiles_struct*files;/*信号相关信息的句柄*
6、/structsignal_struct*signal;structsignal_struct*signal;/*这些是松弛时间值,用来规定select()和poll()的超时时间,单位是纳秒nanoseconds*/unsignedlongtimerslackns;unsignedlongdefault_timer_slack_ns;};1.遍历进程的方法#definelist_entry(ptr;type,member)container_of(ptGtype,member)#defineoffsetoffTYPE,MEMBER)((size_t)&((TYPE*)0
7、)->MEMBER)#definecontainer_of(ptr;type,member)({consttypeof(((type*)O)->member)*_mptr=(ptr);(type*)((char*)_mptr・offsetof(type’member));})#definelist_for_each(pos,head)for(pos=(head)->next;prefetch(pos->next),pos!=(head);pos二pos->next)-~通过这些宏,知道了如何去使用这些宏进行
显示全部收起
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。