ZynqMp Sysmon 记录

cpp 复制代码
#include <cstdint>
#include <fcntl.h>
#include <fstream>
#include <iostream>
#include <regex>
#include <string>
#include <unistd.h>

#define SENSOR_PATH "/sys/bus/iio/devices/iio:device0/"

#define XSysMonPsu_RawToTemperature_OnChip(AdcData)                            \
  ((((float)(AdcData) / 65536.0f) / 0.00196342531f) - 280.2309f)

#define XSysMonPsu_RawToVoltage(AdcData)                                       \
  ((((float)(AdcData)) * (3.0f)) / 65536.0f)

int SysMonPsuFractionToInt(float FloatNum) {
  float Temp;
  Temp = FloatNum;
  if (FloatNum < 0) {
    Temp = -(FloatNum);
  }
  return (((int)((Temp - (float)((int)Temp)) * (1000.0f))));
}
int32_t main(int32_t argc, char *argv[]) {
  if (argc != 2) {
    return -2;
  }
  std::string sensor = std::string(SENSOR_PATH) + std::string(argv[1]);
  if (access(sensor.c_str(), F_OK) != 0) {
    printf("ERR:%s %s\n", strerror(errno), argv[1]);
    return 1;
  }
  std::regex reg1("(.*)temp(.*)");
  std::ifstream ifs;
  char temp[32];
  std::string device;
  float t;
  ifs.open(sensor);
  ifs >> temp;
  if (std::regex_match(temp, reg1)) {
    t = XSysMonPsu_RawToTemperature_OnChip(strtol(temp, NULL, 10));
    printf("%s:%d.%d\n", argv[1], (int)t, SysMonPsuFractionToInt(t));
  } else {
    t = XSysMonPsu_RawToVoltage(strtol(temp, NULL, 10));
    printf("%s:%d.%d\n", argv[1], (int)t, SysMonPsuFractionToInt(t));
  }
  return 0;
}
相关推荐
paopaokaka_luck10 分钟前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
YuTaoShao11 分钟前
【LeetCode 热题 100】206. 反转链表——(解法一)值翻转
算法·leetcode·链表
iteye_993912 分钟前
让 3 个线程串行的几种方式
java·linux
YuTaoShao19 分钟前
【LeetCode 热题 100】142. 环形链表 II——快慢指针
java·算法·leetcode·链表
CCF_NOI.27 分钟前
(普及−)B3629 吃冰棍——二分/模拟
数据结构·c++·算法
找不到、了1 小时前
分布式理论:CAP、Base理论
java·分布式
天天摸鱼的java工程师1 小时前
2025已过半,Java就业大环境究竟咋样了?
java·后端
运器1231 小时前
【一起来学AI大模型】支持向量机(SVM):核心算法深度解析
大数据·人工智能·算法·机器学习·支持向量机·ai·ai编程
人生在勤,不索何获-白大侠1 小时前
day16——Java集合进阶(Collection、List、Set)
java·开发语言
Zedthm1 小时前
LeetCode1004. 最大连续1的个数 III
java·算法·leetcode