shell脚本的编写
使用的是#!/bin/bush脚本
首先if条件句使用的是 "[]"而不是"()"
else if使用的是"elif"
else没有的话就不要空着
if条件判断中传进去的参数为空的话会报错使用双"[[]]"可避免这种报错,使用help也可以
shell中的与或非与c不同
例:布尔运算符
! | 非运算,表达式为 true 则返回 false,否则返回 true。 | [ ! false ] 返回 true。 |
-o | 或运算,有一个表达式为 true 则返回 true。 | [ $a -lt 20 -o $b -gt 100 ] 返回 true。 |
-a | 与运算,两个表达式都为 true 才返回 true。 | [ $a -lt 20 -a $b -gt 100 ] 返回 false。 |
例:逻辑运算符
&& | 逻辑的 AND | [[ $a -lt 100 && $b -gt 100 ]] 返回 false |
|| | 逻辑的 OR | [[ $a -lt 100 || $b -gt 100 ]] 返回 true |
例:关系运算符
-eq | 检测两个数是否相等,相等返回 true。 | [ $a -eq $b ] 返回 false。 |
-ne | 检测两个数是否不相等,不相等返回 true。 | [ $a -ne $b ] 返回 true。 |
-gt | 检测左边的数是否大于右边的,如果是,则返回 true。 | [ $a -gt $b ] 返回 false。 |
-lt | 检测左边的数是否小于右边的,如果是,则返回 true。 | [ $a -lt $b ] 返回 true。 |
-ge | 检测左边的数是否大于等于右边的,如果是,则返回 true。 | [ $a -ge $b ] 返回 false。 |
-le | 检测左边的数是否小于等于右边的,如果是,则返回 true。 | [ $a -le $b ] 返回 true。 |
例:参数的传递
$0 | 传递到脚本的第零个参数(脚本名) |
$1 | 传递到脚本的第一个参数 |
$2 | 传递到脚本的第二个参数 |
$3 | 传递到脚本的第三个参数 |
$# | 传递到脚本的参数个数 |
$* | 以一个单字符串显示所有向脚本传递的参数。 如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。 |
$$ | 脚本运行的当前进程ID号 |
$! | 后台运行的最后一个进程的ID号 |
$@ | 与$*相同,但是使用时加引号,并在引号中返回每个参数。 如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。 |
$- | 显示Shell使用的当前选项,与set命令功能相同。 |
$? | 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。 |
例:数据的打印
echo "It is a test"
也可不要引号效果一样
在脚本文件中使用变量时不用定义直接使用
- 命名只能使用英文字母,数字和下划线,首个字符不能以数字开头。
- 中间不能有空格,可以使用下划线(_)。
- 不能使用标点符号。
- 不能使用bash里的关键字(可用help命令查看保留关键字)。
使用 readonly 命令可以将变量定义为只读变量,只读变量的值不能被改变。
下面的例子尝试更改只读变量,结果报错:
例:
#!/bin/bash
myUrl="http://www.google.com"
readonly myUrl
myUrl="http://www.runoob.com"
例:PREFIX="$Absolute_path/bin/gcc"
但是使用的时候要加$符号例:make install PREFIX=$PREFIX
单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的;
单引号字串中不能出现单独一个的单引号(对单引号使用转义符后也不行),但可成对出现,作为字符串拼接使用。
双引号里可以有变量
双引号里可以出现转义字符
:<<!
注释内容...
注释内容...
注释内容...
!
!可替换为其他符号
例:
#!/bin/bash
#set -o nounset # Treat unset variables as an error#./build.sh hi3559help()
{
echo " help/-h Display help interface"
echo " hi3559 make hi3559 iperf"
echo " hi3556 make hi3556 iperf"
echo " intl make intl iperf"
echo " np7v7a make np7v7a iperf"
echo " gcc make gcc iperf"
}if [ $# -lt 1 ] || [ $1 == help ] || [ $1 == -h ]
then
help
fiAbsolute_path=`pwd`if [[ $1 == hi3559 ]]
then
PREFIX="$Absolute_path/bin/hi3559"
elif [[ $1 == hi3556 ]]
then
PREFIX="$Absolute_path/bin/hi3556"
elif [[ $1 == intel ]]
then
PREFIX="$Absolute_path/bin/intel"
elif [[ $1 == np7v7a ]]
then
PREFIX="$Absolute_path/bin/np7v7a"
elif [[ $1 == gcc ]]
then
PREFIX="$Absolute_path/bin/gcc"
fiif [[ $1 == hi3559 ]]
then
make clean
./configure --prefix=$PREFIX --host=aarch64-himix100-linux \--enable-shared=no --enable-static=yes
make
make install
echo "$PREFIX"
echo "make hi3559 iperf OK"
elif [[ $1 == hi3556 ]]
then
make clean
./configure --prefix=$PREFIX --host=arm-himix200-linux \--enable-shared=no --enable-static=yes
make
make install
echo "$PREFIX"
echo "make hi3556 iperf OK"
elif [[ $1 == intel ]]
then
make clean
./configure --prefix=$PREFIX --host=x86_64-poky-linux \--enable-shared=no --enable-static=yes
make
make install
echo "$PREFIX"
echo "make intel iperf OK"
elif [[ $1 == np7v7a ]]
then
make clean
./configure --prefix=$PREFIX --host=arm-np7v7a-linux-gnueabi \--enable-shared=no --enable-static=yes
make
make install
echo "$PREFIX"
echo "make np7v7a iperf OK"
elif [[ $1 == gcc ]]
then
make clean
./configure --prefix=$PREFIX --host=arm-linux \--enable-shared=no --enable-static=yes
make
make install
echo "$PREFIX"
echo "make linux iperf OK"
fi
#!/bin/bash
#set -o nounset # Treat unset variables as an error#./build.sh hi3559help()
{
echo " help/-h Display help interface"
echo " hi3559 make hi3559 wireless_tools"
echo " hi3556 make hi3556 wireless_tools"
echo " intl make intl wireless_tools"
echo " np7v7a make np7v7a wireless_tools"
echo " gcc make gcc wireless_tools"
}if [ $# -lt 1 ] || [ $1 == help ] || [ $1 == -h ]
then
help
fiAbsolute_path=`pwd`if [[ $1 == hi3559 ]]
then
PREFIX="$Absolute_path/bin/hi3559"
elif [[ $1 == hi3556 ]]
then
PREFIX="$Absolute_path/bin/hi3556"
elif [[ $1 == intel ]]
then
PREFIX="$Absolute_path/bin/intel"
elif [[ $1 == np7v7a ]]
then
PREFIX="$Absolute_path/bin/np7v7a"
elif [[ $1 == gcc ]]
then
PREFIX="$Absolute_path/bin/gcc"
fiif [[ $1 == hi3559 ]]
then
make clean
make CC=aarch64-himix100-linux-gcc
make install PREFIX=$PREFIX
echo "$PREFIX"
echo "make hi3559 wireless_tools OK"
elif [[ $1 == hi3556 ]]
then
make clean
make CC=arm-himix200-linux-gcc
make install PREFIX=$PREFIX
echo "$PREFIX"
echo "make hi3556 wireless_tools OK"
elif [[ $1 == intel ]]
then
make clean
make CC=x86_64-poky-linux-gcc
make install PREFIX=$PREFIX
echo "$PREFIX"
echo "make intel wireless_tools OK"
elif [[ $1 == np7v7a ]]
then
make clean
make CC=arm-np7v7a-linux-gnueabi-gcc
make install PREFIX=$PREFIX
echo "$PREFIX"
echo "make np7v7a wireless_tools OK"
elif [[ $1 == gcc ]]
then
make clean
make CC=arm-linux-gcc
make install PREFIX=$PREFIX
echo "$PREFIX"
echo "make linux wireless_tools OK"
fi
configure学习
--enable-shared=no --enable-static=yes (静态)
--enable-shared=yes --enable-static=no (动态)
下面进行 configure配置选项相信说明:
–cache-file=FILE
‘configure’会在你的系统上测试存在的特性(或者bug!).为了加速随后进行的配置,测试的结果会存储在一个cache file里.当configure一个每个子树里都有’configure’脚本的复杂的源码树时,一个很好的cache file的存在会有很大帮助.
–help
输出帮助信息.即使是有经验的用户也偶尔需要使用使用’–help’选项,因为一个复杂的项目会包含附加的选项.例如,GCC包里的’configure’脚本就包含了允许你控制是否生成和在GCC中使用GNU汇编器的选项.
–no-create
‘configure’中的一个主要函数会制作输出文件.此选项阻止‘configure’生成这个文件.你可以认为这是一种演习(dry run),尽管缓存(cache)仍然被改写了.
–quiet
–silent
当’configure’进行他的测试时,会输出简要的信息来告诉用户正在作什么.这样作是因为’configure’可能会比较慢,没有这种输出的话用户将会被扔在一旁疑惑正在发生什么.使用这两个选项中的任何一个都会把你扔到一旁.(译注:这两句话比较有意思,原文是这样的:If there was no such output, the user would be left wondering what is happening. By using this option, you too can be left wondering!)
–version
打印用来产生’configure’脚本的Autoconf的版本号.
–prefix=preFIX(文件安装的位置)
‘–prefix’是最常用的选项.制作出的’Makefile’会查看随此选项传递的参数,当一个包在安装时可以彻底的重新安置他的结构独立部分. 举一个例子,当安装一个包,例如说Emacs,下面的命令将会使Emacs Lisp file被安装到”/opt/gnu/share”:
$ ./configure –prefix=/opt/gnu/share
–exec-prefix=EPREFIX
与’–prefix’选项类似,但是他是用来设置结构倚赖的文件的安装位置.编译好的’emacs’二进制文件就是这样一个文件.如果没有设置这个选项的话,默认使用的选项值将被设为和’–prefix’选项值一样.
–bindir=DIR
指定二进制文件的安装位置.这里的二进制文件定义为可以被用户直接执行的程序.
—sbindir=DIR
指定超级二进制文件的安装位置.这是一些通常只能由超级用户执行的程序.
–libexecdir=DIR(包目录,程序调用)
指定可执行支持文件的安装位置.与二进制文件相反,这些文件从来不直接由用户执行,但是可以被上面提到的二进制文件所执行.
–datadir=DIR
指定通用数据文件的安装位置.
–sysconfdir=DIR(/etc配置文件目录)
指定在单个机器上使用的只读数据的安装位置.
–sharedstatedir=DIR
指定可以在多个机器上共享的可写数据的安装位置.
–localstatedir=DIR
指定只能单机使用的可写数据的安装位置.
–libdir=DIR(库文件目录)
指定库文件的安装位置.
–includedir=DIR
指定C头文件的安装位置.其他语言如C++的头文件也可以使用此选项.
–oldincludedir=DIR
指定为除GCC外编译器安装的C头文件的安装位置.
–infodir=DIR
指定Info格式文档的安装位置.Info是被GNU工程所使用的文档格式.
–mandir=DIR(帮助文档的安装目录)
指定手册页的安装位置.
–srcdir=DIR
这个选项对安装没有作用.他会告诉’configure’源码的位置.一般来说不用指定此选项,因为’configure’脚本一般和源码文件在同一个目录下.
–program-prefix=PREFIX
指定将被加到所安装程序的名字上的前缀.例如,使用’–program-prefix=g’来configure一个名为’tar’的程序将会使安装的程序被命名为’gtar’.当和其他的安装选项一起使用时,这个选项只有当他被`Makefile.in’文件使用时才会工作.
–program-suffix=SUFFIX
指定将被加到所安装程序的名字上的后缀.
–program-transform-name=PROGRAM
这里的PROGRAM是一个sed脚本.当一个程序被安装时,他的名字将经过`sed -e PROGRAM’来产生安装的名字.
–build=BUILD
指定软件包安装的系统平台.如果没有指定,默认值将是’–host’选项的值.
–host=HOST
指定软件运行的系统平台.如果没有指定,将会运行`config.guess’来检测.
–target=GARGET
指定软件面向(target to)的系统平台.这主要在程序语言工具如编译器和汇编器上下文中起作用.如果没有指定,默认将使用’–host’选项的值.
–disable-FEATURE
一些软件包可以选择这个选项来提供为大型选项的编译时配置,例如使用Kerberos认证系统或者一个实验性的编译器最优配置.如果默认是提供这些特性,可以使用’–disable-FEATURE’来禁用它,这里’FEATURE’是特性的名字.例如:
代码如下:
$ ./configure –disable-gui
-enable-FEATURE[=ARG](系统参数配置,在编译时完成)
相反的,一些软件包可能提供了一些默认被禁止的特性,可以使用’–enable-FEATURE’来起用它.这里’FEATURE’是特性的名字.一个特性可能会接受一个可选的参数.例如:
代码如下:
$ ./configure –enable-buffers=128
`–enable-FEATURE=no’与上面提到的’–disable-FEATURE’是同义的.
–with-PACKAGE[=ARG]
在自由软件社区里,有使用已有软件包和库的优秀传统.当用’configure’来配置一个源码树时,可以提供其他已经安装的软件包的信息.例如,倚赖于Tcl和Tk的BLT器件工具包.要配置BLT,可能需要给’configure’提供一些关于我们把Tcl和Tk装的何处的信息:
代码如下:
$ ./configure –with-tcl=/usr/local –with-tk=/usr/local
‘–with-PACKAGE=no’与下面将提到的’–without-PACKAGE’是同义的.
–without-PACKAGE
有时候你可能不想让你的软件包与系统已有的软
件包交互.例如,你可能不想让你的新编译器使用GNU ld.通过使用这个选项可以做到这一点:
代码如下:
$ ./configure –without-gnu-ld
–x-includes=DIR
这个选项是’–with-PACKAGE’选项的一个特例.在Autoconf最初被开发出来时,流行使用’configure’来作为Imake 的一个变通方法来制作运行于X的软件.’–x-includes’选项提供了向’configure’脚本指明包含X11头文件的目录的方法.
–x-libraries=DIR
类似的,’–x-libraries’选项提供了向’configure’脚本指明包含X11库的目录的方法.
在源码树中运行’configure’是不必要的同时也是不好的.一个由’configure’产生的良好的’Makefile’可以构筑源码属于另一棵树的软件包.在一个独立于源码的树中构筑派生的文件的好处是很明显的:派生的文件,如目标文件,会凌乱的散布于源码树.这也使在另一个不同的系统或用不同的配置选项构筑同样的目标文件非常困难.建议使用三棵树:一棵源码树(source tree),一棵构筑树(build tree),一棵安装树(install tree).这里有一个很接近的例子,是使用这种方法来构筑GNU malloc包:
代码如下:
$ gtar zxf mmalloc-1.0.tar.gz
$ mkdir build && cd build
$ ../mmalloc-1.0/configure
creating cache ./config.cache
checking for gcc… gcc
checking whether the C compiler (gcc ) works… yes
checking whether the C compiler (gcc ) is a cross-compiler… no
checking whether we are using GNU C… yes
checking whether gcc accepts -g… yes
checking for a BSD compatible install… /usr/bin/install -c
checking host system type… i586-pc-linux-gnu
checking build system type… i586-pc-linux-gnu
checking for ar… ar
checking for ranlib… ranlib
checking how to run the C preprocessor… gcc -E
checking for unistd.h… yes
checking for getpagesize… yes
checking for working mmap… yes
checking for limits.h… yes
checking for stddef.h… yes
updating cache ../config.cache
creating ./config.status
这样这棵构筑树就被配置了,下面可以继续构筑和安装这个包到默认的位置’/usr/local':
代码如下:
$ make all && make install
一个软件包通过编译源代码安装后,如何完全的卸载??
如果原先的source还在的话,很多source的Makefile都有写uninstall规则,直接在Souce里make uninstall就可行,不过碰到无良作者没写的,那一句一句看Makefile里install部分他都干了些什么,然后挨个删除。
如果source没了…..那就一边郁闷吧
到目前为止, 我装的都可以make uninstall…….
(因为总是不小心装错地方, 结果就make uninstall&&make clean,然后重新configure……)
makefile学习
在交叉编译链gcc后面添加
强制静态连接 -static
GCC编译选项CFLAGS参数
选项 | 说明 |
---|---|
-c | 用于把源码文件编译成 .o 对象文件,不进行链接过程 |
-o | 用于连接生成可执行文件,在其后可以指定输出文件的名称 |
-g | 用于在生成的目标可执行文件中,添加调试信息,可以使用GDB进行调试 |
-Idir | 用于把新目录添加到include路径上,可以使用相对和绝对路径,“-I.”、“-I./include”、“-I/opt/include” |
-Wall | 生成常见的所有告警信息,且停止编译,具体是哪些告警信息,请参见GCC手册,一般用这个足矣! |
-w | 关闭所有告警信息 |
-O | 表示编译优化选项,其后可跟优化等级0\1\2\3,默认是0,不优化 |
-fPIC | 用于生成位置无关的代码 |
-v | (在标准错误)显示执行编译阶段的命令,同时显示编译器驱动程序,预处理器,编译器的版本号 |
GCC链接选项LDFLAGS参数
选项 | 说明 |
---|---|
-llibrary | 链接时在标准搜索目录中寻找库文件,搜索名为liblibrary.a 或 liblibrary.so |
-Ldir | 用于把新目录添加到库搜索路径上,可以使用相对和绝对路径,“-L.”、“-L./include”、“-L/opt/include” |
-Wl,option | 把选项 option 传递给连接器,如果 option 中含有逗号,就在逗号处分割成多个选项 |
-static | 使用静态库链接生成目标文件,避免使用共享库,生成目标文件会比使用动态链接库大 |