]> git.sur5r.net Git - openocd/blobdiff - src/target/image.h
- added synchronous reset patch, Thanks Øyvind Harboe
[openocd] / src / target / image.h
index 074b906903627cfb55dcc6075ece9371b1265544..47f0215f64e46bad4474b35da3932081c55326da 100644 (file)
 #ifndef IMAGE_H
 #define IMAGE_H
 
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#ifdef HAVE_ELF_H
 #include <elf.h>
+#endif
+#include "replacements.h"
 #include "fileio.h"
 #include "target.h"
 
 #define IMAGE_MAX_ERROR_STRING         (256)
 #define IMAGE_MAX_SECTIONS                     (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 */
-/*
- * Possible future enhancements:
- * IMAGE_SRECORD,
- */
+    IMAGE_SRECORD,     /* motorola s19 */
+    IMAGE_BUILDER,     /* when building a new image */
 } image_type_t;
 
 typedef struct image_section_s
@@ -74,6 +81,8 @@ typedef struct image_ihex_s
 typedef struct image_memory_s
 {
        target_t *target;
+       u8 *cache;
+       u32 cache_address;
 } image_memory_t;
 
 typedef struct fileio_elf_s
@@ -85,11 +94,22 @@ typedef struct fileio_elf_s
        u8 endianness;
 } image_elf_t;
 
-extern int image_open(image_t *image, void *source, char *type_string);
+typedef struct image_mot_s
+{
+       fileio_t fileio;
+       u8 *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);
+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)
+#define ERROR_IMAGE_TEMPORARILY_UNAVAILABLE            (-1402)
+#define ERROR_IMAGE_CHECKSUM           (-1403)
 
 #endif /* IMAGE_H */