首页
/ CPU-X在FreeBSD 14.1上的构建与运行问题分析

CPU-X在FreeBSD 14.1上的构建与运行问题分析

2025-07-03 01:00:38作者:俞予舒Fleming

项目背景

CPU-X是一款功能强大的系统信息检测工具,能够显示CPU、主板、内存等硬件详细信息。该项目支持多种操作系统,包括Linux、FreeBSD等。本文将重点分析CPU-X在FreeBSD 14.1系统上的构建与运行过程中遇到的主要问题及其解决方案。

主要问题分析

1. GTK界面加载失败

在FreeBSD 14.1上构建CPU-X时,用户遇到了GTK界面加载失败的问题。错误表现为:

gtkmm: object 'daemoninfobar' not found in GtkBuilder file
gtkmm: Gtk::Builder: widget 'daemoninfobar' was not found
Gtk::Builder::get_widget(): dynamic_cast<> failed

这些问题源于构建系统未能正确识别UI文件的安装路径。在默认情况下,CPU-X会搜索/usr/local/share/cpu-x//usr/share/cpu-x/目录下的UI文件,但当用户指定了自定义安装前缀(如/opt/cpu-x)时,构建系统未能正确调整搜索路径。

2. 温度检测功能失效

CPU-X在FreeBSD系统上通过sysctlbyname接口获取CPU温度信息。原始代码假设温度值以字符串形式返回,但在FreeBSD 14.1上,温度实际上以整数形式(单位为0.1K)存储在sysctl变量中。

错误表现为:

failed to retrieve CPU temperature (fallback mode)

3. PolKit授权问题

CPU-X需要以root权限运行后台服务(daemon)来获取某些特权信息。在FreeBSD 14.1上,用户遇到了PolKit授权失败的问题:

Error executing command as another user: No authentication agent found
pkexec: authorization could not be obtained (not authorized)

解决方案

1. 路径搜索逻辑修复

针对GTK界面加载问题,开发团队修复了get_data_path()函数的路径搜索逻辑。现在当用户指定自定义安装前缀时,构建系统会优先在该前缀下的share目录中查找UI文件。

2. 温度检测接口适配

对于温度检测问题,代码已更新为正确处理FreeBSD返回的温度值格式。新实现将原始值(单位为0.1K)转换为摄氏度:

int dK;
size_t len = sizeof(dK);
if(!sysctlbyname(format("dev.cpu.%i.temperature", core_id), &dK, &len, NULL, 0)) {
    // 转换公式:(dK - 2731) / 10.0
    casprintf(&temperature_str, "%.1f°C", (dK - 2731) / 10.);
}

3. PolKit规则更新

PolKit授权问题涉及两个方面:

  1. Action ID变更:从v5.0.0开始,CPU-X的PolKit action ID从org.cpu-x-daemon变更为io.github.thetumultuousunicornofdarkness.cpu-x-daemon,用户需要相应更新PolKit规则。

  2. 安装路径问题:当使用自定义前缀(如/opt/cpu-x)安装时,PolKit策略文件被安装到了非标准路径,导致被忽略。修复方案是确保策略文件被安装到FreeBSD的标准路径/usr/local/share/polkit-1/actions/

更新后的PolKit规则示例:

polkit.addRule(function(action, subject) {
    if (action.id == "io.github.thetumultuousunicornofdarkness.cpu-x-daemon" && 
        subject.isInGroup("wheel")) {
        return polkit.Result.YES;
    }
});

构建建议

对于FreeBSD用户,建议使用以下CMake配置选项:

cmake . \
    -DCMAKE_INSTALL_PREFIX=/usr/local \
    -DWITH_NCURSES=0 \
    -DWITH_GETTEXT=0 \
    -DWITH_VULKAN=0 \
    -DFORCE_LIBSTATGRAB=1

关键选项说明:

  • -DCMAKE_INSTALL_PREFIX=/usr/local:使用FreeBSD的标准前缀
  • -DWITH_NCURSES=0:禁用ncurses界面(可选)
  • -DFORCE_LIBSTATGRAB=1:强制使用libstatgrab库

总结

CPU-X在FreeBSD 14.1上的运行问题主要涉及路径搜索、温度检测接口和权限管理三个方面。通过更新代码逻辑和正确配置构建选项,这些问题都已得到解决。对于FreeBSD用户,建议关注项目更新并及时调整系统配置,以确保获得最佳使用体验。

对于仍在使用旧版本FreeBSD port的用户,建议迁移到最新源代码构建,以获得更好的硬件兼容性和功能支持。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
858
509
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
257
300
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
331
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
397
370
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
22
5