aboutsummaryrefslogtreecommitdiffstats
path: root/iceprog/iceprog.c
diff options
context:
space:
mode:
authorThe6P4C <watsonjcampbell@gmail.com>2019-12-08 23:27:46 +1000
committerThe6P4C <watsonjcampbell@gmail.com>2019-12-08 23:52:05 +1000
commit578037dedf557806a5a39ab40a22b9cceade9a07 (patch)
treea177c3f1c5c04279ec19968c7d74e49b6de61205 /iceprog/iceprog.c
parent0ec00d892a91cc68e45479b46161f649caea2933 (diff)
downloadicestorm-578037dedf557806a5a39ab40a22b9cceade9a07.tar.gz
icestorm-578037dedf557806a5a39ab40a22b9cceade9a07.tar.bz2
icestorm-578037dedf557806a5a39ab40a22b9cceade9a07.zip
icepack: Fix Windows-only stack overflow in CRAM pbm generation (fixes #241)
On Windows, attempting to generate a netpbm image of the CRAM with `icepack -b` causes the tool to crash after writing only the netpbm header due to a stack overflow. The bug did not appear on Linux. This was traced to a large stack-allocated variable length array (`tile_type`) inside `FpgaConfig::write_cram_pbm`. For an 8k ice40 with 4 banks, `cram_width = 872` and `cram_height = 272` the `tile_type` array ends up at `4 * 872 * 272 * sizeof(uint32_t) =` 3794944 bytes, or about 3.6 MiB. The fix replaces the large stack VLA with an array of 4 (bank) 2D C++ vectors, moving the large amount of data to the heap. Even though the fix is not in a Windows-specific code path (and hence applies to all platforms), I think it's wise to eliminate such a large stack allocation entirely. The fix has been tested working on both Windows and an Ubuntu WSL install.
Diffstat (limited to 'iceprog/iceprog.c')
0 files changed, 0 insertions, 0 deletions