提交 cb8b7881 编写于 作者: F Frederic Weisbecker 提交者: Ingo Molnar

perf/hw_breakpoint: Pass new breakpoint type to modify_breakpoint_slot()

We soon won't be able to rely on bp->attr anymore to get the new
type of the modifying breakpoint because the new attributes are going
to be copied only once we successfully modified the breakpoint slot.

This will fix the current misdesigned layout where the new attr are
copied to the modifying breakpoint before we actually know if the
modification will be validated.

In order to prepare for that, allow modify_breakpoint_slot() to take
the new breakpoint type.
Signed-off-by: NFrederic Weisbecker <frederic@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Andy Lutomirski <luto@kernel.org>
Cc: Arnaldo Carvalho de Melo <acme@kernel.org>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Chris Zankel <chris@zankel.net>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Joel Fernandes <joel.opensrc@gmail.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Max Filippov <jcmvbkbc@gmail.com>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Rich Felker <dalias@libc.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Will Deacon <will.deacon@arm.com>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Link: http://lkml.kernel.org/r/1529981939-8231-12-git-send-email-frederic@kernel.orgSigned-off-by: NIngo Molnar <mingo@kernel.org>
上级 cffbb3bd
...@@ -345,13 +345,13 @@ void release_bp_slot(struct perf_event *bp) ...@@ -345,13 +345,13 @@ void release_bp_slot(struct perf_event *bp)
mutex_unlock(&nr_bp_mutex); mutex_unlock(&nr_bp_mutex);
} }
static int __modify_bp_slot(struct perf_event *bp, u64 old_type) static int __modify_bp_slot(struct perf_event *bp, u64 old_type, u64 new_type)
{ {
int err; int err;
__release_bp_slot(bp, old_type); __release_bp_slot(bp, old_type);
err = __reserve_bp_slot(bp, bp->attr.bp_type); err = __reserve_bp_slot(bp, new_type);
if (err) { if (err) {
/* /*
* Reserve the old_type slot back in case * Reserve the old_type slot back in case
...@@ -367,12 +367,12 @@ static int __modify_bp_slot(struct perf_event *bp, u64 old_type) ...@@ -367,12 +367,12 @@ static int __modify_bp_slot(struct perf_event *bp, u64 old_type)
return err; return err;
} }
static int modify_bp_slot(struct perf_event *bp, u64 old_type) static int modify_bp_slot(struct perf_event *bp, u64 old_type, u64 new_type)
{ {
int ret; int ret;
mutex_lock(&nr_bp_mutex); mutex_lock(&nr_bp_mutex);
ret = __modify_bp_slot(bp, old_type); ret = __modify_bp_slot(bp, old_type, new_type);
mutex_unlock(&nr_bp_mutex); mutex_unlock(&nr_bp_mutex);
return ret; return ret;
} }
...@@ -481,7 +481,7 @@ modify_user_hw_breakpoint_check(struct perf_event *bp, struct perf_event_attr *a ...@@ -481,7 +481,7 @@ modify_user_hw_breakpoint_check(struct perf_event *bp, struct perf_event_attr *a
err = hw_breakpoint_parse(bp, attr, &hw); err = hw_breakpoint_parse(bp, attr, &hw);
if (!err && modify) if (!err && modify)
err = modify_bp_slot(bp, old_type); err = modify_bp_slot(bp, old_type, bp->attr.bp_type);
if (err) { if (err) {
bp->attr.bp_addr = old_addr; bp->attr.bp_addr = old_addr;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册