mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
perf target: Introduce perf_target_errno
The perf_target_errno enumerations are used to indicate specific error cases on perf target operations. It'd help libperf being a more generic library. Signed-off-by: Namhyung Kim <namhyung.kim@lge.com> Suggested-by: Arnaldo Carvalho de Melo <acme@ghostprotocols.net> Reviewed-by: David Ahern <dsahern@gmail.com> Cc: David Ahern <dsahern@gmail.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Namhyung Kim <namhyung@gmail.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Link: http://lkml.kernel.org/r/1336367344-28071-4-git-send-email-namhyung.kim@lge.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
55261f4670
commit
60bbddaaa3
2 changed files with 46 additions and 12 deletions
|
@ -10,36 +10,47 @@
|
|||
#include "debug.h"
|
||||
|
||||
|
||||
void perf_target__validate(struct perf_target *target)
|
||||
enum perf_target_errno perf_target__validate(struct perf_target *target)
|
||||
{
|
||||
enum perf_target_errno ret = PERF_ERRNO_TARGET__SUCCESS;
|
||||
|
||||
if (target->pid)
|
||||
target->tid = target->pid;
|
||||
|
||||
/* CPU and PID are mutually exclusive */
|
||||
if (target->tid && target->cpu_list) {
|
||||
ui__warning("WARNING: PID switch overriding CPU\n");
|
||||
sleep(1);
|
||||
target->cpu_list = NULL;
|
||||
if (ret == PERF_ERRNO_TARGET__SUCCESS)
|
||||
ret = PERF_ERRNO_TARGET__PID_OVERRIDE_CPU;
|
||||
}
|
||||
|
||||
/* UID and PID are mutually exclusive */
|
||||
if (target->tid && target->uid_str) {
|
||||
ui__warning("PID/TID switch overriding UID\n");
|
||||
sleep(1);
|
||||
target->uid_str = NULL;
|
||||
if (ret == PERF_ERRNO_TARGET__SUCCESS)
|
||||
ret = PERF_ERRNO_TARGET__PID_OVERRIDE_UID;
|
||||
}
|
||||
|
||||
/* UID and CPU are mutually exclusive */
|
||||
if (target->uid_str && target->cpu_list) {
|
||||
ui__warning("UID switch overriding CPU\n");
|
||||
sleep(1);
|
||||
target->cpu_list = NULL;
|
||||
if (ret == PERF_ERRNO_TARGET__SUCCESS)
|
||||
ret = PERF_ERRNO_TARGET__UID_OVERRIDE_CPU;
|
||||
}
|
||||
|
||||
/* PID/UID and SYSTEM are mutually exclusive */
|
||||
if ((target->tid || target->uid_str) && target->system_wide) {
|
||||
ui__warning("PID/TID/UID switch overriding CPU\n");
|
||||
sleep(1);
|
||||
/* PID and SYSTEM are mutually exclusive */
|
||||
if (target->tid && target->system_wide) {
|
||||
target->system_wide = false;
|
||||
if (ret == PERF_ERRNO_TARGET__SUCCESS)
|
||||
ret = PERF_ERRNO_TARGET__PID_OVERRIDE_SYSTEM;
|
||||
}
|
||||
|
||||
/* UID and SYSTEM are mutually exclusive */
|
||||
if (target->uid_str && target->system_wide) {
|
||||
target->system_wide = false;
|
||||
if (ret == PERF_ERRNO_TARGET__SUCCESS)
|
||||
ret = PERF_ERRNO_TARGET__UID_OVERRIDE_SYSTEM;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue