qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3
@ 2016-04-18 19:04 Eduardo Habkost
  2016-04-18 19:04 ` [Qemu-devel] [PULL 1/1] target-i386: Set AMD alias bits after filtering CPUID data Eduardo Habkost
  2016-04-19  9:39 ` [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3 Peter Maydell
  0 siblings, 2 replies; 3+ messages in thread
From: Eduardo Habkost @ 2016-04-18 19:04 UTC (permalink / raw)
  To: Peter Maydell
  Cc: Paolo Bonzini, Richard Henderson, Andreas Färber, qemu-devel

Last-minute fix. Still in time for -rc3, I hope.

The following changes since commit 92b674b62a1aec734280c9019cfb3b3745044b66:

  Merge remote-tracking branch 'remotes/afaerber/tags/qom-cpu-for-peter' into staging (2016-04-18 17:42:59 +0100)

are available in the git repository at:

  git://github.com/ehabkost/qemu.git tags/x86-pull-request

for you to fetch changes up to 9997cf7bdac056aeed246613639675c5a9f8fdc2:

  target-i386: Set AMD alias bits after filtering CPUID data (2016-04-18 15:49:17 -0300)

----------------------------------------------------------------
X86 fix for 2.6.0-rc3

----------------------------------------------------------------

Eduardo Habkost (1):
  target-i386: Set AMD alias bits after filtering CPUID data

 target-i386/cpu.c | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)

-- 
2.1.0

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

* [Qemu-devel] [PULL 1/1] target-i386: Set AMD alias bits after filtering CPUID data
  2016-04-18 19:04 [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3 Eduardo Habkost
@ 2016-04-18 19:04 ` Eduardo Habkost
  2016-04-19  9:39 ` [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3 Peter Maydell
  1 sibling, 0 replies; 3+ messages in thread
From: Eduardo Habkost @ 2016-04-18 19:04 UTC (permalink / raw)
  To: Peter Maydell
  Cc: Paolo Bonzini, Richard Henderson, Andreas Färber, qemu-devel

QEMU complains about -cpu host on an AMD machine:
  warning: host doesn't support requested feature: CPUID.80000001H:EDX [bit 0]
For bits 0,1,3,4,5,6,7,8,9,12,13,14,15,16,17,23,24.

KVM_GET_SUPPORTED_CPUID and and x86_cpu_get_migratable_flags()
don't handle the AMD CPUID aliases bits, making
x86_cpu_filter_features() print warnings and clear those CPUID
bits incorrectly.

To avoid hacking x86_cpu_get_migratable_flags() to handle
CPUID_EXT2_AMD_ALIASES (just like the existing hack inside
kvm_arch_get_supported_cpuid()), simply move the
CPUID_EXT2_AMD_ALIASES code in x86_cpu_realizefn() after the
x86_cpu_filter_features() call.

This will probably make the CPUID_EXT2_AMD_ALIASES hack in
kvm_arch_get_supported_cpuid() unnecessary, too. The hack will be
removed in a follow-up patch after v2.6.0.

Reported-by: Radim Krčmář <rkrcmar@redhat.com>
Tested-by: Radim Krčmář <rkrcmar@redhat.com>
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
---
 target-i386/cpu.c | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)

diff --git a/target-i386/cpu.c b/target-i386/cpu.c
index ddae932..d0b5b69 100644
--- a/target-i386/cpu.c
+++ b/target-i386/cpu.c
@@ -2897,6 +2897,14 @@ static void x86_cpu_realizefn(DeviceState *dev, Error **errp)
         env->cpuid_level = 7;
     }
 
+    if (x86_cpu_filter_features(cpu) && cpu->enforce_cpuid) {
+        error_setg(&local_err,
+                   kvm_enabled() ?
+                       "Host doesn't support requested features" :
+                       "TCG doesn't support requested features");
+        goto out;
+    }
+
     /* On AMD CPUs, some CPUID[8000_0001].EDX bits must match the bits on
      * CPUID[1].EDX.
      */
@@ -2907,14 +2915,6 @@ static void x86_cpu_realizefn(DeviceState *dev, Error **errp)
     }
 
 
-    if (x86_cpu_filter_features(cpu) && cpu->enforce_cpuid) {
-        error_setg(&local_err,
-                   kvm_enabled() ?
-                       "Host doesn't support requested features" :
-                       "TCG doesn't support requested features");
-        goto out;
-    }
-
 #ifndef CONFIG_USER_ONLY
     qemu_register_reset(x86_cpu_machine_reset_cb, cpu);
 
-- 
2.1.0

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

* Re: [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3
  2016-04-18 19:04 [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3 Eduardo Habkost
  2016-04-18 19:04 ` [Qemu-devel] [PULL 1/1] target-i386: Set AMD alias bits after filtering CPUID data Eduardo Habkost
@ 2016-04-19  9:39 ` Peter Maydell
  1 sibling, 0 replies; 3+ messages in thread
From: Peter Maydell @ 2016-04-19  9:39 UTC (permalink / raw)
  To: Eduardo Habkost
  Cc: Paolo Bonzini, Richard Henderson, Andreas Färber,
	QEMU Developers

On 18 April 2016 at 20:04, Eduardo Habkost <ehabkost@redhat.com> wrote:
> Last-minute fix. Still in time for -rc3, I hope.
>
> The following changes since commit 92b674b62a1aec734280c9019cfb3b3745044b66:
>
>   Merge remote-tracking branch 'remotes/afaerber/tags/qom-cpu-for-peter' into staging (2016-04-18 17:42:59 +0100)
>
> are available in the git repository at:
>
>   git://github.com/ehabkost/qemu.git tags/x86-pull-request
>
> for you to fetch changes up to 9997cf7bdac056aeed246613639675c5a9f8fdc2:
>
>   target-i386: Set AMD alias bits after filtering CPUID data (2016-04-18 15:49:17 -0300)
>
> ----------------------------------------------------------------
> X86 fix for 2.6.0-rc3
>
> ----------------------------------------------------------------
Applied, thanks.

-- PMM

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

end of thread, other threads:[~2016-04-19  9:40 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-04-18 19:04 [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3 Eduardo Habkost
2016-04-18 19:04 ` [Qemu-devel] [PULL 1/1] target-i386: Set AMD alias bits after filtering CPUID data Eduardo Habkost
2016-04-19  9:39 ` [Qemu-devel] [PULL 0/1] X86 fix for 2.6.0-rc3 Peter Maydell

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).