]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
net: intel: fix PCI device ID conflict between i40e and ipw2200
authorEthan Nelson-Moore <enelsonmoore@gmail.com>
Tue, 10 Feb 2026 02:12:34 +0000 (18:12 -0800)
committerSasha Levin <sashal@kernel.org>
Wed, 4 Mar 2026 12:21:29 +0000 (07:21 -0500)
[ Upstream commit d03e094473ecdeb68d853752ba467abe13e1de44 ]

The ID 8086:104f is matched by both i40e and ipw2200. The same device
ID should not be in more than one driver, because in that case, which
driver is used is unpredictable. Fix this by taking advantage of the
fact that i40e devices use PCI_CLASS_NETWORK_ETHERNET and ipw2200
devices use PCI_CLASS_NETWORK_OTHER to differentiate the devices.

Fixes: 2e45d3f4677a ("i40e: Add support for X710 B/P & SFP+ cards")
Cc: stable@vger.kernel.org
Acked-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: Ethan Nelson-Moore <enelsonmoore@gmail.com>
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
Link: https://patch.msgid.link/20260210021235.16315-1-enelsonmoore@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/intel/i40e/i40e_main.c
drivers/net/wireless/intel/ipw2x00/ipw2200.c

index d3bc3207054f90e17b7833a8705bdd57503bbea4..02de186dcc8f597bfef93923ccf05b4be2df91bf 100644 (file)
@@ -75,7 +75,13 @@ static const struct pci_device_id i40e_pci_tbl[] = {
        {PCI_VDEVICE(INTEL, I40E_DEV_ID_10G_BASE_T4), 0},
        {PCI_VDEVICE(INTEL, I40E_DEV_ID_10G_BASE_T_BC), 0},
        {PCI_VDEVICE(INTEL, I40E_DEV_ID_10G_SFP), 0},
-       {PCI_VDEVICE(INTEL, I40E_DEV_ID_10G_B), 0},
+       /*
+        * This ID conflicts with ipw2200, but the devices can be differentiated
+        * because i40e devices use PCI_CLASS_NETWORK_ETHERNET and ipw2200
+        * devices use PCI_CLASS_NETWORK_OTHER.
+        */
+       {PCI_DEVICE(PCI_VENDOR_ID_INTEL, I40E_DEV_ID_10G_B),
+               PCI_CLASS_NETWORK_ETHERNET << 8, 0xffff00, 0},
        {PCI_VDEVICE(INTEL, I40E_DEV_ID_KX_X722), 0},
        {PCI_VDEVICE(INTEL, I40E_DEV_ID_QSFP_X722), 0},
        {PCI_VDEVICE(INTEL, I40E_DEV_ID_SFP_X722), 0},
index 24a5624ef207113ec4712e37bc495b15bde41630..3876010c2ce8fb95eb261400540eed4ce58cd5f8 100644 (file)
@@ -11387,7 +11387,13 @@ static const struct pci_device_id card_ids[] = {
        {PCI_VENDOR_ID_INTEL, 0x1043, 0x8086, 0x2754, 0, 0, 0},
        {PCI_VENDOR_ID_INTEL, 0x1043, 0x8086, 0x2761, 0, 0, 0},
        {PCI_VENDOR_ID_INTEL, 0x1043, 0x8086, 0x2762, 0, 0, 0},
-       {PCI_VDEVICE(INTEL, 0x104f), 0},
+       /*
+        * This ID conflicts with i40e, but the devices can be differentiated
+        * because i40e devices use PCI_CLASS_NETWORK_ETHERNET and ipw2200
+        * devices use PCI_CLASS_NETWORK_OTHER.
+        */
+       {PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x104f),
+               PCI_CLASS_NETWORK_OTHER << 8, 0xffff00, 0},
        {PCI_VDEVICE(INTEL, 0x4220), 0},        /* BG */
        {PCI_VDEVICE(INTEL, 0x4221), 0},        /* BG */
        {PCI_VDEVICE(INTEL, 0x4223), 0},        /* ABG */