diff options
author | Kent Overstreet <kent.overstreet@linux.dev> | 2023-12-22 21:21:14 -0500 |
---|---|---|
committer | Kent Overstreet <kent.overstreet@linux.dev> | 2023-12-22 21:21:14 -0500 |
commit | 5134a64cebf9cbc57d76f9e69a8627227803a061 (patch) | |
tree | bf972b061fc8fa51b1dd828caebcdc8f93a3d55e /libbcachefs/util.c | |
parent | e962ffb76959b40016b8b26e366bcb30f4a40bdb (diff) |
Update bcachefs sources to c6d45169c6 bcachefs: Convert split_devs() to darray
Diffstat (limited to 'libbcachefs/util.c')
-rw-r--r-- | libbcachefs/util.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/libbcachefs/util.c b/libbcachefs/util.c index 00ddd91d..d4a23891 100644 --- a/libbcachefs/util.c +++ b/libbcachefs/util.c @@ -1174,3 +1174,37 @@ u64 *bch2_acc_percpu_u64s(u64 __percpu *p, unsigned nr) return ret; } + +void bch2_darray_str_exit(darray_str *d) +{ + darray_for_each(*d, i) + kfree(*i); + darray_exit(d); +} + +int bch2_split_devs(const char *_dev_name, darray_str *ret) +{ + darray_init(ret); + + char *dev_name = kstrdup(_dev_name, GFP_KERNEL), *s = dev_name; + if (!dev_name) + return -ENOMEM; + + while ((s = strsep(&dev_name, ":"))) { + char *p = kstrdup(s, GFP_KERNEL); + if (!p) + goto err; + + if (darray_push(ret, p)) { + kfree(p); + goto err; + } + } + + kfree(dev_name); + return 0; +err: + bch2_darray_str_exit(ret); + kfree(dev_name); + return -ENOMEM; +} |