正点原子-IMX6ULL学习

本文详细解读了ARM Cortex-M0+处理器的启动文件,从全局标号开始,逐步解释了如何进入SVC模式,清除BSS段,设置栈指针以及跳转到主函数的过程。此外,还展示了链接文件的内存布局,特别是对BSS段的对齐要求和数据段的组织方式。
摘要由CSDN通过智能技术生成
启动文件
.global _start  		/* 全局标号 */

/*
 * 描述:	_start函数,程序从此函数开始执行,此函数主要功能是设置C
 *		 运行环境。
 */
_start:
	/* 进入SVC模式 */
	mrs r0, cpsr
	bic r0, r0, #0x1f 	/* 将r0寄存器中的低5位清零,也就是cpsr的M0~M4 	*/
	orr r0, r0, #0x13 	/* r0或上0x13,表示使用SVC模式					*/
	msr cpsr, r0		/* 将r0 的数据写入到cpsr_c中 					*/

	/*清除BSS段*/ 
	ldr r0,_bss_start
	ldr r1, _bss_end
	mov r2, #0
bss_Loop:
	stmia r0!,{r2}	/*比较R0和R1里面的值* /
	cmp r0, r1		/*如果r0地址小于等于r1,继续清除bss段*/
	ble bss_Loop
	
	/* 设置栈指针,
	 * 注意:IMX6UL的堆栈是向下增长的!
	 * 堆栈指针地址一定要是4字节地址对齐的!!!
	 * DDR范围:0X80000000~0X9FFFFFFF
	 */

	ldr sp,=0X80200000	/* 设置用户模式下的栈首地址为0X80200000,大小为2MB	  	   			*/
	b main				/* 跳转到main函数 										*/

链接文件
SECTIONS{
	. = 0X87800000;
	.text :
	{
		obj/start.o 
		*(.text)
	}
	.rodata ALIGN(4) : {*(.rodata*)}     
	.data ALIGN(4)   : { *(.data) }    

	/*
	由于IMX6ULL是32位SOC,在处理数据的时候都是4字节进行访问
	因此BSS段起始地址要是能被4整除的地址,如果不是的话会出现不能访问的现象。
	*/

	. = ALIGN(4);
	__bss_start = .;    
	.bss ALIGN(4)  : { *(.bss)  *(COMMON) }    
	__bss_end = .;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值