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;
}
相关推荐
Miraitowa_cheems16 分钟前
LeetCode算法日记 - Day 64: 岛屿的最大面积、被围绕的区域
java·算法·leetcode·决策树·职场和发展·深度优先·推荐算法
Christo326 分钟前
关于K-means和FCM的凸性问题讨论
人工智能·算法·机器学习·数据挖掘·kmeans
Lisonseekpan37 分钟前
Spring Boot 中使用 Caffeine 缓存详解与案例
java·spring boot·后端·spring·缓存
为java加瓦39 分钟前
Rust 的类型自动解引用:隐藏在人体工学设计中的魔法
java·服务器·rust
SimonKing43 分钟前
分布式日志排查太头疼?TLog 让你一眼看穿请求链路!
java·后端·程序员
消失的旧时光-19431 小时前
Kotlin 判空写法对比与最佳实践
android·java·kotlin
_不会dp不改名_1 小时前
leetcode_1382 将二叉搜索树变平衡树
算法·leetcode·职场和发展
小许学java1 小时前
Spring AI快速入门以及项目的创建
java·开发语言·人工智能·后端·spring·ai编程·spring ai
一叶飘零_sweeeet1 小时前
从 “死锁“ 到 “解耦“:重构中间服务破解 Java 循环依赖难题
java·循环依赖
greentea_20131 小时前
Codeforces Round 173 B. Digits(2043)
c++·算法