- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我需要保留 256-512 Mb 的连续物理内存,并且可以从用户空间访问此内存。
我决定使用 CMA 来保留内存。
以下是我的想法必须执行的步骤:
但下一段代码会导致段错误(大小 = 1Mb):
int file;
void* start;
file=open("/dev/mem", O_RDWR | O_SYNC);
if ( (start = mmap(0, 1024*1024, PROT_READ | PROT_WRITE, MAP_SHARED, file, 0x27400000)) == MAP_FAILED ){
perror("mmap");
}
for (int offs = 0; offs<50; offs++){
cout<<((char *)start)[offs];
}
此代码的输出:“mmap:无效参数”。
当我在 0 上更改 offset = 0x27400000 时,此代码运行良好并且程序显示垃圾。它也适用于我在/proc/iomem 中查看的许多偏移量。根据来自/proc/iomem 的信息,CMA 区域的物理地址(在我的系统上为 0x27400000)始终位于系统 RAM 中。
有没有人有任何想法,如何在/dev/mem 上映射 CMA 区域?我究竟做错了什么?非常感谢您的帮助!
最佳答案
Jeff Haran 在 kernelnewbies 邮件列表中向我建议了这个问题的解决方案。
有必要在 .config 中禁用 CONFIG_x86_PAT 并且 mmap() 已开始工作!
If CONFIG_X86_PAT is configured you will have problems mapping memory to user space. It basically implements the same restrictions as CONFIG_STRICT_DEVMEM.
Jeff Haran
现在我可以在我想要的任何物理地址上映射/dev/mem。
但需要小心:
Word of caution. CONFIG_X86_PAT was likely introduced for a reason. There may be some performance penalties for turning this off, though in my testing so far turning if off doesn’t seem to break anything.
Jeff Haran
关于linux - mmap CMA 区域 on/dev/mem,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21256467/
在mutagen , 我正在注入(inject)各种代码中的突变。我想改变的一件事是模式 if let Ok(x) = y { .. } .然而,这构成了相当大的挑战,因为我不知道 y 的类型– 用户
在多处理器中,我们知道 lock inc mem :锁可以保证没有其他操作可以访问地址mem . 但是当一个处理器正在执行 mov eax,mem首先,然后在完成之前,第二个处理器执行 lock in
在通过 /metrics 端点公开的 Spring Boot 指标中,mem 和 mem.free 的含义是什么? 我们正在对部署在三个节点上的新 Spring Boot 微服务进行负载测试,每个盒子
我看了perf list的手册,找到了memory load/store的PMU事件定义: mem-loads OR cpu/mem-loads/ [Ke
Grub 是一个兼容多重引导的引导加载程序。当它启动操作系统时,它会创建一个定义可用内存的结构,并在内存中留下指向该结构的指针。 我在这里得到了这些信息: http://wiki.osdev.org/
我正在尝试实现 Wildfly 8.1.0。最终域设置,配置文件 full-ha,具有 1 个主服务器和 2 个从服务器,并通过 mod_cluster 进行负载平衡。 我的环境:1) VPS (Di
在 x86 上,如果 mem 是 32 位对齐的,那么 mov 操作保证是原子的。 如果 [mem] 不是 32 位对齐,可以 lock inc [mem]窗台工作正常吗? 工作正常:提供原子性而不是
基本上,我的问题是以下代码是否有效。 void* mem = operator new(sizeof(T)); T* instance = new(mem) T; delete instance; 如
int a[10]; int b[10]; memcmp(a, b, sizeof(int) * 10); memcmp() 只告诉我们哪个内存块更大/更小,因为它只返回 -1,0,+1。有没有一种方
fn main() { let k = "fire"; drop(k); println!("{:?}", k); } Playground 为什么删除后仍然可以使用k? dr
我有这个问题: let list = [(1,2);(2,3);(1,4);(5,0)];; List.mem (1,2) list;; - : bool = true 但是我需要修改这个函数,例如
我正在试验的问题与正确执行的 open() 或 mmap() 函数无关。我在内核中禁用了 CONFIG_STRICT_DEVMEM,所以我可以毫无问题地从 /dev/mem 中读取。实际上,我可以执行
如果我希望直接使用其他应用程序的虚拟地址访问数据,我可以使用虚拟地址访问 proc/[pid]/mem 吗?偏移量与虚拟地址相同吗? 从代码角度来看,如果我 fseeko(the-proc/[pid]
我正在开发 Raspberry PI (Linux rpi 3.12.28+),并且我有以下 C 代码,可用于操作 GPIO 端口: // IO Acces struct bcm2835_periph
我正在尝试为一个类(class)项目完成一个内存分配器的编写,这不是必要的作业,因为它没有被分配,我自己选择了这个项目。 我有两行标记为 #1 和 #2,两者都不起作用并给出不同的错误消息,以下是详细
这是我想写的代码: template class record : public record { using baseT = record; T1 elem; public: re
当使用这个表达式时: mem::size_of::() * 8 像这样: value % (mem::size_of::() * 8); value * (mem::size_of::() * 8);
我正在使用我的 Raspberry Pi,我正在编写一个 cgi python 脚本来创建一个网页来控制我的 gpio 输出引脚。当我尝试将 RPi.GPIO 导入为 GPIO 时,我的脚本崩溃了。这
我想控制对 dev/mem 的访问。 为了做到这一点,我正在考虑创建一个假的 dev/mem,以便进程访问它而不是实际的 dev/mem。 然后,我的进程将根据假进程中的更改修改 dev/mem。 这
我尝试打开/dev/mem。访问 /dev/mem 需要 root 权限才能打开该文件。 但是我无法在 super 用户中使用我的程序。所以我将/dev/mem访问权限更改为666(不要考虑安全问题!
我是一名优秀的程序员,十分优秀!