添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

一、前言:开源固件的前世今生

为何华硕固件开源?

2003年Linksys公司推出WRT-54G,一款基于MIPS架构的无线路由器,WRT-54G操作系统以Linux取代vXworks,哥伦比亚大学法学院教授Eben Moglen向Linksys提出开源要求。
2003年7月,Linksys迫于压力,开源了WRT54G的firmware。
2004年1月出现所谓的OpenWRT,第一个版本是基于Linksys源码及uclibc中的buildroot项目。
2005年初,BrainSlayer发布了一个新的发行版:DD-WRT。接着又有HyperWRT、Tomato。

从此以后,开源路由器系统蓬勃发展,并吸引了一部分厂家的加入 。

华硕路由器固件(Asuswrt)就是基于Tomato-RT/Tomato-USB进行二次开发的版本,需遵守GPL开源协议,除了少部分比如 Broadcom/Ralink驱动以二进制格式闭源提供外,其他大部分模块都以源码格式开源提供。

何为梅林固件、padavan固件?

梅林固件基于华硕固件进行修改和增强,主要支持基于broadcom的设备,如ARM架构的平台(比如AC9):

原版梅林(Asuswrt-merlin)
原始设备:
RT-N66U RAM (256Mb) FlashRAM (32Mb) CPU:BCM4706KPBG. Switch:BCM53125SKMML.

padavan也是基于华硕固件修改,padavan针对的是mipsel(如7620)架构的平台(比如K2)
原版padavan:
原始设备:
RT-N56U RAM (128Mb) FlashRAM (8Mb) CPU:Ralink RT3662F. Switch:Realtek RTL8367M WLAN: Ralink RT3092L
由于开发人员为俄罗斯人,又称老毛子固件

国内常用的梅林、padavan修改版本:

koolshare上面是小宝修改版merlin,Koolshare改版梅林主要就是多了以软件中心为主的第三方应用功能,譬如迅雷快鸟,SS,阿呆猫,kms自建服务器,广告过滤。

恩山上常见的是hiboy修改版padavan

还有一个俄罗斯人开发的 Xwrt-Vortex,增加了支持设备
支持以下型号:
Netgear R7000
Linksys EA6900
Huawei WS880

二、华硕原版固件编译

编译环境:
Ubuntu 16.04 64位系统

1、下载源码

华硕3.0.0.4.380_4089源码:

2、安装依赖包

sudo apt-get install --no-install-recommends autoconf automake bash bison bzip2 diffutils file flex g++ gawk gcc-multilib gettext gperf groff-base libncurses-dev libexpat1-dev libslang2 libssl-dev libtool libxml-parser-perl make patch perl pkg-config python sed shtool tar texinfo unzip zlib1g zlib1g-dev

sudo apt-get install lib32stdc++6 lib32z1-dev

sudo apt-get --no-install-recommends install automake1.11

sudo apt-get install libelf-dev:i386 libelf1:i386

sudo apt-get --no-install-recommends install lib32z1-dev lib32stdc++6

3、修改编译

解压源码到/opt/ac1200g目录

修改GPIO设置适配AC9
asuswrt\release\src-rt-9.x\src\router\rc\init.c,搜索case MODEL_RTAC1200GP,修改GPIO:
nvram_set_int("btn_rst_gpio", 7|GPIO_ACTIVE_LOW);
nvram_set_int("btn_wps_gpio", 9|GPIO_ACTIVE_LOW);
nvram_set_int("led_pwr_gpio", 15);
nvram_set_int("led_wps_gpio", 10);
nvram_set_int("led_usb_gpio", 1);

设置环境变量

export PATH=$PATH:/opt/ac1200g/asuswrt/release/src-rt-9.x/src/toolchains/hndtools-arm-linux-2.6.36-uclibc-4.5.3/bin

cd /opt/ac1200g/asuswrt/release/src-rt-9.x/src/
make RT-AC1200G+

*** No rule to make target 'tcode.c', needed by 'tcode.o'。
修改src/router/shared/Makefile,将“%.o: prebuild/%.o”改变一下位置:

%.o: prebuild/%.o
@echo " [shared] cp $@"
@cp -f $< $@

%.o: %.c .%.depend
@echo " [shared] CC $@"
@$(CC) $(CFLAGS) -o $@ -c $<

.depend: $(OBJS:%.o=%.c)
@$(CC) $(CFLAGS) -M $^ > .depend
编译成功生成的固件在/opt/ac1200g/asuswrt/release/src-rt-9.x/src/image目录下

4、模块定制
修改/opt/ac1200g/asuswrt/release/src-rt-9.x/src/target.mak文件,搜索RT-AC1200G+:
可以看到,RT-AC1200G+是基于RT-AC1200G_BASE进行模块、特性增加,可以修改相应的特性=y或=n来增减特性

也可以通过图形界面来进行定制:
cd /opt/ac1200g/asuswrt/release/src/router
export SRCBASE=/opt/ac1200g/asuswrt/release/src-rt-9.x/src
make menuconfig

三、源码修改与特性增加

华硕AC1200G+与AC9硬件对比:
AC1200G+:CPU:BCM47189、2.4G: BCM43217,5G:Broadcom BCM47189集成、交换芯片:Broadcom BCM 53125、16 MB Flash、128 MB RAM
AC9: CPU:BCM47189、2.4G: BCM43217,5G:Broadcom BCM47189集成、交换芯片:Broadcom BCM 53125、8 MB Flash(硬改16M)、128 MB RAM

硬件上基本一致,因此固件上可以兼容。下面为针对固件的修改过程。

【增加无线扫描功能】

我们首先参照梅林固件的源码来为AC9增加一个特性:搜索周围的无线网络
1、修改/opt/ac1200g/asuswrt/release/src/router/www/state.js,增加搜索页面
搜索“tabtitle[0]”,修改:
tabtitle[0] = new Array("", "<#menu5_1_1#>", "<#menu5_1_2#>", "WDS", "<#menu5_1_4#>", "<#menu5_1_5#>", "<#menu5_1_6#>", "Wi-Fi Proxy");
tabtitle[0] = new Array("", "<#menu5_1_1#>", "<#menu5_1_2#>", "WDS", "<#menu5_1_4#>", "<#menu5_1_5#>", "<#menu5_1_6#>", "Site Survey", "Wi-Fi Proxy");

搜索“tablink[0]”,修改:
tablink[0] = new Array("", "Advanced_Wireless_Content.asp", "Advanced_WWPS_Content.asp", "Advanced_WMode_Content.asp", "Advanced_ACL_Content.asp", "Advanced_WSecurity_Content.asp", "Advanced_WAdvanced_Content.asp", "Advanced_WProxy_Content.asp");
tablink[0] = new Array("", "Advanced_Wireless_Content.asp", "Advanced_WWPS_Content.asp", "Advanced_WMode_Content.asp", "Advanced_ACL_Content.asp", "Advanced_WSecurity_Content.asp", "Advanced_WAdvanced_Content.asp","Advanced_Wireless_Survey.asp", "Advanced_WProxy_Content.asp");

2、拷贝Advanced_Wireless_Survey.asp到/opt/ac1200g/asuswrt/release/src/router/www目录
从梅林源文件中拷贝Advanced_Wireless_Survey.asp到/opt/ac1200g/asuswrt/release/src/router/www目录

3、重新编译固件,并刷入AC9

【多语言支持】

如果想支持多语言,可以将tabtitle[0]中的Site Survey修改:

tabtitle[0] = new Array("", "<#menu5_1_1#>", "<#menu5_1_2#>", "WDS", "<#menu5_1_4#>", "<#menu5_1_5#>", "<#menu5_1_6#>", "<#menu5_1_7#>", "Wi-Fi Proxy");

然后在/opt/ac1200g/asuswrt/release/src/router/www/CN.dict中增加:

menu5_1_7=无线扫描

在/opt/ac1200g/asuswrt/release/src/router/www/EN.dict中增加:

menu5_1_7=Site Survey

【精简语言包】

修改/opt/ac1200g/asuswrt/release/src/router/tools/Lnx_AsusWrtDictPrep/dictctrl.txt,只保留中英文
[MODEL]
RT-AC1200G+
EN,CN

重新编译,固件由原来13M变为12M

【版本号及界面修改】

主版本号位于/opt/ac1200g/asuswrt/release/src-rt/version.conf

子版本号位于/opt/ac1200g/asuswrt/release/src/router/extendno.conf

型号在dict字典文件Web_Title和Web_Title2字段

图标在/opt/ac1200g/asuswrt/release/src/router/www/images/New_ui/asustitle.png

修改后的版本及界面如下:

【增加用户脚本功能】

用户脚(User scripts)本功能是梅林固件一个比较重要的特性,它支持在不同的事件触发下执行用户脚本。比如系统启动后执行脚本(init-start)、网络连接后执行脚本(wan-start)或者在所有服务启动后执行脚本(services-start)。

脚本由用户自己建立,存放在/jffs/scripts目录,并需赋予脚本可执行权限:
chmod a+rx /jffs/scripts/*

比如我要增加一个定时重启任务:
新建/jffs/scripts/init-start文件:
vi /jffs/scripts/init-start
输入如下语句:
#!/bin/sh
cru a ScheduledReboot "0 4 * * * /sbin/reboot"
保存退出后赋予文件执行权限,上述语句设置每晚4点重启路由器
chmod a+rx /jffs/scripts/*
重启路由器生效
cru是华硕固件中的定时任务程序,类似于crontab
# cru
Cron Utility
add: cru a <"min hour day month week command">
delete: cru d
list: cru l

要增加用户脚本功能,我们可以参照梅林固件的源码进行修改,主要是/opt/ac1200g/asuswrt/release/src/router/rc和/opt/ac1200g/asuswrt/release/src/router/share里面的部分c文件,修改后的文件打包如下:
user_script

【增加梅林工具箱】
首先要在界面上增加菜单,工具箱为一级菜单,里面有两个子菜单:系统信息和其他工具
参照梅林源码修改/opt/ac1200g/asuswrt/release/src/router/www/state.js
拷贝www目录下Tools_OtherSettings.asp、Tools_Sysinfo.asp文件
拷贝覆盖图标文件www/images/New_ui/icon_indexes.png,修改www/index_style.css文件

在Tools_Sysinfo.asp文件中调用了sysinfo命令,此命令由httpd进程处理,需拷贝/opt/ac1200g/asuswrt/release/src/router/httpd下的sysinfo.c、sysinfo.h,并修改web.c,映射WEB命令到处理函数。最后修改httpd的makefile进行重新编译。

增加的工具箱界面:

【移植ipset】
很多特性都需要ipset模块,而华硕固件缺省并没有集成ipset,因此我们需要进行移植

拷贝梅林源码目录/opt/ac1200g/asuswrt/release/src/router/ipset、ipset_arm、libmnl, libnfnetlink目录,并且修改router目录下的makefile及相关文件,开启dnsmasq的ipset特性

修改内核/opt/ac1200g/asuswrt/release/src-rt-9.x/src/linux下的相关文件(netfilter)

修改release/src/router/rom/rom/etc/modprobe.conf,加载ipset内核

修改完成后,重新编译、烧写,可以输入ipset creat test hash:net && ipset list来验证模块是否正常

开启tproxy:
修改/opt/ac1200g/asuswrt/release/src-rt-9.x/src/linux/linux-2.6.36/config_base.6a
CONFIG_NETFILTER_TPROXY=m
再在启动的脚本中myrcs.sh中加入
/sbin/modprobe xt_TPROXY

【增加koolproxy】

下面我们在工具箱中增加koolproxy广告过滤特性

1、首先修改/opt/ac1200g/asuswrt/release/src/router/www/state.js文件,增加菜单

2、然后设计koolproxy的ASP页面

3、接下来是让页面上的元素和nvram中的参数对应,比如koolproxy使能按钮,它的id为koolproxy_enable,提交的表单一般为start_apply.htm,表单中有几个重要的参数
指定操作方式、等待时间及执行的脚本名称等。action_mode可以为apply_new或apply,区别是apply_new只有在参数改变时才执行脚本,apply则都会执行脚本。
提交表单后在start_apply.htm中会执行一个重要命令:
update_variables();
我们可以在web.c文件中看到此命令:
{ "update_variables", ej_update_variables},
映射到ej_update_variables函数,在此函数中会调用validate_apply函数,此函数会遍历nvram中的各个参数
for (t = router_defaults; t->name; t++)
比较nvram中的参数与表单中的参数值是否一致,如不一致则将新的值写入nvram
注:router_defaults存放着nvram的各个参数,在share/default.c文件中定义,我们需要先将新增的koolproxy参数(如koolproxy_enable)也在此文件定义

nvram写入后,下面是action_script脚本执行的操作,会调用notify_rc函数
strncpy(notify_cmd, action_script, 128);
nvram_set("freeze_duck", "15");
notify_rc(notify_cmd);
在notify_rc的处理中,会先打印日志:
logmessage_normal("rc_service", "%s %d:notify_rc %s", p2, getpid(), event_name);
然后通知rc程序执行响应命令:
nvram_set("rc_service", event_name);
nvram_set_int("rc_service_pid", getpid());
kill(1, SIGUSR1);

如果要直接调用脚本,可以修改ej_update_variables函数,在适当位置调用sys_script执行脚本

完成后的koolproxy界面如下:
调试时如果想修改固件中的文件,用如下命令:
mount --bind 目的名 原名
mount --bind /tmp/Tools_Koolproxy.asp /www/Tools_Koolproxy.asp
将/www/Tools_Koolproxy.asp映射到/tmp/Tools_Koolproxy.asp文件,你可以修改此文件,修改后的内容即时在WEB上显示。利用此特性,你可以修改任何现有系统的脚本或程序,指向/jffs.

【增加SSR】

首先第一步,你需要获得ssr for arm 的可执行程序
可以参照此文进行交叉编译获得:

其次我们需要设计ssr的交互界面,由于SSR需要设置多个服务器配置,因此我们参照家长控制页面(ParentalControl.asp)进行修改

修改后的界面如下:

最后我们要将界面和脚本进行关联,在提交页面后,会先保存服务器参数到nvram中,然后会调用指定脚本,在脚本中会读取nvram中的服务器参数,并启动ssr程序及生成对应的防火墙规则。

写的很不错!
希望能继续出这类文章,我还是小白,最近使用您修改的腾达ac9固件,遇到了一下问题。
主要原因在于,这个固件没有集成frp(只有ngrok)而我不喜欢ngrok,或者用不好ngrok。
我想把您修改后固件解压,再次基础上添加frp。不过我对此了解很少,不敢下手。

好像还有另一种可行方法,就是在用户script中,加入添加frp脚本,就是没有集成的用得舒服。

如果大佬有空,希望更新一下固件。

  • 近期评论
  • 文章归档
  • 文章 RSS
  • 评论 RSS
  • WordPress.org
  • 阅读统计
  • 腾讯云主机年中优惠
  • 阿里云香港轻量应用服务器
  • 搬瓦工主机推荐
  • Vultr主机推荐
  • CloudCone主机推荐
  •