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 树 ◆ 插入节点 ◆ 左旋 ◆ 右旋 ◆ 左右旋 ◆ 右左旋 ◆ 一般形式 ◆ 实际操作 ◆ 总结 四.红黑树 ◆ 概念 ◆ 示例 ◆ 对比 五.总结 一.引言 前面我们介绍了二叉树、二叉…...
MFC深入-MFC和win32
MFC和Win32 MFC Object和Windows Object的关系 MFC中最重要的封装是对Win32 API的封装,因此,理解Windows Object和MFC Object (C对象,一个C类的实例)之间的关系是理解MFC的关键之一。所谓Windows Object(Windows对象)是…...
【Prometheus】如何分析和解读 Prometheus 的日志信息以定位问题?
Prometheus 日志深度解读指南:从启动异常到 TSDB 损坏的全链路故障定位 用户问题原文:“如何分析和解读 Prometheus 的日志信息以定位问题?” 在支撑单集群500万+时间序列的生产环境中,Prometheus 的日志是 SRE 团队洞察系统内部状态的“黑匣子”。一次未被正确解读的日志警…...
经营分析≠财务分析,经营分析必看的3条路径分析
每个月开经营分析会,我最怕看到什么?就是财务把利润表从头到尾念了一遍,收入多少、成本多少、费用多少,然后开始读PPT。念完就散会。问题解决了吗?没有。说实话,我第一次看这种汇报也觉得数据很全ÿ…...
3分钟掌握AMD Ryzen调试神器:SMUDebugTool终极使用指南
3分钟掌握AMD Ryzen调试神器:SMUDebugTool终极使用指南 【免费下载链接】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…...
非傍轴效应在量子比特操控中的影响与优化策略
1. 非傍轴效应与量子比特操控:从理论到实验的全景解析在量子计算与模拟领域,光学镊子技术正经历着革命性的发展。这项技术通过高度聚焦的激光束,实现了对单个原子或离子的精确操控,为构建大规模量子处理器提供了可能路径。然而&am…...
DSP28335新手避坑指南:手把手教你用CCS6.2生成10KHz SPWM(附完整工程)
DSP28335实战:从零构建10KHz SPWM的完整工程指南 第一次接触DSP28335开发板时,面对复杂的寄存器配置和编译环境问题,很多工程师都会感到无从下手。本文将带你一步步完成从CCS工程创建到SPWM波形输出的全过程,特别针对新手容易遇到…...
5个关键步骤:在PC上部署高性能yuzu Switch模拟器
5个关键步骤:在PC上部署高性能yuzu Switch模拟器 【免费下载链接】yuzu 任天堂 Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/yu/yuzu yuzu是一款开源的任天堂Switch模拟器,让玩家能够在Windows、Linux和macOS系统上流畅运行Swi…...
检索增强生成(RAG)实战:Spring AI 集成向量数据库实现知识问答
系列导读 你现在看到的是《Spring AI 企业级集成与场景实践:从零搭建智能应用》的第 4/10 篇,当前这篇会重点解决:从零搭建一个可工作的 RAG 系统,解决 LLM 知识陈旧和幻觉问题。 上一篇回顾:第 3 篇《对话记忆与上下文管理:Spring AI 实现多轮会话与持久化存储》主要聚…...
告别Windows!手把手教你用Proxmox虚拟机零成本体验深度Deepin 20.6
在Proxmox虚拟环境中优雅体验Deepin:技术爱好者的零成本尝鲜指南 对于技术爱好者而言,尝试新操作系统总伴随着两难:既想深度体验系统特性,又担心影响现有工作环境。Proxmox VE作为开源的虚拟化平台,配合Deepin这一国产…...
Taotoken多模型聚合平台为arm7边缘AI应用提供稳定API服务
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Taotoken多模型聚合平台为arm7边缘AI应用提供稳定API服务 对于在arm7架构硬件上部署轻量级AI应用的开发者而言,将大模型…...
