block: clarify badblocks lifetime

The badblocks list attached to a gendisk is allocated by the driver
which equates to the driver owning the lifetime of the object.  Do not
automatically free it in del_gendisk(). This is in preparation for
expanding the use of badblocks in libnvdimm drivers and introducing
devm_init_badblocks().

Signed-off-by: Dan Williams <dan.j.williams@intel.com>
This commit is contained in:
Dan Williams 2016-01-06 12:03:41 -08:00
Родитель d3b407fb3f
Коммит 20a308f09e
2 изменённых файлов: 2 добавлений и 5 удалений

Просмотреть файл

@ -555,6 +555,8 @@ EXPORT_SYMBOL_GPL(badblocks_init);
*/ */
void badblocks_exit(struct badblocks *bb) void badblocks_exit(struct badblocks *bb)
{ {
if (!bb)
return;
kfree(bb->page); kfree(bb->page);
bb->page = NULL; bb->page = NULL;
} }

Просмотреть файл

@ -670,11 +670,6 @@ void del_gendisk(struct gendisk *disk)
blk_unregister_queue(disk); blk_unregister_queue(disk);
blk_unregister_region(disk_devt(disk), disk->minors); blk_unregister_region(disk_devt(disk), disk->minors);
if (disk->bb) {
badblocks_exit(disk->bb);
kfree(disk->bb);
}
part_stat_set_all(&disk->part0, 0); part_stat_set_all(&disk->part0, 0);
disk->part0.stamp = 0; disk->part0.stamp = 0;