• LC-3 汇编语言 中断实验


    ^_^你有没有想过以后的路怎么走@_@

    目录

    题目描述

    主程序

    中断程序

    思路分析


    题目描述

    一、实验目的与要求

    (1)使用实验证明:中断驱动的输入、输出可以中断一个正在运行的程序,执行中断服务程序,返回被中断的程序,从被中断位置下一个地址继续执行(好像什么也没发生似的)。

    (2)试验中使用键盘作为输入设备,中断正在运行的程序。

    二、实验内容与方法

    试验任务包括实现以下三部分程序:

    A.用户程序

    用户程序将会连续地输出纵横交替的ICS,通过交替,输出两个不同行,如下:

    ICS     ICS     ICS     ICS     ICS     ICS

         ICS     ICS     ICS     ICS     ICS  

    ICS     ICS     ICS     ICS     ICS     ICS

         ICS     ICS     ICS     ICS     ICS  

    ICS     ICS     ICS     ICS     ICS     ICS

         ICS     ICS     ICS     ICS     ICS  

    ICS     ICS     ICS     ICS     ICS     ICS

         ICS     ICS     ICS     ICS     ICS

    确保输出不至于太快,以至于肉眼不能察觉。因而,需要延时操作,可以考虑如下实现:

    1. DELAY ST R1, SaveR1
    2. LD R1, COUNT
    3. REP ADD R1,R1,#-1
    4. BRp REP
    5. LD R1, SaveR1
    6. RET
    7. COUNT .FILL #2500
    8. SaveR1 .BLKW 1

    即用户程序包含一小段代码用于每行间的计数,间隔为从2500开始倒计时,计时结束时,再进行输出

    B. 键盘中断服务程序

    键盘中断服务程序将会简单地在屏幕上写上十次,用户随机输入的字符并以Enter(x0A)结束。

    中断服务程序中要求不使用TRAP指令。

    注意,不要忘记保存和恢复在中端服务程序中使用的那些寄存器。

    C. 操作系统支持的代码

    1.正常情况下,操作系统将会先安装一些栈空间,所以当中断发生的时候 PC和PSR可以被放进栈中(当程序执行RTI,PC和PSR都会被弹出栈,处理器返回到执行被中断的程序)由于没有操作系统,请先把R6初始化为x4000,表示一个空的栈。

    2.正常情况下,操作系统会建立中断向量表,它包含对应中断服务程序的起始地址,必须为键盘中断先建立一个中断向量表。中断向量表的开始地址是x0100,键盘中断的中断向量是x80。必须在中断向量表提供一个入口供本实验使用。

    3.操作系统应该设置KBSR的IE(Interrupt Enable)位。

    主程序

    1. .orig x3000
    2. ld r6,stack
    3. ld r0,inter
    4. sti r0,vector
    5. ld r0,enable
    6. sti r0,kbsr
    7. again lea r0,string1
    8. puts
    9. jsr DELAY
    10. lea r0,string2
    11. puts
    12. jsr DELAY
    13. br again
    14. string1 .stringz "ICS ICS ICS ICS ICS ICS\n"
    15. string2 .stringz " ICS ICS ICS ICS ICS \n"
    16. DELAY ST R1, SaveR1
    17. LD R1, COUNT
    18. REP ADD R1,R1,#-1
    19. BRp REP
    20. LD R1, SaveR1
    21. RET
    22. COUNT .FILL x7fff
    23. SaveR1 .BLKW 1
    24. stack .fill x4000
    25. kbsr .fill xfe00
    26. vector .fill x0180
    27. enable .fill x4000
    28. inter .fill x2000
    29. .end

    中断程序

    1. .orig x2000
    2. add r6,r6,#-1
    3. str r0,r6,#0
    4. add r6,r6,#-1
    5. str r1,r6,#0
    6. add r6,r6,#-1
    7. str r2,r2,#0
    8. return ldi r0,kbsr
    9. brzp return
    10. ldi r0,kbdr
    11. ld r1,lf
    12. add r1,r1,r0
    13. brz tail
    14. ld r1,count
    15. show ldi r2,dsr
    16. brzp show
    17. sti r0,ddr
    18. add r1,r1,#-1
    19. brp show
    20. br return
    21. tail ldr r2,r6,#0
    22. add r6,r6,#1
    23. ldr r1,r6,#0
    24. add r6,r6,#1
    25. ldr r0,r6,#0
    26. add r6,r6,#1
    27. rti
    28. kbsr .fill xfe00
    29. kbdr .fill xfe02
    30. dsr .fill xfe04
    31. ddr .fill xfe06
    32. count .fill #10
    33. lf .fill x-0a
    34. .end

    思路分析

    程序总体设计

    核心数据结构

    1、用户程序

    R6初始化为x4000,表示一个空栈。

    地址为x1080的内存空间存入值x2000,即将中断服务程序的入口地址写入键盘的中断矢量表。

    地址为xfe00的内存空间存入值x4000,即设置KBSR的中断使能位。

    R0存储字符串连续存储空间的首地址。

    2、中断服务程序

    R6是栈指针x4000。

    R0存储KBSR的值,用于判断能否读取KBDR的内容。

    然后R0继续存储KBDR的值,并于存储回车符的负ASCLL码的R1相加,其结果存放于R1,判断是否为回车符。

    然后R1存储输出的次数10。

    R2存储DSR的值,判断能否能否向DDR写入数据。

    然后DDR存储输入的字符。

    算法流程

    中断服务程序

  • 相关阅读:
    用户体验设计常犯逻辑谬误
    7.4缓存
    两种Deformable Attention的区别
    基于新版本Gradle上传jitpack开源项目
    一、Excel VBA 是个啥?
    正式版 API 确定 | Android 12L Beta 1 发布
    [autojs]逍遥模拟器和vscode对接
    SpringBoot微服务的发布与部署(3种方式)
    ES6的export和import
    4.6 IPv6
  • 原文地址:https://blog.csdn.net/weixin_62264287/article/details/126392056