OK6410汇编程序练习


尝试使用一下6410的汇编,发现跟当年的51差不多,一步一步的学习

;*************************************************************************************************************
;* 文件名: ok6410.s
;* 功能:  S3C6410 汇编
;* 作者:  cp1300@139.com
;* 创建时间: 2013年1月4日21:27
;* 最后修改时间:2013年1月4日
;* 详细: 
;*************************************************************************************************************/

TINT_CSTAT  EQU  0x7F006044  ;定时器中断控制和状态寄存器
VIC0ADDRESS  EQU  0x71200F00  ;当前矢量地址寄存器0,写入任意数据清除中断
VIC1ADDRESS  EQU  0x71300F00  ;当前矢量地址寄存器1,写入任意数据清除中断

;调用外部函数
 IMPORT  LED1_flash    ;LED1闪烁程序
 
;外部调用函数
 EXPORT  Time_Isr    ;时钟中断服务程序
 
 
 
 PRESERVE8;
 AREA S3C6410_CPU, CODE, READONLY 

;定时器1中断服务程序,注意:进入中断后6410自动切换为IRQ模式,并关闭了IRQ中断,退出的时候需要自己开启,或者还原CPSR 
Time_Isr
 STMFD SP!, {R0,R1,LR}    ;R0,R1,LR入栈
 
 LDR  R0,  =TINT_CSTAT   
 LDR  R1,  [R0]     ;读取寄存器 TINT_CSTAT
 ORR  R1,  R1,  #0x01<<6  ;写BIT6,清除定时器1中断
 STR  R1,  [R0]     ;回写寄存器
 
 BL  LED1_flash      ;调用LED闪烁程序
 
 LDR  R0,  =VIC0ADDRESS   ;写VIC的当前中断地址寄存器清除中断
 LDR  R1,  =0xffffffff
 STR  R1,  [R0]
 LDR  R0,  =VIC1ADDRESS
 STR  R1,  [R0] 
 
 LDMFD SP!, {R0,R1,LR}    ;R0,R1,LR出栈
 
 ;之前使用SUB,发现程序从中断退出后并没有从SPSR恢复,也就是中断屏蔽没有去除,添加-S后,这条指令会影响CPSR中标志位,在这也就是恢复了SPSR_IRQ到CRSP
 SUBS PC,  LR,  #4    ;从中断程序中退出,LR需要减4放入PC,子程序调用则不需要-4,应该是由于流水线的指令预取造成的

 END

相关内容