Goog下午,我最近下载了www.kernel.org主线2.6.39Linux内核的源代码发行版。我们正在寻找void的Linux源代码(void,size_t长度,int,int标志,int,off_t偏移)。解压缩tar.bz2发行版后,我们找到一个包含内存映射源代码的文件mmap.c。但是,我们无法在mmap.c中为void (void、size_t长度、int、int标志、int、off_t偏移)编写Linux源代码。是否有任何Linux工程师或管理员知道在哪里可以获得void (void、size_t长度、int、int标志、int、off_t偏移量)的Linux源代码?另外,我们对MapViewOfFile的Windows源代码很感兴趣。我很清楚这一点,因为Microsoft源代码不在开源领域。如果有人想知道为什么我们需要这个源代码,我们将尝试使用32位架构上的缓存内存映射文件实现来优化C++去复制程序原型的运行时性能。我们想了解如何使用mmap和MapViewOfFile来优化原型的运行时性能?谢谢。
发布于 2011-05-27 16:27:06
对于MapViewOfFile,我会检查Winbase.h,但它可能只是声明,否则您将不得不转向反向工程,这在大多数国家被认为是非法的。
我发现了一篇关于MMAP及其工作原理的广泛文章这里。也许能帮上忙。
发布于 2011-05-27 16:39:23
从android源码中提取;
#include <unistd.h>
#include <errno.h>
#include <sys/mman.h>
extern void* __mmap2(void*, size_t, int, int, int, size_t);
#define MMAP2_SHIFT 12
void* mmap( void* addr, size_t size, int prot, int flags, int fd, long offset )
{
if ( offset & ((1UL << MMAP2_SHIFT)-1) ) {
errno = EINVAL;
return MAP_FAILED;
}
return __mmap2(addr, size, prot, flags, fd, (size_t)offset >> MMAP2_SHIFT);
}来源:mmap.c
现在,实际的__mmap2调用有程序集,因此它将取决于您的arch。下面是一个x86版本:
/* autogenerated by gensyscalls.py */
#include <sys/linux-syscalls.h>
.text
.type __mmap2, @function
.globl __mmap2
.align 4
__mmap2:
pushl %ebx
pushl %ecx
pushl %edx
pushl %esi
pushl %edi
pushl %ebp
mov 28(%esp), %ebx
mov 32(%esp), %ecx
mov 36(%esp), %edx
mov 40(%esp), %esi
mov 44(%esp), %edi
mov 48(%esp), %ebp
movl $__NR_mmap2, %eax
int $0x80
cmpl $-129, %eax
jb 1f
negl %eax
pushl %eax
call __set_errno
addl $4, %esp
orl $-1, %eax
1:
popl %ebp
popl %edi
popl %esi
popl %edx
popl %ecx
popl %ebx
ret来源:mmap2.S
发布于 2011-05-27 16:50:45
要获得Win32 MapViewOfFile实现,您必须支付昂贵的订阅费,签署合法的保密协议等。
linux mmap是公开可读的。但是,您应该知道有两个部分: glibc中的mmap函数和内核中匹配的syscall,所有有趣的位都在其中。您展示的签名是glibc函数的签名,不要期望syscall具有完全相同的参数。
但是,您可以“理解如何使用mmap和MapViewOfFile”,而无需阅读实现。
https://stackoverflow.com/questions/6155094
复制相似问题