中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
作者:
标题: 大于1M的程序段地址问题 上一主题 | 下一主题
pkuwc
初级用户





积分 36
发帖 12
注册 2010-1-21
状态 离线
『楼 主』:  大于1M的程序段地址问题

目前一个难题,望各位老大帮忙看看。
问题描述:一个可执行文件A.exe在图形模式下输出字符串,调用bgi16.dll中的outtextxy进行字符串输出.我重写了outtextxy,将其字符串的指针值传给我自定义中断,在中断中将地址写入文件。
运行发现偏移地址是正确的,但是段地址差很远。
A.exe本身就1M多,通过IDA分析可见字符串处段地址已经快突破FFFF,中断获取到的值只有350左右,明显不对,还望老大们指点一二

2010-1-22 17:01
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
pkuwc
初级用户





积分 36
发帖 12
注册 2010-1-21
状态 离线
『第 2 楼』:  

我自己给自己回复吧,最终发现这个程序是使用了DPMI,DPMI是DOS PROTECTED MODE INTERFACE的缩写,通过它可以使应用程序进入保护模式,实现整个物理内存(高大4G)直接寻址。在BC 4.5中创建工程时的DOS (16-BIT DPMI)和DOS (32BIT DPMI)创建的就是DPMI 应用程序,其运行需要rtm.exe和dpmi16bi.ovl的支持。

   此帖被 +2 点积分     点击查看详情   
评分人:【 DOSforever 分数: +2  时间:2010-2-3 18:48


2010-1-29 15:53
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: