openwrt 编译烧写流程

1.1. 依赖库
使用Ubuntu进行编译开发,需要安装的依赖库如下:
apt-get install build-essential asciidoc binutils bzip2 gawk gettext git libncurses5-dev libz-dev patch unzip zlib1g-dev等等。
还需要安装svn,apt-get install subversion。
1.2. 下载源码
trunk 版本:
git clone git://git.openwrt.org/openwrt.git
Barrier Breaker版本:
git clone git://git.openwrt.org/14.07/openwrt.git

1.3. 编译
以下为编译步骤,在make menuconfig中做的配置将在后面具体介绍,在make V=s前需要做一些移植修改也将在后面具体介绍。
cd trunk/
git pull
cp feeds.conf.default feeds.conf
./scripts/feeds update -a
./scripts/feeds install -a
make menuconfig
Make V=s
最终在trunk/bin/ar71xx/目录下得到最终的烧写目标代码(在此以EL-M150路由为基础),openwrt-ar71xx-generic-el-m150-squashfs-factory.bin。
1.4. 烧写
官方的Linux SDK开发包的烧录代码与Openwrt的烧录代码的分区规划不同,如果原来开发板上烧录的是官方的linux SDK代码,则需要先将刷新适用于Openwrt的Uboot,然后再烧写上一步中生成的openwrt-ar71xx-generic-el-m150-v2-squashfs-factory.bin。
对开发板烧写程序可以通过多种方式实现:在Uboot中烧写Uboot与固件、编程器烧写、Web配置界面中程序升级。
1.4.1. 烧写Uboot
使用网线连接开发板与PC,然后连接上串口监控(115200-8-n-1,这里使用SecureCRT),开发板上电,在SecureCRT中看到Uboot打印信息,按任意键打断启动进入Uboot命令行,使用printenv命令查看启动参数,记录下serverip,例如为192.168.1.2,并将PC更改为该IP。PC端开启Tftp Sever软件,在uboot命令行中输入命令如下:
#tftpboot 0x80060000 u-boot-ar9331.bin
#erase 0x9f000000 +0x200000
#cp.b 0x80060000 0x9f000000 0x20000
重启开发板,看到uboot正常打印。
1.4.2. 烧写固件
同上面烧写uboot一样,进入uboot命令行模式,输入如下命令:
#tftpboot 0x80060000 openwrt-ar71xx-generic-el-m150-squashfs-factory.bin
#erase 0x9f020000 +0x7c0000
#cp.b 0x80060000 0x9f02000 0x7c0000
1.4.3. 编程器拯救板砖
上面两种方式前提是目标板不是板砖,万一变砖或者开发板上未烧写过程序,则需要使用编程器来烧写目标代码,这就是对普通的SPI flash烧录程序方法,只要知道芯片型号,有固件就行了。
1.4.4. Web升级程序
对于能正常启动的AR9331开发板可以通过web升级程序,登录到web配置界面后选择System->Backup/Flash Firmware,然后选择要升级的固件。
注意这种方式只能升级同一型号的路由固件,如现在正在运行的是el-m150的固件,你编译了一个wr740的固件,是无法通过web升级的,只能在Uboot烧写固件(或者用mtd命令)的方式进行升级。
2. menuconfig配置
这里将介绍上面编译步骤中的make menuconfig中的具体配置。
开始配置,首先选择CPU与路由型号:
Target System—–Atheros AR71xx/AR7240/AR913x/AR934x
Target Profile—-Easylink el-m150
Kernel Modules配置:
Kernel modules —> Native Language Support —> <*> kmod-nls-utf8
Luci配置如下:
LuCI—>Collections—– <*> luci
LuCI—>Applications —> <*>luci-app-qos
LuCI—>Themes —> <*>luci-theme-openwrt
LuCI—>Translations—- <*> luci-i18n-Chinese
LuCI—>Translations—- <*> luci-i18n-English
Network配置:
Network—>Routing and Redirection—- <*> ip
在这里我们只做了必须的配置,更加丰富的功能可以再额外配置添加,如常见的USB storage、3G、Network Share(Samba)等等。
3. 代码修改
在这里我们做的移植中有些可以通过直接修改开发板中的配置文件来实现,而不需要重新编译固件,但是我们要的是一个编出来就是默认配置的固件,所以以下移植都将是在编译前实现的。
3.1. Wifi配置
Openwrt编译出来的固件,wifi默认是不开启的,需要做一些修改让其上电自动开启AP模式。修改trunk/package/kernel/mac80211/files/lib/wifi/mac80211.sh,其中的detect_mac80211函数中就对wifi-device和wifi-iface即无线物理设配与无线接口做了具体的配置。
在wifi-device配置中屏蔽掉“option disable 1”这句就能使wifi上电自启动了,也可以对channel、hwmode、txpower做进一步的配置,如channel设置为auto,txpower设置为30dBm。
在wifi-iface配置中可以改变wifi的模式(mode)、名字(ssid)、加密方式(encryption)、密码(key)。
如下是一个最终配置示例,这其实也就是生成的/etc/config/wireless配置文件。

3.2. 设置默认登陆密码
Openwrt默认不设置密码,而我们需要一个默认的登陆密码,这可以通过修改package/base-files/files/etc/shadow来实现,修改root项如下:
root 1$PjtjPtvn$F7wPtGnsC8lhpfJsB39.E/:16357:0:99999:7::: (对应密码123456)
或者
root 1$0CVWiweD$4Xsq83ZIZtPJe8PVLfqJH0:16357:0:99999:7::: (对应密码admin)
注意Openwrt的登陆用户名为root,且当设置了密码后将不能在使用Telnet来登陆目标板,需使用SSH。
3.3. 设置LAN默认IP
Openwrt固件LAN口默认ip为192.168.1.1,我们可以通过如下方法在编译中修改默认ip:
在trunk目录下新建files/etc/config/目录,然后将已经个性化定制好的network配置文件放在这个目录下,这样再编译出来的固件将执行这个network配置。在此我们只要修改lan口的ipaddr即可,如下所示:
config interface 'lan'
option ifname 'eth1'
option force_link '1'
option type 'bridge'
option proto 'static'
option netmask '255.255.255.0'
option ip6assign '60'
option ipaddr '192.168.12.10'
最根本的方式是通过修改文件package/base-files/files/lib/functions/uci-defaults.sh实现,修改函数ucidef_set_interface_lan中lan口ip即可。
3.4. 串口释放
AR9331只有一个调试串口,如果想要释放调试串口用作他用比如通信等,为此需要释放系统console打印,具体方法如下:
在target/linux/ar71xx/base-files/etc/inittab中注释掉::askconsole:/bin/ash --login,也就是注释掉这个console登陆。
在package/base-files/files/etc/config/system文件中config system下添加以下两句
option 'conloglevel' '1'
option 'kconloglevel' '1'
简单测试:开发板串口连接pc,打开SecureCRT,配115200-8-n-1,使用ssh登陆到开发板,命令行下输入”echo test serial > /dev/ttyATH0”,看到PC端接收正常。
3.5. GPIO控制
如果想使用AR9331的一些GPIO引脚来做一些简单逻辑控制,则需要通过注册gpio设备来实现,修改target/linux/ar71xx/files/arch/mips/ath79/mach-tl-wr741nd-v4.c文件
在el_m150_setup函数中添加我们需要的GPIO管脚注册即可,如:
gpio_request_one(18,GPIOF_OUT_INIT_LOW | GPIOF_EXPORT_DIR_FIXED, "Control GPIO18");
这里的18即是GPIO18,GPIOF_OUT_INIT_LOW限定初始化输出低电平,后面的名字可以自定。
系统启动后可以看到GPIO注册成功:
#ls /sys/class/gpio/
#export gpio18/ gpio22/ gpiochip0/ uexport/
可以使用cat命令获取管脚当前输出值,使用echo命令设置管脚输出。如下:
#cat gpio18/value
1
#echo 0 > gpio18/value

#cat gpio18/value
0
这里说明一下,在写C代码程序控制时候可以直接调用system()函数运行linux命令,比如在你的代码中你想控制GPIO18引脚的输出,那么你可以如下使用。
system(“echo 0 > /sys/class/gpio/gpio22/value”);

3.6. 时间同步
修改package/base-files/files/etc/config/system文件如下,这样默认同步时间正确。
config system
option hostname 'You can Define'
option zonename 'Asia/Shanghai'
option timezone 'CST-8'
注:这里hostname可以改成你想要的主机名字,将来在web页面中显示的也将是这个主机名。
3.7. 语言及主题设置
编译中的默认设置为auto,即自动识别,这将根据浏览器设置而定,例如我们使用ie、360浏览器,登陆后得到的是英文界面,而使用火狐则是中文界面。如果向默认设置问中文,则修改build_dir/feeds/luci/modules/base/root/etc/config/luci配置文件,将默认auto修改问zh_cn,并将主题锁定为bootstrap
config core 'main'
option lang 'zh_cn'
option mediaurlbase '/luci-static/bootstrap'
option resourcebase '/luci-static/resources'
3.8. 自定义脚本的使用
Openwrt为用户预留的自定义启动脚本/package/base-files/files/etc/rc.local来实现一些扩展功能,我们可以在这里添加一些命令,或者调用一个外部脚本来实现一些扩展功能。  

猜你喜欢

转载自blog.csdn.net/buynow123/article/details/51953636