Char device initialization

Daniel Hilst Selli danielhilst at gmail.com
Wed Nov 9 12:59:17 EST 2011


On 11/09/2011 01:28 PM, rohan puri wrote:
>
>
> On Wed, Nov 9, 2011 at 7:22 PM, Alexandru Juncu <alex.juncu at rosedu.org
> <mailto:alex.juncu at rosedu.org>> wrote:
>
>     On Wed, Nov 9, 2011 at 3:41 PM, Daniel Hilst Selli
>     <danielhilst at gmail.com <mailto:danielhilst at gmail.com>> wrote:
>      > I'm trying to create a example char device. The example compiles
>     fine,
>      > but when I try to "cat" I got "No such device or address". I have
>      > reviewed the code thousend times and can't see what I'm missing
>      >
>      > Here is the code -> http://pastebin.com/Td03U0fK
>      >
>      > The read method is not good, I know, but is never called.
>      >
>      > I use my own running kenrel to test, I know that is danger. I'm
>     building
>      > a qemu enviroment to test this better.
>      >
>      > Here is uname -a:
>      > Linux archlinux 3.0-ARCH #1 SMP PREEMPT Fri Oct 7 11:35:34 CEST 2011
>      > x86_64 Intel(R) Core(TM) i3 CPU M 370 @ 2.40GHz GenuineIntel
>     GNU/Linux
>      >
>      > Any idea?
>      >
>      > Thanks
>
>     You tried to 'cat' a /dev/my_device file, right?
>     Was that device file created with the mknod command?
>
>     --
>     Alexandru Juncu
>
>     ROSEdu
>     http://rosedu.org
>
>     _______________________________________________
>     Kernelnewbies mailing list
>     Kernelnewbies at kernelnewbies.org <mailto:Kernelnewbies at kernelnewbies.org>
>     http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies
>
>
>
> Hello Daniel,
>
> I had the look at the code. The issue is with the cdev_add() call in
> init_gcdev() function.
>
> int cdev_add(struct cdev *p, dev_t dev, unsigned count) is the prototype
>
> Now the problem was *instead of passing second argument of type dev_t
> you were passing minor number macro.
>
> *Fix : - Do following additions : -
>
> 1. static int major; // Declare a global major no var.
>
> 2. In init_gcdev() after call to alloc_chrdev_region() get major no and
> store in major var.
>
> major = MAJOR(gcdev->dev);
>
> 3. Replace cdev_add() call like this : -
>
>   cdev_add(&gcdev->cdev, MKDEV(major, FIRST_MINOR), 1);
>
> Now its running and your read methos is getting called.
>
> Hello Alexandru,
>
> That error was due to improper args passed to cdev_add(). If device file
> is not present (no mknod done) error would be "No such file or dir"
>
> Regards,
> Rohan Puri
Thanks Rohan, my fault!





More information about the Kernelnewbies mailing list