嵌入式:Flash的分类以及Jlink/J-flash的编程支持

相关阅读

嵌入式icon-default.png?t=O83Ahttps://blog.csdn.net/weixin_45791458/category_12768532.html?spm=1001.2014.3001.5482


        常见的Flash大致可以分为以下大类:

  • Serial Nor Flash
  • Serial Nand Flash
  • Parallel Nor Flash
  • Parallel Nand Flash
  • Serial EEPROM

Serial Nor Flash

介绍

        Serial Nor Flash是通过串行协议通信的Flash,一般这种串行协议指的是SPI协议(包括普通SPI、 Dual-SPI、Quad-SPI和QPI)。由于拥有Nor Flash的特点,它可以像RAM那样随机数据,这就为XiP(Execute-in-Place,即直接在Flash中读取指令执行)提供了可能,但这只是必要不充分条件,还有一个条件是需要将Flash的地址空间映射到处理器的地址空间,这样的话,当处理器发出指令地址读取指令时,Flash控制器可以将其接收到的地址(可能是某几位)直接作为Flash内的地址进行读取。这对于并行协议的Flash不是什么问题,因为它们有多位宽的地址线和数据线;但对于串行协议来说,这就要求Flash控制器将其接收到的地址转化为串行数据并发送,这需要额外的硬件设计,所以一般来说只有速度较快的Quad-SPI和QPI控制器会硬件支持。

编程

        如果Flash的地址空间被映射到了处理器的地址空间(例如Quad-SPI和QPI),就可以直接使用Jlink/J-flash进行Flash编程,只需要处理器执行芯片对应相应的编程算法即可(通过Flash控制器向Flash的地址空间写数据)。

        如果Flash的地址空间没有映射到处理器的地址空间(例如普通SPI、GPIO模拟的SPI),使用Jlink/J-flash进行Flash编程时需要将地址像数据一样,通过数据总线发送给Flash控制器,这需要特殊的编程算法。

        此外,可以使用J-flash SPI对Serial Nor Flash进行直接编程(无需CPU介入,甚至可以不需要CPU),但需要特殊的引脚连接。

Serial Nand Flash

介绍

        Serial NAND Flash是基于串行协议通信的NAND Flash,一般这种串行协议指的是SPI协议(包括普通SPI、 Dual-SPI、Quad-SPI和QPI)。与Serial NOR Flash不同,NAND Flash的主要特点是较大的存储容量和较低的成本,但随机访问性能较差,这是因为NAND Flash使用的是基于块的擦写操作,其数据读写往往需要先从块级别复制到页缓冲区,再进行数据传输。Serial Nand Flash不会将Flash的地址空间映射到处理器的地址空间,自然也就不支持XiP。

编程

        由于Flash的地址空间没有映射到处理器的地址空间,使用Jlink/J-flash进行Flash编程时需要将地址像数据一样,通过数据总线发送给Flash控制器,这需要特殊的编程算法。

        此外,可以使用J-flash SPI对Serial Nand Flash进行直接编程(无需CPU介入,甚至可以不需要CPU),但需要特殊的引脚连接。

Parallel Nor Flash

介绍

        Parallel NOR Flash是基于并行协议通信的NOR Flash,这种并行协议指的是可以是CFI(Common Flash Interface)或者其他协议。处理器的片上Flash一般就是这种,而有些处理器还会提供FSMC(静态存储器控制器)以连接片外的Parallel Nor Flash。由于拥有Nor Flash的特点,它可以像RAM那样随机访问数据,并且可以很方便地将Flash的地址空间映射到处理器的地址空间,所以XiP可以被很好地支持。顺带一提,由于Serial Nor Flash开始被广泛使用,它有成为Parallel Nor Flash的替代品甚至是后继者的趋势。

编程

        由于Flash的地址空间被映射到了处理器的地址空间,可以直接使用Jlink/J-flash进行Flash编程,只需要处理器执行芯片对应相应的编程算法即可(通过Flash控制器向Flash的地址空间写数据)。

Parallel Nand Flash

        Parallel NAND Flash是基于并行协议通信的NAND Flash,这种并行协议指的是可以是ONFI(Open NAND Flash Interface)或者其他协议。有些处理器会提供FSMC(静态存储器控制器)以连接片外的Parallel Nand Flash。与Parallel Nor Flash不同,NAND Flash的主要特点是较大的存储容量和较低的成本,但随机访问性能较差,这是因为NAND Flash使用的是基于块的擦写操作,其数据读写往往需要先从块级别复制到页缓冲区,再进行数据传输。Parallel Nand Flash不会将Flash的地址空间映射到处理器的地址空间,自然也就不支持XiP。

编程

        由于Flash的地址空间没有映射到处理器的地址空间,使用Jlink/J-flash进行Flash编程时需要将地址像数据一样,通过数据总线发送给Flash控制器,这需要特殊的编程算法。

Serial EEPROM

        Serial EEPROM是基于串行协议通信的EEPROM,一般这种串行协议指的是SPI协议或IIC协议。与Flash相比,EEPROM一般容量较小,最大只有几MB。Serial EEPROM不会将其地址空间映射到处理器的地址空间,自然也就不支持XiP。

编程

        由于Serial EEPROM的地址空间没有映射到处理器的地址空间,使用Jlink/J-flash进行Flash编程时需要将地址像数据一样,通过数据总线发送给Flash控制器,这需要特殊的编程算法。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux系统编程】第五十弹---构建高效单例模式线程池、详解线程安全与可重入性、解析死锁与避免策略,以及STL与智能指针的线程安全性探究

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、将日志加到线程池 1.1、Thread类 1.2、ThreadPool类 1.2.1、HandlerTask() 1.2.2、其他公有成员函数 1.3、主函数 2、…

基于SSM的作业批改系统+LW示例参考

1.项目介绍 功能模块:管理员(学生管理、教师管理、作业信息管理、作业提交管理、作业批改管理等)、学生(个人信息管理、作业提交、作业查看等)、教师(个人中心、作业创建、作业批改等)技术选型…

RabbitMQ高可用延迟消息惰性队列

目录 生产者确认 消息持久化 消费者确认 TTL延迟队列 TTL延迟消息 惰性队列 生产者确认 生产者确认就是:发送消息的人,要确保消息发送给了消息队列,分别是确保到了交换机,确保到了消息队列这两步。 1、在发送消息服务的ap…

嵌入式面试八股文(十)·RS485特性分析、CAN硬件同步和再同步遵从规则、SPI四种工作模式、错误帧基本概念

目录 1. 相较于传统的RS232接口,RS485的接口特性有哪些? 2. 在CAN接口协议中硬件同步和再同步需要遵从哪些规则? 3. 为什么位错误不能用于帧间隔? 4. SPI四种工作模式? 5. 关于错误帧,基本概念&a…

librdns一个开源DNS解析库

原文地址:librdns一个开源DNS解析库 – 无敌牛 欢迎参观我的个人博客:无敌牛 – 技术/著作/典籍/分享等 介绍 librdns是一个开源的异步多功能插件式的解析器,用于DNS解析。 源代码地址:GitHub - vstakhov/librdns: Asynchrono…

cookie反爬----普通服务器,阿里系

目录 一.常见COOKIE反爬 普通: 1. 简介 2. 加密原理 二.实战案例 1. 服务器响应cookie信息 1. 逆向目标 2. 逆向分析 2. 阿里系cookie逆向 1. 逆向目标 2. 逆向分析 实战: 无限debugger原理 1. Function("debugger").call() 2. …

大数据新视界 -- 大数据大厂之 Impala 性能优化:跨数据中心环境下的挑战与对策(上)(27 / 30)

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

width设置100vh但出现横向滚动条的问题

在去做flex左右固定,中间自适应宽度的布局时, 发现这样一个问题: 就是我明明是宽度占据整个视口, 但是却多出了横向的滚动条 效果是这样的 把width改成100%,就没有滚动条了 原因: body是有默认样式的, 会有一定的默认边距, 把默认边距清除就是正常的了 同时, 如果把高度设…

百度在下一盘大棋

这两天世界互联网大会在乌镇又召开了。 我看到一条新闻,今年世界互联网大会乌镇峰会发布“2024 年度中国互联网企业创新发展十大典型案例”,百度文心智能体平台入选。 这个智能体平台我最近也有所关注,接下来我就来讲讲它。 百度在下一盘大棋…

探索 RocketMQ:企业级消息中间件的选择与应用

一、关于RocketMQ RocketMQ 是一个高性能、高可靠、可扩展的分布式消息中间件,它是由阿里巴巴开发并贡献给 Apache 软件基金会的一个开源项目。RocketMQ 主要用于处理大规模、高吞吐量、低延迟的消息传递,它是一个轻量级的、功能强大的消息队列系统&…

Android 基于Camera2 API进行摄像机图像预览

前言 近期博主准备编写一个基于Android Camera2的图像采集并编码为h.264的应用,准备分为三个阶段来完成,第一阶段实现Camera2的摄像机预览,第二阶段完成基于MediaCodec H.264编码,第三阶段完成基于MediaCodec H.264解码,针对不同…

QT 线程 QThread QT5.12.3环境 C++实现

一、线程 QT主线程称为GUI线程,负责初始化界面并监听事件循环,并根据事件处理做出界面上的反馈。如果把一些比较复杂或者费时的操作放在主线程中,界面就会出现卡顿或者无响应的现象。一般主线程负责影响界面上的操作, 子线程负责负…

【LLM】一文学会SPPO

博客昵称:沈小农学编程 作者简介:一名在读硕士,定期更新相关算法面试题,欢迎关注小弟! PS:哈喽!各位CSDN的uu们,我是你的小弟沈小农,希望我的文章能帮助到你。欢迎大家在…

Vue3-后台管理系统

目录 一、完成项目历程 1、构建项目 2、项目的自定义选项 3、 封装组件 4、配置对应页面的路由 5、从后端调接口的方式 二、引入Element Plus、Echarts、国际化组件 1、Element Plus安装 2、Echarts安装 3、国际化 三、介绍项目以及展示 1、项目是基于Vue3、Element …

C0030.Clion中运行提示Process finished with exit code -1073741515 (0xC0000135)解决办法

1.错误提示 2.解决办法 添加环境变量完成之后,重启Clion软件,然后就可以正常调用由mingw编译的opencv库了。

【es6进阶】vue3中的数据劫持的最新实现方案的proxy的详解

vuejs中实现数据的劫持,v2中使用的是Object.defineProperty()来实现的,在大版本v3中彻底重写了这部分,使用了proxy这个数据代理的方式,来修复了v2中对数组和对象的劫持的遗留问题。 proxy是什么 Proxy 用于修改某些操作的默认行为&#xff0…

Python浪漫之画明亮的月亮

目录 1、效果展示 2、完整版代码 1、效果展示 2、完整版代码 import turtledef draw_moon():# 设置画布turtle.bgcolor("black") # 背景颜色为黑色turtle.speed(10) # 设置绘制速度# 绘制月亮的外圈turtle.penup()turtle.goto(0, -100) # 移动到起始…

《线性代数的本质》

之前收藏的一门课,刚好期末复习,顺便看一看哈哈 课程链接:【线性代数的本质】合集-转载于3Blue1Brown官方双语】 向量究竟是什么 线性代数中最基础、最根源的组成部分就是向量,需要先明白什么是向量 不同专业对向量的看法 物理专…

鸿蒙系统ubuntu开发环境搭建

在RISC-V等平台移植鸿蒙系统OpenHarmony,需要使用linux环境进行代码的编译,为兼顾日常办公需要,可采用WindowsUbuntu虚拟机的混合开发的环境,通过网络及文件夹共享,在主机和虚拟机之间共享文件数据。 工具准备&#x…

智能停车解决方案之停车场室内导航系统(二):核心技术与系统架构构建

hello~这里是维小帮,如有项目需求和技术交流欢迎大家私聊我们!点击文章最下方获取智慧停车场方案~撒花! 随着城市化进程的加速,停车难问题日益凸显。智能停车系统作为缓解停车压力的有效手段,其核心技术与架构的构建至…