mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-05 01:54:09 +08:00
Btrfs: fix snprintf usage by send's gen_unique_name
The buffer size argument passed to snprintf must account for the trailing null byte added by snprintf, and it returns a value >= then sizeof(buffer) when the string can't fit in the buffer. Since our buffer has a size of 64 characters, and the maximum orphan name we can generate is 63 characters wide, we must pass 64 as the buffer size to snprintf, and not 63. Signed-off-by: Filipe David Borba Manana <fdmanana@gmail.com> Reviewed-by: David Sterba <dsterba@suse.cz> Signed-off-by: Josef Bacik <jbacik@fb.com> Signed-off-by: Chris Mason <clm@fb.com>
This commit is contained in:
parent
c41570c9d2
commit
f74b86d855
@ -1336,7 +1336,7 @@ static int gen_unique_name(struct send_ctx *sctx,
|
||||
return -ENOMEM;
|
||||
|
||||
while (1) {
|
||||
len = snprintf(tmp, sizeof(tmp) - 1, "o%llu-%llu-%llu",
|
||||
len = snprintf(tmp, sizeof(tmp), "o%llu-%llu-%llu",
|
||||
ino, gen, idx);
|
||||
if (len >= sizeof(tmp)) {
|
||||
/* should really not happen */
|
||||
|
Loading…
Reference in New Issue
Block a user