手把手一起开发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,一经查实,立即删除!

相关文章

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

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

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

删除有序数组中的重复项 题目要求 解题思路 题目要求中提到原地修改&#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.集成开…

腾讯云拼了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; 一个可…

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…

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…

【大模型】Hugging Face下载大模型的相关文件说明

Hugging Face下载大模型文件说明 1.前言 ​ 上图是毛毛张在HuggingFace的官网上的ChatGLM-6B大模型的所有文件,对于初学者来说,对于上面的文件是干什么的很多小伙伴是很迷糊的,根本不知道是干什么的,毛毛张接下来将简单讲述一下上面的每个文件的作用。 2.文件说明 在Hug…

FL Studio21最新官方完整免费版水果音乐制作软件下载

作为音乐制作软件专家&#xff0c;对于FL Studio21这款功能强大的音乐制作软件有着深入的了解&#xff0c;它为用户提供了从创作到后期制作的完整工作流程。以下是对其各项功能的全面、准确且详细的介绍&#xff1a; FL Studio 21 Win-安装包下载如下: https://wm.makeding.c…

vue项目部署服务器,因为跨域设置nginx.config要修改的配置

下面是我在vue项目中vite.config.js设置的配置代理 对于部署项目需要使用nginx进行vue项目的话&#xff0c;需要对nginx的配置文件进行如下修改即可

linux操作系统虚拟机的环境配置

目录 一、虚拟机安装&#xff08;类似硬件的安装&#xff09; &#xff08;1&#xff09;创建虚拟机 &#xff08;2&#xff09;创建虚拟机 二、IP和主机名称配置 1、设置VM上的IP 2、设置我们电脑上VMnet8的IP 3、设置虚拟机上的IP 主机名称映射 以下是设置主机名映射…

linux系统adb调试工具

adb的全称为Android Debug Bridge&#xff0c;就是起到调试桥的作用。通过adb可以在Eclipse中通过DDMS来调试Android程序&#xff0c;说白了就是调试工具。 adb的工作方式比较特殊&#xff0c;采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯&#xff0c;默认情况下adb会…

实时工业控制系统的创新整合:PLC4X与CnosDB的高效数据采集与存储

在当代工业自动化系统中&#xff0c;实时监测和数据分析变得至关重要。本文将介绍如何通过集成Apache PLC4X与CnosDB&#xff0c;实现对工业控制系统中的PLC设备进行高效数据采集和存储&#xff0c;为工程师们提供更强大的数据分析和监测工具。 PLC的定义 PLC是可编程逻辑控制…

哈希表|242.有效的字母异位词

力扣题目链接 bool isAnagram(char* s, char* t) {int len_s strlen(s), len_t strlen(t);if(len_s ! len_t) {return false;}int table[26];memset(table, 0, sizeof(table));for(int i 0; i < len_s; i) {table[s[i] - a];}for(int i 0; i < len_t; i) {table[t[i…

Unity 关节:铰链、弹簧、固定、物理材质:摩檫力、 特效:拖尾、

组件-物理-关节&#xff1a;铰链&#xff08;类似门轴&#xff09; 自动动作、多少力可以将其断开、 弹簧可以连接另一个刚体&#xff08;拖动即可&#xff09; 固定一般是等待一个断裂力&#xff0c;造成四分五裂的效果。 物理材质 设置摩檫力&#xff0c;则可以创造冰面的…

复制表

目录 复制表 将部门 30 的所有员工信息保存在 emp30 表中 将复杂查询结果创建为表 只将 emp 表的结构复制为 empnull 表 从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 复制表 严格来说&#xff0c;复制表不是复制操作&am…