From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
To: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Finn Thain <fthain@telegraphics.com.au>,
linux-m68k <linux-m68k@lists.linux-m68k.org>,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] nubus: Unconditionally register bus type
Date: Mon, 7 May 2018 16:45:11 +0200 [thread overview]
Message-ID: <20180507144511.GA22694@kroah.com> (raw)
In-Reply-To: <CAMuHMdV_5p0Un3xMC1SMw71xpLAzVH0u4oJCTeGeo7jXS4KZSA@mail.gmail.com>
On Mon, May 07, 2018 at 02:53:13PM +0200, Geert Uytterhoeven wrote:
> Hi Finn,
>
> (responding immediately to patches doing non-kosher things ;-)
>
> On Mon, May 7, 2018 at 1:57 AM, Finn Thain <fthain@telegraphics.com.au> wrote:
> > On Sun, 6 May 2018, Greg Kroah-Hartman wrote:
> >> > > Why not just have an "bus is registered" flag in your driver
> >> > > register function that refuses to let drivers register with the
> >> > > driver core if it isn't set?
> >> >
> >> > Perhaps that should happen in the core driver_register() function.
> >> > BUG_ON is frowned upon, after all. Would that be acceptable?
> >>
> >> I don't understand what you mean here, perhaps make a patch to show it?
> >>
> >
> > As an alternative to your suggestion (add flag to avoid the BUG_ON):
> >
> > --- a/drivers/base/driver.c
> > +++ b/drivers/base/driver.c
> > @@ -148,7 +148,10 @@ int driver_register(struct device_driver *drv)
> > int ret;
> > struct device_driver *other;
> >
> > - BUG_ON(!drv->bus->p);
> > + if (!drv->bus->p) {
> > + WARN_ONCE(1, "Cannot register driver with invalid bus\n");
> > + return -EPROBE_DEFER;
> > + }
> >
> > if ((drv->bus->probe && drv->probe) ||
> > (drv->bus->remove && drv->remove) ||
> >
> > I'm not actually proposing this change; just responding to your question.
>
> The bus_type.p field may be unused by some bus drivers, hence this
> would prevent their drivers from being registered.
bus_type.p is an internal-to-the-driver-core structure, no bus driver
should ever be touching it. This is a catch to see if someone is using
the driver core incorrectly.
thanks,
greg k-h
next prev parent reply other threads:[~2018-05-07 14:45 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-05-06 1:47 [PATCH] nubus: Unconditionally register bus type Finn Thain
2018-05-06 4:55 ` Greg Kroah-Hartman
2018-05-06 6:00 ` Finn Thain
2018-05-06 20:20 ` Greg Kroah-Hartman
2018-05-06 21:51 ` Michael Schmitz
2018-05-08 7:00 ` Greg Kroah-Hartman
2018-05-08 7:07 ` Geert Uytterhoeven
2018-05-08 7:25 ` Greg Kroah-Hartman
2018-05-08 7:35 ` Geert Uytterhoeven
2018-05-08 7:41 ` Greg Kroah-Hartman
2018-05-08 8:01 ` Michael Schmitz
2018-05-06 23:57 ` Finn Thain
2018-05-07 12:53 ` Geert Uytterhoeven
2018-05-07 14:45 ` Greg Kroah-Hartman [this message]
2018-05-08 6:28 ` Geert Uytterhoeven
2018-05-07 23:44 ` Finn Thain
2018-05-08 6:32 ` Geert Uytterhoeven
2018-05-08 7:59 ` Finn Thain
2018-05-08 7:01 ` Greg Kroah-Hartman
[not found] <5aee5ede.1c69fb81.353b4.5021SMTPIN_ADDED_MISSING@mx.google.com>
2018-05-08 7:39 ` Geert Uytterhoeven
2018-05-08 8:27 ` Finn Thain
-- strict thread matches above, loose matches on Subject: below --
2018-05-06 1:47 Finn Thain
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180507144511.GA22694@kroah.com \
--to=gregkh@linuxfoundation.org \
--cc=fthain@telegraphics.com.au \
--cc=geert@linux-m68k.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-m68k@lists.linux-m68k.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox