在使用 Proxmox VE (PVE) 或 Ubuntu 虚拟机时,很多新款的 TP-Link 免驱 USB 无线网卡(如采用 AIC8800 芯片的型号)接入后,系统并不会将其识别为网卡(wlan),而是识别为一个"存储设备"(Mass Storage),导致无法联网。
本文记录了从模式切换到驱动安装的完整解决流程。
1. 问题现象
执行 lsusb 命令,发现网卡显示为:
Bus 002 Device 010: ID a69c:5721 aicsemi Aic MSC
其中 MSC 代表 Mass Storage Class。这是因为厂家为了方便 Windows 用户,将驱动内置在了网卡的一块只读存储区中。在 Linux 下,我们需要强制它"变身"回网卡模式。
2. 核心步骤:模式切换 (USB-ModeSwitch)
我们需要使用 usb-modeswitch 工具发送特殊的 SCSI 指令,让网卡从存储模式切换到通信模式。
安装工具
bash
sudo apt update
sudo apt install usb-modeswitch usb-modeswitch-data
手动触发切换
针对 a69c:5721 这个 ID,执行以下指令:
bash
sudo usb_modeswitch -v a69c -p 5721 -M "5553424312345678000000000000061b000000020000000000000000000000"
执行后,再次运行 lsusb,你会发现 ID 发生了变化,通常变为:
ID 2357:0147 TP-Link AIC8800DC
注意: 如果你是在虚拟机中使用,切换瞬间设备会重连,请确保你的 PVE 透传设置能够捕获切换后的新设备(建议透传物理端口 Port)。
3. 解决驱动问题
即使模式切换成功,执行 ip link 可能依然看不到网卡接口。这是因为主流 Linux 内核尚未内置 AIC8800 系列的驱动。
推荐方案:官方驱动包
对于大多数用户,直接去 TP-Link 官网 搜索对应型号的 Linux 驱动是最稳妥的方案。
-
下载 :获取官方提供的
.deb驱动安装包。 -
安装 :
bashsudo dpkg -i tplink-driver-xxx.deb
官方包通常会自动处理内核模块的加载和固件(Firmware)的放置。
备选方案:手动编译
如果官方没有 .deb 包,可以从 GitHub 寻找社区驱动(如 lpw-git/aic8800):
bash
git clone https://github.com/lpw-git/aic8800.git
cd aic8800/aic8800_fdrv
make -j$(nproc)
sudo make install
4. 自动化与持久化 (udev 规则)
为了避免每次重启都要手动运行切换命令,我们可以编写一条 udev 规则。
创建文件:/etc/udev/rules.d/40-tp-link-mode.rules
写入内容:
bash
ACTION=="add", SUBSYSTEM=="usb", ATTRS{idVendor}=="a69c", ATTRS{idProduct}=="5721", RUN+="/usr/sbin/usb_modeswitch -v a69c -p 5721 -M '5553424312345678000000000000061b000000020000000000000000000000'"
5. 总结与建议
- 识别身份 :先看
lsusb,带MSC字样的都需要先做usb-modeswitch。 - 透传技巧 :在 PVE 环境下,透传 USB 物理端口 (Port) 比透传 设备 ID 更能应对模式切换带来的 ID 变更。
- 驱动备份 :保存好那个
.deb包,未来更新 Linux 内核后可能需要重新执行安装以触发 DKMS 重新编译。
现在,你的网卡应该已经乖乖出现在 ip link 的列表里了!