内核数据结构mm_struct中的成员变量start_code和end_code是进程代码段的起始和终止地址,start_data和 end_data是进程数据段的起始和终止地址,start_stack是进程堆栈段起始地址,start_brk是进程动态内存分配起始地址(堆的起始地址),还有一个 brk(堆的当前最后地址),就是动态内存分配当前的终止地址。
C语言的动态内存分配基本函数是malloc(),在Linux上的基本实现是通过内核的brk系统调用。brk()是一个非常简单的系统调用,只是简单地改变mm_struct结构的成员变量brk的值。
http://blog.csdn.net/ugg/archive/2009/07/13/4344522.aspx
brk(0) = 0x890f000
brk(0x8930000) = 0x8930000
一个疑问:在扩展堆的时候,不是以页为单位,而是一下子申请了0x21000页,这个不清楚为什么。
注意:在最后,一个brk调用将堆栈全部释放了,这说明堆栈是可以释放的,通过系统调用brk。另一方面,它是一次性释放,而不是分几步,说明当堆栈末尾还有内容时,是不释放堆栈的。