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;
}
相关推荐
大胆飞猪1 小时前
递归、剪枝、回溯算法---全排列、子集问题(力扣.46,78)
算法·leetcode·剪枝
君不见,青丝成雪1 小时前
网关整合验签
大数据·数据结构·docker·微服务·系统架构
bagadesu2 小时前
使用Docker构建Node.js应用的详细指南
java·后端
没有bug.的程序员2 小时前
Spring Cloud Gateway 性能优化与限流设计
java·spring boot·spring·nacos·性能优化·gateway·springcloud
Kisorge3 小时前
【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
stm32·嵌入式硬件·算法
洛_尘3 小时前
JAVA EE初阶 2: 多线程-初阶
java·开发语言
Slow菜鸟3 小时前
Java 开发环境安装指南(五) | Git 安装
java·git
hnjzsyjyj4 小时前
洛谷 P12141:[蓝桥杯 2025 省 A] 红黑树
数据结构·蓝桥杯·二叉树
铭哥的编程日记4 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(二)基础算法(下)
算法·职场和发展·蓝桥杯
Swift社区4 小时前
LeetCode 421 - 数组中两个数的最大异或值
算法·leetcode·职场和发展