【ZYNQ Ultrascale+ MPSOC FPGA教程】第二十七章System Monitor

描述

原创声明:

本原创教程由芯驿电子科技(上海)有限公司(ALINX)创作,版权归本公司所有,如需转载,需授权并注明出处。

适用于板卡型号:

AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG

 

vivado工程目录为“ps_hello/vivado”

vitis工程目录为“ps_sysmon/vitis”

本章介绍system monitors的使用,用于监测芯片的电压、温度值等,也可以通过PL端的ADC引脚作为外部信号的采集。PL端可以做17路ADC的采集,但开发板并没有在这些管脚上接设备,因此本章不做讲解。如图所示电压传感器可监测芯片的VCCINT,VCCAUX,VCCBRAM等,PL_SYSMON的VP_0和VN_0为一对专用的ADC模拟输入口。VAUXP[*]和VAUXN[*]也是ADC输入口,但是不用作ADC输入口时,可用作普通IO使用。本实验主要测量温度以及电压的值。

 

开发板

 

Vivado工程,同样以“ps_hello”工程为基础。

FPGA工程师工作内容

下面介绍FPGA工程师负责内容。

1. Hardware读取System Monitor

1)打开工程,连接好开发板电源,JTAG下载器,并将开发板调整为JTAG模式,开发板上电,点击Open Hardware Manager,再点击Auto Connect,发现硬件。

 

开发板

 

2)右键选中SysMon,新建Dashboard

 

开发板

 

3)PS端和PL端都选择,点击OK

 

开发板

 

4)默认会有温度信息

 

开发板

 

5)点击+将电压值添加到窗口

 

开发板

 

6)显示如下

 

开发板

 

此方法优点是图形化显示,较为直观,但缺点是无法得到数据值。下面介绍PS读取XADC信息。

软件工程师工作内容

以下为软件工程师负责内容。

2. PS读取System Monitor信息

1)打开Vitis软件,新建Vitis工程

 

开发板

 

2)可以在BSP中看到system monitor,可以导入Example学习

 

开发板

 

3)此实验现象为读取温度和电压的数据,并每隔1S通过串口打印出来。通过XSysMonPsu_GetAdcData函数读取原始值,用XSysMonPsu_RawToTemperature_OnChip宏将ADC值转换为温度值。用XSysMonPsu_RawToVoltage转换为电压值。

 

开发板

 

4)下载后在串口工具中可看到打印信息如下,读到温度,VCCINT,VCCAUX的值

 

开发板
打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分