Skip to content

Commit 3a399a2

Browse files
committed
Merge tag 'perf_urgent_for_v5.15_rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull perf fixes from Borislav Petkov: - Make sure the destroy callback is reset when a event initialization fails - Update the event constraints for Icelake - Make sure the active time of an event is updated even for inactive events * tag 'perf_urgent_for_v5.15_rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: perf/core: fix userpage->time_enabled of inactive events perf/x86/intel: Update event constraints for ICX perf/x86: Reset destroy callback on event init failure
2 parents 52c3c17 + f792565 commit 3a399a2

File tree

4 files changed

+35
-5
lines changed

4 files changed

+35
-5
lines changed

arch/x86/events/core.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2465,6 +2465,7 @@ static int x86_pmu_event_init(struct perf_event *event)
24652465
if (err) {
24662466
if (event->destroy)
24672467
event->destroy(event);
2468+
event->destroy = NULL;
24682469
}
24692470

24702471
if (READ_ONCE(x86_pmu.attr_rdpmc) &&

arch/x86/events/intel/core.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -263,6 +263,7 @@ static struct event_constraint intel_icl_event_constraints[] = {
263263
INTEL_EVENT_CONSTRAINT_RANGE(0xa8, 0xb0, 0xf),
264264
INTEL_EVENT_CONSTRAINT_RANGE(0xb7, 0xbd, 0xf),
265265
INTEL_EVENT_CONSTRAINT_RANGE(0xd0, 0xe6, 0xf),
266+
INTEL_EVENT_CONSTRAINT(0xef, 0xf),
266267
INTEL_EVENT_CONSTRAINT_RANGE(0xf0, 0xf4, 0xf),
267268
EVENT_CONSTRAINT_END
268269
};

include/linux/perf_event.h

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -683,7 +683,9 @@ struct perf_event {
683683
/*
684684
* timestamp shadows the actual context timing but it can
685685
* be safely used in NMI interrupt context. It reflects the
686-
* context time as it was when the event was last scheduled in.
686+
* context time as it was when the event was last scheduled in,
687+
* or when ctx_sched_in failed to schedule the event because we
688+
* run out of PMC.
687689
*
688690
* ctx_time already accounts for ctx->timestamp. Therefore to
689691
* compute ctx_time for a sample, simply add perf_clock().

kernel/events/core.c

Lines changed: 30 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -3707,6 +3707,29 @@ static noinline int visit_groups_merge(struct perf_cpu_context *cpuctx,
37073707
return 0;
37083708
}
37093709

3710+
static inline bool event_update_userpage(struct perf_event *event)
3711+
{
3712+
if (likely(!atomic_read(&event->mmap_count)))
3713+
return false;
3714+
3715+
perf_event_update_time(event);
3716+
perf_set_shadow_time(event, event->ctx);
3717+
perf_event_update_userpage(event);
3718+
3719+
return true;
3720+
}
3721+
3722+
static inline void group_update_userpage(struct perf_event *group_event)
3723+
{
3724+
struct perf_event *event;
3725+
3726+
if (!event_update_userpage(group_event))
3727+
return;
3728+
3729+
for_each_sibling_event(event, group_event)
3730+
event_update_userpage(event);
3731+
}
3732+
37103733
static int merge_sched_in(struct perf_event *event, void *data)
37113734
{
37123735
struct perf_event_context *ctx = event->ctx;
@@ -3725,14 +3748,15 @@ static int merge_sched_in(struct perf_event *event, void *data)
37253748
}
37263749

37273750
if (event->state == PERF_EVENT_STATE_INACTIVE) {
3751+
*can_add_hw = 0;
37283752
if (event->attr.pinned) {
37293753
perf_cgroup_event_disable(event, ctx);
37303754
perf_event_set_state(event, PERF_EVENT_STATE_ERROR);
3755+
} else {
3756+
ctx->rotate_necessary = 1;
3757+
perf_mux_hrtimer_restart(cpuctx);
3758+
group_update_userpage(event);
37313759
}
3732-
3733-
*can_add_hw = 0;
3734-
ctx->rotate_necessary = 1;
3735-
perf_mux_hrtimer_restart(cpuctx);
37363760
}
37373761

37383762
return 0;
@@ -6324,6 +6348,8 @@ static int perf_mmap(struct file *file, struct vm_area_struct *vma)
63246348

63256349
ring_buffer_attach(event, rb);
63266350

6351+
perf_event_update_time(event);
6352+
perf_set_shadow_time(event, event->ctx);
63276353
perf_event_init_userpage(event);
63286354
perf_event_update_userpage(event);
63296355
} else {

0 commit comments

Comments
 (0)