00.ARM - 简介与寻址

一、简介:

大多数ARM芯片从0地址启动


        1、ARM默认小端模式(低字节保存在内存低地址中)。在32位处理器中,一条指令占4字节。CPU在执行当前地址 A 的指令的同时,已经在解析地址 A+4 的指令,而且在读取地址为 A+8 的指令。所以PC值=当前程序执行地址+ 8。即处理器执行完当前命令的2个时钟周期后,才执行当前PC中的指令。

        2、变量在内存中都有对应的存储。一个内存地址的存储空间是一个字节(8bit)。存储总大小根据变量类型决定。地址以Byte为单位进行空间分配的,32位就是4Byte。32位芯片里一个寄存器就必须占用4Byte的地址。

        3、Nor Flash 启动: 

            ①、Nor Flash 基地址为0。

            ②、CPU从Nor Flash 上读出指令执行。

            ③、内存(4K RAM)基地址为0x40000000。

            ④需要把全局变量和静态变量重定位到内存SDRAM里。

        4、Nand Flash 启动: 

            ①、硬件复制Nand Flash 前4K内容到片内SRAM。

            ②、从片内4K RAM开始运行,其基地址为0。

            ③、此状态下Nor Flash不可访问。

            ④、程序如果大于4K,则前4K的代码需要把整个程序读出来放到SDRAM(即代码重定位)。

        5、GPIO引脚(通用输入输出口)分为GPIO模式和功能口模式。GPIO模式是简单的拉高拉低,功能口则是通过协议传输数据。



二、ARM寻址方式(9种):

        1、寄存器寻址:sub r0, r1, r2。

        2、立即寻址:mov r0, #0xFF。

        3、寄存器移位寻址:mov r0, r1, lsl #3。

        4、寄存器间接寻址:ldr r0, [ r1 ]。

        5、基址寻址:ldr r0, [ r1, #0x4 ]。

        6、多寄存器寻址:stmia r0!, { r2-r7, r12 }。允许一条指令传送16个寄存器的任何子集或所有寄存器。

        7、堆栈寻址:堆栈指针寄存器指向堆栈(后进先出的)的栈顶。堆栈可分为两类:向上生长(往高地址延申)的递增堆栈、向下生长(往低地址延申)的递减堆栈。指针指向最后压入的有效数据项的满堆栈、指针指向下一个待压入数据的空位置的空堆栈。组合起来就是:

                满递增:堆栈向上增长,堆栈指针指向内含有效数据项的最高地址。如LDMFA、STMFA等。

                空递增:堆栈向上增长,堆栈指针指向堆栈上的第一个空位置。如LDMEA、STMEA等。

                满递减:堆栈向下增长,堆栈指针指向内含有效数据项的最低地址。如LDMFD、STMFD等。

                空递减:堆栈向下增长,堆栈指针向堆栈下的第一个空位置。如LDMED、STMED等。

        8、块拷贝寻址:stmia r0!, { r1-r7 }。多寄存器传送指令用于将一块数据从存储器的某一位置拷贝到另一位置。存储指针在保存第一个值之前增加,增长方向为向上增长。

        9、相对寻址:bl sub r1。beq loop。相对寻址是基址寻址的一种变通。由PC提供基址,用地址码作偏移量,两者相加即为操作数的有效地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容