Nor Flash中的启动扇区(Boot Sector, Boot Block)

在Nor Flash中,有个启动扇区(Boot Sector,有时也被称为启动块)的概念,这个概念应该是只针对Nor Flash的,因为Nand Flash无法直接寻址,故Nand Flash中是没有Boot Sector的。

一个Nor Flash一般被分为若干块(Block)若干扇区(Sector),这应该只是不同厂家用的名字不同,并不存在一个Block中包含若干Sector的说法。这些扇区的大小一般并不相同,通常情况下会配置为大量大容量扇区加上少量小容量扇区的结构,这些小扇区就被称之为启动扇区。

这样设计是考虑到小容量扇区的擦写速度比较快,而且一般可以对其进行写保护,故可用其存放Bootloader及其他一些用户配置数据。实际上可以有多个小扇区,这些小扇区中具体哪一个是启动扇区,还是都是启动扇区,这一问题并没有明确的说法,也无需纠结于此。

根据启动扇区的地址不同,可分为两大类:Top Boot & Bottom Boot。Top Boot是指Boot Sector位于最高地址处;Bottom Boot是指Boot Sector位于最低地址处,一般同一型号的Nor Flash都会同时提供这两个版本,除了地址分配的差异外,其它的主要参数二者应该完全相同。

一张比较清晰的对比图如下:

下面以AMD公司的Am29LV160D为例来具体看看这个问题。

Am29LV160D可配置为2M 8-Bit或1M 16-Bit,这个是通过一个引脚电平来确定的,下面仅讨论1M * 16-Bit的配置。在此配置下,Am29LV160D被分为35个扇区:

  • 1个8Kword扇区
  • 2个4Kwork扇区
  • 1个16Kword扇区
  • 31个32Kword扇区

这些扇区中,前面那4个扇区就是Boot Sector。AMD公司同时提供了Top Boot和Bottom Boot两种芯片,见下图:

对于Top Boot的器件来说,其扇区分配如下:

可以看到,其中小容量扇区被安排到了最高地址处,即最后几个扇区。

对于Bottom Boot的器件来说,其扇区分配如下:

可以看到,其中小容量扇区被安排到了最低地址处,即最前几个扇区。


不过实际上,像U-Boot这类Bootloader的体积一般都会超过100KByte的,此时显然无法只用启动扇区保存,所以说这时候启动扇区就仅仅只是个名字,使用时也无需特别关注的。不过Top Boot和Bottom Boot器件的器件ID等可能会有所区别,使用时需要注意一下。



原文链接::

点击打开链接

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
U-Boot(Universal Bootloader)是一款开源的、通用的、模块化的嵌入式系统引导加载程序。它可以被用于各种嵌入式系统,如计算机主板、网络设备、无线设备等。 在U-Boot,对于Nor Flash的读写,主要是通过SPI接口进行的。下面是Nor Flash读写代码的走读: 1. 首先需要定义Nor Flash的设备结构体,其包括了Nor Flash的基本信息以及对应的读写函数指针。 ``` struct flash_info { char* name; /* 设备名称 */ unsigned long base; /* 设备物理地址 */ unsigned long size; /* 设备大小 */ unsigned long sector_size; /* 扇区大小 */ unsigned long block_size; /* 块大小 */ void (*erase)(unsigned long); /* 擦除函数指针 */ void (*write)(unsigned long, const uchar*, unsigned long); /* 写函数指针 */ uchar (*read)(unsigned long); /* 读函数指针 */ }; ``` 2. 在U-Boot的配置文件,需要定义Nor Flash的类型以及对应的设备结构体。 ``` #define CONFIG_SPI_FLASH_SST #define CONFIG_SPI_FLASH_WINBOND #define CONFIG_SPI_FLASH_MACRONIX #define CONFIG_SPI_FLASH_SPANSION #define CONFIG_SPI_FLASH_STMICRO #define CONFIG_SPI_FLASH_SST #define CONFIG_SPI_FLASH_ISSI #define CONFIG_SPI_FLASH_EON #define CONFIG_SPI_FLASH_GIGADEVICE #ifdef CONFIG_SPI_FLASH_SST #define CONFIG_FLASH_CFI_DRIVER #define CONFIG_SYS_MAX_FLASH_BANKS_DETECT 1 #define CONFIG_SYS_FLASH_CFI #define CONFIG_SYS_FLASH_PROTECTION #define CONFIG_SYS_FLASH_BASE 0x80000000 #define CONFIG_SYS_FLASH_EMPTY_INFO #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE #endif #ifdef CONFIG_SPI_FLASH_STMICRO #define CONFIG_FLASH_CFI_DRIVER #define CONFIG_SYS_MAX_FLASH_BANKS_DETECT 1 #define CONFIG_SYS_FLASH_CFI #define CONFIG_SYS_FLASH_PROTECTION #define CONFIG_SYS_FLASH_BASE 0x80000000 #define CONFIG_SYS_FLASH_EMPTY_INFO #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE #endif ``` 3. 在Nor Flash的驱动,需要实现读写、擦除等具体操作函数。 ``` static void spi_flash_cmd_write(struct spi_flash *flash, const void *buf, size_t size, uint32_t addr) { /* 发送写命令 */ spi_flash_cmd_write_enable(flash); spi_flash_cmd_addr(flash, addr, flash->cmd.write); spi_flash_cmd_buf(flash, buf, size); spi_flash_cmd_wait_ready(flash); } static void spi_flash_cmd_read(struct spi_flash *flash, void *buf, size_t size, uint32_t addr) { /* 发送读命令 */ spi_flash_cmd_addr(flash, addr, flash->cmd.read); spi_flash_cmd_buf(flash, NULL, size); spi_flash_cmd_read_data(flash, buf, size); } ``` 4. 在Nor Flash的驱动,还需要实现设备初始化、扇区擦除等操作。 ``` static int spi_flash_probe(struct spi_flash *flash) { /* 初始化设备 */ spi_flash_cmd_init(flash); /* 读取设备ID */ spi_flash_cmd_read_id(flash); /* 设置读写擦除函数指针 */ flash->write = spi_flash_cmd_write; flash->read = spi_flash_cmd_read; flash->erase = spi_flash_cmd_erase; return 0; } static int spi_flash_erase_sector(struct spi_flash *flash, uint32_t addr) { /* 发送擦除命令 */ spi_flash_cmd_write_enable(flash); spi_flash_cmd_addr(flash, addr, flash->cmd.erase); spi_flash_cmd_wait_ready(flash); return 0; } ``` 5. 在main函数,需要初始化SPI总线以及Nor Flash设备,并进行读写操作。 ``` int main(void) { /* 初始化SPI总线 */ spi_init(); /* 初始化Nor Flash设备 */ spi_flash_init(); /* 读取数据 */ spi_flash_read_data(FLASH_BASE_ADDR, buf, sizeof(buf)); /* 写入数据 */ spi_flash_write_data(FLASH_BASE_ADDR, buf, sizeof(buf)); /* 擦除扇区 */ spi_flash_erase_sector(FLASH_BASE_ADDR); return 0; } ``` 以上就是Nor Flash读写的主要代码走读。在实际应用,还需要根据具体的Nor Flash型号以及使用场景进行相应的优化和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值