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。
上图可以看到start_brk为heap段的起始,brk为heap段的结束
mmap
malloc通过mmap调用来在memory mapping segment中创建一块内存返回给malloc