[PATCH] md: fix ref-counting problems with kobjects in md
authorNeilBrown <neilb@suse.de>
Wed, 9 Nov 2005 05:39:28 +0000 (21:39 -0800)
committerLinus Torvalds <torvalds@g5.osdl.org>
Wed, 9 Nov 2005 15:56:37 +0000 (07:56 -0800)
Thanks Greg.

Cc: Greg KH <greg@kroah.com>
Signed-off-by: Neil Brown <neilb@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
drivers/md/md.c
drivers/md/raid5.c

index e58d61d9f31bb4b1947e3611ec4347fc007b70d1..fe0137a5b002e02940e718093daaf3e9c1ac2c44 100644 (file)
@@ -805,7 +805,11 @@ static void super_90_sync(mddev_t *mddev, mdk_rdev_t *rdev)
                        if (fixdesc & (1<<rdev2->desc_nr)) {
                                snprintf(rdev2->kobj.name, KOBJ_NAME_LEN, "dev%d",
                                         rdev2->desc_nr);
+                               /* kobject_add gets a ref on the parent, so
+                                * we have to drop the one we already have
+                                */
                                kobject_add(&rdev2->kobj);
+                               kobject_put(rdev->kobj.parent);
                                sysfs_create_link(&rdev2->kobj,
                                                  &rdev2->bdev->bd_disk->kobj,
                                                  "block");
@@ -1178,7 +1182,7 @@ static int bind_rdev_to_array(mdk_rdev_t * rdev, mddev_t * mddev)
 
        rdev->kobj.k_name = NULL;
        snprintf(rdev->kobj.name, KOBJ_NAME_LEN, "dev%d", rdev->desc_nr);
-       rdev->kobj.parent = kobject_get(&mddev->kobj);
+       rdev->kobj.parent = &mddev->kobj;
        kobject_add(&rdev->kobj);
 
        sysfs_create_link(&rdev->kobj, &rdev->bdev->bd_disk->kobj, "block");
@@ -1864,7 +1868,7 @@ static struct kobject *md_probe(dev_t dev, int *part, void *data)
        add_disk(disk);
        mddev->gendisk = disk;
        up(&disks_sem);
-       mddev->kobj.parent = kobject_get(&disk->kobj);
+       mddev->kobj.parent = &disk->kobj;
        mddev->kobj.k_name = NULL;
        snprintf(mddev->kobj.name, KOBJ_NAME_LEN, "%s", "md");
        mddev->kobj.ktype = &md_ktype;
index 061d265ed94ee85cc892e1fb02a379e7437cec42..246c9b1cc4a3ef377e0e307c2f7f24dc31d5d180 100644 (file)
@@ -1975,7 +1975,7 @@ memory = conf->max_nr_stripes * (sizeof(struct stripe_head) +
        }
 
        /* Ok, everything is just fine now */
-       conf->kobj.parent = kobject_get(&mddev->kobj);
+       conf->kobj.parent = &mddev->kobj;
        strcpy(conf->kobj.name, "raid5");
        conf->kobj.ktype = &raid5_ktype;
        kobject_register(&conf->kobj);