- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在 linux 中试验 shm_open 并遇到问题。我经常使用 ftrunc 调整共享内存段的大小,并使用 mmap 重新映射调整大小的段。然而,就在 20 兆字节左右,我从 mmap 获得了 ENOMEM。
我尝试做的事情来解决这个问题:
首先,我了解了这些 sysctl 参数。我重新配置了它们:
kernel.shmmax = 268435456
kernel.shmall = 2097152
(shmall在页面中指定)
此后问题依旧。调查导致问题的调整大小的详细信息表明,调用 ftrunc 以调整共享内存对象的大小成功(/dev/shm 中的相应文件具有请求的新大小)。
此处 http://pubs.opengroup.org/onlinepubs/009695399/functions/mmap.html 的文档提出了 ENOMEM errno 的三个可能原因:
[经济]指定了 MAP_FIXED,范围 [addr,addr+len) 超出了进程地址空间允许的范围;或者,如果未指定 MAP_FIXED 并且地址空间中没有足够的空间来影响映射。
[经济][ML] [Option Start] 如果 mlockall() 需要,则无法将映射锁定在内存中,因为它需要的空间超过系统能够提供的空间。 [选项结束]
[经济][TYM] [Option Start] fildes 指定的类型化内存对象中剩余的未分配内存资源不足,无法分配 len 字节。 [选项结束]
我没有使用 MAP_FIXED 或锁定,/dev/shm 中图像的大小表明第三个原因不是问题所在。我的 mmap 调用如下所示:
mmap(内存, 长度, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0)
其中 mem 最初是 0,此后指的是最后一个地址 mmap 成功映射。
我发现信息表明 ulimit 设置可能将内存可映射限制为单个进程,但我认为问题不在这里。以防万一,ulimit -a 在我的机器上看起来像这样:
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 20
file size (blocks, -f) unlimited
pending signals (-i) 16382
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 65536
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) unlimited
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
我希望这是一个简单的 :)
最佳答案
好吧,前几天我发现了我的问题所在。我误读了 mmap 的文档,它说 mmap 返回一个基于第一个参数的映射(在我的例子中是之前映射的地址),结果由实现定义。我将此视为 mmap 可能会为我重新映射我以前的映射的建议,但事实并非如此。如果我使用了 MAP_FIXED 标志,可能只会出现这种情况,但我避免了这种情况,因为文档建议不要这样做。在任何情况下,都必须在创建新映射之前使用 munmap 删除以前的映射。我希望这篇文章能帮助任何和我一样做出愚蠢误读的人
关于linux - mmap 返回带有 shm_open 文件对象的 ENOMEM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8932604/
我想了解 mmap 的工作原理。mmap 的用户级调用如下所示。 void *mmap(void *addr, size_t len, int prot, int flags, int
我正在做一个Bottle驱动程序,我使用 yield 关键字和 mmap.mmap 对象在输出流中发送多个映射文件,如以下代码所示: for mapping in mappings: yield
我来自 C++/RAII 世界。 所以我对何时以及如何调用 mmap.close() 感到困惑[不是 file.close()]。 或者,根本不调用它?会不会漏气? 至于来自 document 的示例
我正在我的大学上操作系统类(class),我们的任务之一是使用 mmap 实现简单的 malloc。现在我开始工作了,我尝试使用 valgrind 来检测遗留的任何错误。不管是否释放内存,valgri
有谁知道 mmap(2) 和 mmap(3) 的区别是什么?手册第 3 节被描述为“本章描述了除第 2 章中描述的实现系统调用的库函数之外的所有库函数。” mmap(3) 不执行系统调用吗? 阅读这两
我不知道我在理解mmap时错过了哪些知识。我就是想不通。但让我这样问我的问题: 我有很多(例如 3 个)文件 block ,其大小分别为 s1、s2、s3。 s1、s2 和 s3 均小于 Mmap (
在 Linux 下: #free -m total used free shared buffers cachedMem:
我正在尝试将 C 库(beaglebone PRU 驱动程序 prussdrv.c)与 Python 连接。我想要访问的特定函数返回一个 mmap 指针,如下所示: int __prussdrv_me
当我调用mmap时: ptr = mmap(NULL, ...); 并要求系统提供一个缓冲区并将文件映射到其中,然后使用 再次调用 mmap ptr2 = mmap(ptr, ...); 尝试
在 Android 上用 Java 内存映射一个大文件效果很好。但是当映射总数超过 ~1.5GB 时,即使有多个映射调用,它也会失败: mmap failed: ENOMEM (Out of memo
我在具有 64G 内存和大量磁盘空间的 debian-64 上运行一个专门的数据库守护进程。它使用磁盘上的哈希表(mmaped)并通过定期 write() 调用将实际数据写入文件。当进行大量更新时,m
C++代码: #include #include #include #include #include using namespace std; #define FILE_MODE (S_I
我想处理一个由 4Kb block 组成的文件。 随着事情的发生,我将编写更多数据并映射新部分,取消映射我不再需要的部分。 当要映射的文件数据总量约为 4Gb 时,仅 4Kb 的 map() 是否太小
大家好,我正在尝试将下面的代码转换为 python(访问树莓派 1Mhz 计时器),我不知道什么时候要映射对象,我们需要 + TIMER_OFFSET (timer = (long long int
我所做的是一个垃圾收集器,使用mmap(2)为用户空间分配空间,这就要求最初分配时可以从任何地方开始,但是后面的分配地址应该是与之前的分配连续,如下所示: page_size = getpagesiz
众所周知,最重要的 mmap() 功能是在许多进程之间共享文件映射。但众所周知,每个进程都有自己的地址空间。 问题是内存映射文件(更具体地说,它的数据)真正保存在哪里,以及进程如何访问这些内存? 我的
什么限制了内存映射文件的大小?我知道它不能大于未分配地址空间的最大连续块,并且应该有足够的可用磁盘空间。但是还有其他限制吗? 最佳答案 您太保守了:内存映射文件可能大于地址空间。 查看 内存映射文件的
如果我使用 mmap 来编写 uint32_t,我会遇到大端/小端约定的问题吗?特别是,如果我在 big-endian 机器上写入一些数据 mmap,当我尝试在 little-endian 机器上读取
所以,对于我最后一年的项目,我使用 Video4Linux2 从相机中提取 YUV420 图像,将它们解析为 x264(本地使用这些图像),然后通过 Live555 将编码流发送到 RTP/RTCP通
是 mmap在它们的效果中调用原子? 也就是说,是否由 mmap 进行了映射更改以原子方式出现在访问受影响区域的其他线程中? 作为试金石,请考虑您执行 mmap 的情况。在一个全为零的文件中(来自线程
我是一名优秀的程序员,十分优秀!