+ qemu-block experts.
On 7/14/20 11:16 AM, Markus Armbruster wrote:
> Havard Skinnemoen <[email protected]> writes:
>
>> On Mon, Jul 13, 2020 at 7:57 AM Cédric Le Goater <[email protected]> wrote:
>>>
>>> On 7/9/20 2:36 AM, Havard Skinnemoen wrote:
>>>> This allows these NPCM7xx-based boards to boot from a flash image, e.g.
>>>> one built with OpenBMC. For example like this:
>>>>
>>>> IMAGE=${OPENBMC}/build/tmp/deploy/images/gsj/image-bmc
>>>> qemu-system-arm -machine quanta-gsj -nographic \
>>>> -bios ~/qemu/bootrom/npcm7xx_bootrom.bin \
>>>> -drive file=${IMAGE},if=mtd,bus=0,unit=0,format=raw,snapshot=on
>>>>
>>>> Reviewed-by: Tyrone Ting <[email protected]>
>>>> Signed-off-by: Havard Skinnemoen <[email protected]>
>>>
>>> May be we don't need to create the flash object if dinfo is NULL.
>>
>> It's soldered on the board, so you can't really boot the board without
>> it. But if you think it's better to remove it altogether if we don't
>> have an image to load into it, I can do that.
>
> If a device is a fixed part of the physical board, it should be a fixed
> part of the virtual board, too.
We agree so far but ... how to do it?
I never used this API, does that makes sense?
if (!dinfo) {
QemuOpts *opts;
opts = qemu_opts_create(NULL, "spi-flash", 1, &error_abort);
qdict_put_str(opts, "format", "null-co");
qdict_put_int(opts, BLOCK_OPT_SIZE, 64 * MiB);
qdict_put_bool(opts, NULL_OPT_ZEROES, false); // XXX
dinfo = drive_new(opts, IF_MTD, &error_abort);
qemu_opts_del(opts);
}
We should probably add a public helper for that.
'XXX' because NOR flashes erase content is when hardware bit
is set, so it would be more useful to return -1/0xff... rather
than zeroes.