S3C6410的启动代码分析nbsp;一

2024-08-22 19:18

本文主要是介绍S3C6410的启动代码分析nbsp;一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文开始第一篇,启动代码的编写,注意,仅仅是启动代码,并不是bootloader,因为只有boot,没有loader。

       第一要明确:CPU上电之后,会从某个固定地址执行指令。ARM结构的CPU从地址0x00000000开始执行指令,MIPS结构的CPU将会从0XBFC00000取第一条指令并执行。(注意,这个地址是CPU的统一编址,需要把存储器件ROM或者flash映射到这个地址上

       第二要知道启动代码需要做那些事情:

                1、异常向量表

                2、禁看门狗,禁中断

                3、设置系统时钟

                4、初始化存储控制器

                5、设置各个模式下的堆栈

                6、跳转到C环境执行

       第三,要知道CPU的七种工作模式:

                 用户模式:程序正常运行的模式,不能直接从用户模式切换到其他模式

                 系统模式:支持操作系统的特权任务,与用户模式类似,但是可以直接切换到其他模式

                 管理模式:供操作系统使用的保护模式,只有在系统复位和软中断响应后,才能进入该模式

                 终止模式:用于虚拟内存和存储器保护的模式,对程序存储器或数据存储器访问失败时,进入此模式

                 未定义模式:只有在未定义指令异常响应时,才进入该模式

                 中断模式:在IRQ(普通中断)响应时,进入该模式

                 快速中断模式:在FIQ(快速中断)响应时,进入该模式。

        以上做一个简要的前提知识介绍,仅仅了解这些还不够,请自行查阅相关资料。下面我们来实现一个简单的boot代码,不懂汇编的,赶快去学 :-(

                 ARM上电后,从地址0x00000000取指并执行,但是从地址0x00000000开始一直到0x0000001c,都是异常向量表的位置,不要问我为什么,因为硬件是这么做的 :-(

                       [0x00000000] b ResetHandler    ;--CPU上电即在0地址执行这句跳转代码

                       [0x00000004] b UndHandler      ;--CPU遇到未定义指令时,跳转到此地址执行

                       [0x00000008] b SWIHandler      ;--CPU遇到软中断时,跳转到此地址执行

                       [0x0000000c] b PaAbort            ;--CPU取指令出错时,跳转到此地址执行

                       [0x00000010] b DaAbort           ;--CPU取数据出错时,跳转到该地址执行

                       [0x00000014] b 0x00000014;   ;--该地址保留,啥叫保留,就是占个位子,不使用....能否省略,写下句代码?答案是不行!

                       [0x00000018] b IRQHandler     ;--CPU碰到中断时,跳转到该地址执行

                       [0x0000001c] b FIQHandler     ;--CPU碰到快速中断时,跳转到该地址执行。

       本文主要写管理模式的代码,其他模式暂时忽略,以后讨论。本文将点亮开发板上的LED4灯,其他三个LED是灭的。(我用的是OK6410的板子)

                        ResetHandler

                                                ldr r0,=WTCON    ;禁止看门狗

                                                ldr r1,=0x0

                                                str r1,[r0]

                                                

                                                ldr r0,=GPMCON    

                                                ;从地板原理图看出四个LED灯接在GPM接口,那么我们就控制GPMCON寄存器即可,此处把GPMCON的地址写入r0寄存器

                                                ldr r1,=0x111111     ;将数值0x111111

                                                str r1,[r0]                 ;向GPMCON寄存器中写入0x111111直,是的GPM口都作为数据输出口。

                                                ldr r0,=GPMDAT     ;将GPMDAT寄存器地址写入r0

                                                ldr r1,=~(1<<3)       ;向r1寄存器写入二进制 111值

                                                str r1,[r0]                ;向GPMDAT寄存器写入111值,此时可以看到开发板的LED4亮,其他三个LED是灭的

                                                b halt                      ;进入死循环

                        halt

                                                 b halt

                         以下这些代码都是CPU其他工作模式下的代码,本文仅仅是做了一个简单的死循环处理,以后会讨论各种模式的使用方法。

                         HandlerUndef

                                                b HandlerUndef

                         HandlerSWI

                                                b HandlerSWI

                         HandlerPabort

                                                 b HandlerPabort

                         HandlerDabort

                                                 b HandlerDabort

                         HandlerIRQ

                                                 b HandlerIRQ

                         HandlerFIQ

                                                 b HandlerFIQ

          注意,本文代码没有禁中断,没有设置各个模式的堆栈,没有初始化sdram,也没有跳转到C预言执行环境,仅仅是点亮了一盏led灯,是最简单的一个启动代码,在连接选项中要设置Robase 为0x0地址,映像文件入口地址为0x0,映像文件头为startup.o,section为Init。如下图:

             

               

              

              调试方法:使用J-link v8进行调试,首先你得买j-link,Ok6410不带这个仿真器。然后装好驱动Setup_JLinkARM_V410i.zip,按照S3C6410的JLink的调试方法.pdf这个文档配置好开发环境,期间会提示缺少jlinkarm.dll,直接从j-link安装文件夹里把这个文件拷贝过去即可,然后使用axd进行调试。

这篇关于S3C6410的启动代码分析nbsp;一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097155

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺