X-Git-Url: https://review.openocd.org/gitweb?a=blobdiff_plain;f=src%2Ftarget%2Fimage.h;h=8b70b3b1e40e4b1ea853c9fd834ae02767776c0d;hb=3885ab5a5af7ece410ce3eeb1059da3ea950436a;hp=d741ab96148b3643fe32a0e0ec26fd143471a13e;hpb=f251b925ffe230de9aa01849ba7b53230a5c492f;p=openocd.git diff --git a/src/target/image.h b/src/target/image.h index d741ab9614..8b70b3b1e4 100644 --- a/src/target/image.h +++ b/src/target/image.h @@ -2,6 +2,12 @@ * Copyright (C) 2007 by Dominic Rath * * Dominic.Rath@gmx.de * * * + * Copyright (C) 2007,2008 Øyvind Harboe * + * oyvind.harboe@zylin.com * + * * + * Copyright (C) 2008 by Spencer Oliver * + * spen@spen-soft.co.uk * + * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * @@ -20,35 +26,31 @@ #ifndef IMAGE_H #define IMAGE_H -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif +#include "fileio.h" #ifdef HAVE_ELF_H #include #endif -#include "replacements.h" -#include "fileio.h" -#include "target.h" #define IMAGE_MAX_ERROR_STRING (256) -#define IMAGE_MAX_SECTIONS (128) +#define IMAGE_MAX_SECTIONS (512) -#define IMAGE_MEMORY_CACHE_SIZE (128) +#define IMAGE_MEMORY_CACHE_SIZE (2048) typedef enum image_type { - IMAGE_BINARY, /* plain binary */ - IMAGE_IHEX, /* intel hex-record format */ - IMAGE_MEMORY, /* target-memory pseudo-image */ - IMAGE_ELF, /* ELF binary */ - IMAGE_SRECORD /* motorola s19 */ + IMAGE_BINARY, /* plain binary */ + IMAGE_IHEX, /* intel hex-record format */ + IMAGE_MEMORY, /* target-memory pseudo-image */ + IMAGE_ELF, /* ELF binary */ + IMAGE_SRECORD, /* motorola s19 */ + IMAGE_BUILDER, /* when building a new image */ } image_type_t; typedef struct image_section_s { - u32 base_address; - u32 size; + uint32_t base_address; + uint32_t size; int flags; void *private; /* private data */ } image_section_t; @@ -62,8 +64,7 @@ typedef struct image_s 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 */ - u32 start_address; /* start address, if one is set */ - char error_str[IMAGE_MAX_ERROR_STRING]; + uint32_t start_address; /* start address, if one is set */ } image_t; typedef struct image_binary_s @@ -74,14 +75,14 @@ typedef struct image_binary_s typedef struct image_ihex_s { fileio_t fileio; - u8 *buffer; + uint8_t *buffer; } image_ihex_t; typedef struct image_memory_s { - target_t *target; - u8 *cache; - u32 cache_address; + struct target_s *target; + uint8_t *cache; + uint32_t cache_address; } image_memory_t; typedef struct fileio_elf_s @@ -89,19 +90,26 @@ typedef struct fileio_elf_s fileio_t fileio; Elf32_Ehdr *header; Elf32_Phdr *segments; - u32 segment_count; - u8 endianness; + uint32_t segment_count; + uint8_t endianness; } image_elf_t; typedef struct image_mot_s { fileio_t fileio; - u8 *buffer; + uint8_t *buffer; } image_mot_t; -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); +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_add_section(image_t *image, uint32_t base, uint32_t size, + int flags, uint8_t *data); + +int image_calculate_checksum(uint8_t* buffer, uint32_t nbytes, + uint32_t* checksum); #define ERROR_IMAGE_FORMAT_ERROR (-1400) #define ERROR_IMAGE_TYPE_UNKNOWN (-1401)