On 29.04.2013, at 14:48, Pranavkumar Sawargaonkar wrote:

> On 29 April 2013 17:52, Alexander Graf <ag...@suse.de> wrote:
>> 
>> 
>> Am 29.04.2013 um 05:09 schrieb Rusty Russell <ru...@rustcorp.com.au>:
>> 
>>> Alexander Graf <ag...@suse.de> writes:
>>>> On 26.04.2013, at 13:04, Pranavkumar Sawargaonkar wrote:
>>>> 
>>>>> This patch-set implements early printk support for virtio console devices 
>>>>> without using any hypercalls.
>>>>> 
>>>>> The current virtio early printk code in kernel expects that hypervisor 
>>>>> will provide some mechanism generally a hypercall to support early 
>>>>> printk. This patch-set does not break existing hypercall based early 
>>>>> print support.
>>>>> 
>>>>> This implementation adds:
>>>>> 1. Early writeonly register named early_wr in virtio console's config 
>>>>> space.
>>>>> 2. Host feature flags namely VIRTIO_CONSOLE_F_EARLY_WRITE for telling 
>>>>> guest about early-write capability in console device.
>>>>> 
>>>>> Early write mechanism:
>>>>> 1. When a guest wants to out some character, it has to simply write the 
>>>>> character to early_wr register in config space of virtio console device.
>>>> 
>>>> I won't nack this patch set, but I'll definitely express that I'm not 
>>>> happy with it.
>>>> 
>>>> MMIO registers are handled by a different layer than the virtio console 
>>>> itself. After the virtio refactoring in QEMU, they will be completely 
>>>> separate drivers. So we'll be in a similar mess with early printk as we 
>>>> are on the s390-virtio machine, where early printk is done through 
>>>> hypercalls and thus we can't directly link it to the console output.
>>>> 
>>>> I still don't see what the issue is with just implementing a small 
>>>> irq-less virtio driver for early printk.
>>> 
>>> Well, this shouldn't be mmio-specific, but I kind of get what you mean.
>>> 
>>> I consider this misnamed: it's an emergency write facility.  Linux may
>>> use it for an early console,
>> 
>> If Linux uses it for early console, you won't see any messages from before 
>> the virtio-console driver is initialized, because Linux thinks that it's all 
>> been printed out.
> 
> So far i have tried this on foundation model for armv8 and i never saw
> any missed out prints.

It's what I got back on s390. If you run upstream QEMU, you'll simply lose half 
of your log messages. Because in upstream QEMU, the side channel used for early 
printk got nack'ed.

> 
>> 
>>> but it's also useful for bringup and to
>>> give a method of emitting errors like "the console ring is corrupt".
>>> 
>>> A valid implementation may well be to only offer it with some magic
>>> qemu developer-only commandline and dump it to stdout.
>> 
>> Why implement it differently from other machines? There are facilities to 
>> call into firmware, so you could use that. There's the special Foundation 
>> model call that you could implement and reuse for this.
>> 
>> I don't see why anything like this has to live in virtio-mmio. Oh, and it 
>> should default to off.
> 
> All the boards may not have firmware to do this. Foundation model call
> is also not useful on real hardware for armv8.  This is very helpful
> in debugging a guest on real hardware when guest crashes in early

Are you seriously considering to use virtio-console on real hardware?

> stages before virtio drivers come in to the picture.
> This is not a virtio-mmio change it is just an addition of device
> specific register in virtio console.

There are not device specific registers in virtio-console. Virtio-console lives 
behind a virtio bus which doesn't know what these registers are. Even if you 
shove it into config space, it'd be broken because config access happens 
without intercepts on some platforms.


Alex

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to