All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] vga: Allow writing VBE_DISPI_ID5 to ID register
@ 2021-06-07 11:53 Dennis Wölfing
  2021-06-14 13:23 ` Dennis Wölfing
  0 siblings, 1 reply; 2+ messages in thread
From: Dennis Wölfing @ 2021-06-07 11:53 UTC (permalink / raw)
  To: qemu-devel, Gerd Hoffmann; +Cc: Dennis Wölfing

The highest VBE_DISPI_INDEX_ID version supported by QEMU is
VBE_DISPI_ID5. But currently QEMU only allows writing values up to
VBE_DISPI_ID4 to the VBE_DISPI_INDEX_ID register.

As a result of this when a lower version is written to this register and
later VBE_DISPI_ID5 is written back, reads from the register will
continue to report the lower version.

Indeed SeaBIOS is doing that during VGA initialization which causes
guests to always read VBE_DISPI_ID0 instead of the correct version.

Signed-off-by: Dennis Wölfing <denniswoelfing@gmx.de>
---
 hw/display/vga.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/hw/display/vga.c b/hw/display/vga.c
index 28a90e30d0..9d1f66af40 100644
--- a/hw/display/vga.c
+++ b/hw/display/vga.c
@@ -752,7 +752,8 @@ void vbe_ioport_write_data(void *opaque, uint32_t addr, uint32_t val)
                 val == VBE_DISPI_ID1 ||
                 val == VBE_DISPI_ID2 ||
                 val == VBE_DISPI_ID3 ||
-                val == VBE_DISPI_ID4) {
+                val == VBE_DISPI_ID4 ||
+                val == VBE_DISPI_ID5) {
                 s->vbe_regs[s->vbe_index] = val;
             }
             break;
--
2.31.1



^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] vga: Allow writing VBE_DISPI_ID5 to ID register
  2021-06-07 11:53 [PATCH] vga: Allow writing VBE_DISPI_ID5 to ID register Dennis Wölfing
@ 2021-06-14 13:23 ` Dennis Wölfing
  0 siblings, 0 replies; 2+ messages in thread
From: Dennis Wölfing @ 2021-06-14 13:23 UTC (permalink / raw)
  To: qemu-devel; +Cc: Gerd Hoffmann

Ping
https://lore.kernel.org/qemu-devel/20210607115303.228659-1-denniswoelfing@gmx.de/

On 07.06.21 13:53, Dennis Wölfing wrote:
> The highest VBE_DISPI_INDEX_ID version supported by QEMU is
> VBE_DISPI_ID5. But currently QEMU only allows writing values up to
> VBE_DISPI_ID4 to the VBE_DISPI_INDEX_ID register.
>
> As a result of this when a lower version is written to this register and
> later VBE_DISPI_ID5 is written back, reads from the register will
> continue to report the lower version.
>
> Indeed SeaBIOS is doing that during VGA initialization which causes
> guests to always read VBE_DISPI_ID0 instead of the correct version.
>
> Signed-off-by: Dennis Wölfing <denniswoelfing@gmx.de>
> ---
>   hw/display/vga.c | 3 ++-
>   1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/hw/display/vga.c b/hw/display/vga.c
> index 28a90e30d0..9d1f66af40 100644
> --- a/hw/display/vga.c
> +++ b/hw/display/vga.c
> @@ -752,7 +752,8 @@ void vbe_ioport_write_data(void *opaque, uint32_t addr, uint32_t val)
>                   val == VBE_DISPI_ID1 ||
>                   val == VBE_DISPI_ID2 ||
>                   val == VBE_DISPI_ID3 ||
> -                val == VBE_DISPI_ID4) {
> +                val == VBE_DISPI_ID4 ||
> +                val == VBE_DISPI_ID5) {
>                   s->vbe_regs[s->vbe_index] = val;
>               }
>               break;
> --
> 2.31.1
>


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2021-06-14 13:24 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-06-07 11:53 [PATCH] vga: Allow writing VBE_DISPI_ID5 to ID register Dennis Wölfing
2021-06-14 13:23 ` Dennis Wölfing

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.