immortalwrt-mt798x基于immortalwrt项目,特点如下 基于immortalwrt 21.02分支,内核版本5.4,目前仅支持mt7981/mt7986! M- f: D4 M+ o5 h* ?$ d) E6 D
使用mtk-openwrt-feeds提供的有线驱动、hnat驱动、内核补丁及配置工具,支持所有硬件加速特性, H0 u3 n9 Y$ w9 T+ w, B9 u8 L& l
mt7981/mt7986均支持两个ppe,每个ppe有32k Entry(当有线驱动使用ADMAv1时,每个PPE最大支持16k Entry)
; }$ N$ y6 I- V8 C# _$ \1 c使用mtwifi原厂无线驱动(目前默认使用7.6.6.1版本),默认开启802.11k,支持warp在内的所有加速特性
+ }0 \* A3 D W+ k4 |3 I# }6 R新开发的mtwifi-cfg无线配置工具支持openwrt的原生luci界面以及netifd-wireless标准接口。除此以外,还支持mtk原厂提供的luci-app-mtk和wifi-profile 2 v8 C0 ]4 q( j v) D/ \
9 R- @ o6 W: v$ ^- J 固件源码编译说明- 拉取固件源码,参考immortalwrt的README搭建openwrt编译环境,并更新feeds
- 使用defconfig目录内预置的配置文件作为配置模板,, e/ i& ~& W' f2 N9 P
: u7 E" I* `3 G O" q: s
5 [0 H/ N2 b. O- m1 ~( t1 u) Y/ N3 M8 i* l8 D& Y* H
- <font face="宋体"># defconfig/luci-app-mtk-deprecated目录里的配置文件使用旧版luci-app-mtk作为无线配置工具
" |+ Q/ l: T0 |0 [) i" N) m) H( L - $ x. Q+ r: r% }& d9 r
- # 对于mt7981,使用mt7981-ax3000.config- s* u* `( f7 E/ O) I: M1 `" ~) [: H8 h
- cp -f defconfig/mt7981-ax3000.config .config
$ Q/ @$ M) H7 U# c* i - 2 s. i! ?) s* }: B
- # 对于mt7986,使用mt7986-ax6000.config% z# x O* a) D4 q* C5 f6 e+ p% O: j
- #cp -f defconfig/mt7986-ax6000.config .config* d. _$ y* H" _. _9 K( G
! h& B5 L1 U! \4 w7 A4 F5 c- S9 W- Z- # 对于256M内存的mt7986(如磊科N60),使用mt7986-ax6000-256m.config
2 m! @; l0 L g# l( \% v - #cp -f defconfig/mt7986-ax6000-256m.config .config3 X# s: M; y* _ W9 T( T- W
9 J& q; f+ z, W- # 对于AX4200方案的mt7986(如BPI-R3 MINI),使用mt7986-ax4200.config b6 J" i& Y" J' `* u( ^
- #cp -f defconfig/mt7986-ax4200.config .config</font>
复制代码- 运行make menuconfig定制固件
- 运行make V=s开始编译固件,为了加快编译速度,可以使用make V=s -j$(nproc)) a r5 k" E3 T
& {" t% w0 {1 ]- p9 w7 x+ d
! u4 o" ]6 B/ l9 x2 Q! f4 g
# M" U# p1 |$ Y6 o1 p" w
: z4 n! p+ }/ X. F g1 a
, V6 a$ f3 p3 d+ @7 u b* ~
1 }5 l4 ^( X0 D2 T( j, P k/ D$ H注意事项- GL.iNet MT3000/MT2500的WAN/LAN口对应的GMAC不符合参考设计,为了保证HNAT加速功能正常,immortalwrt-mt798x最新源码中已按照mtk公版方案进行修正,上述两款路由器均使用2.5G口作为LAN口
- 不要在开启hwnat时使用主线的flow-offload,即不要启用turbo-acc的flow-offload加速方式
- 推荐选择WPA2-PSK/WPA3-PSK无线认证方式以获得最好的兼容性
- 由于mt798x无线驱动中继扫描所需时间较长,对应频段关联的无线设备可能会在扫描期间断开。因此在触发中继扫描时,要使用有线或者非扫描频段连接路由器操作
- 因未经测试,不推荐同时开启shortcut-fe
- 当前无线驱动的IGMP Snooping功能可能存在问题,新版源码已默认关闭此功能,较旧版本的固件可以手动在无线设置中禁用IGMP Snooping以避免出现问题7 ] ~ v0 n9 p' {- v* }
" c6 ~# {1 n% X! K6 i- |& ~" [
' V& T/ {( O3 F' f" q6 V
( y0 I, O4 Y; z) g/ r6 w
& M+ D7 s$ }! z% _2 z
1 J; ]; R* @3 N7 T! }0 p
6 B8 u3 X$ m9 F; Y$ P( l1 ?6 l
后期计划9 C" h. r Z K. p0 t) J6 [+ v
4 ?# h* b' J; `" C
- 加入mtk-wappd等高级扩展,更好支持802.11k/v/iapp等漫游功能
# Z" v4 t# [/ E0 c& r+ B
- `' V1 C0 s7 {2 p 2 X# a3 j+ m" y: M7 p, ~2 |- [
, J- z0 T2 T1 o( w
/ E/ A7 e) w' k$ |& \' g* @' u7 {硬件加速功能说明* a o# O! O. M4 e' T
! o: l& l6 ]# ?4 p( Y
2 r4 Q2 I, O; h) x5 I0 p4 P9 g
0 M" e6 Z7 g4 V# Dimmortalwrt-mt798x支持mt798x的所有原厂有线、无线硬件加速特性,除此以外还支持以下功能 - 可通过luci直接设置hwnat PPE的启用数量、PPE加速阈值(当NAT连接速率大于阈值时会被硬件加速,默认是30pps,设置更小的值会使NAT连接更容易被加速)、macvlan支持(支持macvlan作为WAN的加速功能)、IPv6开关等
- 每个NAT连接需要占用2个Entry(进站和出站方向),当使用2个PPE时,由GMAC2进入的包将使用PPE1加速,其它情况下均使用PPE0加速。当路由器仅使用GMAC1时(如JCG Q30,CT3003等路由器),PPE1将不会起任何作用
- mt7981/mt7986均支持2个PPE,每个PPE有32768个Entry,当有线驱动使用ADMAv1时,每个PPE最多支持16384个Entry。按照mtk-sdk和最新openwrt主线的有线驱动,mt7981的ADMAv2存在不可修复的问题,immortalwrt-mt798x已参照上述源码将mt7981 ADMAv2回退至ADMAv1,mt7986不受影响
- immortalwrt-mt798x最新源码已支持外部网络设备(如USB3.0 5G模块、USB-RNDIS/ECM网卡等)到有线和无线的双向hwnat PPE加速,mtk-sdk原厂驱动不支持此功能。此功能可降低使用外部网络设备时的CPU占用率,实测mt7981在外接USB-RNDIS/ECM网卡时可跑满千兆速率(原厂只能达到300-500Mbps)。目前仅在RAX3000M中开启,MT7986机型暂未测试
- immortalwrt-mt798x支持硬件QoS的所有特性,该功能已集成到luci-app-eqos-mtk,具体用法参考luci里面的说明。为确保PPE尽可能接管所有的NAT连接,当开启硬件QoS时,PPE加速阈值将会被设置为5pps
- 同一个MBSSID内的无线客户端之间互传数据不支持硬件加速,不同MBSSID之间的无线客户端之间互传数据支持完全硬件加速
' a. X8 o( H+ k o1 |" X* T- D
# c- q8 Z5 q( D& X1 u mtwifi无线配置工具说明immortalwrt-mt798x早期采用的是mtk-sdk提供的luci-app-mtk和wifi-profile作为无线配置工具,并且在mtk-sdk基础上进行了大幅度的精简、修复、适配和汉化以尽可能满足日常使用需求。2023年12月,我开发了新的mtwifi-cfg配置工具,并配套做好了iwinfo和netifd相关支持,至此immortalwrt-mt798x可以选择两种完全不同的无线配置工具,特点分别如下: - mtwifi-cfg:为mtwifi设计的无线配置工具,兼容openwrt原生luci和netifd,可调整无线驱动的参数较少,配置界面美观友好,由于是新开发的工具,可能存在一些问题
- luci-app-mtk:源自mtk-sdk提供的配置工具,需要配合wifi-profile脚本使用,可调整无线驱动的几乎所有参数,配置界面较为简陋$ f' C5 l- A% m" K' r* s; m5 a
' T4 T. s9 }* I3 y/ P3 D
mtwifi-cfg与luci-app-mtk不能在固件里共存,编译时必须选择其中之一,目前最新源码已默认使用mtwifi-cfg作为无线配置工具,如需使用旧版luci-app-mtk,请选择defconfig/luci-app-mtk-deprecated目录里的配置模板文件进行编译 mtwifi-cfg无线配置说明mtwifi-cfg是我为mt798x无线平台新开发的配置工具,支持openwrt的luci和netifd-wireless无线控制界面,具有以下特点: - 使用openwrt原版luci无线配置界面,配置方法非常接近原版openwrt
- 支持apcli中继功能
- 支持已连接站点信息显示(含apcli连接信息)
- 支持读取无线芯片实际发射功率
- 支持mtk原厂无线驱动可配置的大部分选项(含弱信号剔除等)
- 支持WPA-PSK/WPA2-PSK/WPA3-PSK/OWE无线认证方式,支持AP/APCLI工作模式,支持最多开启16个MBSSID
- 部分老旧的2.4G智能家居设备可能无法连接,请尝试以下无线设置:
. `3 b6 z7 V7 O- p9 F! U) P: \9 z. [$ u7 N* A3 F
- 使用WPA-PSK+AES/WPA2-PSK+AES认证加密方式
- 将2.4G无线设置为N模式
- 关闭2.4G的MU-MIMO功能(在较新的源码里,无线设置为N模式时自动关闭MU-MIMO)
- 设置频宽为20MHz,并关闭强制40MHz开关
# F X. I* k; J. G3 P5 g
, H8 a9 _( g S& W
; w* h ^; V7 d' z7 }4 j6 O { mtwifi-cfg配套源码mtwifi-cfg及配套的补丁完全开源,具体参考immortalwrt-mt798x源码内下列目录 - package/mtk/applications/mtwifi-cfg
- package/mtk/applications/luci-app-mtwifi-cfg
- package/mtk/drivers/mt_wifi/patches
- package/network/utils/iwinfo
- package/network/config/netifd/patches
! Z* a3 G, D1 q4 y4 q2 p; U* n8 t( a+ M8 c5 t/ z
5 \5 b o+ x+ c0 h luci-app-mtk无线配置说明luci-app-mtk来源于mtk-sdk,采用wifi-profile作为无线控制脚本,不支持openwrt的原版luci界面和netifd-wireless - luci-app-mtk配置界面已基本汉化,可显示驱动版本、芯片温度、已连接客户端信息等,下面以MT7981为例
; A; r5 H5 f9 Y5 p% L2 Z+ s2 C6 s+ Y8 g% H2 K1 B# q2 A; k
- 第一级MT7981右侧的配置按钮为chip_cfg,配置无线驱动基础参数,一般无需修改
- 第二级MT7981.1.1右侧的配置按钮为dev_cfg,可配置信道、国家代码等频段相关参数
- 第三级接口右侧的配置按钮为vif_cfg,可配置SSID、加密方式、无线中继扫描等5 k0 ~1 }8 ~ k5 V4 v
- c# n5 g7 G( ^ H# T D0 I
- c, S3 Z' H- E# [* j! O
- i0 C: R! v9 U0 U/ l
- 以MT7981.1.1为例,该设备代表MT7981的2.4G频段,其配置页面可以配置自动信道、国家代码、频宽、空间流、发射功率、波束成形等物理参数# M4 h- V0 d# x- e1 P* d, }4 _4 A
n" t0 d1 U. N* p0 ]2 }( g
. Z p" p/ I3 b: c& U5 c0 w
- MBSSID以ra0为例,该vif虚拟接口代表MT7981 2.4G的第一个MBSSID,在配置页面可以配置加密方式、密码、AP隔离、隐藏SSID等参数
$ L- G8 ?, b3 o: j( l+ N# n8 z8 @2 X# z4 S( E, \
; Q9 Z+ P( k- j0 F: s. {
无线中继以apcli0为例,该vif虚拟接口代表MT7981的2.4G无线ApCli,可在其配置页面点击扫描无线网络触发中继扫描功能 * D1 S( K, h4 f* [8 Y; ]2 c
中继扫描结束后,选择想要连接的上级AP并输入密码即可,WAN会自动更新为apcli0。 在禁用ApCli时,只需设置ApClient模式为禁用,WAN会恢复到默认的eth1
# S' p8 U# @& M, L5 r4 t 7 m" D% i# @) x* G# u! x: K0 h
|