malloc用到的系统调用

malloc用到的系统调用

malloc在调用的过程中会用到brk和mmap这两个系统调用来获取内存。

brk

br调用k通过增加program break location(brk)地址来获取内存。初始的时候brk地址和start_brk地址指向同一个地址。

When ASLR is turned off, start_brk and brk would point to end of data/bss segment (end_data).
When ASLR is turned on, start_brk and brk would be equal to end of data/bss segment (end_data) plus random brk offset.

初始时:
当ASLR(堆栈libc地址随机化)关闭时,start_brk和brk都指向bss段的顶部。
当ASLR开启时,start_brk和brk都指向bss段顶部加上一个随机的offset。

Above “process virtual memory layout” picture shows start_brk is the beginning of heap segment and brk (program break) is the end of heap segment.
上图可以看到start_brk为heap段的起始,brk为heap段的结束

mmap

malloc通过mmap调用来在memory mapping segment中创建一块内存返回给malloc