Commit 2a488aaa authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: fix __bch2_xattr_bcachefs_get()

We were returning -ERANGE when the size of the buffer passed in was
exactly the size of the xattr val
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent e0dfc08b
...@@ -387,6 +387,9 @@ static int __bch2_xattr_bcachefs_get(const struct xattr_handler *handler, ...@@ -387,6 +387,9 @@ static int __bch2_xattr_bcachefs_get(const struct xattr_handler *handler,
bch2_inode_opts_to_opts(bch2_inode_opts_get(&inode->ei_inode)); bch2_inode_opts_to_opts(bch2_inode_opts_get(&inode->ei_inode));
const struct bch_option *opt; const struct bch_option *opt;
int id, inode_opt_id; int id, inode_opt_id;
char buf[512];
struct printbuf out = PBUF(buf);
unsigned val_len;
u64 v; u64 v;
id = bch2_opt_lookup(name); id = bch2_opt_lookup(name);
...@@ -407,23 +410,16 @@ static int __bch2_xattr_bcachefs_get(const struct xattr_handler *handler, ...@@ -407,23 +410,16 @@ static int __bch2_xattr_bcachefs_get(const struct xattr_handler *handler,
return -ENODATA; return -ENODATA;
v = bch2_opt_get_by_id(&opts, id); v = bch2_opt_get_by_id(&opts, id);
bch2_opt_to_text(&out, c, opt, v, 0);
if (!buffer) { val_len = out.pos - buf;
char buf[512];
struct printbuf out = PBUF(buf);
bch2_opt_to_text(&out, c, opt, v, 0); if (buffer && val_len > size)
return -ERANGE;
return out.pos - buf; if (buffer)
} else { memcpy(buffer, buf, val_len);
struct printbuf out = _PBUF(buffer, size); return val_len;
bch2_opt_to_text(&out, c, opt, v, 0);
return printbuf_remaining(&out)
? (void *) out.pos - buffer
: -ERANGE;
}
} }
static int bch2_xattr_bcachefs_get(const struct xattr_handler *handler, static int bch2_xattr_bcachefs_get(const struct xattr_handler *handler,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment