关于gcc、glibc和binutils模块之间的关系

标签: gcc glibc binutils | 发表时间:2012-03-31 13:44 | 作者:iTech
出处:http://www.cnblogs.com/itech/


转自: http://www.mike.org.cn/articles/linux-about-gcc-glibc-and-binutils-the-relationship-between-modules/

一、关于gcc、glibc和binutils模块之间的关系
  1、gcc(gnu collect compiler)是一组编译工具的总称。它主要完成的工作任务是“预处理”和“编译”,以及提供了与编译器紧密相关的运行库的支持,如libgcc_s.so、libstdc++.so等。
  2、binutils提供了一系列用来创建、管理和维护二进制目标文件的工具程序,如汇编(as)、连接(ld)、静态库归档(ar)、反汇编(objdump)、elf结构分析工具(readelf)、无效调试信息和符号的工具(strip)等。通常,binutils与gcc是紧密相集成的,没有binutils的话,gcc是不能正常工作的。
  3、glibc是gnu发布的libc库,也即c运行库。glibc是linux系统中最底层的api(应用程序开发接口),几乎其它任何的运行库都会倚赖于glibc。glibc除了封装linux操作系统所提供的系统服务外,它本身也提供了许多其它一些必要功能服务的实现,主要的如下:
 
  (1)string,字符串处理
  (2)signal,信号处理
  (3)dlfcn,管理共享库的动态加载
  (4)direct,文件目录操作
  (5)elf,共享库的动态加载器,也即interpreter
  (6)iconv,不同字符集的编码转换
  (7)inet,socket接口的实现
  (8)intl,国际化,也即gettext的实现
  (9)io
  (10)linuxthreads
  (11)locale,本地化
  (12)login,虚拟终端设备的管理,及系统的安全访问
  (13)malloc,动态内存的分配与管理
  (14)nis
  (15)stdlib,其它基本功能
  二、在现有系统上如何升级
  1、升级这些库时,最好不要覆盖系统中缺省的;因为这些库,尤其是glibc库,是系统中最核心的共享库和工具,如果盲目覆盖,很可能导致整个系统瘫痪,因为一般更新glibc库时,其它所有以来libc库的共享库都需要重新被编译一遍。因此,为了调试某个程序进入glibc时,最好把glibc安装到/usr/local/lib下。
  2、首先编译glibc库。注意最好令建立一个glibc-build的目录,configure时加上–enable-add-ons=linuxthreads选项。make install安装到/usr/local下。
  3、修改gcc的spec文件(/usr/lib/gcc-lib/i386-redhat-linux/3.2.2/specs),更改ld-linux.so.2为/usr/local/lib下的新的共享库装载器。
  4、编译binutils库,此时被编译出的程序会连接到/usr/local/lib下的新的libc库。注意,在configure前,需要设置ld缺省连接的路径(LIBRARY_PATH=/usr/local/lib:/lib:/usr/lib),否则binutils会configure出错,找不到libc中的一些符号。具体步骤如下:
 
  (1)export LIBRARY_PATH=/usr/local/lib:/lib:/usr/lib
  (2)mkdir binutils-build && cd binutils-build
  (3)../binutils-2.13.90.0.18/configure
  (4)make
  (5)make -C ld clean
  (6)make -C ld LIB_PATH=/usr/lib:/lib:/usr/local/bin(设置编译后的ld的缺省库搜索路径,后面的比前面的优先级高)
  (7)make install
  三、总结
  1、运行时,动态库的装载依赖于ld-linux.so.6的实现,它查找共享库的顺序如下:
 
  (1)ld-linux.so.6在可执行的目标文件中被指定,可用readelf命令查看
  (2)ld-linux.so.6缺省在/usr/lib和lib中搜索;当glibc安装到/usr/local下时,它查找/usr/local/lib
  (3)LD_LIBRARY_PATH环境变量中所设定的路径
  (4)/etc/ld.so.conf(或/usr/local/etc/ld.so.conf)中所指定的路径,由ldconfig生成二进制的ld.so.cache中
  2、编译时,搜索库的路径顺序如下:
 
  (1)ld-linux.so.6由gcc的spec文件中所设定
  (2)gcc –print-search-dirs所打印出的路径,主要是libgcc_s.so等库。可以通过GCC_EXEC_PREFIX来设定
  (3)LIBRARY_PATH环境变量中所设定的路径,或编译的命令行中指定的-L/usr/local/lib 
  (4)binutils中的ld所设定的缺省搜索路径顺序,编译binutils时指定。(可以通过“ld –verbose | grep SEARCH”来查看)
  3、二进制程序的搜索路径顺序为PATH环境变量中所设定。一般/usr/local/bin高于/usr/bin
  4、编译时的头文件的搜索路径顺序,与library的查找顺序类似。一般/usr/local/include高于/usr/include

完! 

本文链接

相关 [gcc glibc binutils] 推荐:

关于gcc、glibc和binutils模块之间的关系

- - 博客园_iTech's Blog
转自: http://www.mike.org.cn/articles/linux-about-gcc-glibc-and-binutils-the-relationship-between-modules/. 一、关于gcc、glibc和binutils模块之间的关系.   1、gcc(gnu collect compiler)是一组编译工具的总称.

GCC安装 配置

- - CSDN博客推荐文章
下载:  http://ftp.gnu.org/gnu/gcc/gcc-4.5.1/gcc-4.5.1.tar.bz2. 浏览:  http://ftp.gnu.org/gnu/gcc/gcc-4.5.1/. 查看Changes:  http://gcc.gnu.org/gcc-4.5/changes.htm.

Glibc改变导致bug出现

- allengaller - Solidot
在网上通过Flash插件听MP3遭遇破音的Linux用户也许需要去看下Fedora bugzilla,但这个bug的根源颇有些周折: Glibc开发者改动了memcpy()函数实现,它在理论上只是对目前的处理器进行优化,但不幸的是改动暴露了代码中的bug,开发者忽略了传递给memcpy()函数的源和目标数组不能重叠的规定.

GCC将用C++实现

- Chris - Solidot
Lwn.net报道,GCC(GNU Compiler Collection,GNU编译器套装)将从一个C语言实现变成C++语言实现. Mark Mitchell在官方邮件列表上宣布,GCC指导委员会和自由软件基金会(FSF)同意GCC本身的代码将使用C++语言编写. 此举是为了向用户提供一个更好的编译器,而不是因为C++代码库本身的原因.

GCC功能及使用

- - CSDN博客推荐文章
编译过程(从源代码到可执行文件). 预处理:gcc -Ehello.c -o hello.i //生成预处理后的源文件. 汇编:gcc -S hello.i //生成hello.s. 目标代码生成:gcc -c hello.s //生成hello.o. 连接:gcc hello.o -o hello //生成可以行文件hello.

RMS谈GCC、LLVM和Copyleft

- - Solidot
ESR(Eric S.Raymond)在GCC邮件列表上发贴预言,LLVM/Clang编译器将在3到5年内威胁到GCC的统治地位,认为GCC编译器的反插件政策正成为一大障碍. 虽然Clang尚未达到GCC的成熟度,但在某些方面它拥有比GCC更出色的特性,例如错误信息. ESR建议GCC应允许非自由的插件.

GCC、LLVM-GCC、DragonEgg和Clang编译性能对比

- allengaller - Solidot
Phoronix利用Phoronix Test Suite测试了GCC 4.2.1、4.3.0、4.4.0、4.5.0、GCC 4.6.0 2010-10-30开发预览版,以及LLVM-GCC 2.8、LLVM DragonEgg 2.8和Clang 2.8编译器的编译性能. 测试结果显示,与新贵LLVM-GCC和Clang相比,有二十多年历史的GCC编译器确实比较慢 虽然LLVM和Clang的新版本提供了完整的C++支持,并且能编译Linux kernel,但它们目前还达不到取代成熟GCC的程度,Clang或DragonEgg还无法完成某些常见任务的编译,性能也未能如意.

如何利用GCC编译选项检测栈溢出

- - 极客范 - GeekFan.net
Stack smashing是堆栈缓冲区溢出(stack buffer overflow)的一个时髦称谓. 它表示利用代码中存在的缓冲区溢出bug而发起的攻击. 在早期,这完全是程序员的责任,他们要确保代码中不存在缓冲区溢出的问题. 但是随着时间推移,技术的不断发展,现在像gcc这样的编译器已经有编译选项用来确保缓冲区溢出问题不被攻击者利用来破坏系统或者程序.

gcc创建和使用动态库、静态库

- - CSDN博客综合推荐文章
本文以工程 libtest为例来说明用gcc创建和使用静态库、动态库的过程. libtest工程目录结构如下:. libtest/include/hello.h文件内容:. libtest/lib/hello.c文件内容:. libtest/src/main.c文件内容:. 1,进入libtest/lib目录,执行命令:.

linux下用gcc创建静态链接库和动态链接库

- - CSDN博客推荐文章
上一篇文章介绍了在windows下如何创建静态链接库和动态链接库( http://blog.csdn.net/love_cppandc/article/details/8502773),这一篇介绍一下在linux下如何创建静态链接库和动态链接库. 在linux下,静态库文件是.o结尾,动态库文件是.so结尾.