OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 11659|回复: 3

proteus 7.10 仿真 8086 + 8259 时不能进入中断的 BUG 的说明

[复制链接]

36

主题

1105

帖子

5

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
2195
金钱
2195
注册时间
2012-2-8
在线时间
34 小时
发表于 2013-1-10 20:15:11 | 显示全部楼层 |阅读模式
 最近做微机课程设计, 我们学院要求不如电信学院, 只是设计, 没发硬件给我们, 于是决定用 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, 下载次数: 976

https://github.com/roxma
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2013-1-10 22:08:02 | 显示全部楼层
谢谢分享,Pony279 总是可以带来惊喜啊。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

27

主题

274

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
471
金钱
471
注册时间
2011-11-2
在线时间
11 小时
发表于 2013-1-13 19:11:10 | 显示全部楼层
久违的界面,想想过的真快,LZ加油,可以从你身上学到不少。
回复 支持 反对

使用道具 举报

36

主题

1105

帖子

5

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
2195
金钱
2195
注册时间
2012-2-8
在线时间
34 小时
 楼主| 发表于 2013-1-13 20:07:10 | 显示全部楼层
大一刚学单片机又没有51板子的时候用过一段时间 proteus,感觉还是挺好用的,后来有了板子以后就再没仿真过了。。。

大家相互学习。
https://github.com/roxma
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 12:33

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表