gpt4 book ai didi

file-permissions - 从用户空间 : operation not permitted 读取/dev/cpu/*/msr

转载 作者:行者123 更新时间:2023-12-04 07:23:11 25 4
gpt4 key购买 nike

我正在尝试编写一个可以读取 msr 寄存器的简单应用程序,并且正在从用户空间运行该应用程序。

我已经加载了 msr 模块,并为每个人授予了/dev/cpu/*/msr 的读取权限。但是用户仍然无法访问这些文件,但 root 可以。

权限如下所示:

crw-r--r-- 1 root root 202, 0 sep  6 17:55 /dev/cpu/0/msr

crw-r--r-- 1 root root 202, 1 sep 6 17:55 /dev/cpu/1/msr

crw-r--r-- 1 root root 202, 2 sep 6 17:55 /dev/cpu/2/msr

crw-r--r-- 1 root root 202, 3 sep 6 17:55 /dev/cpu/3/msr

当我尝试从用户空间读取这些文件时,我不断收到“不允许操作”错误消息,但当 root 尝试访问它们时工作正常。我究竟做错了什么?我在内核版本为 3.11.0 的 Ubuntu 13.04 上。

最佳答案

自 3.7 以来,主线 Linux 内核中的更改现在需要可执行文件具有 CAP_SYS_RAWIO 功能来打开 MSR 设备文件 [2]。除了加载 MSR 内核模块并在 msr 设备文件上设置适当的文件权限外,还必须使用以下命令将 CAP_SYS_RAWIO 功能授予需要访问 MSR 驱动程序的任何用户可执行文件:

sudo setcap cap_sys_rawio=ep <user_executable>

关于file-permissions - 从用户空间 : operation not permitted 读取/dev/cpu/*/msr,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18661976/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com