kernel_samsung_a53x/scripts/mod
Masahiro Yamada 97062b280c modpost: remove incorrect code in do_eisa_entry()
[ Upstream commit 0c3e091319e4748cb36ac9a50848903dc6f54054 ]

This function contains multiple bugs after the following commits:

 - ac551828993e ("modpost: i2c aliases need no trailing wildcard")
 - 6543becf26ff ("mod/file2alias: make modalias generation safe for cross compiling")

Commit ac551828993e inserted the following code to do_eisa_entry():

    else
            strcat(alias, "*");

This is incorrect because 'alias' is uninitialized. If it is not
NULL-terminated, strcat() could cause a buffer overrun.

Even if 'alias' happens to be zero-filled, it would output:

    MODULE_ALIAS("*");

This would match anything. As a result, the module could be loaded by
any unrelated uevent from an unrelated subsystem.

Commit ac551828993e introduced another bug.            

Prior to that commit, the conditional check was:

    if (eisa->sig[0])

This checked if the first character of eisa_device_id::sig was not '\0'.

However, commit ac551828993e changed it as follows:

    if (sig[0])

sig[0] is NOT the first character of the eisa_device_id::sig. The
type of 'sig' is 'char (*)[8]', meaning that the type of 'sig[0]' is
'char [8]' instead of 'char'. 'sig[0]' and 'symval' refer to the same
address, which never becomes NULL.

The correct conversion would have been:

    if ((*sig)[0])

However, this if-conditional was meaningless because the earlier change
in commit ac551828993e was incorrect.

This commit removes the entire incorrect code, which should never have
been executed.

Fixes: ac551828993e ("modpost: i2c aliases need no trailing wildcard")
Fixes: 6543becf26ff ("mod/file2alias: make modalias generation safe for cross compiling")
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-12-17 13:24:22 +01:00
..
devicetable-offsets.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
empty.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
file2alias.c modpost: remove incorrect code in do_eisa_entry() 2024-12-17 13:24:22 +01:00
Makefile Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
mk_elfconfig.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
modpost.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
modpost.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
sumversion.c modpost: trim leading spaces when processing source files list 2024-11-18 12:13:29 +01:00