From: Christoffer Dall <cdall@linaro.org>
To: Andrew Jones <drjones@redhat.com>
Cc: peter.maydell@linaro.org, qemu-arm@nongnu.org,
qemu-devel@nongnu.org, agraf@suse.de
Subject: Re: [Qemu-arm] [PATCH v2 2/4] target/arm/kvm: pmu: split init and set-irq stages
Date: Fri, 21 Jul 2017 13:25:59 +0200 [thread overview]
Message-ID: <20170721112559.GB16350@cbox> (raw)
In-Reply-To: <1500471597-2517-3-git-send-email-drjones@redhat.com>
On Wed, Jul 19, 2017 at 09:39:55AM -0400, Andrew Jones wrote:
> When adding a PMU with a userspace irqchip we skip the set-irq
> stage of device creation. Split the 'create' function into two
> functions 'init' and 'set-irq' so they may be called separately.
>
> Signed-off-by: Andrew Jones <drjones@redhat.com>
Reviewed-by: Christoffer Dall <cdall@linaro.org>
> ---
> hw/arm/virt.c | 11 +++++++++--
> target/arm/kvm32.c | 8 +++++++-
> target/arm/kvm64.c | 52 +++++++++++++++++++++++++---------------------------
> target/arm/kvm_arm.h | 10 ++++++++--
> 4 files changed, 49 insertions(+), 32 deletions(-)
>
> diff --git a/hw/arm/virt.c b/hw/arm/virt.c
> index ea26f0c473c2..7157a028adce 100644
> --- a/hw/arm/virt.c
> +++ b/hw/arm/virt.c
> @@ -492,10 +492,17 @@ static void fdt_add_pmu_nodes(const VirtMachineState *vms)
>
> CPU_FOREACH(cpu) {
> armcpu = ARM_CPU(cpu);
> - if (!arm_feature(&armcpu->env, ARM_FEATURE_PMU) ||
> - (kvm_enabled() && !kvm_arm_pmu_create(cpu, PPI(VIRTUAL_PMU_IRQ)))) {
> + if (!arm_feature(&armcpu->env, ARM_FEATURE_PMU)) {
> return;
> }
> + if (kvm_enabled()) {
> + if (!kvm_arm_pmu_set_irq(cpu, PPI(VIRTUAL_PMU_IRQ))) {
> + return;
> + }
> + if (!kvm_arm_pmu_init(cpu)) {
> + return;
> + }
> + }
> }
>
> if (vms->gic_version == 2) {
> diff --git a/target/arm/kvm32.c b/target/arm/kvm32.c
> index 069da0c5fd10..e3aab89a1a94 100644
> --- a/target/arm/kvm32.c
> +++ b/target/arm/kvm32.c
> @@ -522,7 +522,13 @@ bool kvm_arm_hw_debug_active(CPUState *cs)
> return false;
> }
>
> -int kvm_arm_pmu_create(CPUState *cs, int irq)
> +int kvm_arm_pmu_set_irq(CPUState *cs, int irq)
> +{
> + qemu_log_mask(LOG_UNIMP, "%s: not implemented\n", __func__);
> + return 0;
> +}
> +
> +int kvm_arm_pmu_init(CPUState *cs)
> {
> qemu_log_mask(LOG_UNIMP, "%s: not implemented\n", __func__);
> return 0;
> diff --git a/target/arm/kvm64.c b/target/arm/kvm64.c
> index a16abc8d129e..e26638a6fac1 100644
> --- a/target/arm/kvm64.c
> +++ b/target/arm/kvm64.c
> @@ -381,46 +381,44 @@ static CPUWatchpoint *find_hw_watchpoint(CPUState *cpu, target_ulong addr)
> return NULL;
> }
>
> -static bool kvm_arm_pmu_support_ctrl(CPUState *cs, struct kvm_device_attr *attr)
> -{
> - return kvm_vcpu_ioctl(cs, KVM_HAS_DEVICE_ATTR, attr) == 0;
> -}
> -
> -int kvm_arm_pmu_create(CPUState *cs, int irq)
> +static bool kvm_arm_pmu_set_attr(CPUState *cs, struct kvm_device_attr *attr)
> {
> int err;
>
> - struct kvm_device_attr attr = {
> - .group = KVM_ARM_VCPU_PMU_V3_CTRL,
> - .addr = (intptr_t)&irq,
> - .attr = KVM_ARM_VCPU_PMU_V3_IRQ,
> - .flags = 0,
> - };
> -
> - if (!kvm_arm_pmu_support_ctrl(cs, &attr)) {
> - return 0;
> + err = kvm_vcpu_ioctl(cs, KVM_HAS_DEVICE_ATTR, attr);
> + if (err != 0) {
> + return false;
> }
>
> - err = kvm_vcpu_ioctl(cs, KVM_SET_DEVICE_ATTR, &attr);
> + err = kvm_vcpu_ioctl(cs, KVM_SET_DEVICE_ATTR, attr);
> if (err < 0) {
> fprintf(stderr, "KVM_SET_DEVICE_ATTR failed: %s\n",
> strerror(-err));
> abort();
> }
>
> - attr.group = KVM_ARM_VCPU_PMU_V3_CTRL;
> - attr.attr = KVM_ARM_VCPU_PMU_V3_INIT;
> - attr.addr = 0;
> - attr.flags = 0;
> + return true;
> +}
>
> - err = kvm_vcpu_ioctl(cs, KVM_SET_DEVICE_ATTR, &attr);
> - if (err < 0) {
> - fprintf(stderr, "KVM_SET_DEVICE_ATTR failed: %s\n",
> - strerror(-err));
> - abort();
> - }
> +int kvm_arm_pmu_init(CPUState *cs)
> +{
> + struct kvm_device_attr attr = {
> + .group = KVM_ARM_VCPU_PMU_V3_CTRL,
> + .attr = KVM_ARM_VCPU_PMU_V3_INIT,
> + };
> +
> + return kvm_arm_pmu_set_attr(cs, &attr);
> +}
> +
> +int kvm_arm_pmu_set_irq(CPUState *cs, int irq)
> +{
> + struct kvm_device_attr attr = {
> + .group = KVM_ARM_VCPU_PMU_V3_CTRL,
> + .addr = (intptr_t)&irq,
> + .attr = KVM_ARM_VCPU_PMU_V3_IRQ,
> + };
>
> - return 1;
> + return kvm_arm_pmu_set_attr(cs, &attr);
> }
>
> static inline void set_feature(uint64_t *features, int feature)
> diff --git a/target/arm/kvm_arm.h b/target/arm/kvm_arm.h
> index 633d08828a5d..cab5ea9be55c 100644
> --- a/target/arm/kvm_arm.h
> +++ b/target/arm/kvm_arm.h
> @@ -195,7 +195,8 @@ int kvm_arm_sync_mpstate_to_qemu(ARMCPU *cpu);
>
> int kvm_arm_vgic_probe(void);
>
> -int kvm_arm_pmu_create(CPUState *cs, int irq);
> +int kvm_arm_pmu_set_irq(CPUState *cs, int irq);
> +int kvm_arm_pmu_init(CPUState *cs);
>
> #else
>
> @@ -204,7 +205,12 @@ static inline int kvm_arm_vgic_probe(void)
> return 0;
> }
>
> -static inline int kvm_arm_pmu_create(CPUState *cs, int irq)
> +static inline int kvm_arm_pmu_set_irq(CPUState *cs, int irq)
> +{
> + return 0;
> +}
> +
> +static inline int kvm_arm_pmu_init(CPUState *cs)
> {
> return 0;
> }
> --
> 1.8.3.1
>
WARNING: multiple messages have this Message-ID (diff)
From: Christoffer Dall <cdall@linaro.org>
To: Andrew Jones <drjones@redhat.com>
Cc: qemu-devel@nongnu.org, qemu-arm@nongnu.org,
peter.maydell@linaro.org, agraf@suse.de
Subject: Re: [Qemu-devel] [PATCH v2 2/4] target/arm/kvm: pmu: split init and set-irq stages
Date: Fri, 21 Jul 2017 13:25:59 +0200 [thread overview]
Message-ID: <20170721112559.GB16350@cbox> (raw)
In-Reply-To: <1500471597-2517-3-git-send-email-drjones@redhat.com>
On Wed, Jul 19, 2017 at 09:39:55AM -0400, Andrew Jones wrote:
> When adding a PMU with a userspace irqchip we skip the set-irq
> stage of device creation. Split the 'create' function into two
> functions 'init' and 'set-irq' so they may be called separately.
>
> Signed-off-by: Andrew Jones <drjones@redhat.com>
Reviewed-by: Christoffer Dall <cdall@linaro.org>
> ---
> hw/arm/virt.c | 11 +++++++++--
> target/arm/kvm32.c | 8 +++++++-
> target/arm/kvm64.c | 52 +++++++++++++++++++++++++---------------------------
> target/arm/kvm_arm.h | 10 ++++++++--
> 4 files changed, 49 insertions(+), 32 deletions(-)
>
> diff --git a/hw/arm/virt.c b/hw/arm/virt.c
> index ea26f0c473c2..7157a028adce 100644
> --- a/hw/arm/virt.c
> +++ b/hw/arm/virt.c
> @@ -492,10 +492,17 @@ static void fdt_add_pmu_nodes(const VirtMachineState *vms)
>
> CPU_FOREACH(cpu) {
> armcpu = ARM_CPU(cpu);
> - if (!arm_feature(&armcpu->env, ARM_FEATURE_PMU) ||
> - (kvm_enabled() && !kvm_arm_pmu_create(cpu, PPI(VIRTUAL_PMU_IRQ)))) {
> + if (!arm_feature(&armcpu->env, ARM_FEATURE_PMU)) {
> return;
> }
> + if (kvm_enabled()) {
> + if (!kvm_arm_pmu_set_irq(cpu, PPI(VIRTUAL_PMU_IRQ))) {
> + return;
> + }
> + if (!kvm_arm_pmu_init(cpu)) {
> + return;
> + }
> + }
> }
>
> if (vms->gic_version == 2) {
> diff --git a/target/arm/kvm32.c b/target/arm/kvm32.c
> index 069da0c5fd10..e3aab89a1a94 100644
> --- a/target/arm/kvm32.c
> +++ b/target/arm/kvm32.c
> @@ -522,7 +522,13 @@ bool kvm_arm_hw_debug_active(CPUState *cs)
> return false;
> }
>
> -int kvm_arm_pmu_create(CPUState *cs, int irq)
> +int kvm_arm_pmu_set_irq(CPUState *cs, int irq)
> +{
> + qemu_log_mask(LOG_UNIMP, "%s: not implemented\n", __func__);
> + return 0;
> +}
> +
> +int kvm_arm_pmu_init(CPUState *cs)
> {
> qemu_log_mask(LOG_UNIMP, "%s: not implemented\n", __func__);
> return 0;
> diff --git a/target/arm/kvm64.c b/target/arm/kvm64.c
> index a16abc8d129e..e26638a6fac1 100644
> --- a/target/arm/kvm64.c
> +++ b/target/arm/kvm64.c
> @@ -381,46 +381,44 @@ static CPUWatchpoint *find_hw_watchpoint(CPUState *cpu, target_ulong addr)
> return NULL;
> }
>
> -static bool kvm_arm_pmu_support_ctrl(CPUState *cs, struct kvm_device_attr *attr)
> -{
> - return kvm_vcpu_ioctl(cs, KVM_HAS_DEVICE_ATTR, attr) == 0;
> -}
> -
> -int kvm_arm_pmu_create(CPUState *cs, int irq)
> +static bool kvm_arm_pmu_set_attr(CPUState *cs, struct kvm_device_attr *attr)
> {
> int err;
>
> - struct kvm_device_attr attr = {
> - .group = KVM_ARM_VCPU_PMU_V3_CTRL,
> - .addr = (intptr_t)&irq,
> - .attr = KVM_ARM_VCPU_PMU_V3_IRQ,
> - .flags = 0,
> - };
> -
> - if (!kvm_arm_pmu_support_ctrl(cs, &attr)) {
> - return 0;
> + err = kvm_vcpu_ioctl(cs, KVM_HAS_DEVICE_ATTR, attr);
> + if (err != 0) {
> + return false;
> }
>
> - err = kvm_vcpu_ioctl(cs, KVM_SET_DEVICE_ATTR, &attr);
> + err = kvm_vcpu_ioctl(cs, KVM_SET_DEVICE_ATTR, attr);
> if (err < 0) {
> fprintf(stderr, "KVM_SET_DEVICE_ATTR failed: %s\n",
> strerror(-err));
> abort();
> }
>
> - attr.group = KVM_ARM_VCPU_PMU_V3_CTRL;
> - attr.attr = KVM_ARM_VCPU_PMU_V3_INIT;
> - attr.addr = 0;
> - attr.flags = 0;
> + return true;
> +}
>
> - err = kvm_vcpu_ioctl(cs, KVM_SET_DEVICE_ATTR, &attr);
> - if (err < 0) {
> - fprintf(stderr, "KVM_SET_DEVICE_ATTR failed: %s\n",
> - strerror(-err));
> - abort();
> - }
> +int kvm_arm_pmu_init(CPUState *cs)
> +{
> + struct kvm_device_attr attr = {
> + .group = KVM_ARM_VCPU_PMU_V3_CTRL,
> + .attr = KVM_ARM_VCPU_PMU_V3_INIT,
> + };
> +
> + return kvm_arm_pmu_set_attr(cs, &attr);
> +}
> +
> +int kvm_arm_pmu_set_irq(CPUState *cs, int irq)
> +{
> + struct kvm_device_attr attr = {
> + .group = KVM_ARM_VCPU_PMU_V3_CTRL,
> + .addr = (intptr_t)&irq,
> + .attr = KVM_ARM_VCPU_PMU_V3_IRQ,
> + };
>
> - return 1;
> + return kvm_arm_pmu_set_attr(cs, &attr);
> }
>
> static inline void set_feature(uint64_t *features, int feature)
> diff --git a/target/arm/kvm_arm.h b/target/arm/kvm_arm.h
> index 633d08828a5d..cab5ea9be55c 100644
> --- a/target/arm/kvm_arm.h
> +++ b/target/arm/kvm_arm.h
> @@ -195,7 +195,8 @@ int kvm_arm_sync_mpstate_to_qemu(ARMCPU *cpu);
>
> int kvm_arm_vgic_probe(void);
>
> -int kvm_arm_pmu_create(CPUState *cs, int irq);
> +int kvm_arm_pmu_set_irq(CPUState *cs, int irq);
> +int kvm_arm_pmu_init(CPUState *cs);
>
> #else
>
> @@ -204,7 +205,12 @@ static inline int kvm_arm_vgic_probe(void)
> return 0;
> }
>
> -static inline int kvm_arm_pmu_create(CPUState *cs, int irq)
> +static inline int kvm_arm_pmu_set_irq(CPUState *cs, int irq)
> +{
> + return 0;
> +}
> +
> +static inline int kvm_arm_pmu_init(CPUState *cs)
> {
> return 0;
> }
> --
> 1.8.3.1
>
next prev parent reply other threads:[~2017-07-21 11:26 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-07-19 13:39 [Qemu-arm] [PATCH v2 0/4] ARM: KVM: Enable in-kernel PMU with user space gic Andrew Jones
2017-07-19 13:39 ` [Qemu-devel] " Andrew Jones
2017-07-19 13:39 ` [Qemu-devel] [PATCH v2 1/4] hw/arm/virt: add pmu interrupt state Andrew Jones
2017-07-21 11:16 ` [Qemu-arm] " Christoffer Dall
2017-07-21 11:16 ` [Qemu-devel] " Christoffer Dall
2017-07-21 11:35 ` [Qemu-arm] " Andrew Jones
2017-07-21 11:35 ` Andrew Jones
2017-07-21 12:01 ` [Qemu-arm] " Christoffer Dall
2017-07-21 12:01 ` Christoffer Dall
2017-07-19 13:39 ` [Qemu-arm] [PATCH v2 2/4] target/arm/kvm: pmu: split init and set-irq stages Andrew Jones
2017-07-19 13:39 ` [Qemu-devel] " Andrew Jones
2017-07-21 11:25 ` Christoffer Dall [this message]
2017-07-21 11:25 ` Christoffer Dall
2017-07-19 13:39 ` [Qemu-arm] [PATCH v2 3/4] hw/arm/virt: allow pmu instantiation with userspace irqchip Andrew Jones
2017-07-19 13:39 ` [Qemu-devel] " Andrew Jones
2017-07-21 11:28 ` [Qemu-arm] " Christoffer Dall
2017-07-21 11:28 ` [Qemu-devel] " Christoffer Dall
2017-07-19 13:39 ` [Qemu-arm] [PATCH v2 4/4] target/arm/kvm: pmu: improve error handling Andrew Jones
2017-07-19 13:39 ` [Qemu-devel] " Andrew Jones
2017-07-21 11:29 ` Christoffer Dall
2017-07-21 11:29 ` Christoffer Dall
2017-09-04 14:17 ` [Qemu-arm] " Peter Maydell
2017-09-04 14:17 ` [Qemu-devel] " Peter Maydell
2017-09-05 14:44 ` [Qemu-arm] " Andrew Jones
2017-09-05 14:44 ` Andrew Jones
2017-07-19 15:14 ` [Qemu-devel] [PATCH v2 0/4] ARM: KVM: Enable in-kernel PMU with user space gic no-reply
2017-07-19 15:14 ` no-reply
2017-08-08 13:23 ` [Qemu-arm] " Andrew Jones
2017-08-08 13:23 ` Andrew Jones
2017-08-17 10:41 ` [Qemu-arm] " Peter Maydell
2017-08-17 10:41 ` Peter Maydell
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=20170721112559.GB16350@cbox \
--to=cdall@linaro.org \
--cc=agraf@suse.de \
--cc=drjones@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-arm@nongnu.org \
--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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.