1.5.8 glibc malloc
glibc
glibc 即 GNU C Library,是为 GNU 操作系统开发的一个 C 标准库。glibc 主要由两部分组成,一部分是头文件,位于 /usr/include
;另一部分是库的二进制文件。二进制文件部分主要是 C 语言标准库,有动态和静态两个版本,动态版本位于 /lib/libc.so.6
,静态版本位于 /usr/lib/libc.a
。
这一章中,我们将阅读分析 glibc 的源码,下面先把它下载下来,并切换到我们需要的版本:
下面来编译它,首先修改配置文件 Makeconfig,将 -Werror
注释掉,这样可以避免高版本 GCC(v8.1.0) 将警告当做错误处理:
接下来需要打上一个 patch:
然后就可以编译了:
如果我们想要在编译程序时指定 libc,可以像这样:
然后如果希望在调试时指定 libc 的源文件,可以使用 gdb 命令 directory
,但是这种方法的缺点是不能解析子目录,所以推荐使用下面的命令在启动时加载:
malloc.c
下面我们先分析 glibc 2.23 版本的源码,它是 Ubuntu16.04 的默认版本,在 pwn 中也最常见。然后,我们再探讨新版本的 glibc 中所加入的漏洞缓解机制。
相关结构
堆块结构
Allocated Chunk
Free Chunk
Top Chunk
Bins 结构
Fast Bins
Small Bins
Large Bins
Unsorted Bins
Arena 结构
分配函数
_int_malloc()
释放函数
_int_free()
重分配函数
_int_realloc()
参考资料
Last updated