1 / 23
文档名称:

Linux内核实验报告——实验4.doc

格式:doc   页数:23页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

Linux内核实验报告——实验4.doc

上传人:xxj165868 2016/1/29 文件大小:0 KB

下载得到文件列表

Linux内核实验报告——实验4.doc

文档介绍

文档介绍:Linux内核实验报告实验题目:动态模块设计实验实验目的:Linux模块是一些可以独立于内核单独编译的内核函数和数据类型集合,是可增删的内核部分。模块在内核启动时装载称为静态装载,在内核已经运行时装载称为动态装载。模块可以扩充内核所期望的任何功能,但通常用于实现设备驱动程序。通过本实验,将学习到动态模块的设计过程,以及Proc文件系统的部分知识。硬件环境:Pentium(R)Dual-******@:(Ubuntu/-1ubuntu5)内核版本::1、代码分析模块初始化和模块卸载的函数都类同,同时读取proc文件的函数在本次实验中没有用到,所以着重描述写驱动函数。实验A:在这个proc函数中只是简单得输出jiffies的数值。实验B:遍历父进程和所有进程,依然是在proc_read中,通过以下代码片段完成功能,注意在这里,我们是通过直接向系统分配的那一个page直接写入来得到的,所以每次不同的进程访问该proc文件的时候得到的结果都不一样遍历父进程:len+=sprintf(page+len,"遍历父进程\npid\tppid\tcomm\n");while(task!=&init_task){len+=sprintf(page+len,"%d\t%d\t[%s]\n",task->pid,task->parent->pid,task->comm);task=task->parent;}遍历所有进程,通过for_each_process(task)这个宏来遍历所有进程:len+=sprintf(page+len,"遍历任务队列\ncomm\tpid\n");for_each_process(task){len+=sprintf(page+len,"%d\t[%s]\n",task->pid,task->comm);}returnlen;实验C:在模块开头通过module_param声明了模块参数,在装载模块时通过它来传参module_param(param,int,0644);在proc_read函数中通过这个传入的参数来判断应该读取内核的哪些数值,其中标注黄色的一段是从内核实现/proc/loadavg部分中抽取出来的,loops_per_jiffy是每个滴答能执行的循环数,在内核启动的时候计算出来的这个值:if(param==0){//获取loadavglen+=sprintf(page+len,"%lu.%02lu%lu.%02lu%lu.%02lu\n"/*%ld/%d%d\n*/,LOAD_INT(avenrun[0]),LOAD_FRAC(avenrun[0]),LOAD_INT(avenrun[1]),LOAD_FRAC(avenrun[1]),LOAD_INT(avenrun[2]),LOAD_FRAC(avenrun[2])/*,nr_running(),nr_threads,*//*task_active_pid_ns(current)->last_pid*/);}elseif(param==1){len+=sprintf(page+len,"loops_per_jiffy:%lu\n",loops_per_jiffy);len+=sprintf(page+len,"bogomips=lpj/(500000/HZ):\n%lu.%02lu\n",loops_per_jiffy/(500000/HZ),loops_per_jiffy/(5000/HZ)%100);}在这里我们还设计了改写loops_per_jiffy的方法:staticintproc_write(structfile*file,constchar*buffer,unsignedlongcount,void*data){intlen;charbuf[16];if(count>MYDATA_LEN)len=MYDATA_LEN;elselen=count;copy_from_user(buf,buffer,len);loops_per_jiffy=simple_strtol(buf,NULL,10);returnlen;}2、设计说明实验A:对于读取时间,内核提供了do_gettimeofday这个函数,同时在对用户也提供了一个系统调用gettimeofday,这两个获取当前时间的途径都是一样的(在x86上都是访问TSC寄存器——时间戳寄存器来获得时间值),所以一般都要比用jiffies滴答数获得的时间数要准确。在进行这两种比较时,我们可以有两种策略,直接在proc文件中不停输出两者数值(jiffies和当前时间),或者proc文