汇编编程中的内存映射、动态链接与共享库构建
内存映射(mmap)系统调用
在汇编编程里,mmap 系统调用可用于将文件映射到内存,或者请求特定大小的内存块。使用时,有个偏移量(Offset)参数,若要把文件映射到内存,可用它指定文件的起始位置;若不涉及文件映射,就将其设为 0。
请求一个两页长的内存块,示例代码如下:
movq $9, %rax # mmap syscall number
movq $0, %rdi # Linux chooses the destination
movq $8192, %rsi # Two pages of memory
movq $0x03, %rdx # Memory should be read-write
movq $0x22, %r10 # Requesting private memory not tied to a file
movq $-1, %r8 # No file descriptor attached
movq $0, %r9 # No offset requested
syscall
# Result in %rax
若要把分配的内存归还给操作系统,可使用 munmap 系统调用(调用号为 11),它需要两个参数:要取消映射的内存地址(%rdi)和大小(%rsi)。
mmap 系统调用虽灵活,但会带来显著的复杂性。若设想一个基于 mmap 的内存分配器,它每次得请求整页内存,所以需要有两层分配机制:先进行块分配,再进行单个内存分配。当程序请求内存时,得遍历