aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorntfreak <ntfreak@b42882b7-edfa-0310-969c-e2dbd0fdcd60>2008-03-07 16:38:02 +0000
committerntfreak <ntfreak@b42882b7-edfa-0310-969c-e2dbd0fdcd60>2008-03-07 16:38:02 +0000
commit984e9f0e4435afdd24edd3d83dff0145a2613821 (patch)
tree6663e172f525069755441d4efa07a361008e7276 /src
parentd3f3f6149867c6ccd5d10ac469df1d7af95cbf19 (diff)
- The elf loader incorrectly assumed that the program header always follows the ELF header. (Thanks Michael Bruck)
git-svn-id: svn://svn.berlios.de/openocd/trunk@472 b42882b7-edfa-0310-969c-e2dbd0fdcd60
Diffstat (limited to 'src')
-rw-r--r--src/target/image.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/target/image.c b/src/target/image.c
index 3fac0571..39df4aef 100644
--- a/src/target/image.c
+++ b/src/target/image.c
@@ -381,6 +381,14 @@ int image_elf_read_headers(image_t *image)
return ERROR_IMAGE_FORMAT_ERROR;
}
+
+ if ((retval = fileio_seek(&elf->fileio, elf->header->e_phoff)) != ERROR_OK)
+ {
+ ERROR("cannot seek to ELF program header table, read failed");
+ return retval;
+ }
+
+
elf->segments = malloc(elf->segment_count*sizeof(Elf32_Phdr));
if ((retval = fileio_read(&elf->fileio, elf->segment_count*sizeof(Elf32_Phdr), (u8*)elf->segments, &read_bytes)) != ERROR_OK)
@@ -1001,3 +1009,4 @@ int image_calculate_checksum(u8* buffer, u32 nbytes, u32* checksum)
return ERROR_OK;
}
+