/* * Copyright 2005 Openedhand Ltd. * * Author: Richard Purdie * * Based on WM8753.h * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * */ #ifndef _WM8988_H #define _WM8988_H /* WM8988 register space */ #define WM8988_LINVOL 0x00 #define WM8988_RINVOL 0x01 #define WM8988_LOUT1V 0x02 #define WM8988_ROUT1V 0x03 #define WM8988_ADCDAC 0x05 #define WM8988_IFACE 0x07 #define WM8988_SRATE 0x08 #define WM8988_LDAC 0x0a #define WM8988_RDAC 0x0b #define WM8988_BASS 0x0c #define WM8988_TREBLE 0x0d #define WM8988_RESET 0x0f #define WM8988_3D 0x10 #define WM8988_ALC1 0x11 #define WM8988_ALC2 0x12 #define WM8988_ALC3 0x13 #define WM8988_NGATE 0x14 #define WM8988_LADC 0x15 #define WM8988_RADC 0x16 #define WM8988_ADCTL1 0x17 #define WM8988_ADCTL2 0x18 #define WM8988_PWR1 0x19 #define WM8988_PWR2 0x1a #define WM8988_ADCTL3 0x1b #define WM8988_ADCIN 0x1f #define WM8988_LADCIN 0x20 #define WM8988_RADCIN 0x21 #define WM8988_LOUTM1 0x22 #define WM8988_LOUTM2 0x23 #define WM8988_ROUTM1 0x24 #define WM8988_ROUTM2 0x25 #define WM8988_LOUT2V 0x28 #define WM8988_ROUT2V 0x29 #define WM8988_LPPB 0x43 #define WM8988_NUM_REG 0x44 #define WM8988_SYSCLK 0 #endif xt plumbingsTobias Klauser
summaryrefslogtreecommitdiff
path: root/tools/perf/trace/beauty/waitid_options.c
diff options
context:
space:
mode:
authorPeter Zijlstra <peterz@infradead.org>2017-01-26 16:39:55 +0100
committerIngo Molnar <mingo@kernel.org>2017-01-30 11:41:25 +0100
commita76a82a3e38c8d3fb6499e3dfaeb0949241ab588 (patch)
treeb5bc906278fe1ac66d75de984d26bf59b43b3ed8 /tools/perf/trace/beauty/waitid_options.c
parent566cf877a1fcb6d6dc0126b076aad062054c2637 (diff)
perf/core: Fix use-after-free bug
Dmitry reported a KASAN use-after-free on event->group_leader. It turns out there's a hole in perf_remove_from_context() due to event_function_call() not calling its function when the task associated with the event is already dead. In this case the event will have been detached from the task, but the grouping will have been retained, such that group operations might still work properly while there are live child events etc. This does however mean that we can miss a perf_group_detach() call when the group decomposes, this in turn can then lead to use-after-free. Fix it by explicitly doing the group detach if its still required. Reported-by: Dmitry Vyukov <dvyukov@google.com> Tested-by: Dmitry Vyukov <dvyukov@google.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: stable@vger.kernel.org # v4.5+ Cc: syzkaller <syzkaller@googlegroups.com> Fixes: 63b6da39bb38 ("perf: Fix perf_event_exit_task() race") Link: http://lkml.kernel.org/r/20170126153955.GD6515@twins.programming.kicks-ass.net Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'tools/perf/trace/beauty/waitid_options.c')