mirror of
https://github.com/kdave/btrfs-progs
synced 2025-01-07 05:59:30 +00:00
btrfs-progs: add memory allocation fail check in btrfs_add_to_fsid()
In btrfs_add_to_fsid(), strdup() allocates memory to device->name, but the return value is not checked. So add the return value check and error handling code. And clean-up error handling code for ENOMEM case. Signed-off-by: Byongho Lee <bhlee.kernel@gmail.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
6e38141890
commit
657e520a11
20
utils.c
20
utils.c
@ -731,21 +731,18 @@ int btrfs_add_to_fsid(struct btrfs_trans_handle *trans,
|
|||||||
struct btrfs_super_block *super = root->fs_info->super_copy;
|
struct btrfs_super_block *super = root->fs_info->super_copy;
|
||||||
struct btrfs_device *device;
|
struct btrfs_device *device;
|
||||||
struct btrfs_dev_item *dev_item;
|
struct btrfs_dev_item *dev_item;
|
||||||
char *buf;
|
char *buf = NULL;
|
||||||
u64 total_bytes;
|
u64 total_bytes;
|
||||||
u64 num_devs;
|
u64 num_devs;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
device = kzalloc(sizeof(*device), GFP_NOFS);
|
device = kzalloc(sizeof(*device), GFP_NOFS);
|
||||||
if (!device)
|
if (!device)
|
||||||
return -ENOMEM;
|
goto err_nomem;
|
||||||
buf = kmalloc(sectorsize, GFP_NOFS);
|
buf = kzalloc(sectorsize, GFP_NOFS);
|
||||||
if (!buf) {
|
if (!buf)
|
||||||
kfree(device);
|
goto err_nomem;
|
||||||
return -ENOMEM;
|
|
||||||
}
|
|
||||||
BUG_ON(sizeof(*disk_super) > sectorsize);
|
BUG_ON(sizeof(*disk_super) > sectorsize);
|
||||||
memset(buf, 0, sectorsize);
|
|
||||||
|
|
||||||
disk_super = (struct btrfs_super_block *)buf;
|
disk_super = (struct btrfs_super_block *)buf;
|
||||||
dev_item = &disk_super->dev_item;
|
dev_item = &disk_super->dev_item;
|
||||||
@ -763,6 +760,8 @@ int btrfs_add_to_fsid(struct btrfs_trans_handle *trans,
|
|||||||
device->total_ios = 0;
|
device->total_ios = 0;
|
||||||
device->dev_root = root->fs_info->dev_root;
|
device->dev_root = root->fs_info->dev_root;
|
||||||
device->name = strdup(path);
|
device->name = strdup(path);
|
||||||
|
if (!device->name)
|
||||||
|
goto err_nomem;
|
||||||
|
|
||||||
ret = btrfs_add_device(trans, root, device);
|
ret = btrfs_add_device(trans, root, device);
|
||||||
BUG_ON(ret);
|
BUG_ON(ret);
|
||||||
@ -792,6 +791,11 @@ int btrfs_add_to_fsid(struct btrfs_trans_handle *trans,
|
|||||||
list_add(&device->dev_list, &root->fs_info->fs_devices->devices);
|
list_add(&device->dev_list, &root->fs_info->fs_devices->devices);
|
||||||
device->fs_devices = root->fs_info->fs_devices;
|
device->fs_devices = root->fs_info->fs_devices;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
err_nomem:
|
||||||
|
kfree(device);
|
||||||
|
kfree(buf);
|
||||||
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void btrfs_wipe_existing_sb(int fd)
|
static void btrfs_wipe_existing_sb(int fd)
|
||||||
|
Loading…
Reference in New Issue
Block a user