Windows中装软件使用安装包,安装包解压后有2种情况:
linux中安装软件比windows中复杂。linux中安装软件一般有以下几种方法:
总结:我们安装交叉编译工具链(arm-linux-gcc)实际采用第二种安装方式。
我们选择交叉编译工具链的原则:和我们所使用的目标平台(给哪款SoC编程)尽量去匹配。
譬如我们开发S5PV210的程序就是用arm-2009q3这个版本,因为三星官方在开发S5pv210时就使用这个版本的交叉编译工具链,这样可以最大限度的避免稀奇古怪的问题出现。
步骤1:打开虚拟机,在/usr/local/下创建/usr/local/arm文件夹
步骤2:先将安装包从Windows中弄到linux中去。可以用共享文件夹,也可以用Samba,也可以cuteftp。
步骤3:解压。tar -jxvf arm-2009q3.tar.bz2
到此相当于程序已经安装完毕,真正的应用程序安装在/usr/local/arm/arm-2009q3/bin目录下。
注:linux中的目录管理方法。
技术角度来讲,linux 中所有目录性质都是一样的,所以技术角度来讲我们把软件安装到哪里都行。但是因为如果胡乱放置,将来程序可能不好找。所以久而久之大家就总结了一个文件放置的一般定义,譬如说
/bin 目录放置一些系统自带的用户使用的应用程序;
/sbin目录下存放的是系统自带的系统管理方面的应用程序。
那我们装软件放在哪里?一般都在 /usr 目录下。我们安装 arm-linux-gcc,就在 /usr/local/ 底下创建一个 arm 文件夹,然后装到里面。
root@ubuntu:/usr/local/arm# ls
arm-2009q3 arm-2009q3.tar.bz2
root@ubuntu:/usr/local/arm#
到真正的应用程序的安装目录下(也就是 /usr/local/arm/arm-2009q3/bin),去执行 arm-linux-gcc -v.
执行方法是:./arm-none-linux-gnueabi-gcc -v
执行后可以得到一长串输出,其中有“gcc version 4.4.1 ”字样,即表示安装成功。
root@ubuntu:/usr/local/arm/arm-2009q3/bin# ./arm-none-linux-gnueabi-gcc -v
Using built-in specs.
Target: arm-none-linux-gnueabi
Configured with: /scratch/julian/2009q3-respin-linux-lite/src/gcc-4.4/configure --build=i686-pc-linux-gnu --host=i686-pc-linux-gnu --target=arm-none-linux-gnueabi --enable-threads --disable-libmudflap --disable-libssp --disable-libstdcxx-pch --enable-extra-sgxxlite-multilibs --with-arch=armv5te --with-gnu-as --with-gnu-ld --with-specs='%{funwind-tables|fno-unwind-tables|mabi=*|ffreestanding|nostdlib:;:-funwind-tables} %{O2:%{!fno-remove-local-statics: -fremove-local-statics}} %{O*:%{O|O0|O1|O2|Os:;:%{!fno-remove-local-statics: -fremove-local-statics}}}' --enable-languages=c,c++ --enable-shared --disable-lto --enable-symvers=gnu --enable-__cxa_atexit --with-pkgversion='Sourcery G++ Lite 2009q3-67' --with-bugurl=https://support.codesourcery.com/GNUToolchain/ --disable-nls --prefix=/opt/codesourcery --with-sysroot=/opt/codesourcery/arm-none-linux-gnueabi/libc --with-build-sysroot=/scratch/julian/2009q3-respin-linux-lite/install/arm-none-linux-gnueabi/libc --with-gmp=/scratch/julian/2009q3-respin-linux-lite/obj/host-libs-2009q3-67-arm-none-linux-gnueabi-i686-pc-linux-gnu/usr --with-mpfr=/scratch/julian/2009q3-respin-linux-lite/obj/host-libs-2009q3-67-arm-none-linux-gnueabi-i686-pc-linux-gnu/usr --with-ppl=/scratch/julian/2009q3-respin-linux-lite/obj/host-libs-2009q3-67-arm-none-linux-gnueabi-i686-pc-linux-gnu/usr --with-host-libstdcxx='-static-libgcc -Wl,-Bstatic,-lstdc++,-Bdynamic -lm' --with-cloog=/scratch/julian/2009q3-respin-linux-lite/obj/host-libs-2009q3-67-arm-none-linux-gnueabi-i686-pc-linux-gnu/usr --disable-libgomp --enable-poison-system-directories --with-build-time-tools=/scratch/julian/2009q3-respin-linux-lite/install/arm-none-linux-gnueabi/bin --with-build-time-tools=/scratch/julian/2009q3-respin-linux-lite/install/arm-none-linux-gnueabi/bin
Thread model: posix
gcc version 4.4.1 (Sourcery G++ Lite 2009q3-67)
root@ubuntu:/usr/local/arm/arm-2009q3/bin#
环境变量就是操作系统的全局变量。
每一个环境变量对操作系统来说都是唯一的,名字和所代表的意义都是唯一的。linux 系统可以有很多个环境变量。其中有一部分是 linux 系统自带的,还有一些是我们自己来扩充的。我们这里涉及到的一个环境变量是 PATH。PATH 这个环境变量是系统自带的,它的含义就是系统在查找可执行程序时会搜索的路径范围。
export PATH=/usr/local/arm/arm-2009q3/bin:$PATH
在一个终端中执行以上命令后,该终端中就可以直接使用 arm-linux-gcc了,但是只要关掉这个终端再另外打开一个立马就不行了。原因是我们本次终端中执行时的操作只是针对本终端,以后再打开的终端并未被执行过这个命令所以没导出。
解决方案是在 ~/.bashrc 中,添加 export PATH=/usr/local/arm/arm-2009q3/bin:$PATH
即可。
注意:我们导出这个环境变量是在当前用户,如果你登录时在其他用户下是没用的。
shell 脚本文件 mkgcc.sh 内容如下:
#!/bin/bash
# 一键生成 arm-linux-gcc -> arm-none-linux-gnueabi-gcc 这类的工具链符号链接cmd=`ls arm*`
prefix_symbol_name="arm-linux-"
for elem in $cmd
dosuff=`echo $elem | awk -F'-' '{print $5}'`ln $elem -s ${prefix_symbol_name}$suff
done
源自朱有鹏老师.