diff options
| author | Radim Krčmář <rkrcmar@redhat.com> | 2016-11-19 12:02:07 -0500 |
|---|---|---|
| committer | Radim Krčmář <rkrcmar@redhat.com> | 2016-11-19 12:02:07 -0500 |
| commit | e5dbc4bf0b8c9ab50cc5699214240e84515be6eb (patch) | |
| tree | 608554bb7e3aecf05d81106d32c4312c941fecdb /virt | |
| parent | a25f0944ba9b1d8a6813fd6f1a86f1bd59ac25a6 (diff) | |
| parent | b112c84a6ff035271d41d548c10215f18443d6a6 (diff) | |
Merge tag 'kvm-arm-for-4.9-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm
KVM/ARM updates for v4.9-rc6
- Fix handling of the 32bit cycle counter
- Fix cycle counter filtering
Diffstat (limited to 'virt')
| -rw-r--r-- | virt/kvm/arm/pmu.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/virt/kvm/arm/pmu.c b/virt/kvm/arm/pmu.c index 6e9c40eea208..69ccce308458 100644 --- a/virt/kvm/arm/pmu.c +++ b/virt/kvm/arm/pmu.c | |||
| @@ -305,7 +305,7 @@ void kvm_pmu_software_increment(struct kvm_vcpu *vcpu, u64 val) | |||
| 305 | continue; | 305 | continue; |
| 306 | type = vcpu_sys_reg(vcpu, PMEVTYPER0_EL0 + i) | 306 | type = vcpu_sys_reg(vcpu, PMEVTYPER0_EL0 + i) |
| 307 | & ARMV8_PMU_EVTYPE_EVENT; | 307 | & ARMV8_PMU_EVTYPE_EVENT; |
| 308 | if ((type == ARMV8_PMU_EVTYPE_EVENT_SW_INCR) | 308 | if ((type == ARMV8_PMUV3_PERFCTR_SW_INCR) |
| 309 | && (enable & BIT(i))) { | 309 | && (enable & BIT(i))) { |
| 310 | reg = vcpu_sys_reg(vcpu, PMEVCNTR0_EL0 + i) + 1; | 310 | reg = vcpu_sys_reg(vcpu, PMEVCNTR0_EL0 + i) + 1; |
| 311 | reg = lower_32_bits(reg); | 311 | reg = lower_32_bits(reg); |
| @@ -379,7 +379,8 @@ void kvm_pmu_set_counter_event_type(struct kvm_vcpu *vcpu, u64 data, | |||
| 379 | eventsel = data & ARMV8_PMU_EVTYPE_EVENT; | 379 | eventsel = data & ARMV8_PMU_EVTYPE_EVENT; |
| 380 | 380 | ||
| 381 | /* Software increment event does't need to be backed by a perf event */ | 381 | /* Software increment event does't need to be backed by a perf event */ |
| 382 | if (eventsel == ARMV8_PMU_EVTYPE_EVENT_SW_INCR) | 382 | if (eventsel == ARMV8_PMUV3_PERFCTR_SW_INCR && |
| 383 | select_idx != ARMV8_PMU_CYCLE_IDX) | ||
| 383 | return; | 384 | return; |
| 384 | 385 | ||
| 385 | memset(&attr, 0, sizeof(struct perf_event_attr)); | 386 | memset(&attr, 0, sizeof(struct perf_event_attr)); |
| @@ -391,7 +392,8 @@ void kvm_pmu_set_counter_event_type(struct kvm_vcpu *vcpu, u64 data, | |||
| 391 | attr.exclude_kernel = data & ARMV8_PMU_EXCLUDE_EL1 ? 1 : 0; | 392 | attr.exclude_kernel = data & ARMV8_PMU_EXCLUDE_EL1 ? 1 : 0; |
| 392 | attr.exclude_hv = 1; /* Don't count EL2 events */ | 393 | attr.exclude_hv = 1; /* Don't count EL2 events */ |
| 393 | attr.exclude_host = 1; /* Don't count host events */ | 394 | attr.exclude_host = 1; /* Don't count host events */ |
| 394 | attr.config = eventsel; | 395 | attr.config = (select_idx == ARMV8_PMU_CYCLE_IDX) ? |
| 396 | ARMV8_PMUV3_PERFCTR_CPU_CYCLES : eventsel; | ||
| 395 | 397 | ||
| 396 | counter = kvm_pmu_get_counter_value(vcpu, select_idx); | 398 | counter = kvm_pmu_get_counter_value(vcpu, select_idx); |
| 397 | /* The initial sample period (overflow count) of an event. */ | 399 | /* The initial sample period (overflow count) of an event. */ |
