diff options
author | Christoph Hellwig <hch@lst.de> | 2021-11-29 11:21:35 +0100 |
---|---|---|
committer | Dan Williams <dan.j.williams@intel.com> | 2021-12-04 17:58:50 +0100 |
commit | d751939235b9b7bc4af15f90a3e99288a8b844a7 (patch) | |
tree | 1797097e46f8a221f63d5c044ad0fc26574cad70 /drivers/md | |
parent | dax: Kill DEV_DAX_PMEM_COMPAT (diff) | |
download | linux-d751939235b9b7bc4af15f90a3e99288a8b844a7.tar.xz linux-d751939235b9b7bc4af15f90a3e99288a8b844a7.zip |
dm: fix alloc_dax error handling in alloc_dev
Make sure ->dax_dev is NULL on error so that the cleanup path doesn't
trip over an ERR_PTR.
Reported-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/20211129102203.2243509-2-hch@lst.de
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/md')
-rw-r--r-- | drivers/md/dm.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 662742a310cb..acc84dc1bded 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -1786,8 +1786,10 @@ static struct mapped_device *alloc_dev(int minor) if (IS_ENABLED(CONFIG_DAX_DRIVER)) { md->dax_dev = alloc_dax(md, md->disk->disk_name, &dm_dax_ops, 0); - if (IS_ERR(md->dax_dev)) + if (IS_ERR(md->dax_dev)) { + md->dax_dev = NULL; goto bad; + } } format_dev_t(md->name, MKDEV(_major, minor)); |