rhe6 sX64装配gcc411过程
下载
在GCC网站上(http://gcc.gnu.org/ )或者通过网上搜索可以查找到下载资源。目前GCC的最新版本为 3.4.0。可供下载的文件一般有两种形式:gcc-3.4.0.tar.gz和gcc-3.4.0.tar.bz2,只是压缩格式不一样,内容完全一致,下载其中一种即可。
解压缩
根据压缩格式,选择下面相应的一种方式解包(以下的“%”表示命令行提示符):
% tar xzvf gcc-3.4.0.tar.gz
或者
% bzcat gcc-3.4.0.tar.bz2 | tar xvf –
注:如果下载更新的 gcc ,比如 gcc-4.1.1 或 gcc-4.1.0 ,后面就要修改 texinfo 的版本支持信息,因为版本太高了
新生成的gcc-3.4.0这个目录被称为源目录,用${srcdir}表示它。以后在出现${srcdir}的地方,应该用真实的路径来替换它。用pwd命令可以查看当前路径。
在${srcdir}/INSTALL目录下有详细的GCC安装说明,可用浏览器打开index.html阅读。
建立目标目录
目标目录(用${objdir}表示)是用来存放编译结果的地方。GCC建议编译后的文件不要放在源目录${srcdir}中(虽然这样做也可以),最好单独存放在另外一个目录中,而且不能是${srcdir}的子目录。
例如,可以这样建立一个叫 gcc-build 的目标目录(与源目录${srcdir}是同级目录):
% mkdir gcc-build
% cd
gcc-build
以下的操作主要是在目标目录 ${objdir} 下进行。
配置
配置的目的是决定将GCC编译器安装到什么地方(${destdir}),支持什么语言以及指定其它一些选项等。其中,${destdir}不能与${objdir}或${srcdir}目录相同。
${srcdir}下的configure来完成的。其命令格式为(记得用你的真实路径替换${destdir}) 配置是通过执行
% ${srcdir}/configure --prefix=${destdir}
[
其它选项
]
例如,如果想将GCC 3.4.0安装到/usr/local/gcc-3.4.0目录下,则${destdir}就表示这个路径。
在我的机器上,我是这样配置的:
% ../gcc-3.4.0/configure --prefix=/usr/local/gcc-3.4.0
--enable-threads=posix --disable-checking --enable--long-long
--host=i386-redhat-linux --with-system-zlib
--enable-languages=c,c++,java
注:这里我把--host=i386-redhat-linux --with-system-zlib 都删除了,前面是你的机器名,后面如果不删除我就碰到了这个问题:
../../gcc-4.1.1/gcc/java/jcf-io.c
-o java/jcf-io.o
../../gcc-4.1.1/gcc/java/jcf-io.c:43:18: error: zlib.h:
没有这个文件或目录
../../gcc-4.1.1/gcc/java/jcf-io.c: In function
\u2018read_zip_member\u2019:
../../gcc-4.1.1/gcc/java/jcf-io.c:193: error:
\u2018Z_NO_COMPRESSION\u2019 undeclared (fir st use in this
function)
../../gcc-4.1.1/gcc/java/jcf-io.c:193: error: (Each undeclared
identifier is rep orted only once
../../gcc-4.1.1/gcc/java/jcf-io.c:193: error: for each function it
appears in.)
../../gcc-4.1.1/gcc/java/jcf-io.c:206: error: \u2018z_stream\u2019
undeclared (first use i n this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:206: error: expected
\u2018;\u2019 before \u2018d_stream\u2019
../../gcc-4.1.1/gcc/java/jcf-io.c:207: error: \u2018d_stream\u2019
undeclared (first use i n this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:207: error:
\u2018alloc_func\u2019 undeclared (first
use in this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:207: error: expected
\u2018;\u2019 before numeric consta nt
../../gcc-4.1.1/gcc/java/jcf-io.c:208: error: \u2018free_func\u2019
undeclared (first use in this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:208: error: expected
\u2018;\u2019 before numeric consta nt
../../gcc-4.1.1/gcc/java/jcf-io.c:209: error: \u2018voidpf\u2019
undeclared (first use in this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:209: error: expected
\u2018;\u2019 before numeric consta nt
../../gcc-4.1.1/gcc/java/jcf-io.c:225: warning: implicit
declaration of
function \u2018inflateInit2\u2019
../../gcc-4.1.1/gcc/java/jcf-io.c:225: error: \u2018MAX_WBITS\u2019
undeclared (first use in this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:226: warning: implicit
declaration of
function \u2018inflate\u2019
../../gcc-4.1.1/gcc/java/jcf-io.c:226: error:
\u2018Z_NO_FLUSH\u2019 undeclared (first
use in this function)
../../gcc-4.1.1/gcc/java/jcf-io.c:227: warning: implicit
declaration of
function \u2018inflateEnd\u2019
make[2]: *** [java/jcf-io.o]
错误
1
make[2]: Leaving directory `/usr/src/gcc-4.1.1-build/gcc'
make[1]: *** [stage2_build]
错误
2
make[1]: Leaving directory `/usr/src/gcc-4.1.1-build/gcc'
make: *** [bootstrap] \u9519\u8bef 2
原因很简单是因为--with-system-zlib,当然要你装好 zlib ,特别是 zlib 的开发包了,一般是 zlib-devel,删除该条即可。
将GCC安装在/usr/local/gcc-3.4.0目录下,支持C/C++和JAVA语言,其它选项参见GCC提供的帮助说明。
编译
% make
这是一个漫长的过程。在我的机器上(P4-1.6),这个过程用了50多分钟。
注:若你用的gcc版本较高的话,可能会出现以下错误:
WARNING: `makeinfo' is
missing on your system. You
should only need it if
you modified
a `.texi' or `.texinfo' file, or any other file
indirectly
affecting the aspect of the
manual. The spurious
call might
also be the consequence of using a buggy `make' (AIX,
DU,
IRIX). You might want to install
the `Texinfo' package or
the `GNU
make' package. Grab either from
any GNU archive site.
make[4]: *** [fastjar.info] 错误1
make[4]: Leaving directory `/usr/src/gcc-4.1.1-build/fastjar'
make[3]: *** [all] 错误 2
make[3]: Leaving directory `/usr/src/gcc-4.1.1-build/fastjar'
make[2]: *** [all-fastjar] 错误 2
make[2]: Leaving directory `/usr/src/gcc-4.1.1-build'
make[1]: *** [all] 错误2
make[1]: Leaving directory `/usr/src/gcc-4.1.1-build'
make: *** [bootstrap] 错误2
出现此错误的原因是在configure文件中texinfo对该版本不支持可以在configure里找到
以下语句
if ${MAKEINFO} --version \
| egrep 'texinfo[^0-9]*([1-3][0-9]|4\.[2-9]|[5-9])' >/dev/null 2>&1; then
:
else
MAKEINFO="$MISSING makeinfo"
fi
;;
其中4\.[2-9]|[5-9]表示的是支持4.2-4.9之间的几个版本,所以需要自己添加4\.[1-9][0-9]*,以支持4.11版本。即把'texinfo[^0-9]*([1-3][0-9]|4\.[2-9]|[5-9])'编辑成'texinfo[^0-9]*([1-3][0-9]|4\.[2-9]|4\.[1-9][0-9]*|[5-9])'后保存,编译通过。
安装
执行下面的命令将编译好的库文件等拷贝到${destdir}目录中(根据你设定的路径,可能需要管理员的权限):
% make install
至此,GCC 3.4.0安装过程就完成了。
其它设置
GCC 3.4.0的所有文件,包括命令文件(如gcc、g++)、库文件等都在${destdir}目录下分别存放,如命令文件放在bin目录下、库文件在 lib下、头文件在include下等。由于命令文件和库文件所在的目录还没有包含在相应的搜索路径内,所以必须要作适当的设置之后编译器才能顺利地找到并使用它们。
gcc 、 g++ 、 gcj 的设置
要想使用GCC ${destdir}/bin放在环境变量PATH中。我不用这种方式,而是用符号连接的方式实现,这样做的好处是我仍然可以使用系统上原来的旧版本的GCC编译器。 3.4.0的gcc等命令,简单的方法就是把它的路径
首先,查看原来的gcc所在的路径:
% which gcc
在我的系统上,上述命令显示:/usr/bin/gcc。因此,原来的gcc命令在/usr/bin目录下。我们可以把GCC
3.4.0中的gcc、g++、gcj等命令在/usr/bin目录下分别做一个符号连接:
% cd /usr/bin
% ln -s ${destdir}/bin/gcc
gcc34
% ln -s ${destdir}/bin/g++
g++34
% ln -s ${destdir}/bin/gcj gcj34
这样,就可以分别使用gcc34、g++34、gcj34来调用GCC 3.4.0的gcc、g++、gcj完成对C、C++、JAVA程序的编译了。同时,仍然能够使用旧版本的GCC编译器中的gcc、g++等命令。
库路径的设置
将${destdir}/lib路径添加到环境变量LD_LIBRARY_PATH中,最好添加到系统的配置文件中,这样就不必要每次都设置这个环境变量了。
例如,如果GCC 3.4.0安装在/usr/local/gcc-3.4.0目录下,在RH Linux下可以直接在命令行上执行或者在文件/etc/profile中添加下面一句:
$LD_LIBRARY_PATH
测试
用新的编译命令(gcc34、g++34等)编译你以前的C、C++程序,检验新安装的GCC编译器是否能正常工作。
根据需要,可以删除或者保留${srcdir}和${objdir}目录。
1.在http://ftp.gnu.org/gnu/texinfo/下载个4.11
2.安装 ./configure --prefix=/usr &&
make &&
make install &&
make TEXMF=/usr/share/texmf install-tex
搞一个g++-multilib
http://linuxappfinder.com/package/g++-multilib
意思是换一个目录编译
http://oss.org.cn/ossdocs/gnu_linux/lfs/lfs-5.0/chapter06/glibc.htmlGlibc 的安装指南推荐用一个新建的目录来编译它,而不是在源码目录中:
mkdir ../glibc-build
cd ../glibc-build
为编译 Glibc 做准备:
../glibc-2.3.2/configure --prefix=/usr \
--disable-profile --enable-add-ons \
--libexecdir=/usr/bin --with-headers=/usr/include
新的配置参数意思是:
*
--libexecdir=/usr/bin: 将 pt_chown 程序安装到 /usr/bin 目录下。
*
--with-headers=/usr/include: 确保本次编译使用 /usr/include 里的内核头文件。如果你不指定这个参数,可能会用到/tools/include里的头文件,就不太完美了(尽管它们其实是一样的)。用这个参数还有个好处,如果你忘了在 /usr/include 目录下安装内核头文件,马上就能知道。
编译软件包:
make
运行测试套件:
make check
安装 Glibc-2.3.2 在 第 5 章里的测试套件说明这里也同样适用,有疑问的话,就参考一下前面的内容。
安装软件包:
make install
上面的命令没有安装 locale ( Glibc 用它来使你的 Linux 系统能用另一种语言反馈信息),所以用下面的命令来安装它们:
make localedata/install-locales