X-Git-Url: https://review.openocd.org/gitweb?a=blobdiff_plain;f=src%2Ftarget%2Fimage.h;h=064654b35c691b33d74981a77ce160305d59e294;hb=5a6dc5a325756132ce20be598c278022c7b1c185;hp=d741ab96148b3643fe32a0e0ec26fd143471a13e;hpb=f251b925ffe230de9aa01849ba7b53230a5c492f;p=openocd.git diff --git a/src/target/image.h b/src/target/image.h index d741ab9614..064654b35c 100644 --- a/src/target/image.h +++ b/src/target/image.h @@ -34,7 +34,7 @@ #define IMAGE_MAX_ERROR_STRING (256) #define IMAGE_MAX_SECTIONS (128) -#define IMAGE_MEMORY_CACHE_SIZE (128) +#define IMAGE_MEMORY_CACHE_SIZE (2048) typedef enum image_type { @@ -42,7 +42,8 @@ typedef enum image_type IMAGE_IHEX, /* intel hex-record format */ IMAGE_MEMORY, /* target-memory pseudo-image */ IMAGE_ELF, /* ELF binary */ - IMAGE_SRECORD /* motorola s19 */ + IMAGE_SRECORD, /* motorola s19 */ + IMAGE_BUILDER, /* when building a new image */ } image_type_t; typedef struct image_section_s @@ -63,7 +64,6 @@ typedef struct image_s int base_address; /* base address, if one is set */ int start_address_set; /* whether the image has a start address (entry point) associated */ u32 start_address; /* start address, if one is set */ - char error_str[IMAGE_MAX_ERROR_STRING]; } image_t; typedef struct image_binary_s @@ -102,6 +102,9 @@ typedef struct image_mot_s extern int image_open(image_t *image, char *url, char *type_string); extern int image_read_section(image_t *image, int section, u32 offset, u32 size, u8 *buffer, u32 *size_read); extern int image_close(image_t *image); +extern int image_add_section(image_t *image, u32 base, u32 size, int flags, u8 *data); + +extern int image_calculate_checksum(u8* buffer, u32 nbytes, u32* checksum); #define ERROR_IMAGE_FORMAT_ERROR (-1400) #define ERROR_IMAGE_TYPE_UNKNOWN (-1401)