qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Andre Przywara <andre.przywara@amd.com>
To: Avi Kivity <avi@redhat.com>
Cc: qemu-devel@nongnu.org, Gleb Natapov <gleb@redhat.com>,
	Alexander Graf <agraf@suse.de>,
	"Michael S. Tsirkin" <mst@redhat.com>
Subject: Re: [Qemu-devel] cpuid problem in upstream qemu with kvm
Date: Mon, 21 Dec 2009 13:59:31 +0100	[thread overview]
Message-ID: <4B2F7133.8030500@amd.com> (raw)
In-Reply-To: <4B2F58BC.30307@redhat.com>

Avi Kivity wrote:
> On 12/20/2009 07:59 PM, Anthony Liguori wrote:
>> Gleb Natapov wrote:
>>> Windows is a mystery box, so we can speculate as much as we want 
>>> about it.
>>> If you don't like something just say "it may break Windows" :) Losing
>>> activation does sound like an issue too.
>>
>> Downgrading seems more likely to cause problems.  Considering running 
>> mplayer in a guest.  If it detects SSE3 in one host and migrate to 
>> another host that doesn't have SSE3, you'll be running an instruction 
>> stream that uses instructions the processor doesn't support resulting 
>> in the application faulting due to an illegal operation.
>>
> 
> Migration needs preparation beforehand.  You can't take two random hosts 
> with two random qemu flag sets and expect it to work.
> 
>> KVM's cpuid filter doesn't help here because it won't attempt to mask 
>> things like sse3.  It would be insane to emulate sse3 too.
> 
> It does expose sse3 support (called pni in Linux IIRC).  Not sure if 
> qemu masks it, but the information is there.
What about using -cpu kvm64?
This has SSE3 as well as CMPXCHG16, both are available in all VMX/SVM 
capable machines (as far as I could find out) and in TCG.
This gives a pretty descent base without loosing many relevant 
performance features.

>... 
>> This is a classic management tool problem and the solution usually is 
>> a set of heuristics depending on how conservative the target audience is.
> 
> Right.  My concern is with casual users upgrading their machine, not 
> enterprise users who should be protected by their tools.
Then what about fixing the CPUID bits to those returned by the KVM 
module the first time the guest is started? Later you would only use 
those bits (which may have been cropped) for later restarts of the same 
guest. If you only upgrade your machine, then there should be no problems.

Regards,
Andre.

P.S. What feature bits do we talk about?
Maybe we should group them and use aliases for those.
SS_S_E3 and SSE4.x come to mind, are any other bits really relevant? (Or 
do they justify the pain we have when propagating them?)
Then we would only need: Athlon64, Core2, Nehalem (and maybe Phenom).

-- 
Andre Przywara
AMD-Operating System Research Center (OSRC), Dresden, Germany
Tel: +49 351 448 3567 12
----to satisfy European Law for business letters:
Advanced Micro Devices GmbH
Karl-Hammerschmidt-Str. 34, 85609 Dornach b. Muenchen
Geschaeftsfuehrer: Andrew Bowd; Thomas M. McCoy; Giuliano Meroni
Sitz: Dornach, Gemeinde Aschheim, Landkreis Muenchen
Registergericht Muenchen, HRB Nr. 43632

  reply	other threads:[~2009-12-21 13:00 UTC|newest]

Thread overview: 113+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-12-14 19:35 [Qemu-devel] cpuid problem in upstream qemu with kvm Michael S. Tsirkin
2009-12-14 19:44 ` Anthony Liguori
2009-12-14 19:44   ` Michael S. Tsirkin
2009-12-14 19:57     ` Anthony Liguori
2009-12-14 20:00       ` Gleb Natapov
2009-12-14 20:02         ` Anthony Liguori
2009-12-14 20:08           ` Gleb Natapov
2009-12-14 20:14             ` Michael S. Tsirkin
2009-12-14 20:10           ` Michael S. Tsirkin
2009-12-14 20:18             ` Anthony Liguori
2009-12-14 20:31               ` Michael S. Tsirkin
2009-12-14 20:54                 ` Anthony Liguori
2009-12-14 21:10                   ` Michael S. Tsirkin
2009-12-14 21:49                     ` Anthony Liguori
2009-12-15 14:28                       ` Michael S. Tsirkin
2009-12-15 17:37                         ` Anthony Liguori
2009-12-15 17:56                           ` Michael S. Tsirkin
2009-12-20  9:42                             ` Avi Kivity
2009-12-20  9:49               ` Avi Kivity
2009-12-20 14:48                 ` Anthony Liguori
2009-12-20 14:55                   ` Avi Kivity
2009-12-20 15:33                     ` Anthony Liguori
2009-12-20 15:36                       ` Avi Kivity
2009-12-20 15:38                         ` Gleb Natapov
2009-12-20 15:40                           ` Avi Kivity
2009-12-20 15:49                             ` Michael S. Tsirkin
2009-12-20 15:53                               ` Avi Kivity
2009-12-20 15:51                 ` Michael S. Tsirkin
2009-12-20 15:59                   ` Avi Kivity
2009-12-20 16:56                     ` Michael S. Tsirkin
2009-12-20 17:17                       ` Alexander Graf
2009-12-20 17:18                         ` Michael S. Tsirkin
2009-12-20 17:23                           ` Alexander Graf
2009-12-20 17:23                           ` Gleb Natapov
2009-12-20 17:29                             ` Alexander Graf
2009-12-20 17:37                               ` Gleb Natapov
2009-12-20 17:59                                 ` Anthony Liguori
2009-12-20 18:06                                   ` Alexander Graf
2009-12-21  7:48                                     ` Gleb Natapov
2009-12-21 13:25                                       ` [Qemu-devel] " Paolo Bonzini
2009-12-20 18:12                                   ` [Qemu-devel] " Michael S. Tsirkin
2009-12-21  7:43                                   ` Gleb Natapov
2009-12-21  8:28                                     ` Dor Laor
2009-12-21 22:51                                       ` john cooper
2009-12-22 13:54                                         ` Dor Laor
2009-12-22 15:19                                           ` john cooper
2009-12-22 16:12                                       ` Anthony Liguori
2010-01-05  6:06                                         ` john cooper
2010-01-06  8:02                                           ` [Qemu-devel] " Paolo Bonzini
     [not found]                                         ` <4B31F1BA.10005@redhat.com>
2010-01-06  0:10                                           ` [Qemu-devel] " Anthony Liguori
2010-01-06  3:25                                             ` Avi Kivity
2010-01-06 13:25                                               ` Anthony Liguori
2010-01-06 13:35                                                 ` Michael S. Tsirkin
2010-01-06 13:47                                                 ` Avi Kivity
2010-01-06 13:49                                                   ` Anthony Liguori
2010-01-06 13:54                                                     ` Avi Kivity
2010-01-06 13:55                                                       ` Alexander Graf
2010-01-06 13:58                                                         ` Avi Kivity
2010-01-06 14:22                                                           ` Michael S. Tsirkin
2010-01-06 14:32                                                             ` Avi Kivity
2010-01-06 14:48                                                               ` Dor Laor
2010-01-06 15:16                                                                 ` Anthony Liguori
2010-01-07  8:03                                                                   ` Dor Laor
2010-01-07  8:18                                                                     ` Avi Kivity
2010-01-07  9:11                                                                       ` Dor Laor
2010-01-07  9:24                                                                         ` Avi Kivity
2010-01-07  9:40                                                                           ` Dor Laor
2010-01-07 11:39                                                                             ` Anthony Liguori
2010-01-07 11:44                                                                               ` Dor Laor
2010-01-07 12:00                                                                                 ` Avi Kivity
2010-01-07 12:20                                                                                   ` Dor Laor
2010-01-07 12:33                                                                                     ` Anthony Liguori
2010-01-07 12:40                                                                                       ` Avi Kivity
2010-01-07 12:47                                                                                         ` Daniel P. Berrange
2010-01-07 12:50                                                                                           ` Avi Kivity
2010-01-07 13:14                                                                                         ` Anthony Liguori
2010-01-07 13:42                                                                                           ` Dor Laor
2010-01-11 13:26                                                                                         ` Markus Armbruster
2010-01-07 11:59                                                                             ` Avi Kivity
2010-01-07 12:17                                                                               ` Dor Laor
2010-01-07  8:24                                                                     ` Daniel P. Berrange
2010-01-07  9:13                                                                       ` Dor Laor
2010-01-06 15:02                                                               ` Michael S. Tsirkin
2010-01-06 15:12                                                       ` Anthony Liguori
2010-01-06  9:44                                             ` Daniel P. Berrange
2010-01-06  9:54                                               ` Avi Kivity
2010-01-06 10:21                                                 ` Daniel P. Berrange
2010-01-06 10:25                                                   ` Avi Kivity
2010-01-06 16:19                                             ` Lennart Sorensen
2009-12-21 11:15                                   ` Avi Kivity
2009-12-21 12:59                                     ` Andre Przywara [this message]
2009-12-21 16:14                                       ` Avi Kivity
2009-12-22 23:02                                   ` Jamie Lokier
2009-12-21 11:12                           ` Avi Kivity
2009-12-21 11:18                             ` Michael S. Tsirkin
2009-12-21 11:22                               ` Alexander Graf
2009-12-21 11:38                                 ` Michael S. Tsirkin
2009-12-21 11:45                                   ` Alexander Graf
2009-12-21 12:02                                     ` Michael S. Tsirkin
2009-12-22 22:52                                       ` Jamie Lokier
2009-12-21 12:05                                     ` Avi Kivity
2009-12-21 13:45                                       ` David S. Ahern
2009-12-21 13:51                                         ` Michael S. Tsirkin
2009-12-21 14:07                                           ` David S. Ahern
2009-12-21 16:11                                         ` Avi Kivity
2009-12-21 12:04                               ` Avi Kivity
2009-12-21 12:04                                 ` Michael S. Tsirkin
2009-12-21 12:09                                   ` Avi Kivity
2009-12-21 12:17                                     ` Michael S. Tsirkin
2009-12-21 11:38                             ` Yaniv Kaul
2009-12-21 13:31                               ` [Qemu-devel] " Paolo Bonzini
2009-12-22 22:56                                 ` Jamie Lokier
2009-12-16 14:23           ` [Qemu-devel] " Andre Przywara

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4B2F7133.8030500@amd.com \
    --to=andre.przywara@amd.com \
    --cc=agraf@suse.de \
    --cc=avi@redhat.com \
    --cc=gleb@redhat.com \
    --cc=mst@redhat.com \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).