手把手一起开发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

相关文章

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

如何基于Python开发一个微信自动化工具

《如何基于Python开发一个微信自动化工具》在当今数字化办公场景中,自动化工具已成为提升工作效率的利器,本文将深入剖析一个基于Python的微信自动化工具开发全过程,有需要的小伙伴可以了解下... 目录概述功能全景1. 核心功能模块2. 特色功能效果展示1. 主界面概览2. 定时任务配置3. 操作日志演示

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录