本文主要是介绍AMI BMC读取VR(voltage regulator)温度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
现在有一个读取vr温度作为传感器的需求
拿到vr芯片手册,查看pmbus相关命令
可以看到Command code 是 8E h,Direct的格式代表两个byte作为温度
经过询问同事得知vr的i2c信号是通过cpld转过来到i2c-9上
查看原理图找到i2c-9的连线,看看怎么连的
继续往下追发现连到一个switch芯片上(搞不懂为什么要switch,明明没有什么冲突的)
注意这里RESET这个 GPIO需要pull low,不然芯片不会作用,找不到这个0xE2的地址的
Reset信号往下找找,找到gpio号
可以看到是GPIOG7,计算一下 6 * 8 + 7=55
利用gpiotool来拉低和设置direct
注意如果是ast2600的平台,比如archercity,那么这个GPIOG7是被复用成sd2的,结果就会发现gpiotool set fail, 因此需要保证bootloader和kernel部分没有复用芯片这部分功能(要把dts中的配置disable)
GPIOG7 default 是做gpio
这样就保证该GPIO没有被复用了
可以看到这个PCA9546的地址出来了
接下来就要利用i2c来做switch control
先看看PCA9546的datasheet ,看看怎么做switch
由原理图可以看出,我们需要switch channel 2
由上图原理图可知i2c-9是SMB_HOST_STBY_BMC_LVC3_R_SDA ,对应pca9546的SD2(channel 2)
接着查看pca9546 datasheet
找到control register 描述部分,可以看到如果想要switch channel 2, 需要往该寄存器的bit 2置为1,也就是04h(这里由于没有地址冲突,其他channel也没接,所以我写了FF h,偷懒了)
利用i2cset工具,往pca8546的地址 71h写入04h,你看vr芯片的地址都可以看到了
VR的地址有了,接下来只需要看vr datasheet的read temperature部分,利用pmbus读就OK了
先拉几个sensor出来
由上文的vr datasheet可以知道8Eh这个command code读取internal temperature,所以read部分的函数只有address不同,所以我们自己建一个ddf文件
下图为read 函数部分
在ddf中配置SLAVE_ADDR等需要的config项
Reflash,Build一下,烧录,开机
可以看到vr的温度了!
这篇关于AMI BMC读取VR(voltage regulator)温度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!