完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
最近做微机课程设计, 我们学院要求不如电信学院, 只是设计, 没发硬件给我们, 于是决定用 proteus 仿真来实现
前面的都测试的很好, 到 8259 的时候就一直卡住了, 进不了中断. 测试了几个小时, 才发现问题的根源. 现在烦了不想做下去, 就顺手写个帖子, 希望后人遇到同样问题的时候能看到这个帖子, 少走弯路. 问题根源: 8086 取的中断号是最后一次IO操作时出现在总线上的数据, 而不是 8259 中设置的中断号! 直接说结论很难让人相信, 我上传了工程让大家测试: 下面是用 proteus 画的仿真原理图 其他的东西不用管, 仿真的时候只管点击图中右下角的 switch, 现象为: 每点击一次会产生一个中断, 产生中断后 PB0 显示的数据会加1, 如第 2 张图所示. 然后可以打开 code 文件夹下 src.asm 文件 其中第 107-110 行代码如下, 可以看出是这死循环. dead_while: mov al, INT_NUM_BASE out 0, al jmp dead_while; 把上面的 out 0, al 注释掉, 这句代码本来是用来让总线上的最后一次 IO 操作的数据为中断号的. 重新用 masm 生成 exe 文件, 再仿真, 就没上面说的现象了. 这就足以说明 proteus 的 8086 模型有问题了. 上面的 demo 好像很简单. 真正调试的时候当然没那么容易找, 我是事先在向量表上对应的内存块全写 01 02 03 .... 的数据, 然后单步仿真得到中断向量, 对比后得到中断号, 再经过比较后才发现是最后一次IO操作时出现在总线上的数据的... 囧, 仿真模型有问题, 课程设计上又要求要用8259, 现在有点不知该怎样做下去了... 最后顺便吐槽下清华出版社的这本教材写的跟 shit 一样, 读教材跟读 datasheet 一样, 甚至还没 datasheet 清楚. 20130110-03 - 8086.zip (82.07 KB ) |
|
相关推荐
3个回答
|
|
谢谢分享,Pony279 总是可以带来惊喜啊。
|
|
|
|
久违的界面,想想过的真快,LZ加油,可以从你身上学到不少。
|
|
|
|
|
|
|
|
只有小组成员才能发言,加入小组>>
请问下图大疆lightbridge2遥控器主板电源芯片型号是什么?
4468 浏览 1 评论
使用常见的二极管、三极管和mos做MCU和模组的电平转换电路,但是模组和MCU无法正常通信,为什么?
345浏览 2评论
为了提高USIM卡电路的可靠性和稳定性,在电路设计中须注意的点有哪些?
348浏览 2评论
372浏览 2评论
366浏览 2评论
413浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-23 15:33 , Processed in 0.969055 second(s), Total 80, Slave 64 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号