On Mon, Oct 30, 2023 at 01:32:12PM +0100, Lukas Wunner wrote: > It is possible to enable CONFIG_PCI but disable CONFIG_SYSFS and for > space-constrained devices such as routers, such a configuration may > actually make sense. > > However pci-sysfs.c is compiled even if CONFIG_SYSFS is disabled, > unnecessarily increasing the kernel's size. > > To rectify that: > > * Move pci_mmap_fits() to mmap.c. It is not only needed by > pci-sysfs.c, but also proc.c. > > * Move pci_dev_type to probe.c and make it private. It references > pci_dev_attr_groups in pci-sysfs.c. Make that public instead for > consistency with pci_dev_groups, pcibus_groups and pci_bus_groups, > which are likewise public and referenced by struct definitions in > pci-driver.c and probe.c. > > * Define pci_dev_groups, pci_dev_attr_groups, pcibus_groups and > pci_bus_groups to NULL if CONFIG_SYSFS is disabled. Provide empty > static inlines for pci_{create,remove}_legacy_files() and > pci_{create,remove}_sysfs_dev_files(). > > Result: > > vmlinux size is reduced by 122996 bytes in my arm 32-bit test build. > > Signed-off-by: Lukas Wunner <lukas@xxxxxxxxx> Both applied to pci/sysfs with Alistair's Reviewed-by, thanks! > --- > drivers/pci/Makefile | 4 ++-- > drivers/pci/mmap.c | 29 +++++++++++++++++++++++++++++ > drivers/pci/pci-sysfs.c | 29 +---------------------------- > drivers/pci/pci.h | 18 ++++++++++++++---- > drivers/pci/probe.c | 4 ++++ > 5 files changed, 50 insertions(+), 34 deletions(-) > > diff --git a/drivers/pci/Makefile b/drivers/pci/Makefile > index cc8b4e01e29d..96f4759f2bd3 100644 > --- a/drivers/pci/Makefile > +++ b/drivers/pci/Makefile > @@ -4,7 +4,7 @@ > > obj-$(CONFIG_PCI) += access.o bus.o probe.o host-bridge.o \ > remove.o pci.o pci-driver.o search.o \ > - pci-sysfs.o rom.o setup-res.o irq.o vpd.o \ > + rom.o setup-res.o irq.o vpd.o \ > setup-bus.o vc.o mmap.o setup-irq.o > > obj-$(CONFIG_PCI) += msi/ > @@ -12,7 +12,7 @@ obj-$(CONFIG_PCI) += pcie/ > > ifdef CONFIG_PCI > obj-$(CONFIG_PROC_FS) += proc.o > -obj-$(CONFIG_SYSFS) += slot.o > +obj-$(CONFIG_SYSFS) += pci-sysfs.o slot.o > obj-$(CONFIG_ACPI) += pci-acpi.o > endif > > diff --git a/drivers/pci/mmap.c b/drivers/pci/mmap.c > index 4504039056d1..8da3347a95c4 100644 > --- a/drivers/pci/mmap.c > +++ b/drivers/pci/mmap.c > @@ -11,6 +11,8 @@ > #include <linux/mm.h> > #include <linux/pci.h> > > +#include "pci.h" > + > #ifdef ARCH_GENERIC_PCI_MMAP_RESOURCE > > static const struct vm_operations_struct pci_phys_vm_ops = { > @@ -50,3 +52,30 @@ int pci_mmap_resource_range(struct pci_dev *pdev, int bar, > } > > #endif > + > +#if (defined(CONFIG_SYSFS) || defined(CONFIG_PROC_FS)) && \ > + (defined(HAVE_PCI_MMAP) || defined(ARCH_GENERIC_PCI_MMAP_RESOURCE)) > + > +int pci_mmap_fits(struct pci_dev *pdev, int resno, struct vm_area_struct *vma, > + enum pci_mmap_api mmap_api) > +{ > + resource_size_t pci_start = 0, pci_end; > + unsigned long nr, start, size; > + > + if (pci_resource_len(pdev, resno) == 0) > + return 0; > + nr = vma_pages(vma); > + start = vma->vm_pgoff; > + size = ((pci_resource_len(pdev, resno) - 1) >> PAGE_SHIFT) + 1; > + if (mmap_api == PCI_MMAP_PROCFS) { > + pci_resource_to_user(pdev, resno, &pdev->resource[resno], > + &pci_start, &pci_end); > + pci_start >>= PAGE_SHIFT; > + } > + if (start >= pci_start && start < pci_start + size && > + start + nr <= pci_start + size) > + return 1; > + return 0; > +} > + > +#endif > diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c > index 2321fdfefd7d..44ed30df08c3 100644 > --- a/drivers/pci/pci-sysfs.c > +++ b/drivers/pci/pci-sysfs.c > @@ -1022,29 +1022,6 @@ void pci_remove_legacy_files(struct pci_bus *b) > #endif /* HAVE_PCI_LEGACY */ > > #if defined(HAVE_PCI_MMAP) || defined(ARCH_GENERIC_PCI_MMAP_RESOURCE) > - > -int pci_mmap_fits(struct pci_dev *pdev, int resno, struct vm_area_struct *vma, > - enum pci_mmap_api mmap_api) > -{ > - unsigned long nr, start, size; > - resource_size_t pci_start = 0, pci_end; > - > - if (pci_resource_len(pdev, resno) == 0) > - return 0; > - nr = vma_pages(vma); > - start = vma->vm_pgoff; > - size = ((pci_resource_len(pdev, resno) - 1) >> PAGE_SHIFT) + 1; > - if (mmap_api == PCI_MMAP_PROCFS) { > - pci_resource_to_user(pdev, resno, &pdev->resource[resno], > - &pci_start, &pci_end); > - pci_start >>= PAGE_SHIFT; > - } > - if (start >= pci_start && start < pci_start + size && > - start + nr <= pci_start + size) > - return 1; > - return 0; > -} > - > /** > * pci_mmap_resource - map a PCI resource into user memory space > * @kobj: kobject for mapping > @@ -1660,7 +1637,7 @@ static const struct attribute_group pcie_dev_attr_group = { > .is_visible = pcie_dev_attrs_are_visible, > }; > > -static const struct attribute_group *pci_dev_attr_groups[] = { > +const struct attribute_group *pci_dev_attr_groups[] = { > &pci_dev_attr_group, > &pci_dev_hp_attr_group, > #ifdef CONFIG_PCI_IOV > @@ -1677,7 +1654,3 @@ static const struct attribute_group *pci_dev_attr_groups[] = { > #endif > NULL, > }; > - > -const struct device_type pci_dev_type = { > - .groups = pci_dev_attr_groups, > -}; > diff --git a/drivers/pci/pci.h b/drivers/pci/pci.h > index 5ecbcf041179..aedaf4e51146 100644 > --- a/drivers/pci/pci.h > +++ b/drivers/pci/pci.h > @@ -31,8 +31,6 @@ bool pcie_cap_has_rtctl(const struct pci_dev *dev); > > /* Functions internal to the PCI core code */ > > -int pci_create_sysfs_dev_files(struct pci_dev *pdev); > -void pci_remove_sysfs_dev_files(struct pci_dev *pdev); > void pci_cleanup_rom(struct pci_dev *dev); > #ifdef CONFIG_DMI > extern const struct attribute_group pci_dev_smbios_attr_group; > @@ -152,7 +150,7 @@ static inline int pci_proc_detach_bus(struct pci_bus *bus) { return 0; } > /* Functions for PCI Hotplug drivers to use */ > int pci_hp_add_bridge(struct pci_dev *dev); > > -#ifdef HAVE_PCI_LEGACY > +#if defined(CONFIG_SYSFS) && defined(HAVE_PCI_LEGACY) > void pci_create_legacy_files(struct pci_bus *bus); > void pci_remove_legacy_files(struct pci_bus *bus); > #else > @@ -185,10 +183,22 @@ static inline int pci_no_d1d2(struct pci_dev *dev) > return (dev->no_d1d2 || parent_dstates); > > } > + > +#ifdef CONFIG_SYSFS > +int pci_create_sysfs_dev_files(struct pci_dev *pdev); > +void pci_remove_sysfs_dev_files(struct pci_dev *pdev); > extern const struct attribute_group *pci_dev_groups[]; > +extern const struct attribute_group *pci_dev_attr_groups[]; > extern const struct attribute_group *pcibus_groups[]; > -extern const struct device_type pci_dev_type; > extern const struct attribute_group *pci_bus_groups[]; > +#else > +static inline int pci_create_sysfs_dev_files(struct pci_dev *pdev) { return 0; } > +static inline void pci_remove_sysfs_dev_files(struct pci_dev *pdev) { } > +#define pci_dev_groups NULL > +#define pci_dev_attr_groups NULL > +#define pcibus_groups NULL > +#define pci_bus_groups NULL > +#endif > > extern unsigned long pci_hotplug_io_size; > extern unsigned long pci_hotplug_mmio_size; > diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c > index ed6b7f48736a..500ac154fdfb 100644 > --- a/drivers/pci/probe.c > +++ b/drivers/pci/probe.c > @@ -2307,6 +2307,10 @@ static void pci_release_dev(struct device *dev) > kfree(pci_dev); > } > > +static const struct device_type pci_dev_type = { > + .groups = pci_dev_attr_groups, > +}; > + > struct pci_dev *pci_alloc_dev(struct pci_bus *bus) > { > struct pci_dev *dev; > -- > 2.40.1 >