1.环境:
Ubuntu 16.04
2.获取
wget mirrors.ustc.edu.cn/gnu/gcc/gcc-4.8.3/gcc-4.8.3.tar.bz2
3.解压
tar xvf gcc-4.8.3.tar.bz2
4.切换目录
cd gcc-4.8.3
5.下载mpfr等依赖库
./contrib/download_prerequisites
6.创建编译目录
mkdir build
7.切换到build目录
cd build
8.配置
CC=arm-linux-gcc AR=arm-linux-ar ../configure --prefix=/mnt/ssd/gcc --enable-checking=release --enable-languages=c,c++ --enable-threads=posix --disable-multilib --host=arm-linux --target=arm-linux
8.1 --prefix=/mnt/ssd/gcc 指定安装目录
8.2 --enable-languages=c,c++ 支持的编程语言
8.3 --enable-threads=posix 使用posix/unix98作为支持线程库
8.4 --disable-multilib 取消32位库编译
8.5 --host --build --target 举例如下:
--build=i686-pc-linux-gnu --host=arm --target=mips
表示在pc上进行编译,编译运行在arm上的gcc,gcc生成mips指令架构的程序
9.编译
make -j10
10.安装
make install
转自:https://www.cnblogs.com/dakewei/p/7508116.html
一.gcc编译的情况:
1.linux gcc包含的c/c++编译器,gcc和cc是一样的,c++和g++是一样的,一般c程序就用gcc编译,c++程序就用g++编译。
2.linux gcc的应用:直接编译生成 a.out文件 -o 指定生成文件名字。
3.linux gcc 编译时遇到"undefined reference to 'xxxxx'"的错误,不是编译出错,是连接出错,没有指定链接程序要用到的库。比如数学函数库要
加-lm ,数据库库要加 -lsqlite3,线程函数库要加 -lpthread 等。
分析:-l参数就是用来指定程序要链接的库,-l参数紧接着就是库名,比如数学库,他的库名是m,他的库文件名是libm.so,很容易看出,把库文件名的头lib和尾.so去掉就是库名。
当我们自已要用到一个第三方提供的库名字libtest.so,那么我们只要把libtest.so拷贝到/usr/lib里,编译时加上-ltest参数,我们就能用上libtest.so库了(当然要用libtest.so库里的函数,我们还需要与libtest.so配套的头文件)。在/lib和 /usr/lib和/usr/local/lib里的库直接用-l参数就能链接了,但如果库文件没放在这三个目录里,而是放在其他目录里,这时我们只用 -l参数的话,链接还是会出错,
出错信息大概是:“/usr/bin/ld: cannot find -lxxx”,也就是链接程序ld在那3个目录里找不到libxxx.so,这时另外一个参数-L就派上用场了,比如常用的X11的库,它在/usr /X11R6/lib目录下,我们编译时就要用-L/usr/X11R6/lib -lX11参数,-L参数跟着的是库文件所在的目录名。再比如我们把libtest.so放在/aaa/bbb/ccc目录下,那链接参数就是-L /aaa/bbb/ccc -ltest
4.linux gcc 编译时遇到"xxxx.h: No such file or directory"的错误
-I参数是用来指定头文件目录,/usr/include目录一般是不用指定的,gcc知道去那里找,但是如果头文件不在/usr/include里我们就要用-I参数指定了,比如头文件放在/myinclude目录里,那编译命令行就要加上-I/myinclude参数了。
5.linux gcc 程序优化参数
一般用-O2就是,用来优化程序用的,比如gcc test.c -O2,优化得到的程序比没优化的要小,执行速度可能也有所提高。
6.linux下的交叉编译工具和使用方法(平台移植和嵌入式开发时用到)
我们平常做的编译就叫本地编译,也就是在当前平台编译,编译得到的程序也是在本地执行,在本地机器上编译程序到其
他机器上的编译器就叫交叉编译器,
使用方法跟本地的gcc差不多,但有一点特殊的是:必须用-L和-I参数指定编译器用第三方系统的库和头文件,不能用本
地(X86)的库(头文件有时可以用本地的)
例子:sparc-xxxx-linux-gnu-gcc test.c -L/path/to/sparcLib -I/path/to/sparcInclude
Linux 中最重要的软件开发工具是 GCC。GCC 是 GNU 的 C 和 C++ 编译器。实际上,GCC 能够编译三种语言:C、C++
和 Object C(C 语言的一种面向对象扩展)。利用 gcc 命令可同时编译并连接 C 和 C++ 源程序。
GCC 可同时用来编译 C 程序和 C++ 程序。一般来说,C 编译器通过源文件的后缀名来判断是 C 程序还是 C++
程序。在 Linux 中,C 源文件的后缀名为 .c,而 C++ 源文件的后缀名为 .C 或 .cpp。
gcc 命令只能编译 C++ 源文件,而不能自动和 C++ 程序使用的库连接。因此,通常使用 g++ 命令来完成 C++
程序的编译和连接,该程序会自动调用 gcc 实现编译。
-ansi 只支持 ANSI 标准的 C 语法。这一选项将禁止 GNU C 的某些特色,例如 asm 或 typeof 关键词。
-c 只编译并生成目标文件。
-DMACRO 以字符串“1”定义 MACRO 宏。
-DMACRO=DEFN 以字符串“DEFN”定义 MACRO 宏。
-E 只运行 C 预编译器。
-g 生成调试信息。GNU 调试器可利用该信息。
-IDIRECTORY 指定额外的头文件搜索路径DIRECTORY。
-LDIRECTORY 指定额外的函数库搜索路径DIRECTORY。
-lLIBRARY 连接时搜索指定的函数库LIBRARY。
-m486 针对 486 进行代码优化。
-o FILE 生成指定的输出文件。用在生成可执行文件时。
-O0 不进行优化处理
-O 或 -O1 优化生成代码。
-O2 进一步优化。
-O3 比 -O2 更进一步优化,包括 inline 函数。
-shared 生成共享目标文件。通常用在建立共享库时。
-static 禁止使用共享连接。
-UMACRO 取消对 MACRO 宏的定义
-w 不生成任何警告信息。
-Wall 生成所有警告信息。
7.build,host,target的含义
【build】当前你使用的计算机。
【host】你的目的是编译出来的程序可以在host上运行。
【target】普通程序没有这个概念。对于想编译出编译器的人来说此属性决定了新编译器编译出的程序可以运行在哪!
如:
我要在FL2440arm开发板上写点程序,但是因为在板子上调试麻烦,我不想在arm开发板上开发编译,于是我就想在自己电脑上
开发然后copy过去给它用。这时我就需要一个在我的x86(build)上编译一个“可以在我x86(host)本机上运行的gcc,这个新gcc
编出来的程序是可以在arm(target)上运行的”。 此时选项为 build=x86,host=x86,target = arm。
此时我用这个gcc编译一个helloworld,这个helloworld的build=x86,host=arm
二.以configure --host=arm-linux 命令也可以交叉编译