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 树 ◆ 插入节点 ◆ 左旋 ◆ 右旋 ◆ 左右旋 ◆ 右左旋 ◆ 一般形式 ◆ 实际操作 ◆ 总结 四.红黑树 ◆ 概念 ◆ 示例 ◆ 对比 五.总结 一.引言 前面我们介绍了二叉树、二叉…...
Linux链表操作全解析
Linux C语言链表深度解析与实战技巧 一、链表基础概念与内核链表优势1.1 为什么使用链表?1.2 Linux 内核链表与用户态链表的区别 二、内核链表结构与宏解析常用宏/函数 三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势5.1 插入效率5.2 安全…...

docker详细操作--未完待续
docker介绍 docker官网: Docker:加速容器应用程序开发 harbor官网:Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台,用于将应用程序及其依赖项(如库、运行时环…...
【Linux】C语言执行shell指令
在C语言中执行Shell指令 在C语言中,有几种方法可以执行Shell指令: 1. 使用system()函数 这是最简单的方法,包含在stdlib.h头文件中: #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...

零基础设计模式——行为型模式 - 责任链模式
第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...
NPOI操作EXCEL文件 ——CAD C# 二次开发
缺点:dll.版本容易加载错误。CAD加载插件时,没有加载所有类库。插件运行过程中用到某个类库,会从CAD的安装目录找,找不到就报错了。 【方案2】让CAD在加载过程中把类库加载到内存 【方案3】是发现缺少了哪个库,就用插件程序加载进…...
【LeetCode】3309. 连接二进制表示可形成的最大数值(递归|回溯|位运算)
LeetCode 3309. 连接二进制表示可形成的最大数值(中等) 题目描述解题思路Java代码 题目描述 题目链接:LeetCode 3309. 连接二进制表示可形成的最大数值(中等) 给你一个长度为 3 的整数数组 nums。 现以某种顺序 连接…...

rknn toolkit2搭建和推理
安装Miniconda Miniconda - Anaconda Miniconda 选择一个 新的 版本 ,不用和RKNN的python版本保持一致 使用 ./xxx.sh进行安装 下面配置一下载源 # 清华大学源(最常用) conda config --add channels https://mirrors.tuna.tsinghua.edu.cn…...

算术操作符与类型转换:从基础到精通
目录 前言:从基础到实践——探索运算符与类型转换的奥秘 算术操作符超级详解 算术操作符:、-、*、/、% 赋值操作符:和复合赋值 单⽬操作符:、--、、- 前言:从基础到实践——探索运算符与类型转换的奥秘 在先前的文…...