<div dir="ltr">We use this name as video mode that the driver uses and passes to the BasicVideo is expected to be supported by BIOS or UEFI. "VGA Compatible" sounds like conformance to some specification, which is not a case. Name of the field "<span style="font-size:12.8px">SupportNonVGA" related to this feature is also inclear and seems at least inverted. </span><span style="font-size:12.8px">The difference between VGA mode and QXL mode is that first uses video modes declared by the BIOS and changes them via BIOS calls, when the seconds does not.</span><div><div><div><br></div></div></div><div><br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jan 25, 2017 at 6:26 PM, Frediano Ziglio <span dir="ltr"><<a href="mailto:fziglio@redhat.com" target="_blank">fziglio@redhat.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">><br>
> <a href="https://bugzilla.redhat.com/show_bug.cgi?id=1411340" rel="noreferrer" target="_blank">https://bugzilla.redhat.com/<wbr>show_bug.cgi?id=1411340</a><br>
> Do not set SupportNonVGA field for device rev.4 and higher.<br>
> Then the class driver will not call miniport's procedure<br>
> StopDeviceAndReleasePostDispla<wbr>yOwnership upon PnP stop.<br>
> QXL device modes are not compatible with VGA ones; the<br>
> driver in this procedure returns display information related<br>
> to QXL mode which later used by BasicDisplay driver and causes<br>
> it to show the screen incorrectly or fail to show it at all.<br>
><br>
> Signed-off-by: Yuri Benditovich <<a href="mailto:yuri.benditovich@daynix.com">yuri.benditovich@daynix.com</a>><br>
> ---<br>
> qxldod/QxlDod.cpp | 2 +-<br>
> qxldod/QxlDod.h | 2 ++<br>
> 2 files changed, 3 insertions(+), 1 deletion(-)<br>
><br>
> diff --git a/qxldod/QxlDod.cpp b/qxldod/QxlDod.cpp<br>
> index 7adbec4..001cd67 100755<br>
> --- a/qxldod/QxlDod.cpp<br>
> +++ b/qxldod/QxlDod.cpp<br>
> @@ -411,7 +411,7 @@ NTSTATUS QxlDod::QueryAdapterInfo(_In_ CONST<br>
> DXGKARG_QUERYADAPTERINFO* pQueryAda<br>
> pDriverCaps->PointerCaps.<wbr>Monochrome = 1;<br>
> pDriverCaps->PointerCaps.Color = 1;<br>
><br>
> - pDriverCaps->SupportNonVGA = TRUE;<br>
> + pDriverCaps->SupportNonVGA = m_pHWDevice->IsBIOSCompatible(<wbr>);<br>
><br>
> DbgPrint(TRACE_LEVEL_VERBOSE, ("<--- %s 1\n", __FUNCTION__));<br>
> return STATUS_SUCCESS;<br>
> diff --git a/qxldod/QxlDod.h b/qxldod/QxlDod.h<br>
> index 4df4c61..8df1fcf 100755<br>
> --- a/qxldod/QxlDod.h<br>
> +++ b/qxldod/QxlDod.h<br>
> @@ -263,6 +263,7 @@ public:<br>
> virtual NTSTATUS Escape(_In_ CONST DXGKARG_ESCAPE* pEscap) = 0;<br>
> NTSTATUS AcquireDisplayInfo(DXGK_<wbr>DISPLAY_INFORMATION& DispInfo);<br>
> ULONG GetId(void) { return m_Id; }<br>
> + virtual BOOLEAN IsBIOSCompatible() { return TRUE; }<br>
> protected:<br>
> virtual NTSTATUS GetModeList(DXGK_DISPLAY_<wbr>INFORMATION* pDispInfo) = 0;<br>
> protected:<br>
> @@ -480,6 +481,7 @@ public:<br>
> NTSTATUS SetPointerShape(_In_ CONST DXGKARG_SETPOINTERSHAPE*<br>
> pSetPointerShape);<br>
> NTSTATUS SetPointerPosition(_In_ CONST DXGKARG_SETPOINTERPOSITION*<br>
> pSetPointerPosition);<br>
> NTSTATUS Escape(_In_ CONST DXGKARG_ESCAPE* pEscap);<br>
> + BOOLEAN IsBIOSCompatible() { return FALSE; }<br>
> protected:<br>
> NTSTATUS GetModeList(DXGK_DISPLAY_<wbr>INFORMATION* pDispInfo);<br>
> VOID BltBits (BLT_INFO* pDst,<br>
<br>
</div></div>Why you used IsBIOSCompatible name instead of IsVGACompatible ?<br>
<span class="HOEnZb"><font color="#888888"><br>
Frediano<br>
</font></span></blockquote></div><br></div>