From: Nandakumar Edamana Date: Fri, 21 Feb 2025 21:01:11 +0000 (+0530) Subject: libbpf: Fix out-of-bound read X-Git-Tag: block-6.15-20250403~19^2~52 X-Git-Url: https://git.kernel.dk/?a=commitdiff_plain;h=236d3910117e9f97ebf75e511d8bcc950f1a4e5f;p=linux-block.git libbpf: Fix out-of-bound read In `set_kcfg_value_str`, an untrusted string is accessed with the assumption that it will be at least two characters long due to the presence of checks for opening and closing quotes. But the check for the closing quote (value[len - 1] != '"') misses the fact that it could be checking the opening quote itself in case of an invalid input that consists of just the opening quote. This commit adds an explicit check to make sure the string is at least two characters long. Signed-off-by: Nandakumar Edamana Signed-off-by: Andrii Nakryiko Link: https://lore.kernel.org/bpf/20250221210110.3182084-1-nandakumar@nandakumar.co.in --- diff --git a/tools/lib/bpf/libbpf.c b/tools/lib/bpf/libbpf.c index 6df258912e1e..899e98225f3b 100644 --- a/tools/lib/bpf/libbpf.c +++ b/tools/lib/bpf/libbpf.c @@ -2106,7 +2106,7 @@ static int set_kcfg_value_str(struct extern_desc *ext, char *ext_val, } len = strlen(value); - if (value[len - 1] != '"') { + if (len < 2 || value[len - 1] != '"') { pr_warn("extern (kcfg) '%s': invalid string config '%s'\n", ext->name, value); return -EINVAL;