RH850P1X芯片学习笔记-Flash Memory
文章目录
- Features
- Clock Supply
- Block Diagram
- Flash Size
- Memory Configuration
- Registers
- Register Base Address
- List of Registers
- Register Reset Condition
- 与Flash Memory相关的操作模式
- Functional Overview
- Option Bytes
- OPBT0 — Option Byte 0
- OPBT1 — Option Byte 1
- OPBT2 — Option Byte 2
- OPBT13 — Option Byte 13
- OPBT14 — Option Byte 14
- OPBT15 — Option Byte 15
Features
•代码flash容量:高达10兆字节的用户区域
编程方法:
- 通过串行接口与专用闪存编程器通信编程(串行编程)。
- 用户程序编程Flash(自编程)。
支持安全功能,以防止非法篡改或读取闪存中的数据。
支持保护功能,防止flash错误覆盖。
在Code Flash上支持OTP(一次性编程)
支持检测和纠正闪存中的错误。
支持BGO(后台操作)功能
- Code flash可以读取,而data flash正在编程。
- 当一个bank的flash被擦除/编程/读取时,另一个bank的flash可以被擦除/编程/读取。
Option Bytes寄存器值(设备的某些设置)可以在flash的扩展区域中配置
Code Flash上的最小可写单元是256bytes,Data Flash上的最小可写单元是4bytes
最小的可擦除单位是块。在Code Flash上8 kb或32 kb,在数据Flash上64bytes。
Clock Supply
下表列出了Flash控制逻辑(FACI)的时钟供应。

Block Diagram

Flash Size

Memory Configuration
RH850/P1x-C代码闪存中的用户区分为8kbytes或32kbytes块,可单独擦除


RH850/P1x-C数据闪存中的数据区被划分为64字节的块,可以单独擦除。

Registers
Register Base Address

List of Registers

Register Reset Condition

与Flash Memory相关的操作模式

可编程和可擦除的flash区域以及复位后的启动程序取决于所选模式。模式之间的差异如表32.6所示

Functional Overview
RH850/P1x-C的片上闪存可以在安装到目标系统之前和之后进行编程,其编程功能采用专用的闪存编程器(串行编程)。
此外,还支持禁止在片上闪存中编写用户程序的安全功能,以防止程序被外部人员伪造
使用用户程序的编程功能(自编程)是适用于预期在目标系统的生产或装运之后修改程序的应用的方法。还支持对闪存区域进行安全编程的保护功能。
此外,通过在自编程期间利用对中断处理的支持,可以在各种条件下进行编程,例如与外部通信并行。
表32.7概述了编程方法和相应的操作模式。
Option Bytes
flash memory具有扩展区域(可选字节)来存储用户为各种目的指定的数据。设置的更改,例如使用选项字节的外设功能的初始设置,在从复位状态释放后生效。
OPBT0 — Option Byte 0

OPWDRUN0:该位启用或禁用WDTA0的自动启动。
0:禁用WDTA0自动启动。
1:启用WDTA0自动启动
OPWDOFV2 to OPWDOFV0:这些位选择WDTA0、WDTA1的溢出时间

OPWD0MD:该位选择WDTA0、WDTA1的模式
0:慢速模式(WDTACLKI = 1/32 of CLK_IOSC)
1:快速模式(WDTACLKI = CLK_IOSC的1/1)
OPWDVAC:选择WDTA0、WDTA1变量启动代码)
该位指定触发寄存器,用于生成计数器重启触发器以避免计数器溢出。
0: WDTAnWDTE(固定)
1: WDTAnEVAC(变量)
注意:有关WDTA启动选项的详细信息,请参见第23节,窗口看门狗定时器A (WDTA)。
OPWDRUN1:该位启用或禁用WDTA1的自动启动(P1M-C除外)。
[p1h-c (4mb), p1h-c (8mb), p1h-ce]
0:关闭WDTA1自动启动。
1:启用WDTA1自动启动。
(P1M-C)
1:写值必须为1。
ETHDISABLE:以太网控制
0:表示以太网模块未启用。
1:以太网模块使能。
OPAUDR:选择AUD RAM监视器启用/禁用(仅限P1H-CE)
(P1H-CE)
0:禁用AUDR
1:启用AUDR
[P1M-C, P1H-C]
1:写值必须为1。
OPBT1 — Option Byte 1
OPBT1与时钟频率相关,如下图所示



PLL0FREQ:CLKD0DIV和CLKD1DIV的分频器配置以及SWDT时钟分频器。
位必须根据锁相环频率设置(由PLL0MDIVPLL0NDIV和PLL0PDIV设置)和所需的最大值。CPU频率(CLK_CPU)。
[P1M-C, P1H-CE]
00: PLL0 = 480MHz, CLK_CPU = 120MHz
01: PLL0 = 320MHz, CLK_CPU = 160MHz
10: PLL0 = 480MHz, CLK_CPU = 240MHz
11:禁止设置
(P1H-C)
00:禁止设置
01: PLL0 = 320MHz, CLK_CPU = 160MHz
10: PLL0 = 480MHz, CLK_CPU = 240MHz
11:禁止设置
一般设置为10b,即PLL0设置为480MHz,CLK_CPU设置为240MHz
EXCLKIN:选择外部时钟代替MOSC
0:选择外部时钟输入
1:选择晶振
一般设置为1
PLL0MDIV:PLL0 m分压器设置
001: 1/2 (mr = 2)
010: 1/3 (mr = 3)
other:禁止设置
一般设置为001
PLL0NDIV:PLL0 n分频器设置
0001_1111: 1/32 (nr = 32)
0010_0111: 1/40 (nr = 40)
0010_1111: 1/48 (nr = 48)
0011_1011: 1/60 (nr = 60)
other:禁止设置
一般设置为0011_1011
PLL0PDIV:PLL0 P分频器设置
000: 1/1 (pr = 1)
001: 1/2 (pr = 2)
other:禁止设置
一般设置为0
OPBT2 — Option Byte 2

OPJTAG1,OPJTAG0:选择调试接口
OPBT13 — Option Byte 13

CVMHDETEN:CVM过压检测控制,1使能
CVMLDETEN:CVM欠压检测控制,1使能
OPBT14 — Option Byte 14

EMF:仿真模式选择,只有P1H-CE可以用,P1M-C,P1H-C都需要写1
PE2PB:PE2校验位是否启用,1启用

RD_SEL:阻尼电阻配置
PE2DIS:是否使能PE2,0使能

STARTUPPE:选择Start up PE使能控制
OPBT15 — Option Byte 15

CAP_SEL:主OSC电容配置
AMP_SEL:主OSC AMP配置
相关文章:
RH850P1X芯片学习笔记-Flash Memory
文章目录 FeaturesClock Supply Block DiagramFlash SizeMemory ConfigurationRegistersRegister Base AddressList of RegistersRegister Reset Condition 与Flash Memory相关的操作模式Functional OverviewOption BytesOPBT0 — Option Byte 0OPBT1 — Option Byte 1OPBT2 —…...
利用XSS漏洞打cookie
目录 1、为什么要打cookie? 2、怎样利用XSS来打cookie? 3、利用Bluelotus_xssReceiver平台来打cookie 4、利用beef-xss平台来打cookie 上一篇给大家介绍了xss漏洞的基础知识,在本篇章将会介绍和演示一下利用xss漏洞打cookie的演示&#x…...
用java写个redis工具类
下面是一个简单的Redis工具类的示例,使用Java语言编写: import redis.clients.jedis.Jedis;public class RedisUtils {private static Jedis jedis;public static void connect(String host, int port) {jedis new Jedis(host, port);}public static v…...
实现防抖函数
// 防抖就是,事件触发 delay 秒后再执行,如果有重新的触发,重新计时 function debounce(func, delay) {if(typeof func ! function) {return}let timer 0return function () {if (timer) {clearTimeout(timer)timer null}timer setTimeout…...
MetaGPT task1学习
基础知识学习了解: 安装环境: 获取MetaGPT 使用pip获取MetaGPT pip install -i https://pypi.tuna.tsinghua.edu.cn/simple metagpt0.5.2 配置MetaGPT 完成MetaGPT后,我们还需要完成一些配置才能开始使用这个强力的框架,包括配…...
关于量子计算机的设想
从CPU架构说起 CISCRISCNISCCCSC CISC是复杂指令集计算机,以x86为代表; RISC是精简指令集计算机,以ARM为代表; NISC是无指令集计算机,CCSC是核-电路分离计算机,这两个是本文要讨论的内容。 如果没有指令…...
序列模型(4)—— Scaling Laws
本文介绍 LLM 训练过程中重要的 Scaling Laws,这是一个经验规律,指出了固定训练成本(总计算量FLOPs) C C C 时,如何调配模型规模(参数量) N N N 和训练 Token 数据量 D D D,才能实现…...
【软件测试学习笔记1】测试基础
1.软件测试的定义 软件的定义:控制计算机硬件工作的工具 软件的基本组成:页面客户端,代码服务器,数据服务器 软件产生的过程:需求产生(产品经理),需求文档,设计效果图…...
pytorch详细探索各种cnn卷积神经网络
目录 torch.nn.functional子模块详解 conv1d 用法和用途 使用技巧 适用领域 参数 注意事项 示例代码 conv2d 用法和用途 使用技巧 适用领域 参数 注意事项 示例代码 conv3d 用法和用途 使用技巧 适用领域 参数 注意事项 示例代码 conv_transpose1d 用法…...
OpenCV——八邻域断点检测
目录 一、理论基础1、八邻域2、断点检测 二、代码实现三、结果展示四、参考链接 OpenCV——八邻域断点检测由CSDN点云侠原创,爬虫自重。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、理论基础 1、八邻域 图1 八邻域示意图 图…...
leetcode238:除自身以外数组的乘积
文章目录 1.使用除法(违背题意)2.左右乘积列表3.空间复杂度为O(1)的方法 在leetcode上刷到了这一题,一开始并没有想到好的解题思路,写篇博客再来梳理一下吧。 题目要求: 不使用除法在O(n)时间复杂度内 1.使用除法&am…...
VTK开发调试环境下载(VTK开发环境一步到位直接开发,无需自己配置编译 VS2017+Qt5.12.10+VTK)
一、无与伦比的优势 直接下载代码就可以调试的VTK代码仓库。 二、资源制作原理 这个资源根据VTK源码 编译出动态库文件 pdb lib dll 文件( x64 debug ) 并将这两者同时放在一个代码仓库里,下载就能用。 三、使用方法(vtk-so…...
【JAVA】在 Queue 中 poll()和 remove()有什么区别
🍎个人博客:个人主页 🏆个人专栏:JAVA ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 poll() 方法: remove() 方法: 区别总结: 结语 我的其他博客 前言 在Java的Queue接口中&…...
常用Java代码-Java中的Optional类和null安全编程
在Java中,Optional 是一个可以为null的容器对象。如果值存在则isPresent()方法返回true。调用get()方法会返回值,如果值为null则抛出NullPointerException。以下是一个详细的代码详解。 在之前的Java版本中,程序员需要手动检查是否为null&am…...
android.os.NetworkOnMainThreadException
问题 android.os.NetworkOnMainThreadException详细问题 核心代码如下: import android.os.Bundle;import androidx.appcompat.app.AppCompatActivity;import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import ja…...
Java生成四位数随机验证码
引言: 我们生活中登录的时候都要输入验证码,这些验证码是为了增加注册或者登录难度,减少被人用脚本疯狂登录注册导致的一系列危害,减少数据库的一些压力。 毕竟那些用脚本生成的账号都是垃圾账号 本次实践:生成这样的…...
编程探秘:Python深渊之旅-----数据可视化(八)
客户提出了对数据报告和图表的具体要求,这使得团队需要快速掌握数据可视化的技巧。派超决定深入了解 Python 中的数据可视化工具。 派超(兴奋地):我们有机会做些真正酷炫的数据报告了!我听说 Python 有很棒的图表库。…...
上海亚商投顾:创业板指冲高回落 光伏、航运股逆势走强
上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 一.市场情绪 沪指1月12日冲高回落,创业板指午后跌近1%。北证50指数跌超6%,倍益康、华信永道、众诚科…...
Python3 中常用字符串函数介绍
介绍 Python 中有几个与 字符串数据类型相关的内置函数。这些函数让我们能够轻松修改和操作字符串。我们可以将函数视为在代码元素上执行的操作。内置函数是在 Python 编程语言中定义的,并且可以随时供我们使用的函数。 在本教程中,我们将介绍在 Pytho…...
Python - 深夜数据结构与算法之 AVL 树 红黑树
目录 一.引言 二.高级树的简介 1.树 2.二叉树 3.二叉搜索树 4.平衡二叉树 三.AVL 树 ◆ 插入节点 ◆ 左旋 ◆ 右旋 ◆ 左右旋 ◆ 右左旋 ◆ 一般形式 ◆ 实际操作 ◆ 总结 四.红黑树 ◆ 概念 ◆ 示例 ◆ 对比 五.总结 一.引言 前面我们介绍了二叉树、二叉…...
网络六边形受到攻击
大家读完觉得有帮助记得关注和点赞!!! 抽象 现代智能交通系统 (ITS) 的一个关键要求是能够以安全、可靠和匿名的方式从互联车辆和移动设备收集地理参考数据。Nexagon 协议建立在 IETF 定位器/ID 分离协议 (…...
2025年能源电力系统与流体力学国际会议 (EPSFD 2025)
2025年能源电力系统与流体力学国际会议(EPSFD 2025)将于本年度在美丽的杭州盛大召开。作为全球能源、电力系统以及流体力学领域的顶级盛会,EPSFD 2025旨在为来自世界各地的科学家、工程师和研究人员提供一个展示最新研究成果、分享实践经验及…...
如何在看板中体现优先级变化
在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序
一、开发准备 环境搭建: 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 项目创建: File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...
Java - Mysql数据类型对应
Mysql数据类型java数据类型备注整型INT/INTEGERint / java.lang.Integer–BIGINTlong/java.lang.Long–––浮点型FLOATfloat/java.lang.FloatDOUBLEdouble/java.lang.Double–DECIMAL/NUMERICjava.math.BigDecimal字符串型CHARjava.lang.String固定长度字符串VARCHARjava.lang…...
前端开发面试题总结-JavaScript篇(一)
文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包(Closure)?闭包有什么应用场景和潜在问题?2.解释 JavaScript 的作用域链(Scope Chain) 二、原型与继承3.原型链是什么?如何实现继承&a…...
如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”
目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...
Springboot社区养老保险系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,社区养老保险系统小程序被用户普遍使用,为方…...
CSS设置元素的宽度根据其内容自动调整
width: fit-content 是 CSS 中的一个属性值,用于设置元素的宽度根据其内容自动调整,确保宽度刚好容纳内容而不会超出。 效果对比 默认情况(width: auto): 块级元素(如 <div>)会占满父容器…...
