diff options
| author | Pierre-Clément Tosi <[email protected]> | 2022-05-25 14:38:55 +0100 |
|---|---|---|
| committer | Tom Rini <[email protected]> | 2022-06-06 18:01:21 -0400 |
| commit | 24272ffd505be0597703032dbdd8ffdd7ef7a1a9 (patch) | |
| tree | e80f1d1bc0927a4a12822b5d5889a5a39cad35f5 /cmd | |
| parent | b257c4e9064dc4c2b86d30cec5ece368ca981225 (diff) | |
qfw: Don't fail if setup data size is 0
Skip missing setup data (which is valid) rather than failing with an
error.
Cc: Bin Meng <[email protected]>
Cc: Simon Glass <[email protected]>
Reported-by: Andrew Walbran <[email protected]>
Signed-off-by: Pierre-Clément Tosi <[email protected]>
Diffstat (limited to 'cmd')
| -rw-r--r-- | cmd/qfw.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/cmd/qfw.c b/cmd/qfw.c index d58615040c6..ccbc967ca9f 100644 --- a/cmd/qfw.c +++ b/cmd/qfw.c @@ -25,15 +25,17 @@ static int qemu_fwcfg_cmd_setup_kernel(void *load_addr, void *initrd_addr) qfw_read_entry(qfw_dev, FW_CFG_SETUP_SIZE, 4, &setup_size); qfw_read_entry(qfw_dev, FW_CFG_KERNEL_SIZE, 4, &kernel_size); - if (setup_size == 0 || kernel_size == 0) { + if (kernel_size == 0) { printf("warning: no kernel available\n"); return -1; } data_addr = load_addr; - qfw_read_entry(qfw_dev, FW_CFG_SETUP_DATA, - le32_to_cpu(setup_size), data_addr); - data_addr += le32_to_cpu(setup_size); + if (setup_size != 0) { + qfw_read_entry(qfw_dev, FW_CFG_SETUP_DATA, + le32_to_cpu(setup_size), data_addr); + data_addr += le32_to_cpu(setup_size); + } qfw_read_entry(qfw_dev, FW_CFG_KERNEL_DATA, le32_to_cpu(kernel_size), data_addr); |
