1. gzyueqian
      13352868059

      匯編程序要注意中斷搗鬼---進(jìn)入死循環(huán)!

      更新時(shí)間: 2006-03-09 14:19:55來(lái)源: 粵嵌教育瀏覽量:4196

      取堆棧中的PC值一般采用2種方法:

      1.利用PUSH/POP
      ;.........................
      XXXXH: lcall _getPC;
      YYYYH: ;................
      等效為:
      PUSH low YYYYH ;先壓入低8位地址,SP+1
      PUSH high YYYYH ;后壓入高8位地址,SP+1
      JMP _getPC;跳入_getPC后遇到RET返回YYYYH

      _getPC: pop DPTH ;先彈出高8位地址,SP-1
      pop DPTL ;后彈出低8位地址,SP-1
      ;...................................
      ; 假設(shè)此處立即響應(yīng)某中斷
      ;...................................
      ZZZZH:
      INC SP ;恢復(fù)低8位地址low YYYYH
      INC SP ;恢復(fù)高8位地址high YYYYH
      ;...................................
      ;...................................
      RET ;返回YYYYH

      但若在第1個(gè)INC SP前來(lái)中斷時(shí),則由于2個(gè)POP和中斷的2個(gè)PUSH
      將使原棧頂存入的返回地址YYYYH被中斷返回地址ZZZZH覆蓋!!!

      以上程序等效為:

      ;.........................
      XXXXH: lcall _getPC;
      YYYYH: ;................
      等效為:
      PUSH low YYYYH ;先壓入低8位地址,SP+1
      PUSH high YYYYH ;后壓入高8位地址,SP+1
      JMP _getPC;跳入_getPC后遇到RET返回YYYYH

      _getPC: POP DPTH ;先彈出高8位地址YYYYH,SP-1
      POP DPTL ;后彈出低8位地址YYYYH,SP-1
      ;...................................
      ; 假設(shè)此處立即響應(yīng)某中斷(INT0)
      PUSH low ZZZZH;覆蓋YYYYH!!!,SP+1
      PUSH high ZZZZH;覆蓋YYYYH!!!,SP+1
      JMP 0x0003;跳入INT0_ISR;遇RETI返回ZZZZH,且SP-2
      ;...................................
      ZZZZH:
      INC SP ;恢復(fù)低8位地址low ZZZZH
      INC SP ;恢復(fù)高8位地址high ZZZZH
      ;...................................
      ;...................................
      RET ;返回ZZZZH;哈哈,等效為SP-2,JMP ZZZZH

      結(jié)果很震驚---死循環(huán)!!!!!!!!!!!!!!!!!!!!!!!!!!!

      所以,這種方法要特別注意!!!---也是一種中斷如何"傷人"的案例.

      2.利用SP,@R0
      ;.........................
      XXXXH: lcall _getPC;
      YYYYH: ;................


      _getPC: MOV R0,SP;取SP是安全的
      MOV DPTH, @R0;先彈出高8位地址YYYYH
      DEC R0
      MOV DPTL, @R0;再?gòu)棾龅?位地址YYYYH
      ..............................................
      RET

      這種方法不受中斷的影響,因?yàn)橛脩?hù)沒(méi)有操作SP(沒(méi)改變其值)...

      免費(fèi)預(yù)約試聽(tīng)課

      亚洲另类欧美综合久久图片区_亚洲中文字幕日产无码2020_欧美日本一区二区三区桃色视频_亚洲AⅤ天堂一区二区三区

      
      

      1. 在线看片国产的免费的 | 日韩精品亚洲国产中文一区蜜芽 | 亚洲午夜精品福利视频 | 热久久这里只有精品 | 亚洲欧美日本国产专区一区 | 六月丁香婷婷亚洲中文字幕 |