Bug: 升级内核后有线网络无法使用

预备知识

1.R8169驱动和R8168驱动区别

R8169驱动是Linux内核自带的开源驱动,支持的硬件范围比较广,但是跟随内核一起发布更新,因此对于新发布的硬件支持不够及时。R8168驱动是Realtek官方提供的闭源驱动,对特定硬件进行了优化,稳定性更高,更新及时。

R8169驱动主要针对Realtek的地段或早期千兆以太网芯片,包括但不限于RTL8101/8102E,RTL8168/8111,RTl8411/8412等。

R8168驱动是Realtek官方为RTL8168系列(如RTL8168B/C/D/E/F等)开发的专用驱动,针对性更强。

因此R8169驱动和R8168驱动都可以支持RTL8168芯片。

2.内核编译配置

编译内核源码之前可以通过make menuconfig配置内核编译选项,也可以基于defconfig创建自己的内核配置,例如 my_x86_desktop_defconfig ,配置完毕后再make my_x86_desktop_defconfig加载自定义配置。

安装内核后,通过 /boot/config-$(uname -r) 文件可以查看当前版本内核的配置选项

一、Bug描述

将内核从4.19-7322升级到4.19-7326后发现有线连接无法使用

二、Bug分析

查看4.19-7322内核的编译配置,发现只有CONFIG_R8168=m,而没有CONFIG_R8169=m;

查看4.19-7326内核的编译配置,发现只有CONFIG_R8169=m,而没有CONFIG_R8168=m;

查找到当前系统中存在/etc/modprobe.d/balcklist-r8169.conf,说明系统禁用了R8169模块。

再根据Bug描述,很容易分析出"由于4.19-7326内核不支持R8168驱动,同时又禁用了R8169驱动,所以才导致有线连接无法使用"的结论。

三、Bug修复

编写deb包,在psotinst中加入如下逻辑:

bash 复制代码
#检查内核配置文件是否存在
CONFIG_FILE="/boot/config-$(uname -r)"
if [ ! -f "$CONFIG_FILE" ]; then
    exit 1
fi

#检查内核配置是否支持R8169驱动且不支持R8168驱动
if grep -q "^CONFIG_R8169=[ym]$" "$CONFIG_FILE" && ( grep -q "^CONFIG_R8168=n$" "$CONFIG_FILE" || ! grep -q "^CONFIG_R8168=" "$CONFIG_FILE" ); then
    #检查R8169驱动是否被加入黑名单
    if [ -f /etc/modprobe.d/blacklist_r8169.conf ]; then
        #删除R8169的黑名单配置文件
        rm -f /etc/modprobe.d/blacklist_r8169.conf
        echo "已删除 /etc/modprobe.d/blacklist_r8169.conf"
    fi
fi
相关推荐
Swift社区19 小时前
RN 项目中“页面存在 ≠ 页面可见”会导致哪些隐藏 Bug?
react native·bug·react
tongyue20 小时前
天问esp32驱动DHT11官方程序BUG修复
bug
laocooon5238578862 天前
写代码 调bug相关信息
bug
鸿儒5172 天前
记录一个C++操作8位影像的一个bug
开发语言·c++·bug
·云扬·2 天前
【Bug】 Elasticsearch启动失败(exit code 78):2个bootstrap检查问题排查与解决
elasticsearch·bootstrap·bug
BrianGriffin3 天前
get_download_file_path: command not found (asdf bug已解决)
bug
咸虾米_3 天前
解决九两酒商城[uni-pay-co]: Error:执行失败,积 分需要大于等于1的bug
bug·unicloud云开发·微信小程序商城·uniapp项目
凯子坚持 c3 天前
Git分支实战指南:如何优雅地管理版本、修复Bug并解决合并冲突
git·bug
北冥有渔jy3 天前
BT6.0常见的BUG
网络·安全·bug·蓝牙
测试19984 天前
一个只能通过压测发现Bug
自动化测试·软件测试·python·selenium·测试工具·bug·压力测试