【正点原子FPGA连载】第十章PS SYSMON测量温度电压实验 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Vitis开发指南

news2025/2/26 4:08:28

1)实验平台:正点原子MPSoC开发板
2)平台购买地址:https://detail.tmall.com/item.htm?id=692450874670
3)全套实验源码+手册+视频下载地址: http://www.openedv.com/thread-340252-1-1.html

第十章PS SYSMON测量温度电压实验

系统监视器(System Monitors)是MPSOC中用来测量电压和温度的模块,能够将电压和温度信息提供给系统的其它部分,包括平台管理单元(PMU),实时处理单元(RPU)和应用处理单元(APU)。MPSOC中有两个SYSMON模块:PL端SYSMON模块和PS端SYSMON模块。
本章我们将使用PS端SYSMON模块,读取芯片的温度电压等信息。本章包括以下几个部分:
1010.1简介
10.2实验任务
10.3硬件设计
10.4软件设计
10.5下载验证

10.1简介

PS SYSMON模块位于PS端低功耗域内,由VCC_PSAUX和VCC_PSADC供电。PS SYSMON能同时测量两个温度和几个固定的电压节点。AXI互联主机通过PS SYSMON和AMS寄存器组控制PS端SYSMON模块。
MPSOC中PS SYSMON和PL SYSMON模块都属于SYSMONE4结构,结构上存在很多相似处。也有许多不同点,例如采样率,参考电压,编程接口,电源域,温度传感器等。PS SYSMON模块框图如下图所示:
在这里插入图片描述

图10.1.1 PS SYSMON模块框图
PS SYSMON监测的内部电压节点位于低功耗域和全功耗域,包含内部和IO缓冲区节点。PS中所有电压测量都是单极的,内部电压节点测量范围是03V或06V。PS内部有两个温度传感器,一个物理位置在RPU附近,另外一个在APU附近。在图10.1.1中,软件通过APB SLAVE接口配置PS SYSMON的寄存器。
PS和PL的SYSMON模块各自独立运行。运行模式包括单通道读模式,默认的序列模式和自动序列器模式,SYSMON通常以默认的序列模式运行。在默认模式下,可以通过CONFIG_REG寄存器将SYSMON配置成自定义序列。
单通道读模式一次只能测量一个通道的传感器信号。在使用单通道模式时,先向CONFIG_REG0寄存器[mux_channel]比特位写入通道序号,再将CONFIG_REG1寄存器[sequence_mode]比特位设置成单通道模式,然后等待EOC(end of conversion)中断,当中断触发时,读取相关测量寄存器。
自动序列器模式下,SYSMON模块可以一次或连续的对打开的通道列表进行顺序访问。模拟输入按照固定顺序进行时间多路复用,并且每次只有一路信号送给ADC输入。读取每个通道的测量值时,最大值和最小值都会被存储。测量值也可以在连续测量结果的平均值。
10.2实验任务
本章的实验任务是通过APB Slave接口,读取PS SYSMON测量的芯片温度、供电电压等信息,并通过串口打印出来。
10.3硬件设计
根据实验任务我们可以画出本次实验的系统框图,如下图所示:
在这里插入图片描述

图 10.3.1 系统框图
在图 10.3.1中,CPU作为AXI主机连接到SYSMON模块APB Slave接口,读取SYSMON模块采集的温度和电压数据,然后通过串口打印出来。
本次实验在《Hello World》实验中的最小系统上就可以完成,也就是说不需要额外配置PS端或者添加PL端的外设。
打开《hello_world》工程,另存为本次实验工程《ps_sysmon》,导出硬件设计(Hardware),具体步骤可以参照前面的实验,最后打开Vitis软件。
10.4软件设计
在VITIS软件中新建一个空的应用工程,应用工程名为“ps_sysmon”。然后为应用工程新建一个源文件“main.c”,我们在新建的main.c文件中输入本次实验的代码:

1   #include "xsysmonpsu.h"
2   #include "xparameters.h"
3   #include "xstatus.h"
4   #include "stdio.h"
5   #include "sleep.h"
6   
7   #define SYSMON_DEVICE_ID    XPAR_XSYSMONPSU_0_DEVICE_ID
8   #define printf xil_printf
9   
10  int    PS_SYSMON_Test(u16 SysMonDeviceId);
11  static int SysMonPsuFractionToInt(float FloatNum);
12  static XSysMonPsu SysMonInst;                          //PS SYSMON实例
13  
14  int main(void)
15  {
16      xil_printf("Run Sysmon Polled Test\r\n");
17  
18      PS_SYSMON_Test(SYSMON_DEVICE_ID);
19  
20      return XST_SUCCESS;
21  }
22  
23  int PS_SYSMON_Test(u16 SysMonDeviceId)
24  {
25      XSysMonPsu_Config *ConfigPtr;
26      u32 TempRawData;                              //温度         原始数据
27      u32 VccAuxRawData;                            //PS 辅助电压  原始数据
28      u32 VccIntRawData;                            //PS 内核电压  原始数据
29      u32 VCCO_PSIO0RawData;                        //Bank500电压  原始数据
30      u32 VCCO_PSIO1RawData;                        //Bank501电压  原始数据
31      float TempData;                               //温度
32      float VccAuxData;                             //PS 辅助电压
33      float VccIntData;                             //PS 内核电压
34      float VCCO_PSIO0Data;                         //Bank500电压
35      float VCCO_PSIO1Data;                         //Bank501电压
36      u64 IntrStatus;
37      XSysMonPsu *SysMonInstPtr = &SysMonInst;
38  
39      printf("\r\nEntering the SysMon Test. \r\n");
40  
41      ConfigPtr = XSysMonPsu_LookupConfig(SysMonDeviceId);
42      if (ConfigPtr == NULL) {
43          return XST_FAILURE;
44      }
45      XSysMonPsu_CfgInitialize(SysMonInstPtr, ConfigPtr,
46                  ConfigPtr->BaseAddress);
47  
48      XSysMonPsu_SetSequencerMode(SysMonInstPtr,
49              XSM_SEQ_MODE_SAFE, XSYSMON_PS);            //设置Sequence Mode为安全模式
50  
51      XSysMonPsu_SetAlarmEnables(SysMonInstPtr,          //关闭寄存器1中指定信号的警报
52              0x0, XSYSMON_PS);
53  
54      XSysMonPsu_SetAvg(SysMonInstPtr,
55              XSM_AVG_16_SAMPLES, XSYSMON_PS);           //设置采样16次后计算平均值
56  
57      XSysMonPsu_SetSeqAvgEnables(SysMonInstPtr,
58              XSYSMONPSU_SEQ_CH0_TEMP_MASK |             //使能Temp_LPD通道平均值测量
59              XSYSMONPSU_SEQ_CH0_SUP1_MASK |             //使能VCC_PSINTLP通道平均值测量
60              XSYSMONPSU_SEQ_CH0_SUP3_MASK |             //使能VCC_PSAUX通道平均值测量
61              XSYSMONPSU_SEQ_CH0_SUP6_MASK |             //使能VCCO_PSIO0通道平均值测量
62              XSYSMONPSU_SEQ_CH2_SUP7_MASK ,             //使能VCCO_PSIO1通道平均值测量
63              XSYSMON_PS);
64  
65      XSysMonPsu_SetSeqChEnables(SysMonInstPtr,
66              XSYSMONPSU_SEQ_CH0_TEMP_MASK |             //打开Temp_LPD通道
67              XSYSMONPSU_SEQ_CH0_SUP1_MASK |             //打开VCC_PSINTLP通道
68              XSYSMONPSU_SEQ_CH0_SUP3_MASK |             //打开VCC_PSAUX通道
69              XSYSMONPSU_SEQ_CH0_SUP6_MASK |             //打开VCCO_PSIO0通道
70              XSYSMONPSU_SEQ_CH2_SUP7_MASK ,             //打开VCCO_PSIO1通道
71              XSYSMON_PS);
72  
73      IntrStatus = XSysMonPsu_IntrGetStatus(SysMonInstPtr); //读中断状态寄存器
74      XSysMonPsu_IntrClear(SysMonInstPtr, IntrStatus);  //清除中断状态寄存器
75  
76      XSysMonPsu_SetSequencerMode(SysMonInstPtr,
77              XSM_SEQ_MODE_CONTINPASS, XSYSMON_PS);     //设定Sequence Mode为通道循环模式
78  
79      while ((XSysMonPsu_IntrGetStatus(SysMonInstPtr) & ((u64)XSYSMONPSU_ISR_1_EOS_MASK<< 
80          32))!= ((u64)XSYSMONPSU_ISR_1_EOS_MASK<< 32));//等待EOS(end of sequence)发生
81  
82      while(1)
83      {
84      //从ADC数据寄存器读实时温度值
85      TempRawData = XSysMonPsu_GetAdcData(SysMonInstPtr,
86                              XSM_CH_TEMP, XSYSMON_PS);      //读Temp_LPD通道数据
87      TempData = XSysMonPsu_RawToTemperature_OnChip(TempRawData);
88      printf("The Current Temperature is %0d.%03d Centigrades.\r\n",
89                  (int)(TempData), SysMonPsuFractionToInt(TempData));
90  
91      //从ADC数据寄存器读VccInt电压值
92      VccIntRawData = XSysMonPsu_GetAdcData(SysMonInstPtr,
93                              XSM_CH_SUPPLY1, XSYSMON_PS);   //读VCC_PSINTLP通道数据
94      VccIntData = XSysMonPsu_RawToVoltage(VccIntRawData);
95      printf("The Current VCCINT is %0d.%03d Volts. \r\n",
96              (int)(VccIntData), SysMonPsuFractionToInt(VccIntData));
97  
98      //从ADC数据寄存器读VccAux电压值
99      VccAuxRawData = XSysMonPsu_GetAdcData(SysMonInstPtr,
100                             XSM_CH_SUPPLY3, XSYSMON_PS);   //读VCC_PSAUX通道数据
101     VccAuxData = XSysMonPsu_RawToVoltage(VccAuxRawData);
102     printf("The Current VCCAUX is %0d.%03d Volts. \r\n",
103             (int)(VccAuxData), SysMonPsuFractionToInt(VccAuxData));
104 
105     VCCO_PSIO0RawData = XSysMonPsu_GetAdcData(SysMonInstPtr,
106                             XSM_CH_SUPPLY6, XSYSMON_PS);   //读Bank500电压
107     VCCO_PSIO0Data = XSysMonPsu_VccopsioRawToVoltage(VCCO_PSIO0RawData);
108     printf("The Current VCCO_PSIO0 is %0d.%03d Volts. \r\n",
109                 (int)(VCCO_PSIO0Data), SysMonPsuFractionToInt(VCCO_PSIO0Data));
110 
111     VCCO_PSIO1RawData = XSysMonPsu_GetAdcData(SysMonInstPtr,
112                             XSM_CH_SUPPLY7, XSYSMON_PS);   //读Bank501电压
113     VCCO_PSIO1Data = XSysMonPsu_VccopsioRawToVoltage(VCCO_PSIO1RawData);
114     printf("The Current VCCO_PSIO1 is %0d.%03d Volts. \r\n\r\n\r\n",
115                 (int)(VCCO_PSIO1Data), SysMonPsuFractionToInt(VCCO_PSIO1Data));
116 
117     //延时5s
118     sleep(5);
119     }
120 
121     return XST_SUCCESS;
122 }
123 
124 //将小数转换成整数
125 int SysMonPsuFractionToInt(float FloatNum)
126 {
127     float Temp;
128 
129     Temp = FloatNum;
130     if (FloatNum < 0) {
131         Temp = -(FloatNum);
132     }
133 
134     return( ((int)((Temp -(float)((int)Temp)) * (1000.0f))));
135 }

代码第14行至第21行,是程序的主函数,主函数比较简单,先输出打印信息“Run Sysmon Polled Test”,然后调用PS_SYSMON_Test()函数,该函数是在官方函数基础上修改而来。
在PS_SYSMON_Test()函数中,首先对SYSMON进行初始化,如程序第41行至第46行所示。通过调用XSysMonPsu_SetSequencerMode()函数,将SYSMON操作模式设置为默认模式(安全模式)。程序第54行至第55行,设置平均值的采样次数为16次。接下来是使能通道的平均值测量,即测量结果是采样16次后计算的平均值,如第57行至第63行所示,如果不打开通道的平均值测量,则测量结果是最后一次采样值。
程序第92行至第93行中,通过调用XSysMonPsu_GetAdcData()函数,读取Vcc_Int内核电压的原始数据。该函数中,第二个参数XSM_CH_SUPPLY1代表supply1通道,通过查看ug1085手册,supply1通道实际就是VCC_PSINTLP通道,如下图所示:
在这里插入图片描述

图10.4.1 PS SYSMON传感器通道
通过查看ug1087手册可知,该通道物理地址为0x00FFA50804,而XSysMonPsu_GetAdcData()函数通过对第二和第三个参数计算,最终获取的就是物理地址为0x00FFA50804的VCC_PSINTLP通道的原始数据。程序第94行中,XSysMonPsu_RawToVoltage()函数对原始数据先乘以3再除以65536,公式详细讲解可参考ug580手册,如图10.4.2所示。其它通道的电压温度测量类似,这里不详细讲解。注意MIO通道电压计算公式和其它通道是不同的。
在这里插入图片描述

图10.4.2 电压计算公式
程序第96行调用SysMonPsuFractionToInt()函数,该函数将浮点型数据的小数部分转换成整数,函数定义如第125行至第135行所示。
10.5下载验证
首先我们将下载器与开发板上的JTAG接口连接,下载器另外一端与电脑连接。然后使用USB连接线将USB_UART(开发板PS PORT)接口与电脑连接,用于串口通信。最后连接开发板的电源,给开发板上电。
打开Vitis Terminal终端,设置并连接串口。然后下载本次实验的程序,下载完成后,在下方的VITIS Terminal中可以看到应用程序每隔5秒打印一次芯片温度和电压等信息,如下图所示:
在这里插入图片描述

图 10.5.1 串口终端中打印的信息
从图 10.5.1中可以看到,串口终端能够正确打印温度和电压信息,说明本次实验在MPSOC开发板上面下载验证成功。

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

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

相关文章

如何正确的在Flutter中添加webview

前言 为什么要在flutter中引入webview&#xff1f;这不是废话么&#xff0c;当然是为了加载一个网页&#xff0c;这不是移动端最基本的需求么&#xff0c;哈哈&#xff01;说的真不错&#xff0c;接下来我要是告诉你我的用法&#xff0c;你可能要大吃一惊。我的用处很简单&…

【音视频处理】码率、帧率越高越清晰?分辨率、像素、dpi之间是什么关系?码率的真实作用,I帧、B帧、P帧是什么

大家好&#xff0c;欢迎来到停止重构的频道。本期我们介绍一下视频的一些基础概念&#xff0c;如帧率、码率、分辨率、像素、dpi、视频帧、I帧、P帧、gop等。会解释多少码率是清晰的&#xff0c;是否帧率越高越流畅等问题。这些概念是比较杂乱的&#xff0c;我们按这样的顺序介…

Seata源码学习(四)-数据源代理

Seata源码分析-数据源代理 上节课我们分析了整体的Seata-AT模式的2PC执行流程&#xff0c;那么这节课我们要分析的就是在AT模式中的关键点&#xff0c;数据源代理 AT模式的核心点&#xff1a; 获取全局锁、开启全局事务解析SQL并写入undolog 那么上节课其实我们已经把第一步…

【目标检测】K-means和K-means++计算anchors结果比较(附完整代码,全网最详细的手把手教程)

写在前面: 首先感谢兄弟们的订阅,让我有创作的动力,在创作过程我会尽最大努力,保证作品的质量,如果有问题,可以私信我,让我们携手共进,共创辉煌。 一、介绍 YOLO系列目标检测算法中基于anchor的模型还是比较多的,例如YOLOv3、YOLOv4、YOLOv5等,我们可以随机初始化a…

简约精美电商小程序【源码好优多】

简介 一款开源的电商系统&#xff0c;包含微信小程序和H5端&#xff0c;为大中小企业提供移动电子商务优秀的解决方案。 后台采用Thinkphp5.1框架开发&#xff0c;执行效率、扩展性、稳定性值得信赖。并且Jshop小程序商城上手难度低&#xff0c;可大量节省定制化开发周期。 功…

设计模式(适配器模式)

设计模式&#xff08;适配器模式&#xff09; 第二章 设计模式之适配器模式&#xff08;Adapter&#xff09; 一、Adapter模式介绍 适配器模式位于实际情况和需求之间&#xff0c;填补两者之间的差距。 二、示例程序1&#xff08;使用继承的适配器&#xff09; 1.示例程序示…

操作系统(五):编译过程,静态链接,目标文件,动态链接

文章目录一、程序的编译过程二、静态链接三、目标文件四、动态链接一、程序的编译过程 在linux上编译一个c文件hello.c的命令为: g -o hello hello.c 整个过程大致要经过一下四步: 预处理 &#xff1a; 处理以#开头的预处理命令编译 &#xff1a; 翻译成汇编文件汇编 &…

HTTPS基础原理和配置-3

书接上文&#xff1a;HTTPS 基础原理和配置 - 2&#xff0c;接下来介绍&#xff1a; 配置 NGINX后端 HTTPS检查配置配置 HSTSOCSP Stapling 重要部分来了。如何使用这些选项并配置NGINX? 一、NGINX 的 HTTPS 配置 这里有一些基本的原语&#xff08;或叫做指令&#xff09;…

GEE学习笔记八十八:在自己的APP中使用绘制矢量(上)

在GEE中尤其是自己的APP中调用绘制的矢量图形方法之前没有合适的方法&#xff0c;但是现在可以通过ui.Map.DrawingTools(...)以及ui.Map.GeometryLayer(...)结合来做。具体的API如下图&#xff1a; 在这一篇中我先通过一个简单的例子来展示一下使用这些API后可以实现什么效果&a…

C#底层库--日期扩展类(上周、本周、明年、前年等)

系列文章 C#底层库–记录日志帮助类 本文链接&#xff1a;https://blog.csdn.net/youcheng_ge/article/details/124187709 C#底层库–数据库访问帮助类&#xff08;MySQL版&#xff09; 本文链接&#xff1a;https://blog.csdn.net/youcheng_ge/article/details/126886379 …

axios中的GET POST PUT PATCH,发送请求时params和data的区别

axios 中 get/post请求方式 1. 前言 最近突然发现post请求可以使用params方式传值&#xff0c;然后想总结一下其中的用法。 2.1 分类 经过查阅资料&#xff0c;get请求是可以通过body传输数据的&#xff0c;但是许多工具类并不支持此功能。 在postman中&#xff0c;选择get请…

以before为例 完成一个aop代理强化方法案例

观看本文 首先 您需要做好Spring aop的准备工作 具体可以参考我的文章 java Spring aop入门准备工作 首先 我们创建一个包 我这里叫 Aop 然后在Aop包下创建一个类 叫 User 参考代码如下 package Aop;public class User {public void add(){System.out.println("add....…

android kotlin 协程(三) 理解挂起,恢复以及job

android kotlin 协程(三) 理解挂起,恢复以及job 前言: 通过上两篇的基础入门,相信大家对协程api已经有了一个基本的影响,本篇开始尝试理解挂起于恢复. 本篇不涉及源码, 通过很多应用案例,来理解挂起于恢复! 协程执行流程理解 还是老套路,先来看原始效果 参考图1 在这里我们知…

电子技术——目录

电子技术——目录 第一章——信号与放大器 第二章——运算放大器 第三章——半导体器件 第四章——二极管 第五章——金属氧化物场效应晶体管 目录&#xff1a; MOS管的物理结构MOS管的CV特性MOS放大器基础MOS管的小信号模型基本MOS放大器配置MOS放大器的DC偏置分立MOS放…

传奇开服方法教程:传奇开服在哪些网站打广告?传奇发布站打广告技巧

传奇开服方法教程&#xff1a;传奇开服在哪些网站打广告&#xff1f;传奇发布站打广告技巧 纯分享经验以及方法&#xff1a;开传奇sf&#xff0c;成本最高的就是广告费用了&#xff0c;为了让服人气更高&#xff0c;主播和发布站相信你们都已经尝试了&#xff0c;上人效果如何你…

全网详解 .npmrc 配置文件:比如.npmrc的优先级、命令行,如何配置.npmrc以及npm常用命令等

文章目录1. 文章引言2. 简述.npmrc3. 配置.npmrc3.1 .npmrc配置文件的优先级3.2 .npmrc设置的命令行3.3 如何设置.npmrc4. 配置发布组件5. npm常用命令6. 重要备注6.1 yarn6.2 scope命名空间6.3 镜像出错1. 文章引言 今天在某低代码平台开发项目时&#xff0c;看到如下编译配置…

Java实现调用ChatGPT的相关接口(附详细思路)

目录1.0.简单版2.0.升级版2-1.call.timeout()怎么传入新的超时值2-2.timeout(10, TimeUnit.SECONDS)两个参数的意思&#xff0c;具体含义3.0.进阶版3-1.java.net.SocketTimeoutException: 超时如何解决4.0.终极版1.0.简单版 以下是一个使用 Java 实际请求 ChatGPT 的简单示例代…

EasyExcel详解-写Excel

一、注解使用注解很简单&#xff0c;只要在对应的实体类上面加上注解即可。ExcelProperty用于匹配excel和实体类的匹配,参数如下&#xff1a;名称默认值描述value空用于匹配excel中的头&#xff0c;必须全匹配,如果有多行头&#xff0c;会匹配最后一行头orderInteger.MAX_VALUE…

硬件系统工程师宝典(6)-----如何减小信号串扰?

各位同学大家好&#xff0c;欢迎继续做客电子工程学习圈&#xff0c;今天我们继续来讲这本书&#xff0c;硬件系统工程师宝典。 上篇我们说到描述信号传输的过程的需要做好阻抗匹配&#xff0c;以减小信号的反射。今天我们来看看传输线之间的噪声干扰&#xff0c;那就是信号的…

rdma rocev2报文格式总结

格式如下&#xff1a; wireshark抓包&#xff0c;soft-roce(基于rocev2实现的)格式如下&#xff1a; 其实这里看着有点奇怪&#xff0c;ICRC是跟在Payload头后面的&#xff0c;不知道为什么抓包看到的却是在BTH头后面的&#xff0c;还有就是看不到FCS?? 其中BTH头的格式有…