Re: Re: [PATCH v2] PCI: Remove redundant macro
From: DongdongZhang
Date: Thu Jan 02 2025 - 22:05:07 EST
Hi Alex,
Thank you for the review and for providing your Acked-by!
I agree that this patch primarily involves PCI changes,
including a modification to PCI UAPI. Therefore, I believe
it would make the most sense to have it go through the PCI tree.
Please let me know if there are any additional steps I
should take to ensure a smooth submission.
Thanks again for your time and support!
Best regards,
Dongdong Zhang
> -----原始邮件-----
> 发件人: "Alex Williamson" <alex.williamson@xxxxxxxxxx>
> 发送时间:2025-01-03 07:50:04 (星期五)
> 收件人: zhangdongdong@xxxxxxxxxxxxxxxxxx
> 抄送: bhelgaas@xxxxxxxxxx, yishaih@xxxxxxxxxx, avihaih@xxxxxxxxxx, yi.l.liu@xxxxxxxxx, ankita@xxxxxxxxxx, kvm@xxxxxxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx, linux-pci@xxxxxxxxxxxxxxx
> 主题: Re: [PATCH v2] PCI: Remove redundant macro
>
> On Mon, 16 Dec 2024 09:35:36 +0800
> zhangdongdong@xxxxxxxxxxxxxxxxxx wrote:
>
> > From: Dongdong Zhang <zhangdongdong@xxxxxxxxxxxxxxxxxx>
> >
> > Removed the duplicate macro `PCI_VSEC_HDR` and its related macro
> > `PCI_VSEC_HDR_LEN_SHIFT` from `pci_regs.h` to avoid redundancy and
> > inconsistencies. Updated VFIO PCI code to use `PCI_VNDR_HEADER` and
> > `PCI_VNDR_HEADER_LEN()` for consistent naming and functionality.
> >
> > These changes aim to streamline header handling while minimizing
> > impact, given the niche usage of these macros in userspace.
> >
> > Signed-off-by: Dongdong Zhang <zhangdongdong@xxxxxxxxxxxxxxxxxx>
> > ---
> > drivers/vfio/pci/vfio_pci_config.c | 5 +++--
>
> Acked-by: Alex Williamson <alex.williamson@xxxxxxxxxx>
>
> Let me know if this is expected to go through the vfio tree. Given
> that vfio is just collateral to a PCI change and it's touching PCI
> uapi, I'm assuming it'll go through the PCI tree. Thanks,
>
> Alex
>
> > include/uapi/linux/pci_regs.h | 3 ---
> > 2 files changed, 3 insertions(+), 5 deletions(-)
> >
> > diff --git a/drivers/vfio/pci/vfio_pci_config.c b/drivers/vfio/pci/vfio_pci_config.c
> > index ea2745c1ac5e..5572fd99b921 100644
> > --- a/drivers/vfio/pci/vfio_pci_config.c
> > +++ b/drivers/vfio/pci/vfio_pci_config.c
> > @@ -1389,11 +1389,12 @@ static int vfio_ext_cap_len(struct vfio_pci_core_device *vdev, u16 ecap, u16 epo
> >
> > switch (ecap) {
> > case PCI_EXT_CAP_ID_VNDR:
> > - ret = pci_read_config_dword(pdev, epos + PCI_VSEC_HDR, &dword);
> > + ret = pci_read_config_dword(pdev, epos + PCI_VNDR_HEADER,
> > + &dword);
> > if (ret)
> > return pcibios_err_to_errno(ret);
> >
> > - return dword >> PCI_VSEC_HDR_LEN_SHIFT;
> > + return PCI_VNDR_HEADER_LEN(dword);
> > case PCI_EXT_CAP_ID_VC:
> > case PCI_EXT_CAP_ID_VC9:
> > case PCI_EXT_CAP_ID_MFVC:
> > diff --git a/include/uapi/linux/pci_regs.h b/include/uapi/linux/pci_regs.h
> > index 1601c7ed5fab..bcd44c7ca048 100644
> > --- a/include/uapi/linux/pci_regs.h
> > +++ b/include/uapi/linux/pci_regs.h
> > @@ -1001,9 +1001,6 @@
> > #define PCI_ACS_CTRL 0x06 /* ACS Control Register */
> > #define PCI_ACS_EGRESS_CTL_V 0x08 /* ACS Egress Control Vector */
> >
> > -#define PCI_VSEC_HDR 4 /* extended cap - vendor-specific */
> > -#define PCI_VSEC_HDR_LEN_SHIFT 20 /* shift for length field */
> > -
> > /* SATA capability */
> > #define PCI_SATA_REGS 4 /* SATA REGs specifier */
> > #define PCI_SATA_REGS_MASK 0xF /* location - BAR#/inline */