- added patch to check some malloc problems.

(thanks to Øyvind Harboe for the patch)

git-svn-id: svn://svn.berlios.de/openocd/trunk@276 b42882b7-edfa-0310-969c-e2dbd0fdcd60
__archive__
mifi 2008-01-24 21:04:09 +00:00
parent dd318a2c8d
commit 080b2e3f2f
1 changed files with 14 additions and 4 deletions

View File

@ -781,6 +781,11 @@ int target_checksum_memory(struct target_s *target, u32 address, u32 size, u32*
size, &checksum)) == ERROR_TARGET_RESOURCE_NOT_AVAILABLE) size, &checksum)) == ERROR_TARGET_RESOURCE_NOT_AVAILABLE)
{ {
buffer = malloc(size); buffer = malloc(size);
if (buffer==NULL)
{
ERROR("error allocating buffer for section (%d bytes)", size);
return ERROR_OK;
}
target_read_buffer(target, address, size, buffer); target_read_buffer(target, address, size, buffer);
/* convert to target endianess */ /* convert to target endianess */
@ -1435,10 +1440,10 @@ int handle_halt_command(struct command_context_s *cmd_ctx, char *cmd, char **arg
break; break;
case ERROR_TARGET_TIMEOUT: case ERROR_TARGET_TIMEOUT:
command_print(cmd_ctx, "target timed out... shutting down"); command_print(cmd_ctx, "target timed out... shutting down");
exit(-1); return retval;
default: default:
command_print(cmd_ctx, "unknown error... shutting down"); command_print(cmd_ctx, "unknown error... shutting down");
exit(-1); return retval;
} }
} }
@ -1920,6 +1925,11 @@ int handle_verify_image_command(struct command_context_s *cmd_ctx, char *cmd, ch
for (i = 0; i < image.num_sections; i++) for (i = 0; i < image.num_sections; i++)
{ {
buffer = malloc(image.sections[i].size); buffer = malloc(image.sections[i].size);
if (buffer==NULL)
{
command_print(cmd_ctx, "error allocating buffer for section (%d bytes)", image.sections[i].size);
break;
}
if ((retval = image_read_section(&image, i, 0x0, image.sections[i].size, buffer, &buf_cnt)) != ERROR_OK) if ((retval = image_read_section(&image, i, 0x0, image.sections[i].size, buffer, &buf_cnt)) != ERROR_OK)
{ {
ERROR("image_read_section failed with error code: %i", retval); ERROR("image_read_section failed with error code: %i", retval);