forked from auracaster/openocd
flash/nor: improved API of flash_driver.info & fixed buffer overruns
1) The API of "info" callback in "struct flash_driver" has been improved. Fixed buffers for strings 2) Removed the calls to snprintf() from the flash_driver.info implementations. Many of them were used in an unsafe manner (buffer overruns were possible). Change-Id: I42ab8a8018d01f9af43c5ba49f650c3cb5d31dcb Signed-off-by: Jan Matyas <matyas@codasip.com> Reviewed-on: http://openocd.zylin.com/6182 Tested-by: jenkins Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com> Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
This commit is contained in:
committed by
Antonio Borneo
parent
f2958fc04b
commit
64c2e03b23
@@ -2778,7 +2778,7 @@ static int kinetis_auto_probe(struct flash_bank *bank)
|
||||
return kinetis_probe(bank);
|
||||
}
|
||||
|
||||
static int kinetis_info(struct flash_bank *bank, char *buf, int buf_size)
|
||||
static int kinetis_info(struct flash_bank *bank, struct command_invocation *cmd)
|
||||
{
|
||||
const char *bank_class_names[] = {
|
||||
"(ANY)", "PFlash", "FlexNVM", "FlexRAM"
|
||||
@@ -2788,7 +2788,7 @@ static int kinetis_info(struct flash_bank *bank, char *buf, int buf_size)
|
||||
struct kinetis_chip *k_chip = k_bank->k_chip;
|
||||
uint32_t size_k = bank->size / 1024;
|
||||
|
||||
snprintf(buf, buf_size,
|
||||
command_print_sameline(cmd,
|
||||
"%s %s: %" PRIu32 "k %s bank %s at " TARGET_ADDR_FMT,
|
||||
bank->driver->name, k_chip->name,
|
||||
size_k, bank_class_names[k_bank->flash_class],
|
||||
|
||||
Reference in New Issue
Block a user