news 2026/5/1 4:45:33

UBuntu18.04 解决 Linux 5.4 下 Intel I226-V (0x125C) 2.5G 网卡驱动识别问题 (probe failed with error -2)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UBuntu18.04 解决 Linux 5.4 下 Intel I226-V (0x125C) 2.5G 网卡驱动识别问题 (probe failed with error -2)

解决 Linux 5.4 下 Intel I226-V (0x125C) 2.5G 网卡驱动识别问题 (probe failed with error -2)

背景

在 Ubuntu 18.04 (Kernel 5.4.0) 平台上使用 Intel NUC13 或某些定制主板时,遇到了板载的 Intel I226-V 2.5G 网卡无法识别的问题。
lspci可以看到设备,但驱动加载失败,dmesg报错probe failed with error -5error -2

本文记录了通过修改 Intel IGC 源码驱动来适配该未知设备 ID (0x125C) 的完整过程。

硬件信息

架构: x86_64 CPU 运行模式:32-bit,64-bit 字节序: Little Endian CPU:16在线 CPU 列表:0-15 每个核的线程数:1每个座的核数:10座:1NUMA 节点:1厂商 ID: GenuineIntel CPU 系列:6型号:186型号名称: 13th Gen Intel(R)Core(TM)i7-13620H 步进:2CPU MHz:553.048CPU 最大 MHz:6300.0000CPU 最小 MHz:400.0000BogoMIPS:5836.80虚拟化: VT-x L1d 缓存: 48K L1i 缓存: 32K L2 缓存: 1280K L3 缓存: 24576K NUMA 节点0 CPU:0-15 标记: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc art arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc cpuid aperfmperf tsc_known_freq pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 sdbg fma cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm abm 3dnowprefetch cpuid_fault epb invpcid_single ssbd ibrs ibpb stibp ibrs_enhanced tpr_shadow vnmi flexpriority ept vpid ept_ad fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms invpcid rdseed adx smap clflushopt clwb intel_pt sha_ni xsaveopt xsavec xgetbv1 xsaves dtherm ida arat pln pts hwp hwp_notify hwp_act_window hwp_epp hwp_pkg_req umip pku ospke waitpkg gfni vaes vpclmulqdq rdpid movdiri movdir64b md_clear flush_l1d arch_capabilities

通过lspci -nnk查询到的网卡信息如下:

55:00.0 Ethernet controller[0200]: Intel Corporation Device[8086:125c](rev 04)Subsystem: Intel Corporation Device[8086:3037]56:00.0 Ethernet controller[0200]: Intel Corporation Device[8086:125c](rev 04)Subsystem: Intel Corporation Device[8086:0000]

关键点在于 Device ID 为125c,这是一个在 Linux 5.4 内核自带驱动中未被定义的 ID。

问题现象

  1. 驱动无法加载lspci显示没有Kernel driver in use
  2. 报错信息
    • 初始报错:igc: probe of 0000:55:00.0 failed with error -5(MAC初始化错误)
    • 修正 ID 后报错:igc: probe of 0000:55:00.0 failed with error -2(PHY ID 检查或 NVM 校验错误)

解决方案

我们需要下载 Intel IGC 独立驱动源码(基于 5.4.0-7642.46 或类似版本),并修改源码以添加对0x125C的支持。

1. 准备工作

安装编译环境和内核头文件:

sudoapt-getupdatesudoapt-getinstalldkms build-essential linux-headers-$(uname-r)

2. 获取源码

假设你已经有了intel-igc的驱动源码(可以从 GitHub 或 Intel 官网获取旧版源码)。

3. 修改源码

需要修改三个文件来适配此硬件。

修改一:添加设备 ID 宏定义

文件:src/igc_hw.h
在设备 ID 列表处添加0x125C的定义:

#defineIGC_DEV_ID_I225_LM0x15F2// ... 其他 ID ...#defineIGC_DEV_ID_I225_BLANK_NVM0x15FD#defineIGC_DEV_ID_I226_V0x125C/* 添加这一行 */
修改二:注册 PCI 设备表

文件:src/igc_main.c
igc_pci_tbl数组中添加新的 ID,使其能被 probe 探测到:

staticconststructpci_device_idigc_pci_tbl[]={{PCI_VDEVICE(INTEL,IGC_DEV_ID_I225_LM),board_base},// ...{PCI_VDEVICE(INTEL,IGC_DEV_ID_I226_V),board_base},/* 添加这一行 */{0,}};
修改三:适配初始化流程与绕过 PHY 检查

文件:src/igc_base.c

步骤 A:在igc_get_invariants_base中添加初始化分支
防止返回 error -5 (MAC Init Error):

statics32igc_get_invariants_base(structigc_hw*hw){// ...switch(hw->device_id){caseIGC_DEV_ID_I225_LM:// ...caseIGC_DEV_ID_I226_V:/* 添加这一行 */mac->type=igc_i225;break;default:return-IGC_ERR_MAC_INIT;}// ...}

步骤 B:在igc_init_phy_params_base中放宽 PHY ID 检查
防止返回 error -2 (PHY Error/ENOENT)。由于这是定制版或新版 PHY,ID 可能不在白名单中,我们将其默认视为 I225 PHY 处理:

statics32igc_init_phy_params_base(structigc_hw*hw){// ... (获取 PHY ID 后)/* Verify phy id and set remaining function pointers */switch(phy->id){caseI225_I_PHY_ID:phy->type=igc_phy_i225;break;default:/* 修改:不再直接返回错误,而是兼容处理 */// ret_val = -IGC_ERR_PHY;// goto out;phy->type=igc_phy_i225;/* 强制指定为 I225 */break;}// ...}

4. 编译与安装

方式一:使用 DKMS(推荐)

这样内核升级后驱动会自动重编。

# 1. 确保在源码根目录cd~/intel-igc# 2. 清理旧版本(如果有)sudodkms remove igc/5.4.0-7642.46 --all# 3. 添加到 DKMSsudodkmsadd.# 4. 安装sudodkmsinstalligc/5.4.0-7642.46# 5. 加载驱动sudormmod igcsudomodprobe igc
方式二:手动编译
cdsrcmake-C /lib/modules/$(uname-r)/buildM=$(pwd)modulessudoinsmod igc.ko

5. 验证结果

执行以下命令查看状态:

# 1. 查看内核日志,确认 probe 成功dmesg|tail# 应显示:Intel(R) 2.5G Ethernet Linux Driver... 且无报错# 2. 查看 PCI 驱动绑定lspci -nnk|grep-A3 125c# 应显示:Kernel driver in use: igc# 3. 查看网口并启用ipaddrsudoiplinksetenp85s0 upsudodhclient enp85s0

至此,Intel 0x125C 网卡在 Ubuntu 18.04 下成功驱动。


注意:本文基于 Linux 5.4 内核环境。更高版本的内核(如 5.15+)可能已经原生支持该设备,建议优先考虑升级内核。但在无法升级内核的嵌入式/工控场景下,此 patch 方法非常有效。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:05:45

CS83722 17W R类音频功率放大器 ESOP10L 内置BOOST防破音 AB/D类切换

CS83722E是一款内置自适应BOOST升压模块的R类单声道音频功率放大器,输入电压范围2.7~5.5V,支持AB类与D类模式切换,3Ω负载下最高输出17W功率(10% THDN),4Ω负载下最高13.5W(10% THDN&#xff09…

作者头像 李华
网站建设 2026/5/1 7:12:15

3步快速上手renren-fast-vue后台管理系统开发

3步快速上手renren-fast-vue后台管理系统开发 【免费下载链接】renren-fast-vue 项目地址: https://gitcode.com/gh_mirrors/ren/renren-fast-vue 还在为后台管理系统开发效率低而烦恼吗?🚀 renren-fast-vue是一个基于Vue.js和Element-UI的前端解…

作者头像 李华
网站建设 2026/4/14 1:25:07

【必学收藏】向量数据库完全指南:大模型开发者的核心技术与实战应用

文章以猫的分类为例,生动解释了向量数据库的概念与原理。通过将猫的特征转换为多维坐标向量,展示了如何利用向量表示和区分不同数据。文章对比了传统数据库与向量数据库在搜索方式、数据存储上的差异,详细介绍了向量数据库在人脸识别、图像搜…

作者头像 李华
网站建设 2026/5/1 3:28:03

VScode中函数和变量跳转定义配置文件设置

vscode中有两种方式去设置,一种是基于MinGW ,一种是基于LLVM中的clang工具配置文件在vscode打开的工程中,路径在I:\TBOX\111\.vscode\settings.json,或者I:\TBOX\222\.vscode\settings.json两种内容分别如下:I:\TBOX\111\.vscode\…

作者头像 李华
网站建设 2026/4/28 3:03:32

Jmeter 快速生成测试报告,学会领导主动给你加薪

我们使用Jmeter工具进行接口测试或性能测试后一般是通过察看结果数、聚合报告等监听器来查看响应结果。如果要跟领导汇报测试结果,无法直接通过监听器的结果来进行展示和汇报,因为太low了,因此测试完成后去整理一个数据齐全且美观的报告是非常…

作者头像 李华
网站建设 2026/4/23 14:58:58

第一章CentOS安装和卸载httpd

1,挂载光盘 mount /dev/cdrom /mnt2,切换到软件包目录 cd /mnt/Packages3,安装httpd rpm -ivh mailcap-2.1.41-2.el7.noarch.rpm httpd-tools-2.4.6-95.el7.centos.x86_64.rpm httpd-2.4.6-95.el7.centos.x86_64.rpm4,启动httpd s…

作者头像 李华