From: Marc Zyngier <maz@kernel.org>
To: "Veith, Simon" <sveith@amazon.de>
Cc: "kvmarm@lists.linux.dev" <kvmarm@lists.linux.dev>,
"kvm@vger.kernel.org" <kvm@vger.kernel.org>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"yuzenghui@huawei.com" <yuzenghui@huawei.com>,
"dwmw2@infradead.org" <dwmw2@infradead.org>,
"coltonlewis@google.com" <coltonlewis@google.com>,
"james.morse@arm.com" <james.morse@arm.com>,
"suzuki.poulose@arm.com" <suzuki.poulose@arm.com>,
"oliver.upton@linux.dev" <oliver.upton@linux.dev>,
"joey.gouly@arm.com" <joey.gouly@arm.com>,
"reijiw@google.com" <reijiw@google.com>,
"ricarkol@google.com" <ricarkol@google.com>
Subject: Re: [PATCH v3 00/18] KVM: arm64: Rework timer offsetting for fun and profit
Date: Thu, 30 Mar 2023 18:46:17 +0100 [thread overview]
Message-ID: <86cz4qw2s6.wl-maz@kernel.org> (raw)
In-Reply-To: <67fd090a26beb831a3ae754853c9419e1cbcfcd8.camel@amazon.de>
On Wed, 29 Mar 2023 06:41:07 +0100,
"Veith, Simon" <sveith@amazon.de> wrote:
>
> Hello Marc,
>
> thanks again for your proposal.
>
> On Fri, 2023-03-24 at 14:46 +0000, Marc Zyngier wrote:
> > This series aims at satisfying multiple goals:
> >
> > - allow a VMM to atomically restore a timer offset for a whole VM
> > instead of updating the offset each time a vcpu get its counter
> > written
> >
> > - allow a VMM to save/restore the physical timer context, something
> > that we cannot do at the moment due to the lack of offsetting
> >
> > - provide a framework that is suitable for NV support, where we get
> > both global and per timer, per vcpu offsetting, and manage
> > interrupts in a less braindead way.
> >
> > We fix a couple of issues along the way, both from a stylistic and
> > correctness perspective. This results in a new per VM KVM API that
> > allows a global offset to be set at any point in time, overriding
> > both
> > of the timer counter writebacks.
> >
> > We also take this opportunity to rework the way IRQs are associated
> > with timers, something that was always a bit dodgy. This relies on a
> > new lock, which should disappear once Oliver's lock ordering series
> > is
> > merged (we can reuse the config_lock for this).
> >
> > This has been tested with nVHE, VHE and NV. I do not have access to
> > CNTPOFF-aware HW, but Colton managed to give it a go. Note that the
> > NV patches in this series are here to give a perspective on how this
> > gets used.
> >
> > I've updated the arch_timer selftest to allow an offset to be
> > provided
> > from the command line, and fixed a couple of glaring issues along the
> > way.
> >
> > Note that this is at best 6.4 material. I have a branch stashed at
> > [0]
> > and based on 6.3-rc3, as well as a minimal example of the use of the
> > API at [3] based on kvmtool.
> >
> > Simon: I'd appreciate some feedback as whether this change fits your
> > requirements, given that you brought this up the first place.
>
> The interface looks good to me. I have yet to deliver on my promise to
> test your patch series with our userspace; I am on leave this week, but
> I'll give your latest iteration a go next week.
No worries. I'm about to post v4, which I think is pretty ripe at this
stage. Do let me know when you get a chance to try it.
Thanks,
M.
--
Without deviation from the norm, progress is not possible.
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
prev parent reply other threads:[~2023-03-30 17:47 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-03-24 14:46 [PATCH v3 00/18] KVM: arm64: Rework timer offsetting for fun and profit Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 01/18] KVM: arm64: timers: Use a per-vcpu, per-timer accumulator for fractional ns Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 02/18] arm64: Add CNTPOFF_EL2 register definition Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 03/18] arm64: Add HAS_ECV_CNTPOFF capability Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 04/18] KVM: arm64: timers: Use CNTPOFF_EL2 to offset the physical timer Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 05/18] KVM: arm64: timers: Allow physical offset without CNTPOFF_EL2 Marc Zyngier
2023-03-30 6:42 ` Oliver Upton
2023-03-30 10:09 ` Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 06/18] KVM: arm64: Expose {un,}lock_all_vcpus() to the rest of KVM Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 07/18] KVM: arm64: timers: Allow userspace to set the global counter offset Marc Zyngier
2023-03-30 6:26 ` Oliver Upton
2023-03-30 10:15 ` Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 08/18] KVM: arm64: timers: Allow save/restoring of the physical timer Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 09/18] KVM: arm64: timers: Rationalise per-vcpu timer init Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 10/18] KVM: arm64: timers: Abstract per-timer IRQ access Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 11/18] KVM: arm64: timers: Move the timer IRQs into arch_timer_vm_data Marc Zyngier
2023-03-30 7:02 ` Oliver Upton
2023-03-30 10:19 ` Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 12/18] KVM: arm64: Abstract the number of valid timers per vcpu Marc Zyngier
2023-03-24 14:46 ` [PATCH v3 13/18] KVM: arm64: Document KVM_ARM_SET_CNT_OFFSETS and co Marc Zyngier
2023-03-24 14:47 ` [PATCH v3 14/18] KVM: arm64: nv: timers: Add a per-timer, per-vcpu offset Marc Zyngier
2023-03-24 14:47 ` [PATCH v3 15/18] KVM: arm64: nv: timers: Support hyp timer emulation Marc Zyngier
2023-03-24 14:47 ` [PATCH v3 16/18] KVM: arm64: selftests: Add physical timer registers to the sysreg list Marc Zyngier
2023-03-24 14:47 ` [PATCH v3 17/18] KVM: arm64: selftests: Deal with spurious timer interrupts Marc Zyngier
2023-03-24 14:47 ` [PATCH v3 18/18] KVM: arm64: selftests: Augment existing timer test to handle variable offset Marc Zyngier
2023-03-29 5:41 ` [PATCH v3 00/18] KVM: arm64: Rework timer offsetting for fun and profit Veith, Simon
2023-03-30 17:46 ` Marc Zyngier [this message]
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=86cz4qw2s6.wl-maz@kernel.org \
--to=maz@kernel.org \
--cc=coltonlewis@google.com \
--cc=dwmw2@infradead.org \
--cc=james.morse@arm.com \
--cc=joey.gouly@arm.com \
--cc=kvm@vger.kernel.org \
--cc=kvmarm@lists.linux.dev \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=oliver.upton@linux.dev \
--cc=reijiw@google.com \
--cc=ricarkol@google.com \
--cc=suzuki.poulose@arm.com \
--cc=sveith@amazon.de \
--cc=yuzenghui@huawei.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;
as well as URLs for NNTP newsgroup(s).