All of lore.kernel.org
 help / color / mirror / Atom feed
From: Greg KH <greg@kroah.com>
To: linux-hotplug@vger.kernel.org
Subject: Re: USB driver assignment with udev
Date: Wed, 11 Mar 2009 23:37:30 +0000	[thread overview]
Message-ID: <20090311233730.GA22610@kroah.com> (raw)
In-Reply-To: <loom.20090311T231825-449@post.gmane.org>

On Wed, Mar 11, 2009 at 11:20:53PM +0000, Steve Calfee wrote:
> I am trying to understand how a USB driver gets assigned to a device.

Have you read the documentation on how this happens in the book, Linux
Device Drivers, third edition, which is free online?

> It seems that a udev rule does a modprobe for a driver to handle a device.
> In most cases the module is already in-kernel and this step does nothing.

Not really true, lots of times the module is not present.

> The module/driver probe routine is called by the kernel, only if there is a
> match in its registered usb_device_id table. If more than one driver
> matches, the first one installed gets called first. In 2.6.16, if the probe
> "failed" (returned non-zero), no more modules were probed. I think this is
> broken, and I am now trying 2.6.28, maybe it does the right thing and
> continues looking for a driver that wants a device.
> 
> I have a different situation, but a classic issue is if a user wants to
> have ub handle one device and usb-storage handle others. How can this be
> done? udev loads the driver, but the driver itself grabs the devices. The
> first module loaded will hog all the devices. USBIP will also sooner or
> later hit this problem, some devices might need to be local and some placed
> remotely.  Presumably separate drivers will be needed.

See the libusual code for how this is handled.

> So right now, a Linux USB driver will in-kernel determine if it wants to
> bind to a particular device. This is weakly controlled by userspace by the
> order of module registering (usually by order of insmod). But there is no
> way for userspace to determine a mapping between devices and drivers. Is
> there a udev solution for this?

Not really, but I fail to see the problem that you are trying to solve
here.

What exactly are you trying to do?

thanks,

greg k-h

  reply	other threads:[~2009-03-11 23:37 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-03-11 23:20 USB driver assignment with udev Steve Calfee
2009-03-11 23:37 ` Greg KH [this message]
2009-03-12  0:32 ` Steve Calfee
2009-03-12  0:35 ` Kay Sievers
2009-03-12  2:01 ` Greg KH
2009-03-12 10:21 ` Scott James Remnant
2009-03-12 23:01 ` Steve Calfee
2009-03-12 23:59 ` Kay Sievers

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=20090311233730.GA22610@kroah.com \
    --to=greg@kroah.com \
    --cc=linux-hotplug@vger.kernel.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.