草庐IT

mmap_sem

全部标签

linux - 为什么我不能在 64 位内核上 mmap(MAP_FIXED) 32 位 Linux 进程中的最高虚拟页面?

在尝试测试时Isitallowedtoaccessmemorythatspansthezeroboundaryinx86?在Linux的用户空间中,我编写了一个32位测试程序,试图映射32位虚拟地址空间的低页和高页。在echo0|之后sudotee/proc/sys/vm/mmap_min_addr,我可以映射零页,但是我不知道为什么我不能映射-4096,即(void*)0xfffff000,最高页。为什么mmap2((void*)-4096)返回-ENOMEM?strace./a.outexecve("./a.out",["./a.out"],0x7ffe08827c10/*65va

linux - 为什么我不能在 64 位内核上 mmap(MAP_FIXED) 32 位 Linux 进程中的最高虚拟页面?

在尝试测试时Isitallowedtoaccessmemorythatspansthezeroboundaryinx86?在Linux的用户空间中,我编写了一个32位测试程序,试图映射32位虚拟地址空间的低页和高页。在echo0|之后sudotee/proc/sys/vm/mmap_min_addr,我可以映射零页,但是我不知道为什么我不能映射-4096,即(void*)0xfffff000,最高页。为什么mmap2((void*)-4096)返回-ENOMEM?strace./a.outexecve("./a.out",["./a.out"],0x7ffe08827c10/*65va

c - 如何在内核模块中使用 do_mmap()

我想在内核模块中使用do_mmap()。根据thisquestion这应该是可能的。这是一个最小的非工作示例:hp_km.c:#include#includeMODULE_LICENSE("GPL");staticint__inithp_km_init(void){do_mmap(0,0,0,0,0,0,0,0,0);return0;}staticvoid__exithp_km_exit(void){}module_init(hp_km_init);module_exit(hp_km_exit);Makefile:obj-m+=hp_km.oall:make-C/lib/modules

c - 如何在内核模块中使用 do_mmap()

我想在内核模块中使用do_mmap()。根据thisquestion这应该是可能的。这是一个最小的非工作示例:hp_km.c:#include#includeMODULE_LICENSE("GPL");staticint__inithp_km_init(void){do_mmap(0,0,0,0,0,0,0,0,0);return0;}staticvoid__exithp_km_exit(void){}module_init(hp_km_init);module_exit(hp_km_exit);Makefile:obj-m+=hp_km.oall:make-C/lib/modules

c - 使堆栈指针指向 mmap 返回的指针。 (Linux,32 位虚拟机)

我试图将我的堆栈指针移动到一个mmap-ed区域以模拟上下文切换,但不知何故下面的代码总是给出一个段错误:C:structsavectx{void*regs[JB_SIZE];};structsavectx*initctx=(structsavectx*)malloc(sizeof(savectx));void*newsp;if((newsp=mmap(0,STACK_SIZE,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANONYMOUS,0,0))==MAP_FAILED){perror("mmapfailed");}initctx->regs[4]=

c - 使堆栈指针指向 mmap 返回的指针。 (Linux,32 位虚拟机)

我试图将我的堆栈指针移动到一个mmap-ed区域以模拟上下文切换,但不知何故下面的代码总是给出一个段错误:C:structsavectx{void*regs[JB_SIZE];};structsavectx*initctx=(structsavectx*)malloc(sizeof(savectx));void*newsp;if((newsp=mmap(0,STACK_SIZE,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANONYMOUS,0,0))==MAP_FAILED){perror("mmapfailed");}initctx->regs[4]=

c++ - 用于大文件 I/O 的 mmap()?

我正在用C++创建一个在Linux上运行的实用程序,它可以将视频转换为专有格式。视频帧非常大(高达16兆像素),我们需要能够直接查找准确的帧数,因此我们的文件格式使用libz单独压缩每个帧,并将压缩数据附加到文件中。完成所有帧的写入后,包含每个帧的元数据(包括它们的文件偏移量和大小)的日志将写入文件末尾。我目前正在使用ifstream和ofstream来执行文件i/o,但我希望尽可能地进行优化。我听说mmap()在很多情况下可以提高性能,我想知道我的情况是否是其中之一。我们的文件将在几十到几百GB之间,虽然写入总是按顺序进行,但随机访问读取应该在恒定时间内完成。关于我是否应该进一步调查

c++ - 用于大文件 I/O 的 mmap()?

我正在用C++创建一个在Linux上运行的实用程序,它可以将视频转换为专有格式。视频帧非常大(高达16兆像素),我们需要能够直接查找准确的帧数,因此我们的文件格式使用libz单独压缩每个帧,并将压缩数据附加到文件中。完成所有帧的写入后,包含每个帧的元数据(包括它们的文件偏移量和大小)的日志将写入文件末尾。我目前正在使用ifstream和ofstream来执行文件i/o,但我希望尽可能地进行优化。我听说mmap()在很多情况下可以提高性能,我想知道我的情况是否是其中之一。我们的文件将在几十到几百GB之间,虽然写入总是按顺序进行,但随机访问读取应该在恒定时间内完成。关于我是否应该进一步调查

c - 如何为 mmap() 禁用写时复制和按需填零

我正在使用mmap()执行cp(文件复制)命令。为此,我将源文件映射到MAP_PRIVATE(因为我只想读取)模式,将目标文件映射到MAP_SHARED模式(因为我必须写回目标文件的更改内容)。在执行此操作时,我观察到由于2个原因导致的许多次要页面错误导致性能下降。1)为源文件调用mmap(MAP_PRIVATE)时按需填零。2)在为目标文件调用mmap(MAP_SHARED)时复制写入。有什么方法可以禁用按需填零和写时复制吗?谢谢,哈里什 最佳答案 mmap(2)有MMAP_POPULATE标志:http://linux.die.

c - 如何为 mmap() 禁用写时复制和按需填零

我正在使用mmap()执行cp(文件复制)命令。为此,我将源文件映射到MAP_PRIVATE(因为我只想读取)模式,将目标文件映射到MAP_SHARED模式(因为我必须写回目标文件的更改内容)。在执行此操作时,我观察到由于2个原因导致的许多次要页面错误导致性能下降。1)为源文件调用mmap(MAP_PRIVATE)时按需填零。2)在为目标文件调用mmap(MAP_SHARED)时复制写入。有什么方法可以禁用按需填零和写时复制吗?谢谢,哈里什 最佳答案 mmap(2)有MMAP_POPULATE标志:http://linux.die.