程序的PSP可能有些地方写的不是很清楚,同时有些朋友也不明白为什么COM文件要偏移100H,再这里说明下。
PSP并不是文件里存在的段,而是在程序被装载进内存以后,操作系统建立的一个区域,这个区域包含了很多有用的信息,其中我们感兴趣的比如参数的传递,以下是 关于COM文件的。。。
.COM文件包含程序的一个绝对映象----就是说,为了运行程序准确的
处理器指令和内存中的数据,MS-DOS通过直接把该映象从文件拷贝到内存
而加载.COM程序;它不作任何改变.
为加载一个.COM程序,MS-DOS首先试图分配内存,因为.COM程序必须
位于一个64K的段中,所以.COM文件的大小不能超过65,024(64K减去用于
PSP的256字节和用于一个起始堆栈的至少256字节).如果MS-DOS不能为程
序,一个PSP,一个起始堆栈分配足够内存,则分配尝试失败.否则,MS-DOS
分配尽可能多的内存(直至所有保留内存),即使.COM程序本身不能大于64
K.在试图运行另一个程序或分配另外的内存之前,大部分.COM程序释放任
何不需要的内存.
分配内存后,MS-DOS在该内存的头256字节建立一个PSP,如果PSP中的
第一个FCB含有一个有效驱动器标识符,则置AL为00h,否则为0FFh.MS-DOS
还置AH为00h或0FFh,这依赖于第二个FCB是否含有一个有效驱动器标识符.
建造PSP后,MS-DOS在PSP后立即开始(偏移100h)加载.COM文件,它置
SS,DS和ES为PSP的段地址,接着创建一个堆栈.为创建一个堆栈,MS-DOS置
SP为0000h,若已分配了至少64K内存;否则,它置寄存器为比所分配的字节
总数大2的值.最后,它把0000h推进栈,这是为了保证与在早期MS-DOS版本
上设计的程序的兼容性.
MS-DOS通过把控制传递偏移100h处的指令而启动程序.程序设计者必
须保证.COM文件的第一条指令是程序的入口点.
注意,因为程序是在偏移100h处加载,因此所有代码和数据偏移也必
须相对于100h.汇编语言程序设计者可通过置程序的初值为100h而保证这
一点(例如通过在原程序的开始使用语句org 100h).
有一个问题在这 com 文件的 有PSP么? 呵呵刚开始感觉这个问题比较白痴,但是很有意思的是 COM文件在装入内存的时候IP为100H,而exe文件却是0,这里迷糊了好久,后来终于明白了。
COM文件开始的偏移100H就是为了让操作系统建立PSP段的。我想这个对各位可能有用处,在EXE里PSP段是系统申请的内存,而COM里,系统直接使用了文件开始偏移的100H。
- [chervy] 我还是初学汇编的。 我学着弄了一遍,接下来怎么弄呢?谢谢。 09/17 17:24
- [ghi] 先收藏了 以后再看 哈哈 好东西都得看见就收藏了 07/02 22:06
- [wuerlang] 我也收藏. 也许用来研究学习汇编的时候有用. 至于研究病毒,倒不觉得有什么兴趣. 12/25 17:24
- [happy] 学习了! 10/22 20:19
- [happy] 厉害! 10/22 20:07
- [happy] 不错,支持一下 10/22 20:05
- [goal00001111] 很不错,收藏了。 10/21 12:51
- [dreamhk] 博主可否把病毒文件加密码virus压缩发送到 rar.virus@gmail.com 谢谢,我没有 10/20 21:27
- [jyycool] 呵呵,不错强啊,我还不行,我想最多半个月,我就可以看的懂了 10/20 19:48