S3C2440启动代码解析:从Nor/Nand到SDRAM的转移

需积分: 10 0 下载量 7 浏览量 更新于2024-09-12 收藏 144KB PDF 举报
"这篇内容主要解析了S3C2440处理器的启动代码,包括了从nor或nand启动的判断以及程序如何被移动到SDRAM中执行,并且详细介绍了代码中的关键部分,如模式寄存器设置、异常模式堆栈配置以及ARM的工作状态和编译方式选择。" 在嵌入式系统设计中,处理器的启动代码至关重要,因为它决定了系统的初始配置和程序的加载流程。S3C2440是一款基于ARM920T内核的微处理器,广泛应用于嵌入式设备。本文将深入解析其启动代码`2440init.s`,了解它是如何使系统从上电到执行用户程序的。 首先,启动代码通常包含几个部分,比如初始化硬件、设置处理器模式、配置内存系统等。在这个例子中,我们看到`GET`命令用于引入一些配置文件,如`option.inc`、`memcfg.inc`和`2440addr.inc`,这些文件可能包含了系统配置的细节,如内存映射和选项设置。 接着,代码涉及到了SDRAM的初始化,SDRAM在启动过程中是存放操作系统和应用程序的主要存储区域。`BIT_SELFREFRESH`定义了SDRAM工作在自刷新模式,这是SDRAM的一种节能工作状态。在初始化阶段,SDRAM需要正确配置其控制信号,以确保数据的稳定存储和读取。 然后,代码中出现了对ARM处理器模式寄存器的定义,如`USERMODE`、`FIQMODE`等,这些是CPSR(Current Program Status Register)的一部分,决定了处理器运行在何种模式下。异常模式的堆栈地址也在这里进行了配置,这些堆栈用于保存异常发生时的处理器状态,以便于恢复。 此外,ARM处理器有两种工作状态:32位的ARM状态和16位的Thumb状态。这里的代码会根据处理器当前的工作模式来决定使用哪种编译方式。Thumb状态提供了更紧凑的指令集,适用于空间有限的应用场景,而ARM状态则提供更高的性能。 总结来说,S3C2440启动代码的主要任务是设置好硬件环境,确保SDRAM可用,并将程序加载到SDRAM中。通过对模式寄存器的配置和异常处理堆栈的设定,系统能正确响应各种中断和异常情况,最终跳转到主函数执行用户程序。理解这部分启动代码对于开发和调试嵌入式系统至关重要,因为它揭示了系统从零开始到正常运行的全过程。