immortalwrt-mt798x基于immortalwrt项目,特点如下 基于immortalwrt 21.02分支,内核版本5.4,目前仅支持mt7981/mt79866 _) j% C9 ^% N" |* H5 r3 |
使用mtk-openwrt-feeds提供的有线驱动、hnat驱动、内核补丁及配置工具,支持所有硬件加速特性1 G: ^% n) a/ }) `, i8 _; h9 l
mt7981/mt7986均支持两个ppe,每个ppe有32k Entry(当有线驱动使用ADMAv1时,每个PPE最大支持16k Entry)3 m7 V' j% e2 F6 e$ J
使用mtwifi原厂无线驱动(目前默认使用7.6.6.1版本),默认开启802.11k,支持warp在内的所有加速特性
2 e$ q- ?# \$ J0 o8 |1 Q# m新开发的mtwifi-cfg无线配置工具支持openwrt的原生luci界面以及netifd-wireless标准接口。除此以外,还支持mtk原厂提供的luci-app-mtk和wifi-profile
! v* |9 t* S! _/ _: v# G) G% |9 l# q* {( f1 P4 A3 [; Z+ m
固件源码编译说明- 拉取固件源码,参考immortalwrt的README搭建openwrt编译环境,并更新feeds
- 使用defconfig目录内预置的配置文件作为配置模板,
3 p% D0 r) ?/ |5 p0 X0 w/ S
& _3 G4 h: B3 U% x7 X m& W6 g/ {. x4 t/ U2 A8 e# @2 n3 |
6 I; o5 b8 A& j4 L e F9 `; R- <font face="宋体"># defconfig/luci-app-mtk-deprecated目录里的配置文件使用旧版luci-app-mtk作为无线配置工具& M7 ]3 y* S% v, p# y
- 5 E5 A+ N' s2 g o- Y, p
- # 对于mt7981,使用mt7981-ax3000.config) H' D4 I' `1 c- r
- cp -f defconfig/mt7981-ax3000.config .config
* x* `& X! T" z9 |' o8 d - & k9 i9 V4 y( ]) x- a) V
- # 对于mt7986,使用mt7986-ax6000.config
8 l" F8 C3 I- U0 h; E - #cp -f defconfig/mt7986-ax6000.config .config
( v% @& U0 D: B: a: g - 8 C/ H! s u R3 r( I
- # 对于256M内存的mt7986(如磊科N60),使用mt7986-ax6000-256m.config
* d& b4 O; Y' g - #cp -f defconfig/mt7986-ax6000-256m.config .config
4 v$ X! [) {' g+ U! {0 B) D" r
& V9 n8 }+ o H2 a7 e. F* @- # 对于AX4200方案的mt7986(如BPI-R3 MINI),使用mt7986-ax4200.config [9 I$ T4 u. m
- #cp -f defconfig/mt7986-ax4200.config .config</font>
复制代码- 运行make menuconfig定制固件
- 运行make V=s开始编译固件,为了加快编译速度,可以使用make V=s -j$(nproc)
! p/ V/ X+ l3 ^, N8 v6 S* f
3 Y% W. z7 ^, [& @! x' D) S+ B
0 U4 F- p3 w7 n) r% [6 Y9 V" a; S# e
" L6 A- |( s" q# c4 @- E. R. w
5 J2 n* Y& X" Y) @& C( _8 C ~8 `4 v5 V- o
' U. d, Y! U/ K4 e5 E, L/ B
注意事项- 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以避免出现问题
4 f% |2 { ]' }8 n6 \, ~1 r
' c& z }! V5 t9 W$ C9 D6 y
) n1 C: t( p D7 e0 q/ u) K/ S
' d2 H5 [# W/ M$ y% F5 v" u3 w4 ~9 }) R. c. ^0 ?* r5 {
8 S9 q' J$ J) A; x
5 v- t" [# P4 I" |1 D后期计划6 k4 d2 V6 M& k" k. F) V1 P! P; N
9 ~$ J$ b8 t, h8 c- 加入mtk-wappd等高级扩展,更好支持802.11k/v/iapp等漫游功能
5 C5 n% d0 H2 G1 ?
; c7 w% S# b! z) E 4 Y1 {2 S4 t- t' n4 a8 d8 Q
8 `! K9 v9 t. C# j6 ?5 R+ ^3 ?/ F1 x/ s* P/ N* B! `
硬件加速功能说明! n1 ]1 q: s' }) W( @
) v! i9 o) G" e0 @7 B! O' J c$ a8 f4 p! p
. p1 G9 i9 ]5 m5 A' g4 f6 t, B
immortalwrt-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之间的无线客户端之间互传数据支持完全硬件加速
' ^# y" @ e. a8 b1 I
& m7 L/ P6 E& s9 x. e9 a 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脚本使用,可调整无线驱动的几乎所有参数,配置界面较为简陋0 A0 t! g. e) L1 ^: O
5 a$ \2 g- V3 @, w3 W) R) 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智能家居设备可能无法连接,请尝试以下无线设置:, Y% a/ I0 C) F! {4 H' L
% c% K9 Q6 A& L: b- 使用WPA-PSK+AES/WPA2-PSK+AES认证加密方式
- 将2.4G无线设置为N模式
- 关闭2.4G的MU-MIMO功能(在较新的源码里,无线设置为N模式时自动关闭MU-MIMO)
- 设置频宽为20MHz,并关闭强制40MHz开关0 v I" X4 c+ ]) C
1 B7 l% I. p0 v/ W
- `8 S& R6 T- d- x- ^$ W
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) b T8 [7 Q2 K
3 ?6 v$ X/ R3 ^; r6 a
" r& k4 [( v) \
luci-app-mtk无线配置说明luci-app-mtk来源于mtk-sdk,采用wifi-profile作为无线控制脚本,不支持openwrt的原版luci界面和netifd-wireless - luci-app-mtk配置界面已基本汉化,可显示驱动版本、芯片温度、已连接客户端信息等,下面以MT7981为例
$ W S; ]: j1 X8 o2 K! d6 P& E" e# {2 T8 v" u) m
- 第一级MT7981右侧的配置按钮为chip_cfg,配置无线驱动基础参数,一般无需修改
- 第二级MT7981.1.1右侧的配置按钮为dev_cfg,可配置信道、国家代码等频段相关参数
- 第三级接口右侧的配置按钮为vif_cfg,可配置SSID、加密方式、无线中继扫描等1 G1 P3 z# d4 W. Z* h
( H3 Q2 f% c! W
& e% R( t7 y5 v8 r9 @% \
8 n, A2 y* Q* H+ A4 Y" H
- 以MT7981.1.1为例,该设备代表MT7981的2.4G频段,其配置页面可以配置自动信道、国家代码、频宽、空间流、发射功率、波束成形等物理参数4 |1 C) e/ e, V4 \5 F$ Z
7 d: O5 L% N5 @$ D; k' T+ Z8 W6 F
& C1 _2 h( ?# `
- MBSSID以ra0为例,该vif虚拟接口代表MT7981 2.4G的第一个MBSSID,在配置页面可以配置加密方式、密码、AP隔离、隐藏SSID等参数
9 @( T; C: i. }3 w, P; s5 k) v+ g+ V: I7 i
, _0 Y; n2 A& A% G: K' E1 t
: m* a7 }; [) {7 p |