[Intel-wired-lan] [PATCH net-next] net: Consistently define pci_device_ids using named initializers
Loktionov, Aleksandr
aleksandr.loktionov at intel.com
Wed Apr 29 09:19:55 UTC 2026
> -----Original Message-----
> From: Intel-wired-lan <intel-wired-lan-bounces at osuosl.org> On Behalf
> Of Uwe Kleine-König (The Capable Hub)
> Sent: Tuesday, April 28, 2026 7:19 PM
> To: Michael Grzeschik <m.grzeschik at pengutronix.de>; Andrew Lunn
> <andrew+netdev at lunn.ch>; David S. Miller <davem at davemloft.net>; Eric
> Dumazet <edumazet at google.com>; Jakub Kicinski <kuba at kernel.org>; Paolo
> Abeni <pabeni at redhat.com>; Marc Kleine-Budde <mkl at pengutronix.de>;
> Vincent Mailhol <mailhol at kernel.org>; Krzysztof Halasa
> <khc at pm.waw.pl>; Johannes Berg <johannes at sipsolutions.net>
> Cc: Richard Cochran <richardcochran at gmail.com>; Yonglong Liu
> <liuyonglong at huawei.com>; Kees Cook <kees at kernel.org>; linux-
> wireless at vger.kernel.org; Zaremba, Larysa <larysa.zaremba at intel.com>;
> brcm80211 at lists.linux.dev; Daniele Venzano <venza at brownhat.org>; oss-
> drivers at corigine.com; Nguyen, Anthony L <anthony.l.nguyen at intel.com>;
> MD Danish Anwar <danishanwar at ti.com>; Samuel Chessman
> <chessman at tux.org>; Fan Gong <gongfan1 at huawei.com>; Marco Crivellari
> <marco.crivellari at suse.com>; Kevin Curtis
> <kevin.curtis at farsite.co.uk>; Ingo Molnar <mingo at kernel.org>; Ion
> Badulescu <ionut at badula.org>; Shevchenko, Andriy
> <andriy.shevchenko at intel.com>; Leon Romanovsky <leon at kernel.org>;
> Colin Ian King <colin.i.king at gmail.com>; Kitszel, Przemyslaw
> <przemyslaw.kitszel at intel.com>; Peiyang Wang
> <wangpeiyang1 at huawei.com>; Thomas Fourier <fourier.thomas at gmail.com>;
> Sai Krishna <saikrishnag at marvell.com>; Denis Kirjanov
> <kirjanov at gmail.com>; intel-wired-lan at lists.osuosl.org; linux-
> parisc at vger.kernel.org; Keller, Jacob E <jacob.e.keller at intel.com>;
> Mengyuan Lou <mengyuanlou at net-swift.com>; Steffen Klassert
> <klassert at kernel.org>; Stanislav Yakovlev <stas.yakovlev at gmail.com>;
> linux-rdma at vger.kernel.org; Arend van Spriel
> <arend.vanspriel at broadcom.com>; nic_swsd at realtek.com; Jiri Pirko
> <jiri at resnulli.us>; Philipp Stanner <phasta at kernel.org>; Chi-hsien Lin
> <chi-hsien.lin at cypress.com>; Ido Schimmel <idosch at nvidia.com>; Potnuri
> Bharat Teja <bharat at chelsio.com>; Double Lo <double.lo at cypress.com>;
> Markus Schneider-Pargmann <msp at baylibre.com>; Nathan Chancellor
> <nathan at kernel.org>; Jiawen Wu <jiawenwu at trustnetic.com>; Cai Huoqing
> <cai.huoqing at linux.dev>; Bjorn Helgaas <bhelgaas at google.com>; Zilin
> Guan <zilin at seu.edu.cn>; linux-can at vger.kernel.org; Yibo Dong
> <dong100 at mucse.com>; Joe Damato <joe at dama.to>; Petr Machata
> <petrm at nvidia.com>; Kory Maincent <kory.maincent at bootlin.com>;
> brcm80211-dev-list.pdl at broadcom.com; GR-Linux-NIC-Dev at marvell.com;
> Vadim Fedorenko <vadim.fedorenko at linux.dev>; Manish Chopra
> <manishc at marvell.com>; Denis Benato <benato.denis96 at gmail.com>; Rasesh
> Mody <rmody at marvell.com>; netdev at vger.kernel.org; Randy Dunlap
> <rdunlap at infradead.org>; Mark Bloch <mbloch at nvidia.com>; linux-
> kernel at vger.kernel.org; Tariq Toukan <tariqt at nvidia.com>; Jian Shen
> <shenjian15 at huawei.com>; Jijie Shao <shaojijie at huawei.com>; Yeounsu
> Moon <yyyynoom at gmail.com>; Thomas Gleixner <tglx at kernel.org>; Simon
> Horman <horms at kernel.org>; Yicong Hui <yiconghui at gmail.com>; Mark
> Einon <mark.einon at gmail.com>; Ethan Nelson-Moore
> <enelsonmoore at gmail.com>; Saeed Mahameed <saeedm at nvidia.com>;
> Sudarsana Kalluru <skalluru at marvell.com>; Heiner Kallweit
> <hkallweit1 at gmail.com>
> Subject: [Intel-wired-lan] [PATCH net-next] net: Consistently define
> pci_device_ids using named initializers
>
> ... and PCI device helpers.
>
> The various struct pci_device_id arrays were initialized mostly by one
> the PCI_DEVICE macros and then list expressions. The latter isn't
> easily
> readable if you're not into PCI. Using named initializers is more
> explicit and thus easier to parse.
>
> Also use PCI_DEVICE* helper macros to assign .vendor, .device,
> .subvendor and .subdevice where appropriate and skip explicit
> assignments of 0 (which the compiler takes care of).
>
> The secret plan is to make struct pci_device_id::driver_data an
> anonymous union (similar to
> https://lore.kernel.org/all/cover.1776579304.git.u.kleine-
> koenig at baylibre.com/)
> and that requires named initializers. But it's also a nice cleanup on
> its own.
>
> This change doesn't introduce changes to the compiled pci_device_id
> arrays. Tested on x86 and arm64.
>
> Signed-off-by: Uwe Kleine-König (The Capable Hub) <u.kleine-
> koenig at baylibre.com>
> ---
> Hello,
>
> the mentioned follow-up quest allows to do
>
> PCI_DEVICE(0x1571, 0xa203),
> + .driver_data = (kernel_ulong_t)&card_info_10mbit,
> - .driver_data_ptr = &card_info_10mbit,
>
> which gets rid of a bunch of casts and so brings a little bit more
> type
> safety. This patch is a preparation for that.
>
> I handled all of drivers/net/ in a single patch, please tell me if I
> should split by subsystem.
>
> Best regards
> Uwe
> ---
> drivers/net/arcnet/com20020-pci.c | 242 +++------
> drivers/net/can/m_can/m_can_pci.c | 6 +-
> drivers/net/can/sja1000/plx_pci.c | 167 +++----
> drivers/net/ethernet/3com/3c59x.c | 80 +--
> drivers/net/ethernet/3com/typhoon.c | 75 ++-
> drivers/net/ethernet/8390/ne2k-pci.c | 24 +-
> drivers/net/ethernet/adaptec/starfire.c | 4 +-
> drivers/net/ethernet/agere/et131x.c | 6 +-
> drivers/net/ethernet/broadcom/bnx2.c | 62 ++-
> .../net/ethernet/broadcom/bnx2x/bnx2x_main.c | 50 +-
> .../net/ethernet/cavium/liquidio/lio_main.c | 10 +-
> .../ethernet/cavium/liquidio/lio_vf_main.c | 7 +-
> drivers/net/ethernet/chelsio/cxgb/common.h | 2 +-
> drivers/net/ethernet/chelsio/cxgb/subr.c | 2 +-
> .../net/ethernet/chelsio/cxgb3/cxgb3_main.c | 4 +-
> .../net/ethernet/chelsio/cxgb4/cxgb4_main.c | 4 +-
> .../ethernet/chelsio/cxgb4vf/cxgb4vf_main.c | 4 +-
> drivers/net/ethernet/dec/tulip/de2104x.c | 6 +-
> drivers/net/ethernet/dec/tulip/dmfe.c | 12 +-
> drivers/net/ethernet/dec/tulip/tulip_core.c | 78 +--
> drivers/net/ethernet/dec/tulip/uli526x.c | 6 +-
> drivers/net/ethernet/dec/tulip/winbond-840.c | 13 +-
> drivers/net/ethernet/dlink/dl2k.h | 12 +-
> drivers/net/ethernet/dlink/sundance.c | 14 +-
> drivers/net/ethernet/fealnx.c | 8 +-
> .../net/ethernet/hisilicon/hibmcge/hbg_main.c | 2 +-
> .../net/ethernet/hisilicon/hns3/hns3_enet.c | 50 +-
> .../hisilicon/hns3/hns3pf/hclge_main.c | 18 +-
> .../hisilicon/hns3/hns3vf/hclgevf_main.c | 12 +-
> .../net/ethernet/huawei/hinic/hinic_main.c | 12 +-
> .../net/ethernet/huawei/hinic3/hinic3_lld.c | 7 +-
> drivers/net/ethernet/intel/e100.c | 4 +-
> drivers/net/ethernet/intel/e1000e/netdev.c | 471 +++++++++++++----
> -
> drivers/net/ethernet/intel/fm10k/fm10k_pci.c | 10 +-
> drivers/net/ethernet/intel/i40e/i40e_main.c | 59 +--
> drivers/net/ethernet/intel/iavf/iavf_main.c | 10 +-
> drivers/net/ethernet/intel/igb/igb_main.c | 66 +--
> drivers/net/ethernet/intel/igbvf/netdev.c | 4 +-
> drivers/net/ethernet/intel/igc/igc_main.c | 34 +-
> drivers/net/ethernet/intel/ixgbe/ixgbe_main.c | 106 ++--
> .../net/ethernet/intel/ixgbevf/ixgbevf_main.c | 49 +-
> drivers/net/ethernet/mellanox/mlx4/main.c | 6 +-
> .../net/ethernet/mellanox/mlx5/core/main.c | 26 +-
> .../net/ethernet/mellanox/mlxsw/spectrum.c | 16 +-
> drivers/net/ethernet/micrel/ksz884x.c | 8 +-
> .../net/ethernet/mucse/rnpgbe/rnpgbe_main.c | 10 +-
> drivers/net/ethernet/natsemi/natsemi.c | 4 +-
> drivers/net/ethernet/netronome/nfp/nfp_main.c | 81 +--
> .../ethernet/netronome/nfp/nfp_netvf_main.c | 41 +-
> drivers/net/ethernet/qlogic/qede/qede_main.c | 20 +-
> drivers/net/ethernet/realtek/8139too.c | 52 +-
> drivers/net/ethernet/realtek/r8169_main.c | 8 +-
> drivers/net/ethernet/rocker/rocker_main.c | 4 +-
> drivers/net/ethernet/sis/sis190.c | 6 +-
> drivers/net/ethernet/sis/sis900.c | 10 +-
> drivers/net/ethernet/smsc/epic100.c | 18 +-
> drivers/net/ethernet/sun/cassini.c | 8 +-
> drivers/net/ethernet/sun/sungem.c | 26 +-
> drivers/net/ethernet/ti/tlan.c | 41 +-
> drivers/net/ethernet/wangxun/ngbe/ngbe_main.c | 26 +-
> .../net/ethernet/wangxun/ngbevf/ngbevf_main.c | 26 +-
> .../net/ethernet/wangxun/txgbe/txgbe_main.c | 18 +-
> .../ethernet/wangxun/txgbevf/txgbevf_main.c | 18 +-
> drivers/net/wan/farsync.c | 24 +-
> drivers/net/wan/pc300too.c | 14 +-
> drivers/net/wan/pci200syn.c | 6 +-
> drivers/net/wan/wanxl.c | 11 +-
> .../broadcom/brcm80211/brcmfmac/pcie.c | 17 +-
> drivers/net/wireless/intel/ipw2x00/ipw2200.c | 52 +-
> 69 files changed, 1308 insertions(+), 1101 deletions(-)
>
> diff --git a/drivers/net/arcnet/com20020-pci.c
> b/drivers/net/arcnet/com20020-pci.c
> index dbadda08dce2..6474c7be2992 100644
> --- a/drivers/net/arcnet/com20020-pci.c
> +++ b/drivers/net/arcnet/com20020-pci.c
> @@ -459,168 +459,88 @@ static struct com20020_pci_card_info
> card_info_eae_fb2 = {
>
> static const struct pci_device_id com20020pci_id_table[] = {
> {
...
> };
>
> MODULE_DEVICE_TABLE(pci, card_ids);
>
> base-commit: 254f49634ee16a731174d2ae34bc50bd5f45e731
> --
> 2.47.3
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov at intel.com>
More information about the Intel-wired-lan
mailing list