On Sat, Mar 22, 2025 at 7:42 AM Bjorn Helgaas <helgaas@xxxxxxxxxx> wrote: > > On Thu, Mar 06, 2025 at 05:52:10PM +1000, Alistair Francis wrote: > > The PCIe 6 specification added support for the Data Object > > Exchange (DOE). > > When DOE is supported the DOE Discovery Feature must be implemented per > > PCIe r6.1 sec 6.30.1.1. DOE allows a requester to obtain > > information about the other DOE features supported by the device. > > > +#ifdef CONFIG_SYSFS > > +static ssize_t doe_discovery_show(struct device *dev, > > + struct device_attribute *attr, > > + char *buf) > > +{ > > + return sysfs_emit(buf, "0001:00\n"); > > +} > > +DEVICE_ATTR_RO(doe_discovery); > > I think this needs: > > static DEVICE_ATTR_RO(doe_discovery); > > Otherwise sparse complains: > > $ make C=2 drivers/pci/doe.o > CHECK scripts/mod/empty.c > CALL scripts/checksyscalls.sh > DESCEND objtool > INSTALL libsubcmd_headers > CHECK drivers/pci/doe.c > drivers/pci/doe.c:109:1: warning: symbol 'dev_attr_doe_discovery' was not declared. Should it be static? > > > Right? I added this in, so we're all set unless you think that's > wrong. Yeah, I think it's missing a `static`. Thanks for adding it, sorry that I missed this in the first place Alistair > > Bjorn