From: Avi Kivity <avi@redhat.com>
To: "Michael S. Tsirkin" <mst@redhat.com>
Cc: Alex Williamson <alex.williamson@redhat.com>,
kvm@vger.kernel.org, jan.kiszka@siemens.com, jbaron@redhat.com
Subject: Re: [PATCH v2] kvm: Disable MSI/MSI-X in assigned device reset path
Date: Sun, 08 Apr 2012 19:08:17 +0300 [thread overview]
Message-ID: <4F81B7F1.6050800@redhat.com> (raw)
In-Reply-To: <20120408160436.GB14914@redhat.com>
On 04/08/2012 07:04 PM, Michael S. Tsirkin wrote:
> On Sun, Apr 08, 2012 at 06:50:27PM +0300, Avi Kivity wrote:
> > On 04/08/2012 06:46 PM, Michael S. Tsirkin wrote:
> > > > > >
> > > > > > I'm thinking about this flow:
> > > > > >
> > > > > > FLR the device
> > > > > > for each emulated register
> > > > > > read it from the hardware
> > > > > > if different from emulated register:
> > > > > > update the internal model (for example, disabling MSI in kvm if
> > > > > > needed)
> > > > >
> > > > > If we do it this way we get back the problem this patch
> > > > > is trying to solve: MSIX assigned while device
> > > > > memory is disabled would cause unsupported request errors.
> > > >
> > > > Why is that? FLR would presumably disable MSI in the device, and this
> > > > line would disable it in kvm as well.
> > >
> > > The bug is that device memory is disabled (FLR would do that)
> > > while MSI is enabled in kvm. The fix is to
> > > disable MSI in kvm first.
> >
> > Yes, no need to repeat. My question is whether my pseudo-code does the
> > same
>
> It doesn't seem to: FLR (disabling memory) is followed
> by MSI disable in kvm instead of the reverse.
Ah, so the problem is the ordering? I see.
> > and whether or not if it is better (when applied to all emulated
> > config space).
>
> I'm not sure.
> I would like to see an example of a register that you have
> in mind.
I went over the PCI registers and saw none that would be affected.
> > >
> > > Yes. I'm talking about things like enabling memory, setting up irq register,
> > > etc though. Most of this setup is done by bios.
> >
> > I see. So should we have a pci_reset_function() variant that limits
> > itself to restoring just those bits?
>
> We only need kernel to restore whatever qemu emulates, but
> kernel doesn't know what that is.
> What kind of interface do you have in mind?
>
The same as pci_reset_function(), but leaves MSI clear.
I guess it's not worth it if the ordering problem is there.
--
error compiling committee.c: too many arguments to function
next prev parent reply other threads:[~2012-04-08 16:08 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-04-05 3:42 [PATCH v2] kvm: Disable MSI/MSI-X in assigned device reset path Alex Williamson
2012-04-05 7:28 ` Jan Kiszka
2012-04-05 9:34 ` Michael S. Tsirkin
2012-04-05 14:42 ` Alex Williamson
2012-04-05 15:04 ` Michael S. Tsirkin
2012-04-08 13:14 ` Avi Kivity
2012-04-08 13:17 ` Michael S. Tsirkin
2012-04-08 13:18 ` Avi Kivity
2012-04-08 13:21 ` Michael S. Tsirkin
2012-04-08 13:24 ` Avi Kivity
2012-04-08 13:30 ` Michael S. Tsirkin
2012-04-08 13:41 ` Avi Kivity
2012-04-08 13:53 ` Michael S. Tsirkin
2012-04-08 14:01 ` Avi Kivity
2012-04-08 14:42 ` Michael S. Tsirkin
2012-04-08 15:26 ` Avi Kivity
2012-04-08 15:46 ` Michael S. Tsirkin
2012-04-08 15:50 ` Avi Kivity
2012-04-08 16:04 ` Michael S. Tsirkin
2012-04-08 16:08 ` Avi Kivity [this message]
2012-04-08 17:37 ` Jan Kiszka
2012-04-08 18:18 ` Michael S. Tsirkin
2012-04-08 18:39 ` Jan Kiszka
2012-04-08 20:35 ` Michael S. Tsirkin
2012-04-09 8:35 ` Avi Kivity
2012-04-10 16:55 ` Alex Williamson
2012-04-16 14:03 ` Alex Williamson
2012-04-16 14:31 ` Avi Kivity
2012-04-16 15:06 ` Michael S. Tsirkin
2012-04-16 15:10 ` Jan Kiszka
2012-04-16 16:08 ` Michael S. Tsirkin
2012-04-16 16:13 ` Jan Kiszka
2012-04-16 16:36 ` Michael S. Tsirkin
2012-04-16 16:38 ` Jan Kiszka
2012-04-16 17:12 ` Michael S. Tsirkin
2012-04-16 18:47 ` Jan Kiszka
2012-04-16 16:12 ` Jason Baron
2012-04-16 16:34 ` Michael S. Tsirkin
2012-04-16 19:07 ` Alex Williamson
2012-04-16 19:47 ` Michael S. Tsirkin
2012-04-17 0:55 ` Marcelo Tosatti
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=4F81B7F1.6050800@redhat.com \
--to=avi@redhat.com \
--cc=alex.williamson@redhat.com \
--cc=jan.kiszka@siemens.com \
--cc=jbaron@redhat.com \
--cc=kvm@vger.kernel.org \
--cc=mst@redhat.com \
/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