. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->寄存器(内存访问)
主题 : :  第三章最后一个任务整不明白  [待解决] 回复[ 25次 ]   点击[ 2527次 ]  
helloworld
[帖 主] [ 发表时间:2007-10-25 11:21 ] 
荣誉值:10
信誉值:6
注册日期:2007-10-20 14:34
0B07:0100 mov ax,2000
0B07:0103 mov ss,ax
0B07:0105 mov sp,10 
0B07:0108 mov ax,3123 
0B07:010B push ax
0B07:010C mov ax,3366
0B07:010F push ax 

实验问我20000H---2000FH的数据为什么会改变,那这不明摆着代码将栈段设为20000H-2000FH这个范围,push以后,肯定是将ax的数据压进这个段里的,那所以就变了嘛,但我不知道他怎么把cs:ip的数据压进去了,而不是将3123压进去?
jnwz159
[第8楼] [ 回复时间:2008-05-13 21:02 ] 
荣誉值:3
信誉值:0
注册日期:2008-03-27 16:25
这是中断的原因。cpu调用中断例程的时候,会发生中断过程,这个过程会利用当前栈空间临时存放cpu运行的现场状态数据,比如说cs,ip等。而你在debug下的T命令就是一个中断例程。所以,就会出现你看到的现象了。 


T   就是个单步中断, 而8086对任何一个中断的处理都是一样的: 
1.标志寄存器入栈保存:sp<-sp-2,ss:[sp]<-flags 
2.禁止新的可屏蔽中断和但不中断,:if=tf<-0 
3.断点地址入栈保存sp<-sp-2,ss:[sp]<-cs:ip ;sp<-sp-2,ss:[sp]<-ip(注:高地址要存高位,低地址存地位) 
4.读取中断服务程序的起始地址:ip<-[n*4],cs<-[n*4+2](乘4是因为中断服务程序存放在内存0~3FFH地址内,高2为ip,低2为cs,4字节) 
所以,系统执行到第三步操作的时候,对应一下这个题里面d命令后面的那些数就明白了,六个状态标志,全是0(即6对0),ss,sp,cs,ip,就是显示出来的数了,至于最后那两个数是什么暂时没调出来,还请高手继续探索
(第一段是引用的另一个帖子高手的回答,下面是自己的认识)
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved