S5PV210开发之1.0.10------SD卡启动详解

2023-12-12 10:08

本文主要是介绍S5PV210开发之1.0.10------SD卡启动详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.外存设备
2.SD卡启动详解
3.SD卡启动实战

一、外存设备

1 :Flash:NandFlash、NorFlash
(1)NAND Flash一般地址线和数据线共用;而NOR Flash闪存数据线和地址线分开。
(2)大多数情况下闪存只是用来存储少量的代码,这时NOR闪存更适合一些。而NAND则是高数据存储密度的理想解决方案。
2 :SD卡、MMC卡、MicroSD、TF卡
(1)MMC在SD卡之前
(2)MicroSD = TF卡
3 :iNand、MoviNand、eSSD
4 :SSD(固态硬盘)
(1)固态硬盘体积小、读写速度快
(2)机械硬盘体积大、读写速度慢

二、SD卡介绍

(1)物理接口:SD卡由9个针脚与外界进行物理连接,这9个脚中有2个地,1个电源,6个信号线。
(2)SD协议与SPI协议(不同访问SD卡的时序)
(3)SD卡支持SPI协议:就是为了单片机方便使用。
(4)SD协议要求SoC中有SD控制器,运行在高速率下,要求SoC的主频不能太低。

三、SD卡启动详解

(1)启动过程:
210启动首先执行内部的iROM(也就是BL0),BL0会判断OMpin来决定从哪个设备启动,如果启动设备是SD卡,则BL0会从SD卡读取前16KB(不一定是16,反正16是工作的)到SRAM中去启动执行(这部分就是BL1,这就是steppingstone技术),

BL0执行时就是通过调用这些device copy function来读取外部SD卡/NandFlash中的BL1的。

(2)启动的第一种情况是整个镜像大小小于16KB。这时候相当于我的整个镜像作为BL1被steppingstone直接硬件加载执行了而已。
(3)启动的第二种情况就是整个镜像大小大于16KB。(只要大于16KB,哪怕是17KB,或者是700MB都是一样的)这时候就要把整个镜像分为2部分:第一部分16KB大小,第二部分是剩下的大小。然后第一部分作为BL1启动,负责去初始化DRAM并且将第二部分加载到DRAM中去执行(uboot就是这样做的)。
在这里插入图片描述

(4)Device Copy Function: CopySDMMCtoMem
这个内部函数可以将任何数据从 SD/MMC 设备复制到
内存。用户可以在 IROM 启动过程后使用此功能
完全。
在这里插入图片描述

外部源时钟参数用于适配 20MHz 的 EPLL 源时钟。
/**

  • 此功能将 MMC(MoviNAND/iNand) 卡数据复制到内存中。
  • 始终使用 EPLL 源时钟。
  • 此功能工作在 20Mhz。
  • @param u32 StartBlkAddress : 源卡(MoviNAND/iNand MMC)) 地址。(必须是块地址。)
  • @param u16 blockSize :要复制的块数。
  • @param u32* memoryPtr :要从中复制的缓冲区。
  • @param bool with_init : 确定卡初始化。
  • @return bool(u8) - 成功或失败。

四、SD卡启动实战

在这里插入图片描述
1.文件
在这里插入图片描述
BL1:
在这里插入图片描述
BL2:
在这里插入图片描述
从BL1开始分析:
start.S:


#define WTCON		0xE2700000
#define SVC_STACK	0xd0037d80.global _start					// 把_start链接属性改为外部,这样其他文件就可以看见_start了
_start:// 第0步:开发板置锁// 写法1//ldr r0, =0xE010E81C//ldr r1, =0x301//str r1, [r0]// 写法2//ldr r0, =0xE010E81C//ldr r1, [r0]//orr r1, r1, #0x300//orr r1, r1, #0x01//str r1, [r0]// 写法3ldr r0, =0xE010E81Cldr r1, [r0]ldr r2, =0x301orr r1, r1, r2str r1, [r0]// 第1步:关看门狗(向WTCON的bit5写入0即可)// 第2步:设置SVC栈// 第3步:开/关icache		//前三步代码省略// 第4步:初始化ddrbl sdram_asm_init	// 第5步:重定位,从SD卡第45扇区开始,复制32个扇区内容到DDR的0x23E00000bl copy_bl2_2_ddr
// 汇编最后的这个死循环不能丢b .

在这里插入图片描述
BL1是16KB,从BLOCK1~BLOCK32,共32个扇区
BL2假设是16KB,BLOCK45-BLOCK76,共32个扇区

copy_bl2_2_ddr

//在SRAM中执行,用的是iROM里面的Device Copy Function的CopySDMMCtoMem#define SD_START_BLOCK	45
#define SD_BLOCK_CNT	32
#define DDR_START_ADDR	0x23E00000typedef unsigned int bool;
typedef bool(*pCopySDMMC2Mem)(int, unsigned int, unsigned short, unsigned int*, bool);
typedef void (*pBL2Type)(void);// 从SD卡第45扇区开始,复制32个扇区内容到DDR的0x23E00000,然后跳转到23E00000去执行
void copy_bl2_2_ddr(void)
{// 第一步,读取SD卡扇区到DDR中pCopySDMMC2Mem p1 = (pCopySDMMC2Mem)(*(unsigned int *)0xD0037F98);//pCopySDMMC2Mem p1 = (pCopySDMMC2Mem)0xD0037F98);
// 通道号:0,或者2
// 开始扇区号:45
// 读取扇区个数:32
// 读取后放入内存地址:0x23E00000
// with_init:0p1(2, SD_START_BLOCK, SD_BLOCK_CNT, (unsigned int *)DDR_START_ADDR, 0);		// 读取SD卡到DDR中// 第二步,跳转到DDR中的BL2去执行pBL2Type p2 = (pBL2Type)DDR_START_ADDR;p2();
}

BL2:

//重定位:
SECTIONS
{. = 0x23E00000;.text : {start.o* (.text)}.data : {* (.data)}bss_start = .; .bss : {* (.bss)}bss_end  = .;	
}//start.S

五、函数指针复习

1.定义函数指针,指向改函数

void func(void)
{  printf("666\n");
}void (*pfunc)(void);
pfunc = func;

2.通过typedef

某函数:
char *(func)(char *a, char *b)
{printf("xxx\n");
}
则对应的函数指针为:
char *(*pfunc)(char *a, char *b)则,这个函数指针类型为:
char *(*)(char *, char *);	使用typedf改变类型:
typedef char *(*pFunc)(char *, char *);	
其中pFunc是自定义的类型名下次定义函数指针时,只需要pFunc p1;  //代替了char *(*p1)(char *, char *);pFunc p2;  //代替了char *(*p2)(char *, char *);	 pFunc p3;  //代替了char *(*p3)(char *, char *);

总结:
写函数指针时:
1.先在函数名称改为*pfunc
2.typedef直接添加在前面,则生成pfunc的类型名
调用函数指针时:
1.pfunc(参数/无参数);
2.(*pfunc)();

这篇关于S5PV210开发之1.0.10------SD卡启动详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/484223

相关文章

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录

python3 pip终端出现错误解决的方法详解

《python3pip终端出现错误解决的方法详解》这篇文章主要为大家详细介绍了python3pip如果在终端出现错误该如何解决,文中的示例方法讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下... 目录前言一、查看是否已安装pip二、查看是否添加至环境变量1.查看环境变量是http://www.cppcns

Go 语言中的 Struct Tag 的用法详解

《Go语言中的StructTag的用法详解》在Go语言中,结构体字段标签(StructTag)是一种用于给字段添加元信息(metadata)的机制,常用于序列化(如JSON、XML)、ORM映... 目录一、结构体标签的基本语法二、json:"token"的具体含义三、常见的标签格式变体四、使用示例五、使用

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Spring Cache注解@Cacheable的九个属性详解

《SpringCache注解@Cacheable的九个属性详解》在@Cacheable注解的使用中,共有9个属性供我们来使用,这9个属性分别是:value、cacheNames、key、key... 目录1.value/cacheNames 属性2.key属性3.keyGeneratjavascriptor

PyTorch中cdist和sum函数使用示例详解

《PyTorch中cdist和sum函数使用示例详解》torch.cdist是PyTorch中用于计算**两个张量之间的成对距离(pairwisedistance)**的函数,常用于点云处理、图神经网... 目录基本语法输出示例1. 简单的 2D 欧几里得距离2. 批量形式(3D Tensor)3. 使用不

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5