of: module: add buffer overflow check in of_modalias()
authorSergey Shtylyov <s.shtylyov@omp.ru>
Sun, 14 Apr 2024 08:51:39 +0000 (11:51 +0300)
committerRob Herring (Arm) <robh@kernel.org>
Wed, 8 May 2024 16:47:07 +0000 (11:47 -0500)
commitcf7385cb26ac4f0ee6c7385960525ad534323252
tree8e56ca7a0640cc590e16c3f658912e7c1c800782
parent649bad67d4b118380bba1e1daa0db2978f7e20be
of: module: add buffer overflow check in of_modalias()

In of_modalias(), if the buffer happens to be too small even for the 1st
snprintf() call, the len parameter will become negative and str parameter
(if not NULL initially) will point beyond the buffer's end. Add the buffer
overflow check after the 1st snprintf() call and fix such check after the
strlen() call (accounting for the terminating NUL char).

Fixes: bc575064d688 ("of/device: use of_property_for_each_string to parse compatible strings")
Signed-off-by: Sergey Shtylyov <s.shtylyov@omp.ru>
Link: https://lore.kernel.org/r/bbfc6be0-c687-62b6-d015-5141b93f313e@omp.ru
Signed-off-by: Rob Herring <robh@kernel.org>
drivers/of/module.c