Query regarding alloc_chrdev_region()

Query regarding alloc_chrdev_region()

am 29.03.2007 19:20:34 von Rajat Jain

Hi,

I was wondering that while using dynamic device numner allocation, can
we ever have a scenario like following (using alloc_chrdev_region):

1) Char Driver A is hooked on Major num X, minor numbers 0-10
2) Char Driver B is hooked on (same) Major num X, minor numbers 11-20

If yes, how will the userland get to know about the dynamically
allocated range (needed to create device nodes), since /proc/devices
only shows major numbers?

Thanks,

Rajat
-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs

Re: Query regarding alloc_chrdev_region()

am 30.03.2007 04:10:34 von Greg KH

On Thu, Mar 29, 2007 at 10:50:34PM +0530, Rajat Jain wrote:
> Hi,
>
> I was wondering that while using dynamic device numner allocation, can
> we ever have a scenario like following (using alloc_chrdev_region):
>
> 1) Char Driver A is hooked on Major num X, minor numbers 0-10
> 2) Char Driver B is hooked on (same) Major num X, minor numbers 11-20
>
> If yes, how will the userland get to know about the dynamically
> allocated range (needed to create device nodes), since /proc/devices
> only shows major numbers?

Through the exporting of this information in sysfs by using the
device_create() call that you are required to do in order to have your
device show up properly there :)

thanks,

greg k-h
-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs

Re: Query regarding alloc_chrdev_region()

am 30.03.2007 04:36:23 von Rajat Jain

Hi,

> > I was wondering that while using dynamic device numner allocation, can
> > we ever have a scenario like following (using alloc_chrdev_region):
> >
> > 1) Char Driver A is hooked on Major num X, minor numbers 0-10
> > 2) Char Driver B is hooked on (same) Major num X, minor numbers 11-20

So the above is actually possible?

> >
> > If yes, how will the userland get to know about the dynamically
> > allocated range (needed to create device nodes), since /proc/devices
> > only shows major numbers?
>
> Through the exporting of this information in sysfs by using the
> device_create() call that you are required to do in order to have your
> device show up properly there :)

Is that taken care by cdev_add() itself?

Thanks,

Rajat
-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs

Re: Query regarding alloc_chrdev_region()

am 30.03.2007 07:19:26 von Greg KH

On Fri, Mar 30, 2007 at 08:06:23AM +0530, Rajat Jain wrote:
> Hi,
>
> >> I was wondering that while using dynamic device numner allocation, can
> >> we ever have a scenario like following (using alloc_chrdev_region):
> >>
> >> 1) Char Driver A is hooked on Major num X, minor numbers 0-10
> >> 2) Char Driver B is hooked on (same) Major num X, minor numbers 11-20
>
> So the above is actually possible?

Yes, once you have a major number, you can separate out the minor
numbers how ever you wish to.

> >> If yes, how will the userland get to know about the dynamically
> >> allocated range (needed to create device nodes), since /proc/devices
> >> only shows major numbers?
> >
> >Through the exporting of this information in sysfs by using the
> >device_create() call that you are required to do in order to have your
> >device show up properly there :)
>
> Is that taken care by cdev_add() itself?

Nope, not at all.

thanks,

greg k-h
-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs

Re: Query regarding alloc_chrdev_region()

am 30.03.2007 08:26:28 von Rajat Jain

> > >> I was wondering that while using dynamic device numner allocation, can
> > >> we ever have a scenario like following (using alloc_chrdev_region):
> > >>
> > >> 1) Char Driver A is hooked on Major num X, minor numbers 0-10
> > >> 2) Char Driver B is hooked on (same) Major num X, minor numbers 11-20
> >
> > So the above is actually possible?
>
> Yes, once you have a major number, you can separate out the minor
> numbers how ever you wish to.

Hi Greg,

Ok, I understand that we can get a major number from the kernel and
split it into a range of minor numbers.

But does alloc_chrdev_region() reuse the major numbers in such a way?

In other words, is the following scenario possible:

Driver 1
======
alloc_chrdev_region(10 minor nos required)
-> receives major 150 (minor 0-9)

Driver 2
======
alloc_chrdev_region(20 minor nos required)
-> receives major 150 (minor 10-29)

Thanks,

Rajat
-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs

Re: Query regarding alloc_chrdev_region()

am 30.03.2007 08:34:03 von Greg KH

On Fri, Mar 30, 2007 at 11:56:28AM +0530, Rajat Jain wrote:
> >> >> I was wondering that while using dynamic device numner allocation, can
> >> >> we ever have a scenario like following (using alloc_chrdev_region):
> >> >>
> >> >> 1) Char Driver A is hooked on Major num X, minor numbers 0-10
> >> >> 2) Char Driver B is hooked on (same) Major num X, minor numbers 11-20
> >>
> >> So the above is actually possible?
> >
> >Yes, once you have a major number, you can separate out the minor
> >numbers how ever you wish to.
>
> Hi Greg,
>
> Ok, I understand that we can get a major number from the kernel and
> split it into a range of minor numbers.
>
> But does alloc_chrdev_region() reuse the major numbers in such a way?
>
> In other words, is the following scenario possible:
>
> Driver 1
> ======
> alloc_chrdev_region(10 minor nos required)
> -> receives major 150 (minor 0-9)
>
> Driver 2
> ======
> alloc_chrdev_region(20 minor nos required)
> -> receives major 150 (minor 10-29)

If you look at the code in fs/char_dev.c, this can not happen right now,
however, that could change in the future if we start to see a lot of
different drivers all want dynamic numbers.

In short, don't count on the fact that you will always get a different
major number, it is not guaranteed, and in fact, your driver should
never care about such a thing.

And also userspace doesn't care either, udev handles all of that logic
for you automatically.

Hope this helps,

greg k-h
-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs