diff options
author | Bradey Honsinger <bradeyh@gmail.com> | 2010-03-15 08:43:41 +0100 |
---|---|---|
committer | Øyvind Harboe <oyvind.harboe@zylin.com> | 2010-03-16 10:11:40 +0100 |
commit | f85ad1e52a499bc98ae9d559157e8adbe8a5ad1f (patch) | |
tree | edbc78edfafb01e2ea30ebf8ace6ddd176fadfe4 /src/target/etm.c | |
parent | a540033a71eb0b10bb8de85963781ec1b9c06cf1 (diff) | |
download | riscv-openocd-f85ad1e52a499bc98ae9d559157e8adbe8a5ad1f.zip riscv-openocd-f85ad1e52a499bc98ae9d559157e8adbe8a5ad1f.tar.gz riscv-openocd-f85ad1e52a499bc98ae9d559157e8adbe8a5ad1f.tar.bz2 |
image loading: fix problem with offsets > 0x80000000
Fixes bug that prevented users from specifying a base address of
0x80000000 or higher in image commands (flash write_image, etm image,
xscale trace_image).
image.base_address is an offset from the start address contained in
the image file (if there is one), or from 0 (for binary files). As a
signed 32-bit int, it couldn't be greater than 0x7fffffff, which is a
problem when trying to write a binary file to flash above that
address. Changing it to a 64-bit long long keeps it as a signed
offset, but allows it to cover the entire 32-bit address space.
Signed-off-by: Øyvind Harboe <oyvind.harboe@zylin.com>
Diffstat (limited to 'src/target/etm.c')
-rw-r--r-- | src/target/etm.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/target/etm.c b/src/target/etm.c index 10ab72a..67dac06 100644 --- a/src/target/etm.c +++ b/src/target/etm.c @@ -1761,7 +1761,7 @@ COMMAND_HANDLER(handle_etm_image_command) if (CMD_ARGC >= 2) { etm_ctx->image->base_address_set = 1; - COMMAND_PARSE_NUMBER(int, CMD_ARGV[1], etm_ctx->image->base_address); + COMMAND_PARSE_NUMBER(llong, CMD_ARGV[1], etm_ctx->image->base_address); } else { |