设为首页 加入收藏

TOP

OK6410汇编程序练习
2014-11-24 07:40:31 来源: 作者: 【 】 浏览:1
Tags: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


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇S3C6410裸机UART驱动(将printf重.. 下一篇S3C6410 裸机硬件JPEG解码

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Libevent C++ 高并发 (2025-12-26 00:49:30)
·C++ dll 设计接口时 (2025-12-26 00:49:28)
·透彻理解 C 语言指针 (2025-12-26 00:22:52)
·C语言指针详解 (经典 (2025-12-26 00:22:49)
·C 指针 | 菜鸟教程 (2025-12-26 00:22:46)