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

相关文章

一文详解kafka开启kerberos认证的完整步骤

《一文详解kafka开启kerberos认证的完整步骤》这篇文章主要为大家详细介绍了kafka开启kerberos认证的完整步骤,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、kerberos安装部署二、准备机器三、Kerberos Server 安装1、配置krb5.con

Python使用DeepSeek进行联网搜索功能详解

《Python使用DeepSeek进行联网搜索功能详解》Python作为一种非常流行的编程语言,结合DeepSeek这一高性能的深度学习工具包,可以方便地处理各种深度学习任务,本文将介绍一下如何使用P... 目录一、环境准备与依赖安装二、DeepSeek简介三、联网搜索与数据集准备四、实践示例:图像分类1.

StarRocks数据库详解(什么是StarRocks)

《StarRocks数据库详解(什么是StarRocks)》StarRocks是一个高性能的全场景MPP数据库,支持多种数据导入导出方式,包括Spark、Flink、Hadoop等,它采用分布式架构,... 目录StarRocks介绍什么是StarRocks?StarRocks适合什么场景?StarRock

Python中__new__()方法适应及注意事项详解

《Python中__new__()方法适应及注意事项详解》:本文主要介绍Python中__new__()方法适应及注意事项的相关资料,new()方法是Python中的一个特殊构造方法,用于在创建对... 目录前言基本用法返回值单例模式自定义对象创建注意事项总结前言new() 方法在 python 中是一个

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM

StarRocks索引详解(最新整理)

《StarRocks索引详解(最新整理)》StarRocks支持多种索引类型,包括主键索引、前缀索引、Bitmap索引和Bloomfilter索引,这些索引类型适用于不同场景,如唯一性约束、减少索引空... 目录1. 主键索引(Primary Key Index)2. 前缀索引(Prefix Index /

一文详解Nginx的强缓存和协商缓存

《一文详解Nginx的强缓存和协商缓存》这篇文章主要为大家详细介绍了Nginx中强缓存和协商缓存的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、强缓存(Strong Cache)1. 定义2. 响应头3. Nginx 配置示例4. 行为5. 适用场景二、协商缓存(协

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

C++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值