[PATCH] fix array overrun in efi.c
Coverity found an over-run @ line 364 of efi.c This is due to the loop checking the size correctly, then adding a '\0' after possibly hitting the end of the array. Ensure the loop exits with one space left in the array. Signed-off-by: Darren Jenkins <darrenrjenkins@gmail.com> Signed-off-by: Adrian Bunk <bunk@stusta.de> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
3ac8bf077d
commit
d6d21dfdd3
1 changed files with 1 additions and 1 deletions
|
@ -361,7 +361,7 @@ void __init efi_init(void)
|
||||||
*/
|
*/
|
||||||
c16 = (efi_char16_t *) boot_ioremap(efi.systab->fw_vendor, 2);
|
c16 = (efi_char16_t *) boot_ioremap(efi.systab->fw_vendor, 2);
|
||||||
if (c16) {
|
if (c16) {
|
||||||
for (i = 0; i < sizeof(vendor) && *c16; ++i)
|
for (i = 0; i < (sizeof(vendor) - 1) && *c16; ++i)
|
||||||
vendor[i] = *c16++;
|
vendor[i] = *c16++;
|
||||||
vendor[i] = '\0';
|
vendor[i] = '\0';
|
||||||
} else
|
} else
|
||||||
|
|
Loading…
Reference in a new issue