summaryrefslogtreecommitdiff
path: root/cmd
diff options
context:
space:
mode:
authorBen Dooks <ben.dooks@sifive.com>2023-06-06 11:23:28 +0300
committerHeiko Schocher <hs@denx.de>2023-06-06 11:37:25 +0300
commitb46cec41664f35c689385c70c76d274a059c7251 (patch)
treefcc975cdb0063a87e9e0c53b83857e829286ca60 /cmd
parent26659d426548d1c395ef878c3b820e53a6e3b346 (diff)
downloadu-boot-b46cec41664f35c689385c70c76d274a059c7251.tar.xz
ubifs: allow loading to above 4GiB
The ubifsload command is truncating any address above 4GiB as it casts this address to an u32, instead of using an unsigned long which most of the other load commands do. Change this to an unsigned long to allow loading into high memory for boards which use these areas. Fixes the following error: => ubifsload 0x2100000000 /boot/Image.lzma Loading file '/boot/Image.lzma' to addr 0x00000000... Unhandled exception: Store/AMO access fault Signed-off-by: Ben Dooks <ben.dooks@sifive.com> Signed-off-by: Ben Dooks <ben.dooks@codethink.co.uk>
Diffstat (limited to 'cmd')
-rw-r--r--cmd/ubifs.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/cmd/ubifs.c b/cmd/ubifs.c
index 6a01d0988a..2a035bc7ae 100644
--- a/cmd/ubifs.c
+++ b/cmd/ubifs.c
@@ -111,7 +111,7 @@ static int do_ubifs_load(struct cmd_tbl *cmdtp, int flag, int argc,
char *filename;
char *endp;
int ret;
- u32 addr;
+ unsigned long addr;
u32 size = 0;
if (!ubifs_mounted) {
@@ -133,7 +133,7 @@ static int do_ubifs_load(struct cmd_tbl *cmdtp, int flag, int argc,
if (endp == argv[3])
return CMD_RET_USAGE;
}
- debug("Loading file '%s' to address 0x%08x (size %d)\n", filename, addr, size);
+ debug("Loading file '%s' to address 0x%08lx (size %d)\n", filename, addr, size);
ret = ubifs_load(filename, addr, size);
if (ret) {