Re: Rename of debugfs entries

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Nov 20, 2018 at 07:22:47AM +0200, Leon Romanovsky wrote:
> On Mon, Nov 19, 2018 at 10:03:37PM +0000, Jason Gunthorpe wrote:
> > On Sun, Nov 18, 2018 at 04:29:32PM +0200, Leon Romanovsky wrote:
> > > Hi,
> > >
> > > I want to clarify why IB device rename functionality didn't change
> > > debugfs and would like to ask what to do next.
> > >
> > > In drivers/infiniband/hw/*, we have 6 devices which are calling
> > > to debugfs_create_dir() in order to create debugfs root.
> > >
> > > The output is located in /sys/kernel/debug/.
> > >
> > > Such folders are created during driver module load and some of the drivers
> > > creates subfolders for every device initialized, during device probe.
> > >
> > > 1. PCI-based connection
> > > MLX5 and cxgb4 drivers separate the different device by their PCIs.
> > > [leonro@server ~]$ sudo ls  /sys/kernel/debug/mlx5/
> > > 0000:00:0c.0
> > >
> > > 2. Based on IB device name
> > > HFI1, ocrdma and qib create subfolders with device index embedded in it,
> > > like hfi1_0,...,hfi1_N
> > >
> > > 3. No-separation between devices
> > > USNIC like this.
> > >
> > > So device rename works seamlessly for type #1 and #3. Wile for type #2,
> > > the debugfs entries don't change.
> > >
> > > Right now, I see three options:
> > > 1. Do nothing.
> >
> > I don't think this is an option. If we don't also rename debugfs
> > entries then debugfs entry add will fail during hotplug as the names
> > will be in use.
> >
> > The name assigner chooses the lowest number, so, ie, if it plug in
> > hfi0, and rename it to rdma0 then the next plugin will be hfi0 and the
> > debugfs will fail. Presumably the driver will then fail to load.
> 
> "Presumably the driver will then fail to load" <- It is violation of
> debugfs API contract. In many email threads, Greg KH repeated that Failure
> to create debugfs shouldn't fail driver initialization.

Even so, we shouldn't have debugfs randomly disappear on driver load.

Jason




[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux