嵌入式:Flash的分类以及Jlink/J-flash的编程支持
相关阅读
嵌入式
https://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控制器,这需要特殊的编程算法。
相关文章:
嵌入式:Flash的分类以及Jlink/J-flash的编程支持
相关阅读 嵌入式https://blog.csdn.net/weixin_45791458/category_12768532.html?spm1001.2014.3001.5482 常见的Flash大致可以分为以下大类: Serial Nor FlashSerial Nand FlashParallel Nor FlashParallel Nand FlashSerial EEPROM Serial Nor Flash 介绍 Se…...
【爬虫】Firecrawl对京东热卖网信息爬取(仅供学习)
项目地址 GitHub - mendableai/firecrawl: 🔥 Turn entire websites into LLM-ready markdown or structured data. Scrape, crawl and extract with a single API. Firecrawl更多是使用在LLM大模型知识库的构建,是大模型数据准备中的一环(在…...
遗传算法(Genetic Algorithm, GA)
简介 遗传算法(Genetic Algorithm, GA)是一种基于自然选择和遗传机制的优化算法,由 John Holland 于20世纪70年代提出。它是一种模拟生物进化过程的启发式搜索算法,被广泛应用于函数优化、机器学习、调度问题等领域。 代码说明 …...
【二分答案+倍增快速幂】课堂练习
P1678 烦恼的高考志愿 #include<bits/stdc.h> using namespace std; const int N1e55; int n,m,a[N];long long bs(int x){int l1,rn;while(l<r){int midlr>>1;if(a[mid]x) return 0;if(a[mid]>x) rmid-1;else lmid1;}//根据前驱后继返回最小差值//printf(&…...
LeetCode 力扣 热题 100道(九)反转链表(C++)
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 方法一:迭代法 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNod…...
Linux之网络基础
网络发展 网络的发展可以从人与人之间的工作模式开始谈起, 人与人的工作模式反应了机器与机器的工作模式: 1. 独立模式: 在网络发展的早期计算机间处于独立模式, 计算机之间相互独立 最开始计算机之间是独立运行的, 数据之间的交互需要人用软盘等存储介质拷贝过去, 一般涉及…...
Oracle收缩表空间的简单方法
在Oracle数据库中,收缩表空间是一种常见的维护操作,可以回收未使用的空间,减少表空间的碎片,提高性能。以下是一些步骤和方法: 1. 识别未使用的空间 首先,需要识别表空间中未使用的空间。可以通过查询 DB…...
C++设计模式行为模式———中介者模式
文章目录 一、引言二、中介者模式三、总结 一、引言 中介者模式是一种行为设计模式, 能让你减少对象之间混乱无序的依赖关系。 该模式会限制对象之间的直接交互, 迫使它们通过一个中介者对象进行合作。 中介者模式可以减少对象之间混乱无序的依赖关系&…...
YB2503HV:高效率降压IC,助力电动车、太阳能设备等领域的能源转换
今天我要向大家介绍一款引人注目的产品—— YB2503HV 100V 3A SOP8内置MOS 高效率降压IC。这款单片集成芯片具备可设定输出电流的开关型降压恒压驱动器功能,可广泛应用于电动车、太阳能设备、电子电池充电等领域。让我们一起来看看它的特点和应用吧! 首先…...
如何使用Jest测试你的React组件
在本文中,我们将了解如何使用Jest(Facebook 维护的一个测试框架)来测试我们的React组件。我们将首先了解如何在纯 JavaScript 函数上使用 Jest,然后再了解它提供的一些开箱即用的功能,这些功能专门用于使测试 React 应…...
微网能量管理研究
微网能量管理研究的重点 微网系统的建模 建立分布式能源单元模型以及微网系统的整体运行、协调控制和优化配置等方面的模型 分布式电源控制策略 微网内分布式电源及储能系统运行依赖于电力电子接口技术,需要相应的充放电控制策略 再生能源发电预测 准确预测太阳能…...
Java基础面试题02:简述什么是值传递和引用传递?
面试题:简述什么是值传递和引用传递? 什么是值传递? 值传递(pass by value)是指在调用函数时,把实际参数的值复制一份传递给函数。换句话说,函数内部对参数的任何修改,都不会影响到…...
【STL】10.set与map的模拟实现
一、源码及框架分析 SGI-STL30版本源代码,map和set的源代码在map/set/stl_map.h/stl_set.h/stl_tree.h等及个头文件中。 map和set的实现结构框架核心部分截取出来如下: // set #ifndef __SGI_STL_INTERNAL_TREE_H #include <stl_tree.h> #endif …...
Playwright(Java版) - 8: Playwright 元素交互的高级应用
在自动化测试中,处理复杂的页面交互是常见的需求。例如,应对动态加载的元素、处理弹窗与对话框、模拟拖放操作,甚至在绘图板上进行绘图操作。 1 动态元素与弹窗处理 1.1 动态元素的加载与等待 动态页面可能会导致元素在操作时尚未完全加载&…...
播放器开发之ffmpeg 硬件解码方案
硬件编解码的概念 硬件编解码是⾮CPU通过烧写运⾏视频加速功能对⾼清视频流进⾏编解码,其中⾮CPU可包括GPU、FPGA或者 ASIC等独⽴硬件模块,把CPU⾼使⽤率的视频解码⼯作从CPU⾥分离出来,降低CPU的使⽤负荷,使得平台能 ⾼效且流畅…...
n、nvm、nrm、pnpm、yarn各种指令大全
n mac的版本管理工具(可能与nvm冲突) 安装 # 使用 npm / yarn npm i -g n yarn global add n # 使用 brew brew install n环境变量 export PATH"/usr/local/n/versions/node:$PATH"命令详解 版本查看 # 查看 n 版本 n --version/-V # 查…...
数据库管理-根据日期字段进行数据筛选更新数据
项目场景 数据插入、更新、查询 数据库中一张审计表格用来记录数据的操作包括数据的id,数据名称sjmc,数据状态sjzt,数据创建时间createtime,数据更新时间updatetime。 具体需求如下: 根据数据名称更新sjzt和update…...
03. 运算符
一、运算符与表达式 运算符 就是对字面量或者变量进行操作的符号;表达式 是指用运算符把字面量或者变量连接起来,符合 Python 语法的式子。不同运算符连接的表达式体现的是不同类型的表达式;Python 中的运算符主要包括 算术运算符、赋值运算符…...
【最优清零方案——贪心+滑动窗口+线段树】
题目 代码 #include <bits/stdc.h> using namespace std; using ll long long; const int N 1e6 10; int a[N]; struct node {int l, r;int m, p, lazy; } tr[4 * N]; void pushup(node &u, node &l, node &r) {if (l.m r.m){u.m l.m;u.p max(l.p, r.…...
一个点绕任意点旋转后的点的坐标
在平面坐标上,任意点P(x1,y1),绕一个坐标点Q(x2,y2)逆时针旋转θ角度后,新的坐标设为(x, y)的计算公式: x (x1 - x2)*cos(θ) - (y1 - y2)*sin(θ) x2 ; y (x1 - x2)*sin(θ) (y1 - y2)*cos(θ) y2 ; 另一个场景应用,坐标轴绕…...
快速搭建stm32f103c8t6引脚验证原型:快马平台一键生成初始化代码
最近在做一个基于STM32的小项目时,发现每次新建工程都要重复配置引脚功能,特别浪费时间。后来发现用InsCode(快马)平台可以快速生成初始化代码,简直打开了新世界的大门。今天就来分享下如何用这个平台快速搭建STM32F103C8T6的引脚验证原型。 …...
为什么选择Zabbix而不是Prometheus?K8s监控工具深度对比与实战配置
Zabbix与Prometheus在Kubernetes监控中的技术决策指南 当企业级容器平台需要构建监控体系时,技术选型往往成为困扰架构师的核心难题。作为当下最主流的两个开源监控解决方案,Zabbix与Prometheus在Kubernetes生态中的表现各有千秋。本文将基于实际生产环境…...
AI辅助前端设计:让快马平台生成酷炫的滚动视差与3D交互效果代码
AI辅助前端设计:让快马平台生成酷炫的滚动视差与3D交互效果代码 最近在做一个科技公司的产品介绍页,想实现一些炫酷的交互效果来提升用户体验。传统方式需要手动编写大量CSS和JavaScript代码,调试起来也很耗时。不过现在有了AI辅助开发工具&…...
开源项目常见安装故障的系统性排查与解决
开源项目常见安装故障的系统性排查与解决 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various custom nodes of ComfyUI. Fur…...
Ryzen SDT调试工具:解锁AMD处理器潜能的系统级配置平台
Ryzen SDT调试工具:解锁AMD处理器潜能的系统级配置平台 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://g…...
三步打造个性化Windows任务栏:TranslucentTB效率工具完全指南
三步打造个性化Windows任务栏:TranslucentTB效率工具完全指南 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB 你是否曾觉得Wi…...
5块钱的国产RISC-V芯片CH32V103能干啥?我用它复刻了一个STM32F103的小项目
5元国产RISC-V芯片实战:用CH32V103复刻STM32经典项目 在电子DIY领域,成本始终是创客们无法回避的现实问题。当我在某电商平台发现CH32V103这颗标价仅5元的RISC-V芯片时,第一反应是怀疑它的实用性——毕竟同级别的STM32F103C8T6价格通常在15-2…...
忍者像素绘卷惊艳案例:生成支持CSS Sprite切片的像素角色动作序列图
忍者像素绘卷惊艳案例:生成支持CSS Sprite切片的像素角色动作序列图 1. 像素艺术的新纪元 在游戏开发领域,像素艺术始终保持着独特的魅力。忍者像素绘卷作为一款基于Z-Image-Turbo深度优化的图像生成工具,为开发者带来了革命性的解决方案。…...
C++的std--allocator_traits分配器特性与自定义内存管理的适配
C标准库中的内存管理一直是个既基础又复杂的主题。std::allocator_traits作为C11引入的分配器特性模板,为自定义内存管理提供了统一的适配接口,让开发者能在不重写整套分配逻辑的情况下,灵活扩展内存管理策略。无论是实现高性能内存池&#x…...
Cocos Creator实战:5步搞定棋牌游戏大厅场景开发(附完整代码)
Cocos Creator实战:5步构建高交互棋牌游戏大厅(附模块化代码) 棋牌游戏大厅作为玩家进入游戏的第一印象,其体验直接决定了用户留存率。根据行业数据,精心设计的大厅界面能提升30%以上的玩家次日留存。不同于传统游戏开…...
