X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Ftarget%2Fimage.h;h=5b5d11f6b94485220e9e131ad156df5d9b3bd375;hb=a0bd3c9924870c3b8f428648410181040dabc33c;hp=0dac5baed7d83d4e843ee736a571c5f51f5556c7;hpb=51862bb98c26e9b3f03d46ae0f8ceb434f0743d0;p=fw%2Fopenocd diff --git a/src/target/image.h b/src/target/image.h index 0dac5baed..5b5d11f6b 100644 --- a/src/target/image.h +++ b/src/target/image.h @@ -8,6 +8,9 @@ * Copyright (C) 2008 by Spencer Oliver * * spen@spen-soft.co.uk * * * + * Copyright (C) 2018 by Advantest * + * florian.meister@advantest.com * + * * * 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 * @@ -19,14 +22,14 @@ * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * - * along with this program; if not, write to the * - * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * along with this program. If not, see . * ***************************************************************************/ -#ifndef IMAGE_H -#define IMAGE_H -#include "fileio.h" +#ifndef OPENOCD_TARGET_IMAGE_H +#define OPENOCD_TARGET_IMAGE_H + +#include +#include #ifdef HAVE_ELF_H #include @@ -37,8 +40,7 @@ #define IMAGE_MEMORY_CACHE_SIZE (2048) -enum image_type -{ +enum image_type { IMAGE_BINARY, /* plain binary */ IMAGE_IHEX, /* intel hex-record format */ IMAGE_MEMORY, /* target-memory pseudo-image */ @@ -47,73 +49,73 @@ enum image_type IMAGE_BUILDER, /* when building a new image */ }; -struct imageection -{ - uint32_t base_address; +struct imagesection { + target_addr_t base_address; uint32_t size; int flags; void *private; /* private data */ }; -struct image -{ +struct image { enum image_type type; /* image type (plain, ihex, ...) */ void *type_private; /* type private data */ - int num_sections; /* number of sections contained in the image */ - 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 */ + unsigned int num_sections; /* number of sections contained in the image */ + struct imagesection *sections; /* array of sections */ + bool base_address_set; /* whether the image has a base address set (for relocation purposes) */ + long long base_address; /* base address, if one is set */ + bool start_address_set; /* whether the image has a start address (entry point) associated */ uint32_t start_address; /* start address, if one is set */ }; -struct image_binary -{ - struct fileio fileio; +struct image_binary { + struct fileio *fileio; }; -struct image_ihex -{ - struct fileio fileio; +struct image_ihex { + struct fileio *fileio; uint8_t *buffer; }; -struct image_memory -{ +struct image_memory { struct target *target; uint8_t *cache; uint32_t cache_address; }; -struct image_elf -{ - struct fileio fileio; - Elf32_Ehdr *header; - Elf32_Phdr *segments; +struct image_elf { + struct fileio *fileio; + bool is_64_bit; + union { + Elf32_Ehdr *header32; + Elf64_Ehdr *header64; + }; + union { + Elf32_Phdr *segments32; + Elf64_Phdr *segments64; + }; uint32_t segment_count; uint8_t endianness; }; -struct image_mot -{ - struct fileio fileio; +struct image_mot { + struct fileio *fileio; uint8_t *buffer; }; 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, +int image_read_section(struct image *image, int section, target_addr_t offset, uint32_t size, uint8_t *buffer, size_t *size_read); void image_close(struct image *image); -int image_add_section(struct image *image, uint32_t base, uint32_t size, - int flags, uint8_t *data); +int image_add_section(struct image *image, target_addr_t base, uint32_t size, + int flags, uint8_t const *data); -int image_calculate_checksum(uint8_t* buffer, uint32_t nbytes, - uint32_t* checksum); +int image_calculate_checksum(const uint8_t *buffer, uint32_t nbytes, + uint32_t *checksum); #define ERROR_IMAGE_FORMAT_ERROR (-1400) #define ERROR_IMAGE_TYPE_UNKNOWN (-1401) #define ERROR_IMAGE_TEMPORARILY_UNAVAILABLE (-1402) #define ERROR_IMAGE_CHECKSUM (-1403) -#endif /* IMAGE_H */ +#endif /* OPENOCD_TARGET_IMAGE_H */