Re: [RTC] Remove superfluous call to call to cdev_del()

From: Alessandro Zummo
Date: Thu Sep 21 2006 - 03:56:46 EST


On Thu, 21 Sep 2006 09:46:06 +0200
Rolf Eike Beer <eike-kernel@xxxxxxxxx> wrote:

> If cdev_add() fails there is no good reason to call cdev_del().
>
> Signed-off-by: Rolf Eike Beer <eike-kernel@xxxxxxxxx>
>
> rtc->char_dev.owner = rtc->owner;
>
> if (cdev_add(&rtc->char_dev, MKDEV(MAJOR(rtc_devt), rtc->id), 1)) {
> - cdev_del(&rtc->char_dev);
> dev_err(class_dev->dev,
> "failed to add char device %d:%d\n",
> MAJOR(rtc_devt), rtc->id);

I'm not sure.. this is drivers/char/raw.c:


cdev_init(&raw_cdev, &raw_fops);
if (cdev_add(&raw_cdev, dev, MAX_RAW_MINORS)) {
kobject_put(&raw_cdev.kobj);
unregister_chrdev_region(dev, MAX_RAW_MINORS);
goto error;
}

in case of failure, it does a kobject_put.
tha same call is done by cdev_del.

other drivers have implemented different error paths.
which one is correct?

--

Best regards,

Alessandro Zummo,
Tower Technologies - Turin, Italy

http://www.towertech.it

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