书签 分享 收藏 举报 版权申诉 / 19
上传文档赚钱

类型linux内核taskstruct结构体字段分析课件.ppt

  • 上传人(卖家):晟晟文业
  • 文档编号:4690225
  • 上传时间:2023-01-01
  • 格式:PPT
  • 页数:19
  • 大小:115.86KB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《linux内核taskstruct结构体字段分析课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    linux 内核 taskstruct 结构 字段 分析 课件
    资源描述:

    1、linux 内核源码分析内核源码分析进程管理(一)进程管理(一)郭海林2012.9.29重要数据结构双向链表(1)结构体定义:struct list_head struct list_head*next,*prev;list_headlist_headlist_headlist_headnextprevnextprevnextprevnextprev重要数据结构双向链表(2)为什么要使用这种结构?容器机制容器机制将对象嵌入到另一个对象中 怎样通过链表元素找到容器对象的实例?nextprevtask_structlist_headnextprevtask_structlist_headnextp

    2、revtask_structlist_head重要数据结构双向链表(3)./include/linux/list.hlist_entry(p,t,m)已知类型为t的数据结构包含了一个list_head字段,该字段的名字是m,地址为p,返回类型为t的数据结构地址list_entry(0 x.,struct task_struct,tasks)重要数据结构散列表(1)结构体定义表头:表头:struct hlist_head struct hlist_node*first;节点:节点:struct hlist_node struct hlist_node*next,*pprev;重要数据结构散列表(

    3、2)pprev nexthlist_headhlist_nodenullfirstfirstfirsthlist_nodepprev nextpprev nexthlist_nodenull为什么要这么定义?进程结构体剖析(1)struct task_struct volatile long state;/*-1 unrunnable,0 runnable,0 stopped*/.long exit_state;/.进程的状态宏定义:#define TASK_RUNNING0#define TASK_INTERRUPTIBLE1#define TASK_UNINTERRUPTIBLE2#def

    4、ine _TASK_STOPPED4#define _TASK_TRACED8/*in tsk-exit_state*/#define EXIT_ZOMBIE16#define EXIT_DEAD32/.进程结构体剖析(2)struct task_struct/.struct list_head tasks;/将系统中所有进程通过双向链表链接起来!将系统中所有进程通过双向链表链接起来!/.怎样访问所有的进程呢?怎样访问所有的进程呢?#define for_each_process(p)for(p=&init_task;(p=next_task(p)!=&init_task;)#define n

    5、ext_task(p)list_entry_rcu(p)-tasks.next,struct task_struct,tasks)给出全局给出全局pid号,怎么找到相应进程的号,怎么找到相应进程的task_struct?进程结构体剖析(3)struct task_struct/.pid_t pid;/进程标识符(线程)pid_t tgid;/线程组的领头线程IDstruct task_struct*group_leader;/threadgroup leader/.系统调用系统调用 getpid()返回什么?返回什么?进程结构体剖析(4.1)struct task_struct/.struct

    6、 task_struct _rcu*real_parent;/*real parent process*/struct task_struct _rcu*parent;/*recipient of SIGCHLD,wait4()reports*/struct list_head children;/*list of my children*/struct list_head sibling;/*linkage in my parents children list*/.进程之间的关系:进程之间的关系:父子关系兄弟关系childrensiblingchildrensiblingchildrens

    7、iblingchildrensiblingchildrensiblingADCBEPNNPPPNNP进程结构体剖析(4.2)假设现在有进程A,生成三个子进程B、C、D,B进程又生成一个子进程E。五个五个task_struct怎么进行链接?怎么进行链接?进程结构体剖析(5.1)struct task_struct/./*PID/PID hash table linkage.*/struct pid_link pidsPIDTYPE_MAX;/.enum pid_typePIDTYPE_PID,PIDTYPE_PGID,PIDTYPE_SID,PIDTYPE_MAX;/进程PID/线程组领头线程P

    8、ID/会话领头进程ID/类型个数pids0pids1pids2关键结构体struct upid int nr;struct pid_namespace*ns;struct hlist_node pid_chain;struct pid_link struct hlist_node node;struct pid*pid;struct pid atomic_t count;unsigned int level;struct hlist_head tasksPIDTYPE_MAX;struct rcu_head rcu;struct upid numbers1;countlevertask0tas

    9、k1task2nrnodepidnodepidnspid_chain 213pid命名空间(1)123456781092131lever 0lever 1lever 2pid命名空间(2)struct nsproxy atomic_t count;struct uts_namespace*uts_ns;struct ipc_namespace*ipc_ns;struct mnt_namespace*mnt_ns;struct pid_namespace*pid_ns;struct net *net_ns;struct pid_namespace /.unsigned int level;str

    10、uct pid_namespace*parent;/.;结构图见板书.重要函数(1)根据进程的命名空间ns以及局部PID号nr,怎么找到进程的task_struct?nr,ns -upid -pid -task_structstruct pid*find_pid_ns(int nr,struct pid_namespace*ns)struct task_struct*pid_task(struct pid*pid,enum pid_type type)重要函数(2)给出task_struct、ID类型、命名空间,怎么取得命名空间局部的ID号?task_struct -pid -upid -nrstruct pid*task_pid(struct task_struct*task)pid_t pid_nr_ns(struct pid*pid,struct pid_namespace*ns)重要函数(3)对于一个新建的进程,怎么在各个命名空间内生成唯一的PID号?struct pid*alloc_pid(struct pid_namespace*ns)(见源代码见源代码)

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:linux内核taskstruct结构体字段分析课件.ppt
    链接地址:https://www.163wenku.com/p-4690225.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库