📄 glibc2-howto-6.html
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN"><HTML><HEAD><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=gb2312"> <META NAME="GENERATOR" CONTENT="SGML-Tools 1.0.7"> <TITLE>Glibc 2 HOWTO 中文版: 使用非主要的 C 函式库编译程式</TITLE> <LINK HREF="Glibc2-HOWTO-7.html" REL=next> <LINK HREF="Glibc2-HOWTO-5.html" REL=previous> <LINK HREF="Glibc2-HOWTO.html#toc6" REL=contents></HEAD><BODY><A HREF="Glibc2-HOWTO-7.html">Next</A><A HREF="Glibc2-HOWTO-5.html">Previous</A><A HREF="Glibc2-HOWTO.html#toc6">Contents</A><HR><H2><A NAME="s6">6. 使用非主要的 C 函式库编译程式</A></H2><P><P>有些时候你会想要使用不同的函式库来编译你的程式,这一节会解释如何达成这个目的。我会使用在前两节中所使用的目录与安装名称,记得要改变这些名称以符合你的设定。<P><H2><A NAME="ss6.1">6.1 一个关於使用非主要 C 函式库的警告</A></H2><P>在你开始编译任何会在开机时用到的程式之前,假如程式是动态连结,并且是在 non-root partition 被 mount 之前使用的话,那所有连结用的函式库都必须在 root partition 上。在前面的安装程序里,我们将 glibc 安装成主要的函式库,而旧的函式库仍然保留在 <CODE>/lib</CODE>,<CODE>/lib</CODE> 会在 root partition 上,也就是说,所有在开机时会用到的程式都能正常工作。然而,若你的 <CODE>/usr</CODE> 是在不同的 partition 上,且把 glibc 当成测试用的函式库,安装在 <CODE>/usr/i486-linuxglibc2</CODE>,那除非 <CODE>/usr</CODE> 已经被 mount,否则所有你用 glibc 编译的程式都将不能使用。<P><H2><A NAME="ss6.2">6.2 用测试安装的 glibc 编译程式</A></H2><P>要用测试安装的 glibc 编译程式,你必须要将 include 路径重设成 glibc 的 include 路径。指定 "-nostdinc" 会取消正常 include 路径,而 "-I/usr/i486-linuxglibc2/include" 则会指到 glibc 的 include目录,你也必须要指定 gcc 标准 include 目录,通常是 <CODE>/usr/lib/gcc-lib/i486-linuxglibc2/2.7.2.2/include</CODE>。(这里假设你安装测试的函式库在 i486-linuxglibc2,而 gcc 的版本是 2.7.2.2)<P>要用测试安装的 glibc 来连结,你必须指明 gcc 设定,这是由 "-b i486-linuxglibc2" 这选项来达成。<P>对大部份的程式,你可以简单的将其加入 makefile 的<CODE>$CFLAGS</CODE>与<CODE>$LDFLAGS</CODE>选项中:<BLOCKQUOTE><CODE><PRE> CFLAGS = -nostdinc -I/usr/i486-linuxglibc2/include -I/usr/lib/gcc-lib/i486-linuxglibc2/2.7.2.2/include -b i486-linuxglibc2 LDFLAGS = -b i486-linuxglibc2 </PRE></CODE></BLOCKQUOTE>假如你使用 configure 这个 script,在执行 configure 之前,定义 shell 变数 <CODE>$CFLAGS</CODE> 与 <CODE>$LDFLAGS</CODE>(在 csh/tcsh 下用 env/setenv在 sh/bash/其它之下用 set/export)。这样产生的 makefile 应该会包含正确的 <CODE>$CFLAGS</CODE> 与<CODE>$LDFLAGS</CODE>。不过并非所有的 configure scrpt 都会去取得这些变数,所以在执行完 configure 之後,你还是要检查一下 makefile,假如需要的话,手动修改它。<P>假如你所要编译的程式只呼叫 gcc,(而不直接呼叫 cpp 或 binutils)你可以使用以下的 script,省去每次指定所有选项的麻烦:<BLOCKQUOTE><CODE><PRE> #!/bin/bash /usr/bin/gcc -b i486-linuxglibc2 -nostdinc \ -I/usr/i486-linuxglibc2/include \ -I/usr/lib/gcc-lib/i486-linuxglibc2/2.7.2.2/include "$@" </PRE></CODE></BLOCKQUOTE>编译时你可以使用这个 script 而不是 gcc。<P><H2><A NAME="ss6.3">6.3 当 glibc 是主要函式库时用 libc 5 编译程式</A></H2><P>当你已经将 glibc 安装成主要的函式库之後,又想用旧的函式库来编译程式的时候,你必须将 include 路径重设成旧的路径。指定 "-nostdinc" 将会使预设的路径无效,而 "-I/usr/i486-linuxlibc5/include" 会将 include的路径指到旧函式库的 include 路径,你也必须要指定"-I/usr/lib/gcc-lib/i486-linuxlibc5/2.7.2.2/include"以含入 gcc 所需的 include 档。注意要视你新的目录与 gcc 版本来调整这些路径。<P>要用旧的 libc 来做连结,你必须指定 gcc 所用的架构。这是由 "-b i486-linuxlibc5" 这个选项所指定的。<P>对大部份的程式,你可以简单的将这些选项加入到 makefile 里的<CODE>$CFLAGS</CODE>与<CODE>$LDFLAGS</CODE>选项里:<BLOCKQUOTE><CODE><PRE> CFLAGS = -nostdinc -I/usr/i486-linuxlibc5/include -I/usr/lib/gcc-lib/i486-linuxlibc5/2.7.2.2/include -b i486-linuxlibc5 LDFLAGS = -b i486-linuxlibc5 </PRE></CODE></BLOCKQUOTE>假如你使用 configure 这个 script,在执行 configure 之前,定义 shell 变数 <CODE>$CFLAGS</CODE> 与 <CODE>$LDFLAGS</CODE>(在 csh/tcsh 下用 env/setenv在 sh/bash/或其它之下用 set/export)。这样产生的 makefile 应该会包含正确的 <CODE>$CFLAGS</CODE> 与<CODE>$LDFLAGS</CODE>。不过并非所有的 configure scrpt 都会去取得这些变数,所以在执行完 configure 之後,你还是要简检查一下 makefile,假如需要的话,手动修改它。<P>假如你所要编译的程式只呼叫 gcc,(而不直接呼叫 cpp 或 binutils)你可以使用以下的 script,省去每次指定所有选项的麻烦:<BLOCKQUOTE><CODE><PRE> #!/bin/bash /usr/bin/gcc -b i486-linuxlibc5 -nostdinc \ -I/usr/i486-linuxlibc5/include \ -I/usr/lib/gcc-lib/i486-linuxlibc5/2.7.2.2/include "$@" </PRE></CODE></BLOCKQUOTE>编译时你可以使用这个 script 而不是 gcc。<P><P><HR><A HREF="Glibc2-HOWTO-7.html">Next</A><A HREF="Glibc2-HOWTO-5.html">Previous</A><A HREF="Glibc2-HOWTO.html#toc6">Contents</A></BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -