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

2024-03-10 19:28

本文主要是介绍手把手一起开发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例程

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

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

这篇关于手把手一起开发SV4E-I3C设备(四)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/795269

相关文章

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

录音功能在哪里? 电脑手机等设备打开录音功能的技巧

《录音功能在哪里?电脑手机等设备打开录音功能的技巧》很多时候我们需要使用录音功能,电脑和手机这些常用设备怎么使用录音功能呢?下面我们就来看看详细的教程... 我们在会议讨论、采访记录、课堂学习、灵感创作、法律取证、重要对话时,都可能有录音需求,便于留存关键信息。下面分享一下如何在电脑端和手机端上找到录音功能

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同