实验三进程的创建汇编

上传人:今*** 文档编号:108299688 上传时间:2019-10-23 格式:DOC 页数:20 大小:1.01MB
返回 下载 相关 举报
实验三进程的创建汇编_第1页
第1页 / 共20页
实验三进程的创建汇编_第2页
第2页 / 共20页
实验三进程的创建汇编_第3页
第3页 / 共20页
实验三进程的创建汇编_第4页
第4页 / 共20页
实验三进程的创建汇编_第5页
第5页 / 共20页
点击查看更多>>
资源描述

《实验三进程的创建汇编》由会员分享,可在线阅读,更多相关《实验三进程的创建汇编(20页珍藏版)》请在金锄头文库上搜索。

1、上海应用技术学院程序设计语言实验报告实验名称进程的创建实验序号实验三实验日期姓 名学 号指导教师专 业计算机科学与技术班 级 成 绩1、 实验目的及要求 练习使用EOS API函数CreateProcess创建一个进程,掌握创建进程的方法,理解进程和程序的区别。 调试跟踪CreateProcess函数的执行过程,了解进程的创建过程,理解进程是资源分配的单位。2、 实验环境 Windows XP;Tevation OS Lab。3、 实验内容 1 准备实验按照下面的步骤准备本次实验:1. 启动OS Lab。2. 新建一个EOS Kernel项目,如图1。图13. 分别使用Debug配置和Rele

2、ase配置生成此项目,从而在该项目文件夹中生成完全版本的EOS SDK文件夹,如图2、图3。图2图34. 新建一个EOS应用程序项目,如图4。图45. 使用在第3步生成的SDK文件夹覆盖EOS应用程序项目文件夹中的SDK文件夹,使用Debug配置和Release配置生成此项目如图5、6;使用在第3步生成的SDK文件夹覆盖EOS应用程序项目文件夹中的SDK文件夹,如图7。图5图6图72 练习使用控制台命令创建EOS应用程序的进程练习使用控制台命令创建EOS应用程序进程的具体步骤如下:1. 在EOS应用程序项目的“项目管理器”窗口中双击Floppy.img文件如图8,使用FloppyImageEd

3、itor工具打开此软盘镜像文件。图82. 在OS Lab的“帮助”菜单中选择“示例”,打开示例文件夹如图9。图93. 将示例文件夹中的Hello.exe文件(一个EOS应用程序的可执行文件,源代码可以参见该实验文件夹中的Hello.c源文件)拖动到FloppyImageEditor工具窗口的文件列表中释放如图10,Hello.exe文件即被添加到软盘镜像文件中。图104. 在FloppyImageEditor中选择“文件”菜单中的“保存”如图11后关闭FloppyImageEditor。图115. 按F7生成EOS应用项目。6. 按F5启动调试。OS Lab会弹出一个调试异常对话框,并中断应用

4、程序的执行。7. 在调试异常对话框中选择“否”,忽略异常继续执行应用程序。8. 激活虚拟机窗口,待该应用程序执行完毕后,在EOS的控制台中输入命令“A:Hello.exe”后回车结果如图12。图129. Hello.exe应用程序开始执行,观察其输出如图13。图1310.待Hello.exe执行完毕后可以重复第8步,或者结束此次调试。3 练习通过编程的方式让应用程序创建另一个应用程序的进程使用OS Lab打开本实验文件夹中的NewProc.c文件(将此文件拖动到OS Lab窗口中释放即可),仔细阅读此文件中的源代码和注释,main函数的流程图可以参见图3。按照下面的步骤查看应用程序创建另一个应

5、用程序的进程的执行结果:1. 使用NewProc.c文件中的源代码替换之前创建的EOS应用程序项目中的EOSApp.c文件内的源代码。(去掉Newproc.h,保留原来的EOSApp.h)2. 按F7生成修改后的EOS应用程序项目。3. 按F5启动调试。OS Lab会首先弹出一个调试异常对话框如图14。4. 在调试异常对话框中选择“否”,继续执行结果如图15。A图14图155. 激活虚拟机窗口查看应用程序输出的内容,如图16。可以看到父进程(EOSApp.exe)首先开始执行并输出内容,父进程创建了子进程阿(Hello.exe)后,子进程开始执行并输出内容,待子进程结束后父进程再继续执行。图1

6、66. 结束此次调试。main函数流程图4 调试CreateProcess函数按照下面的步骤调试CreateProcess函数创建进程的过程:1. 按F5启动调试EOS应用程序,OS Lab会首先弹出一个调试异常对话框。2. 选择“是”调试异常,调试会中断。3. 在main函数中调用CreateProcess函数的代码行(第56行)添加一个断点如图17。图174. 按F5继续调试,在断点处中断如图18。图185. 按F11调试进入CreateProcess函数如图19。此时已经开始进入EOS内核进行调试。图19EOS应用程序eosapp.exe创建的进程从图4中可以看到,当EOS应用程序eos

7、app.exe存储在磁盘上的时候,它是静态的,只包含应用程序的指令和数据。而创建进程后,进程不但包含应用程序的指令和数据,也会包含操作系统内核的指令和数据。同时也说明了一个进程可以包含多个程序。可以按照下面的步骤来分别验证应用程序和操作系统内核在进程的4G虚拟地址空间中所处的位置:1. 由于此时在内核的CreateProcess函数内中断执行,所以在“调试”菜单的“窗口”中选择“反汇编”,会在“反汇编”窗口中显示CreateProcess函数的指令对应的反汇编代码如图20。“反汇编”窗口的左侧显示的是指令所在的虚拟地址。可以看到所有指令的虚拟地址都大于0x80000000,说明内核处于高2G的

8、虚拟地址空间中。 图202. 在“调用堆栈”窗口中双击main函数项如图21,设置main函数的调用堆栈帧为活动的。在“反汇编”窗口中查看main函数的指令所在的虚拟地址都是小于0x80000000如图22,说明应用程序处于低2G的虚拟地址空间中。图21图223. 关闭“反汇编”窗口。接下来观察CreateProcess函数的源代码,可以看到此函数只是调用了EOS内核函数PsCreateProcess并将创建进程所用到的参数传递给了此函数。所以,按F11可以调试进入create.c文件中的PsCreateProcess函数结果如图23,在此函数中才开始执行创建进程的各项操作。图235 调试Ps

9、CreateProcess函数创建进程最主要的操作就是创建进程控制块并初始化其中的各种信息(也就是为进程分配各种资源)。所以在PsCreateProcess函数中首先调用了PspCreateProcessEnvironment函数来创建进程控制块。调试PspCreateProcessEnvironment函数的步骤如下:1. 在PsCreateProcess函数中找到调用PspCreateProcessEnvironment函数的代码行(create.c文件的第163行)并添加一个断点如图24。图242. 按F5继续调试,到此断点处中断如图25。图253. 按F11调试进入PspCreateP

10、rocessEnvironment函数结果如图26。图26由于PspCreateProcessEnvironment函数的主要功能就是创建进程控制块并初始化其中的部分信息,所以在此函数的开始,定义了一个进程控制块的指针变量NewProcess。在此函数中查找到创建进程控制块的代码行(create.c文件的第418行)如图27。Status = ObCreateObject( PspProcessType,NULL,sizeof(PROCESS) + ImageNameSize + CmdLineSize,0,(PVOID*)&NewProcess );图27这里的ObCreateObject函

11、数在由EOS内核管理的内存中创建了一个新的进程控制块(也就是分配了一块内存),并由NewProcess返回了进程控制块的指针(也就是所分配内存的起始地址)。 按照下面的步骤调试进程控制块的创建过程:1. 在调用ObCreateObject函数的代码行(create.c文件的第418行)添加一个断点如图28。图282. 按F5继续调试,到此断点处中断如图29。 图293. 按F10执行此函数后中断如图30。图304. 此时为了查看进程控制块中的信息,将表达式*NewProcess添加到“监视”窗口中。5. 将鼠标移动到“监视”窗口中此表达式的“值”属性上,会弹出一个临时窗口,在临时窗口中会按照进

12、程控制块的结构显示各个成员变量的值(可以参考PROCESS结构体的定义)。由于只是新建了进程控制块,还没有初始化其中成员变量,所以值都为0,如图31。图31接下来调试初始化进程控制块中各个成员变量的过程:1. 首先创建进程的地址空间。在代码行(create.c文件的第437行)NewProcess-Pas = MmCreateProcessAddressSpace();处添加一个断点如图32。图322. 按F5继续调试,到此断点处中断如图33。图333. 按F10执行此行代码后中断结果如图34。图344. 在“监视”窗口中查看进程控制块的成员变量Pas的值已经不再是0,如图35。说明已经初始化

13、了进程的4G虚拟地址空间。图355. 使用F10一步步调试PspCreateProcessEnvironment函数中后面的代码,在调试的过程中根据执行的源代码,查看“监视”窗口中*NewProcess表达式的值,观察进程控制块中哪些成员变量是被哪些代码初始化的,哪些成员变量还没有被初始化。6. 当从PspCreateProcessEnvironment函数返回到PsCreateProcess函数后,停止按F10。此时“监视”窗口中已经不能再显示表达式*NewProcess的值了,在PsCreateProcess函数中是使用ProcessObject指针指向进程控制块的,所以将表达式*Proc

14、essObject添加到“监视”窗口中就可以继续观察新建进程控制块中的信息。7. 接下来继续使用F10一步步调试PsCreateProcess函数中的代码,同样要注意观察执行后的代码修改了进程控制块中的哪些成员变量。当调试到PsCreateProcess函数的最后一行代码时,查看进程控制块中的信息,此时所有的成员变量都已经被初始化了(注意观察成员ImageName的值)。8. 按F5继续执行,EOS内核会为刚刚初始化完毕的进程控制块新建一个进程。激活虚拟机窗口查看新建进程执行的结果如图36。图369. 在OS Lab中选择“调试”菜单中的“停止调试”结束此次调试。6 练习通过编程的方式创建应用

15、程序的多个进程使用OS Lab打开本实验文件夹中的参考源代码文件NewTwoProc.c,仔细阅读此文件中的源代码。使用NewTwoProc.c文件中的源代码替换EOS应用程序项目中的EOSApp.c文件内的源代码,并查看多个进程并发执行的结果。同时创建应用程序的多个进程4、 实验结果与分析 1、基本完成了此次实验的要求; 2、在实验中存在以下问题:问题:在FloppyImageEditor中选择“文件”菜单中的“保存”如图1后关闭FloppyImageEditor。图1 然后按F7生成EOS应用项目。再按F5启动调试。这是OS Lab没有弹出调试异常的对话框而是提醒没有该文件。解决方案:反复好多次试验依然没有跳出调试一场窗口,最后发现在生成EOSAPP后没有将其配置工具还原为Debug如图2而是停留在

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号