On 08/04/2010 12:31 PM, Alexander Graf wrote:
On 04.08.2010, at 19:26, Anthony Liguori wrote:

On 08/04/2010 11:45 AM, Alexander Graf wrote:
Frankly, I partially agreed to your point when we were talking about 300ms vs. 
2 seconds. Now that we're talking 8 seconds that whole point is moot. We chose 
the wrong interface to transfer kernel+initrd data into the guest.

Now the question is how to fix that. I would veto against anything normally 
guest-OS-visible. By occupying the floppy, you lose a floppy drive in the 
guest. By occupying a disk, you see an unwanted disk in the guest.

Introduce a new virtio device type (say, id 6).  Teach SeaBIOS that 6 is 
exactly like virtio-blk (id 2).  Make it clear that id 6 is only to be used by 
firmware and that normal guest drivers should not be written for id 6.
Why not make id 6 be a fw_cfg virtio interface?

Because that's a ton more work and we need fw_cfg to be available before PCI is. IOW, fw_cfg cannot be a PCI interface.

Regards,

Anthony Liguori

  That way we'd stay 100% compatible to everything we have and also get a fast 
path for reading big chunks of data from fw_cfg. All we'd need is a command to 
set the 'file' we're in.

Even better yet, why not use virtio-9p and expose all of fw_cfg as files? Then 
implement a simple virtio-9p client in SeaBIOS and maybe even get direct 
kernel/initrd boot from a real 9p system ;).


Alex



Reply via email to