• Will Deacon's avatar
    perf/core: Avoid freeing static PMU contexts when PMU is unregistered · df0062b2
    Will Deacon authored
    Since commit:
    
      1fd7e416 ("perf/core: Remove perf_cpu_context::unique_pmu")
    
    ... when a PMU is unregistered then its associated ->pmu_cpu_context is
    unconditionally freed. Whilst this is fine for dynamically allocated
    context types (i.e. those registered using perf_invalid_context), this
    causes a problem for sharing of static contexts such as
    perf_{sw,hw}_context, which are used by multiple built-in PMUs and
    effectively have a global lifetime.
    
    Whilst testing the ARM SPE driver, which must use perf_sw_context to
    support per-task AUX tracing, unregistering the driver as a result of a
    module unload resulted in:
    
     Unable to handle kernel NULL pointer dereference at virtual address 00000038
     Internal error: Oops: 96000004 [#1] PREEMPT SMP
     Modules linked in: [last unloaded: arm_spe_pmu]
     PC is at ctx_resched+0x38/0xe8
     LR is at perf_event_exec+0x20c/0x278
     [...]
     ctx_resched+0x38/0xe8
     perf_event_exec+0x20c/0x278
     setup_new_exec+0x88/0x118
     load_elf_binary+0x26c/0x109c
     search_binary_handler+0x90/0x298
     do_execveat_common.isra.14+0x540/0x618
     SyS_execve+0x38/0x48
    
    since the software context has been freed and the ctx.pmu->pmu_disable_count
    field has been set to NULL.
    
    This patch fixes the problem by avoiding the freeing of static PMU contexts
    altogether. Whilst the sharing of dynamic contexts is questionable, this
    actually requires the caller to share their context pointer explicitly
    and so the burden is on them to manage the object lifetime.
    Reported-by: default avatarKim Phillips <kim.phillips@arm.com>
    Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
    Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
    Acked-by: default avatarMark Rutland <mark.rutland@arm.com>
    Cc: Linus Torvalds <torvalds@linux-foundation.org>
    Cc: Peter Zijlstra <peterz@infradead.org>
    Cc: Thomas Gleixner <tglx@linutronix.de>
    Fixes: 1fd7e416 ("perf/core: Remove perf_cpu_context::unique_pmu")
    Link: http://lkml.kernel.org/r/1507040450-7730-1-git-send-email-will.deacon@arm.comSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
    df0062b2
core.c 267 KB