【ARM裸机s5pv210 】芯片初始化

#define GPJ0CON        0xE0200240
#define GPJ0DAT        0xE0200244
#define WTCON        0xE2700000
#define SVC_STACK    0xd0037d80

.global _start
_start:

    // 第1步:关看门狗(向WTCON的bit5写入0即可)
    ldr r0, =WTCON
    ldr r1, =0x0
    str r1, [r0]
    
    // 第2步:设置SVC栈    满减栈,满的意思是入栈先移动指针再填入数据,减的意思是栈从高到低用
    ldr sp, =SVC_STACK
    
    // 第3步:开/关icache
    mrc p15,0,r0,c1,c0,0;            // 读出cp15的c1到r0中  mrc和mcr是协处理器的相关汇编指令
    //bic r0, r0, #(1<<12)            // bit12 置0  关icache
    orr r0, r0, #(1<<12)            // bit12 置1  开icache
    mcr p15,0,r0,c1,c0,0;


blink:
    ldr r0, =0x11111111        //所有引脚设置为输出模式对应的16进制数
    ldr r1, =GPJ0CON        //GPJ0CON  寄存器位置
    str r0, [r1]            //把r0中的数存到r1指向的地方
    
    ldr r0, =~(1<<3)        //3 位拉低,其他位拉高
    ldr r1, =GPJ0DAT        //GPJ0DAT 寄存器位置
    str r0, [r1]                //把r0中的数存到r1指向的地方
    
    bl delay
    
    ldr r0, =~(1<<4)        // 4位拉低,其他位拉高
    ldr r1, =GPJ0DAT        //GPJ0DAT 寄存器位置
    str r0, [r1]                //把r0中的数存到r1指向的地方
    
    bl delay
    
    ldr r0, =~(1<<5)        //5位拉低,其他位拉高
    ldr r1, =GPJ0DAT        //GPJ0DAT 寄存器位置
    str r0, [r1]                //把r0中的数存到r1指向的地方
    
    bl delay
    b blink

    
delay:
    ldr r2, =9000000
    ldr r3, =0x0
delay_loop:
    sub r2, r2, #1        //r2 = r2 -r1
    cmp r2, r3            //cmp影响Z标志位,如果r2等于r3,则Z=1,下一句中eq就会成立
    bne delay_loop      //如果Z等于0,则ne成立,该句执行
    
    mov pc, lr            //如果Z不等于0,则该句执行
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值