本地环境
虚拟机
Description: Deepin 20.4
Release: 20.4
Codename: apricot
开始操作
#首先随便找个位置,mkdir libc用来保存你的最后编译好的so,我这里就用/home/xxx/libc
cd /usr/src/
mkdir glibc
cd glibc
wget http://ftp.gnu.org/gnu/glibc/glibc-2.23.tar.gz
tar -zxvf glibc-2.23.tar.gz
cd glibc-2.23
mkdir build
cd build/
CFLAGS=" -g3 -ggdb -gdwarf-4 -Og -Wno-error"
CXXFLAGS=" -g3 -ggdb -gdwarf-4 -Og -Wno-error"
../configure --prefix=/home/xxxx/libc --disable-werror
make -j4
make install -j4
中间可能有报错
一个是
/tmp/cc2dus00.s: 错误:`loc1@GLIBC_2.2.5' can't be versioned to common symbol 'loc1'
4 /tmp/cc2dus00.s: 错误:`loc2@GLIBC_2.2.5' can't be versioned to common symbol 'loc2'
5 /tmp/cc2dus00.s: 错误:`locs@GLIBC_2.2.5' can't be versioned to common symbol 'locs'
将misc/regexp.c源文件中的:
char *loc1
char *loc2
char *locs
修改为:
char *loc1 __attribute__ ((nocommon));
char *loc2 __attribute__ ((nocommon));
char *locs __attribute__ ((nocommon));
还有一个就是
error: suggest explicit braces to avoid ambiguous ‘else’ [-Werror=dangling-else]
if (*np != NULL)
^
找到对应文件就加个{}就好
另外再提一嘴,configure的时候可能会报错缺失组件,你看确实什么就apt install 什么就好,很简单的
下载patchelf
当编译好libc.so后,下载一个patchelf,这个网上挺多的
patchelf --set-interpreter ./ld-2.23.so ./a.out
patchelf --replace-needed libc.so.6 ./libc-2.23.so ./a.out
a.out就是对应的自己的测试程序,编译的时候最好加上-g参数
开始调试
1.c
#include<malloc.h>
int main(){
void *p=malloc(0x10);
void *p2=malloc(0x20);
free(p);
free(p2);
p=NULL;
p2=NULL;
return 0;
}
gcc 1.c -g
patchelf --set-interpreter ./ld-2.23.so ./a.out
patchelf --replace-needed libc.so.6 ./libc-2.23.so ./a.out
gdb a.out
b main
r
s
可以看到进入源码了
如果进不去的尝试在gdb里面输入
dir /path/to/you/glic/malloc/source
我的就是
dir /usr/src/glibc/glibc-2.23/malloc
32位源码环境
跟64位差不多,只是加了一点点参数
mkdir test
cd test
../configure --prefix=/home/zhou/libc-so-32/libc-2.23 --disable-werror \
--host=i686-linux-gnu \
--build=i686-linux-gnu \
CC="gcc -m32" CXX="g++ -m32" \
CFLAGS="-g3 -ggdb -gdwarf-4 -Og -Wno-error -march=i686" \
CXXFLAGS="-g3 -ggdb -gdwarf-4 -Og -Wno-error -march=i686"