Skip to content
Snippets Groups Projects
Commit 32d7cdd3 authored by Michal Simek's avatar Michal Simek
Browse files

fpga: Add support for gzip images with bitstreams


Here is the set of command which has been performed
to proof this feature.

gzip < fpga.bin > fpga.bin.gz
mkimage -A arm -O u-boot -T firmware -C gzip \
-a 20000000 -n "zc702_fpga_bin" -d fpga.bin.gz fpga.bin.gz.ub

tftp 100000 fpga.bin.gz.ub
fpga loadmk 0 100000

This flow should speedup loading bitstream data
from external memory and save image footprint in non volatile
memory.

Signed-off-by: default avatarMichal Simek <michal.simek@xilinx.com>
Acked-by: default avatarJagannadha Sutradharudu Teki <jaganna@xilinx.com>
parent b129e8cf
No related branches found
No related tags found
No related merge requests found
...@@ -160,9 +160,25 @@ int do_fpga(cmd_tbl_t *cmdtp, int flag, int argc, char *const argv[]) ...@@ -160,9 +160,25 @@ int do_fpga(cmd_tbl_t *cmdtp, int flag, int argc, char *const argv[])
image_header_t *hdr = image_header_t *hdr =
(image_header_t *)fpga_data; (image_header_t *)fpga_data;
ulong data; ulong data;
uint8_t comp;
data = (ulong)image_get_data(hdr);
data_size = image_get_data_size(hdr); comp = image_get_comp(hdr);
if (comp == IH_COMP_GZIP) {
ulong image_buf = image_get_data(hdr);
data = image_get_load(hdr);
ulong image_size = ~0UL;
if (gunzip((void *)data, ~0UL,
(void *)image_buf,
&image_size) != 0) {
puts("GUNZIP: error\n");
return 1;
}
data_size = image_size;
} else {
data = (ulong)image_get_data(hdr);
data_size = image_get_data_size(hdr);
}
rc = fpga_load(dev, (void *)data, data_size); rc = fpga_load(dev, (void *)data, data_size);
} }
break; break;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment