西电Linux内核分析大作业

ID:44667238

大小:112.40 KB

页数:6页

时间:2019-10-24

西电Linux内核分析大作业_第1页
西电Linux内核分析大作业_第2页
西电Linux内核分析大作业_第3页
西电Linux内核分析大作业_第4页
西电Linux内核分析大作业_第5页
资源描述:

《西电Linux内核分析大作业》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、Linux内核作业、程序设计思路题目中说明要使用系统调用,所以首先要先下载编译Linux内核,并在内核中加入相关的系统调用声明,序号等等的。进程是通过list_head双向链表连接起來的,所以根据一个进程就可以得到其他的进程描述符。要获得第一个进程,我们选择了init进程。要把进程以树的形式输岀,所以要用到深度优先遍历。在进程描述符屮,通过children可以获得这个进程的了进程。根据优先遍丿力的方法,进行递归的打卬输出,就可以生成一棵进程树。打印过程中,缩进采用层级的打印空格实现。二、程序内容程序中首先要在一些表中进行声明。主要的

2、程序在sys.c屮实现。主要冇两个函数构成,一个系统调用函数,一个用于递归调用的函数。在系统调用函数屮,会调用这个递归调用函数。三、问题及解决办法1.不了解进程描述符structtask_struct{〃这个是进程的运行时状态,J代表不可运行,0代表可运行,>0代表已停止。volatilelongstate;/*flags是进程当前的状;态标志,貝-体的如:0x00000002表示进程正在被创建;0x00000004表示进程正准备退岀;0x00000040表示此进程被forkHl,但是并没冇执frexec;0x00000400表示此

3、进程由于其他进程发送相关信号而被杀死。*/unsignedintflags;〃表示此进程的运行优先级unsignedintrt_priority;structlistheadtasks;〃该结构体记录了进程内存使用的相关情况structmmstruct*mm;/*进程的一些状态参数*/intexit_state;intexit_code,exit_signal;〃进程号Pid_tpid;〃进程组号pid_ttgid;//real_parent是该进程的“亲生父亲”,不管其是否被“寄养”。structtask_struct*real_

4、parent;//parent是该进程现在的父进程,有可能是“继父”structtask_struct*parent;〃这里children指的是该进程孩子的链表,可以得到所有孩子的进程描述符structlist_headchildren;//sibling该进程兄弟的链表,也就是其父亲的所冇孩子的链表structlist_headsibling;〃这个是主线程的进程描述符structtask_struct*group_leader;〃这个是该进程所有线程的链表。structlist_headthread_group;〃该进程使用c

5、pu时间的信息,utime是在用户态卜•执行的时间,stime是在内核态下执行的时间cputime_tutime,stime;〃下而的是启动的时间,只是时间基准不一样structtimespecstart_time;structtimespecreal_start_time;//comm是保存该进程名字的字符数组,长度最长为15,因为TASK_COMM_LEN为16charcomm[TASK_COMM_LEN];/*文件系统信息计数*/intlink_count,totalJink_count;/*该进程在特定CPU下的状态*/st

6、ructthread_structthread;/*文件系统相关信息结构体*/structfs_struct*fs;/*打开的文件相关信息结构体*/structfiles_struct*files;厂信号相关信息的句柄*/structsignal_struct*signal;structsignal_struct水signal;/*这些是松弛时间值,用来规定select()和poll()的超时时间,单位是纳秒nanoseconds*/unsignedlongtimerslackns;unsignedlongdefault_tirne

7、r_slack_ns;};1.遍历进程的方法#definelist_entry(ptr,type,member)、container_of(ptr,type,member)//defineoffsetof(TYPE,MEMBER)((size_t)&((TYPE*)0)->MEMBER)#definecontainer_of(ptGtype,member)({consttypeof(((type*)O)->member)*_mptr=(ptr);(type*)((char*)_mptr-offsetof(type,member)

8、);})#definelist_for_each(pos,head)for(pos=(head)->next;prefetch(pos->next),pos!=(head);pos=pos->next)通过这些宏,知道了如何去使用

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
正文描述:

《西电Linux内核分析大作业》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、Linux内核作业、程序设计思路题目中说明要使用系统调用,所以首先要先下载编译Linux内核,并在内核中加入相关的系统调用声明,序号等等的。进程是通过list_head双向链表连接起來的,所以根据一个进程就可以得到其他的进程描述符。要获得第一个进程,我们选择了init进程。要把进程以树的形式输岀,所以要用到深度优先遍历。在进程描述符屮,通过children可以获得这个进程的了进程。根据优先遍丿力的方法,进行递归的打卬输出,就可以生成一棵进程树。打印过程中,缩进采用层级的打印空格实现。二、程序内容程序中首先要在一些表中进行声明。主要的

2、程序在sys.c屮实现。主要冇两个函数构成,一个系统调用函数,一个用于递归调用的函数。在系统调用函数屮,会调用这个递归调用函数。三、问题及解决办法1.不了解进程描述符structtask_struct{〃这个是进程的运行时状态,J代表不可运行,0代表可运行,>0代表已停止。volatilelongstate;/*flags是进程当前的状;态标志,貝-体的如:0x00000002表示进程正在被创建;0x00000004表示进程正准备退岀;0x00000040表示此进程被forkHl,但是并没冇执frexec;0x00000400表示此

3、进程由于其他进程发送相关信号而被杀死。*/unsignedintflags;〃表示此进程的运行优先级unsignedintrt_priority;structlistheadtasks;〃该结构体记录了进程内存使用的相关情况structmmstruct*mm;/*进程的一些状态参数*/intexit_state;intexit_code,exit_signal;〃进程号Pid_tpid;〃进程组号pid_ttgid;//real_parent是该进程的“亲生父亲”,不管其是否被“寄养”。structtask_struct*real_

4、parent;//parent是该进程现在的父进程,有可能是“继父”structtask_struct*parent;〃这里children指的是该进程孩子的链表,可以得到所有孩子的进程描述符structlist_headchildren;//sibling该进程兄弟的链表,也就是其父亲的所冇孩子的链表structlist_headsibling;〃这个是主线程的进程描述符structtask_struct*group_leader;〃这个是该进程所有线程的链表。structlist_headthread_group;〃该进程使用c

5、pu时间的信息,utime是在用户态卜•执行的时间,stime是在内核态下执行的时间cputime_tutime,stime;〃下而的是启动的时间,只是时间基准不一样structtimespecstart_time;structtimespecreal_start_time;//comm是保存该进程名字的字符数组,长度最长为15,因为TASK_COMM_LEN为16charcomm[TASK_COMM_LEN];/*文件系统信息计数*/intlink_count,totalJink_count;/*该进程在特定CPU下的状态*/st

6、ructthread_structthread;/*文件系统相关信息结构体*/structfs_struct*fs;/*打开的文件相关信息结构体*/structfiles_struct*files;厂信号相关信息的句柄*/structsignal_struct*signal;structsignal_struct水signal;/*这些是松弛时间值,用来规定select()和poll()的超时时间,单位是纳秒nanoseconds*/unsignedlongtimerslackns;unsignedlongdefault_tirne

7、r_slack_ns;};1.遍历进程的方法#definelist_entry(ptr,type,member)、container_of(ptr,type,member)//defineoffsetof(TYPE,MEMBER)((size_t)&((TYPE*)0)->MEMBER)#definecontainer_of(ptGtype,member)({consttypeof(((type*)O)->member)*_mptr=(ptr);(type*)((char*)_mptr-offsetof(type,member)

8、);})#definelist_for_each(pos,head)for(pos=(head)->next;prefetch(pos->next),pos!=(head);pos=pos->next)通过这些宏,知道了如何去使用

显示全部收起
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。
关闭