手把手一起开发SV4E-I3C设备(四)

JEDEC DDR5 SPD Hub Devices例程

所有例程,SV4E-I3C设备连接器件均为SPD5芯片,Reg表示MR寄存器,Mem表示NVM存储器

1、ENEC CCC

ENEC 启用事件中断,ENEC CCC 仅在设备置于 I3C 基本模式后才受支持。当 SPD5 注册 ENEC CCC 时,更新MR27[4]为1

在这里插入图片描述
图片源自《JESD300-5B》

ENINT=1时,使能IBI中断

status = sidebandBusController.doBroadcastWrite('ENEC',cccDefiningBytes=[0x01])
if status == True:pass
else:svt.printMsg('ENEC CCC FAIL', 'red')return False

2、DISEC CCC

DISEC 禁用带内中断,只有在器件进入 I3C 基本模式后才支持 DISEC CCC。当 SPD5 注册 DISEC CCC 时,更新MR27[4]为0

在这里插入图片描述
图片源自《JESD300-5B》

DISINT=1时,禁用IBI中断

status = sidebandBusController.doBroadcastWrite('DISEC',cccDefiningBytes=[0x01])
if status == True:pass
else:svt.printMsg('DISEC CCC FAIL', 'red')return False

3、RSTDAA CCC

RSTDAA 将设备置于 I2C 模式,只有在器件进入 I3C 基本模式后才支持 RSDAA CCC。 当 SPD5 注册 RSDAA CCC 时,它会更新MR18[5]为0

status = sidebandBusController.doBroadcastWrite('RSTDAA')
if status == True:pass
else:svt.printMsg('RSTDAA CCC FAIL', 'red')return False

4、SETASSA CCC

SETASSA 将设备置于 I3C 模式,仅当设备处于 I2C 模式时才支持 SETAASA CCC。在 I2C 模式下,当发出这个 CCC 时,为了保证这个 CCC 被设备正确注册,主机应该限制这个 CCC 的最大运行速度为 1 MHz。当 SPD5 注册 RSDAA CCC 时,它会更新MR18[5]为1

sidebandBusController.enableLowBitRateMode()
status = sidebandBusController.doBroadcastWrite('SETAASA')
if status == True:pass
else:svt.printMsg('SETAASA CCC FAIL', 'red')return False
sidebandBusController.disableLowBitRateMode()

5、GETSTATUS CCC

I3C 基本模式支持 GETSTATUS CCC

在这里插入图片描述
图片源自《JESD300-5B》

PEC_Err:0表示没有Error,1表示发生 PEC Error
P_Err:0表示没有Error,1表示发生Parity Error
Pending Interrupt:0000表示没有挂起的中断,0001表示有挂起的中断

实现方式一:

bytesFromTarget = sidebandBusController.doDirectRead('GETSTATUS', 'DIMM0-SPD')
msByte = bytesFromTarget[0]
lsByte = bytesFromTarget[1]
pecErr = bool(msByte & 128)
protocolErr = bool(lsByte & 32)
pendingInterrupt = lsByte & 4369
if pecErr == 0x00:pass
else:svt.printMsg('pecErr_verify FAIL', 'red')return False
if protocolErr == 0x01:pass
else:svt.printMsg('protocolErr_verify FAIL', 'red')return False
if pendingInterrupt == 0x01:pass
else:svt.printMsg('pendingInterrupt_verify FAIL', 'red')return False

实现方式二:

statusTuple = sidebandBusController.getTargetStatus('DIMM0-SPD')
if statusTuple is not None:(pecErr, protocolErr, pendingInterrupt) = statusTupleif pecErr == 0x00:passelse:svt.printMsg('pecErr_verify FAIL', 'red')return Falseif protocolErr == 0x01:passelse:svt.printMsg('protocolErr_verify FAIL', 'red')return Falseif pendingInterrupt == 0x01:passelse:svt.printMsg('pendingInterrupt_verify FAIL', 'red')return False

6、DEVCAP CCC

只有在设备进入 I3C 基本模式后才支持 DEVCAP CCC

在这里插入图片描述
图片源自《JESD300-5B》

在这里插入图片描述
图片源自《JESD300-5B》

实现方式一:

bytesFromTarget = sidebandBusController.doDirectRead('DEVCAPS', 'DIMM0-SPD')
if bytesFromTarget[0] == 0x04:pass
else:svt.printMsg('MSB_verify FAIL', 'red')return False
if bytesFromTarget[1] == 0x00:pass
else:svt.printMsg('LSB_verify FAIL', 'red')return False

实现方式二:

devCapTuple = sidebandBusController.getTargetDevCaps('DIMM0-SPD')
if devCapTuple is not None:(getbcr, getdcr, setmrl, setmwl, getpid, tReset) = devCapTupleif tReset == True:passelse:svt.printMsg('tReset_verify FAIL', 'red')return False

7、SETHID CCC

仅当设备处于 I2C 模式时才支持 SETHID CCC。在 SPD5 注册SETHID CCC 时,它会停止 3 位 HID 转换

在这里插入图片描述
图片源自《JESD300-5B》

status = sidebandBusController.doBroadcastWrite('SETHID', cccDefiningBytes=[0x00])
if status == True:pass
else:svt.printMsg('SETHID CCC FAIL', 'red')return False

8、DEVCTRL CCC

在典型的 I3C 基本总线上,最多可以有 120 个设备。 对于 DDR5 DIMM 应用环境,最多有 8 个 SPD5 Hub 设备,每个 SPD5 Hub 设备后面有 4 个本地 Target 设备,I3C Basic 总线上总共有 40 个或更多设备。 对于某些操作,例如启用或禁用所有设备通用的功能(即数据包错误检查),主机必须一次通过一个设备,这在初始上电时会花费大量时间。 此外,它需要主机上的额外复杂性,因为它必须根据访问设备的方式使用不同的协议,直到所有设备都配置相同

为帮助加快此配置操作并简化主机复杂性,该器件支持 DEVCTRL CCC。 DEVCTRL CCC 在 I2C 模式或 I3C 基本操作模式下均受支持

在这里插入图片描述
图片源自《JESD300-5B》

Broadcast 使能PEC,实现方式一:

status = sidebandBusController.sendDevCtrl(pecEnabled=1)
if status == True:pass
else:svt.printMsg('sendDevCtrl FAIL', 'red')return False

Broadcast 使能PEC,实现方式二:

sidebandBusController.doBroadcastWrite('DEVCTRL', msgBytes=[0xE0,0x00,0x80])
if status == True:pass
else:svt.printMsg('DEVCTRL CCC FAIL', 'red')return False

Multicast 使能PEC:

sidebandBusController.doBroadcastWrite('DEVCTRL', msgBytes=[0x60,0xA0,0x80])
if status == True:pass
else:svt.printMsg('DEVCTRL CCC FAIL', 'red')return False

Unicast 使能PEC:

sidebandBusController.doBroadcastWrite('DEVCTRL', msgBytes=[0x00,0xA0,0x80])
if status == True:pass
else:svt.printMsg('DEVCTRL CCC FAIL', 'red')return False

Unicast RegMod = 1 I2C模式写MR28-MR35

sidebandBusController.doBroadcastWrite('DEVCTRL', msgBytes=[0x01, 0xA0, 0x1C, 0x1F, 0xFC, 0x1F, 0xFC, 0x1F, 0xFC, 0x1F, 0xFC])
if status == True:pass
else:svt.printMsg('DEVCTRL CCC FAIL', 'red')return False

Unicast RegMod = 1 I3C模式写MR28-MR35

sidebandBusController.doBroadcastWrite('DEVCTRL', msgBytes=[0x01, 0xA0, 0x1C, 0x00, 0x1F, 0xFC, 0x1F, 0xFC, 0x1F, 0xFC, 0x1F, 0xFC])
if status == True:pass
else:svt.printMsg('DEVCTRL CCC FAIL', 'red')return False

本博文暂时分享到这里,后续博文将继续为大家呈现JEDEC DDR5 SPD Hub Devices例程

希望本文对大家有帮助,上文若有不妥之处,欢迎指正

分享决定高度,学习拉开差距

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何删除github中已经被追踪的文件

以.idea目录为例,如果在添加.gitignore规则之前已经将.idea目录或其下的某些文件添加到了版本控制中,那么这些文件将会被追踪,即使后来添加了.gitignore规则,它们仍然会出现在Changes中。您需要先将这些文件从版本控制中移除,然后再次提交。可以使用以下命令将已追踪的文件…

AcWing算法基础课——简单数据结构模板

说明 本篇文章只给出代码模板,以及自己对该模板的理解。如果想看正确的算法思路,可以移步AcWing官网看详情。链接:常用代码模板2——数据结构 - AcWing 如有错误,欢迎大家批评指正。 简单数据结构模板 一、链表 1.1 数组模拟单…

【CSS面试题】高度塌陷问题及解决

什么情况下产生 (when 父盒子没有定义高度&#xff0c;但是子元素有高度&#xff0c;希望用子盒子撑起父盒子的高度&#xff0c;但是子盒子添加了浮动属性之后&#xff0c;父盒子高度为0 <template><div class"father"><div class"son"&…

pyqt QPlainTextEdit 中捕获回车

pyqt QPlainTextEdit 中捕获回车 在PyQt的QPlainTextEdit控件中&#xff0c;可以通过重写keyPressEvent()函数来捕获键盘事件。当按下回车键时&#xff0c;会发送一个Key_Return信号&#xff0c;我们可以连接这个信号到自定义的槽函数上进行处理。 以下是示例代码&#xff1a;…

Java 继承与多态

一、继承 在Java中&#xff0c;继承是一种重要的面向对象编程概念&#xff0c;它允许一个类&#xff08;称为子类或派生类&#xff09;继承另一个类&#xff08;称为父类或基类&#xff09;的属性和方法。这意味着子类可以使用父类的成员变量和方法&#xff0c;并且可以添加自…

算法第二十六天-删除有序数组中的重复项Ⅱ

删除有序数组中的重复项 题目要求 解题思路 题目要求中提到原地修改&#xff0c;那么肯定需要一个指针指向当前即将放置元素的位置&#xff0c;需要另外一个指针向后遍历所有元素&#xff0c;所以[双指针]解法呼之欲出。 慢指针slow&#xff1a;指向当前元素放置的位置&…

F - Earn to Advance

解题思路 由于对于一点不知道后面得花费&#xff0c;所以无法决策当前是否要停下赚钱或要停下多久考虑一点&#xff0c;可以由其左上方的所有点到达所以从往前推&#xff0c;得出到的总花费然后考虑从之后不赚钱直接到最终所用次数和剩余钱若存在&#xff0c;在后面点赚钱更优…

Python错题集-8:AttributeError(找不到对应的对象的属性)

1问题描述 AttributeError: AxesSubplot object has no attribute arc 2代码详情 import matplotlib.pyplot as plt# 创建一个新的图形和坐标轴 fig, ax plt.subplots()# 定义弧线的参数 center (0.5, 0.5) # 圆心坐标 (x, y) width 1.0 # 半径 height 0.5 # 半径 ang…

沁恒CH32V307VCT6开发板记录---kalrry

沁恒CH32V307VCT6开发板记录---kalrry 一、官网申请开发板二、环境准备图一 一、官网申请开发板 1.沁恒官网 二、环境准备 1.数据手册&#xff1a;CH32V307DS0.PDF&#xff0c;CH32FV2x_V3xRM.PDF 2.CH32V307评估板说明及参考应用例程&#xff1a;CH32V307EVT_ZIP 3.集成开…

【kvm企业级虚拟化】之初级篇

目录 一、kvm介绍二、kvm软件安装三、GuestOS安装第一种方式&#xff1a;图形化安装第二种方式&#xff1a;命令行模式安装 四、GuestOS升级配置五、KVM存储六、磁盘格式七、创建磁盘文件八、KVM基本管理九、虚拟机克隆十、虚拟机快照十一、KVM网络管理1、kvm修改virbr0地址段&…

每日一面——封装、继承和多态

写前声明&#xff1a;参考链接 C面经、面试宝典 等 ✊✊✊每日一面——封装、继承和多态 一、简述一下什么是面向对象&#xff1f;二、讲一讲封装、继承、多态是什么&#xff1f;三、C的多态怎么实现&#xff1f;四、C中类成员的访问权限和继承权限问题五、C中的重载、重写&…

腾讯云拼了99元服务器老用户能买,续费不涨价!

良心腾讯云推出99元一年服务器&#xff0c;新用户和老用户均可以购买&#xff0c;续费不涨价&#xff0c;续费也是99元&#xff0c;配置为轻量2核2G4M、50GB SSD盘、300GB月流量、4M带宽&#xff1a;优惠价格99元一年&#xff0c;续费99元&#xff0c;官方活动页面 txybk.com/g…

C++类和对象(中篇)

目录 1. 类的6个默认成员函数 2. 构造函数 3.析构函数 4.拷贝构造函数 5.赋值运算符重载 6.const成员 7.取地址及const取地址操作符重载 1. 类的6个默认成员函数 如果一个类中什么成员都没有&#xff0c;简称为空类。 空类中真的什么都没有吗&#xff1f;并不是&#…

OpenMP

介绍 OpenMP 是一个应用程序接口 &#xff08;API&#xff09;&#xff0c;由一组主要的计算机硬件和软件供应商共同定义。OpenMP 为共享内存并行应用程序的开发人员提供了一个可移植、可扩展的模型。该 API 支持各种架构上的 C/C 和 Fortran。 OpenMP是&#xff1a; 一个可…

基于动态内存设计的通讯录

test.c #define _CRT_SECURE_NO_WARNINGS 1 #include"contact.h"void menu(){printf("\n");printf("1.增加联系人\n");printf("2.删除联系人\n");printf("3.查找联系人\n");printf("4.修改联系人\n");printf(&qu…

python学习笔记------字典

字典的定义 字典的定义&#xff0c;同样是使用{}&#xff0c;不过存储的元素是一个个的键值对 基本语法&#xff1a; #定义字典字面量 {key:value,key:value,key:value,......key:value} #定义字典变量 my_dict{key:value,key:value,key:value,......key:value} #定义空…

elasticsearch篇:RestClient操作

1. RestClient ES官方提供了各种不同语言的客户端&#xff0c;用来操作ES。这些客户端的本质就是组装DSL语句&#xff0c;通过http请求发送给ES。官方文档地址&#xff1a;Elasticsearch Clients | Elastic 其中的Java Rest Client又包括两种&#xff1a; Java Low Level Res…

Leetcode 3076. Shortest Uncommon Substring in an Array

Leetcode 3076. Shortest Uncommon Substring in an Array 1. 解题思路2. 代码实现 题目链接&#xff1a;3076. Shortest Uncommon Substring in an Array 1. 解题思路 这一题我的思路上很暴力&#xff0c;就是直接把所有可能的substring全部统计出来放到一起。 然后&#…

windows10+cpu+pycharm跑yolov5

1、安装anaconda和pycharm&#xff0c;安装方法参考&#xff1a; anaconda和pycharm安装&#xff08;windows10 &#xff09;-CSDN博客 2、创建yolov5环境&#xff0c;打开Anaconda Prompt命令打开cmd命令行窗口&#xff0c;如下所示&#xff1a; 输入&#xff1a;conda crea…

android pdf框架-6,文本生成pdf

前文介绍如何使用图片生成pdf,这里介绍如何使用文本生成pdf 使用mupdf生成 mupdf生成的pdf略大,字体可以自定义. 生成的代码不复杂,也有好几种,以story的方式生成为例 fun createPdfFromText(sourcePath: String, destPath: String): Boolean {val text EncodingDetect.rea…