X-Git-Url: https://review.openocd.org/gitweb?a=blobdiff_plain;f=src%2Ftarget%2Fimage.h;h=0dac5baed7d83d4e843ee736a571c5f51f5556c7;hb=f86137066a6b42c46c457c9837a8015990bf71e6;hp=8b70b3b1e40e4b1ea853c9fd834ae02767776c0d;hpb=3885ab5a5af7ece410ce3eeb1059da3ea950436a;p=openocd.git diff --git a/src/target/image.h b/src/target/image.h index 8b70b3b1e4..0dac5baed7 100644 --- a/src/target/image.h +++ b/src/target/image.h @@ -37,7 +37,7 @@ #define IMAGE_MEMORY_CACHE_SIZE (2048) -typedef enum image_type +enum image_type { IMAGE_BINARY, /* plain binary */ IMAGE_IHEX, /* intel hex-record format */ @@ -45,67 +45,67 @@ typedef enum image_type IMAGE_ELF, /* ELF binary */ IMAGE_SRECORD, /* motorola s19 */ IMAGE_BUILDER, /* when building a new image */ -} image_type_t; +}; -typedef struct image_section_s +struct imageection { uint32_t base_address; uint32_t size; int flags; void *private; /* private data */ -} image_section_t; +}; -typedef struct image_s +struct image { - image_type_t type; /* image type (plain, ihex, ...) */ + enum image_type type; /* image type (plain, ihex, ...) */ void *type_private; /* type private data */ int num_sections; /* number of sections contained in the image */ - image_section_t *sections; /* array of sections */ + struct imageection *sections; /* array of sections */ int base_address_set; /* whether the image has a base address set (for relocation purposes) */ int base_address; /* base address, if one is set */ int start_address_set; /* whether the image has a start address (entry point) associated */ uint32_t start_address; /* start address, if one is set */ -} image_t; +}; -typedef struct image_binary_s +struct image_binary { - fileio_t fileio; -} image_binary_t; + struct fileio fileio; +}; -typedef struct image_ihex_s +struct image_ihex { - fileio_t fileio; + struct fileio fileio; uint8_t *buffer; -} image_ihex_t; +}; -typedef struct image_memory_s +struct image_memory { - struct target_s *target; + struct target *target; uint8_t *cache; uint32_t cache_address; -} image_memory_t; +}; -typedef struct fileio_elf_s +struct image_elf { - fileio_t fileio; + struct fileio fileio; Elf32_Ehdr *header; Elf32_Phdr *segments; uint32_t segment_count; uint8_t endianness; -} image_elf_t; +}; -typedef struct image_mot_s +struct image_mot { - fileio_t fileio; + struct fileio fileio; uint8_t *buffer; -} image_mot_t; +}; -int image_open(image_t *image, char *url, char *type_string); -int image_read_section(image_t *image, int section, uint32_t offset, - uint32_t size, uint8_t *buffer, uint32_t *size_read); -void image_close(image_t *image); +int image_open(struct image *image, const char *url, const char *type_string); +int image_read_section(struct image *image, int section, uint32_t offset, + uint32_t size, uint8_t *buffer, size_t *size_read); +void image_close(struct image *image); -int image_add_section(image_t *image, uint32_t base, uint32_t size, +int image_add_section(struct image *image, uint32_t base, uint32_t size, int flags, uint8_t *data); int image_calculate_checksum(uint8_t* buffer, uint32_t nbytes,