blob: 7381b1ca4041f2975f5d4e7e26f25809601704b2 [file] [log] [blame]
Namhyung Kim12864b32012-04-26 14:15:22 +09001#ifndef _PERF_TARGET_H
2#define _PERF_TARGET_H
3
4#include <stdbool.h>
5#include <sys/types.h>
6
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -03007struct target {
Namhyung Kim12864b32012-04-26 14:15:22 +09008 const char *pid;
9 const char *tid;
10 const char *cpu_list;
11 const char *uid_str;
12 uid_t uid;
13 bool system_wide;
Namhyung Kimd1cb9fc2012-05-16 18:45:49 +090014 bool uses_mmap;
Adrian Hunter3aa59392013-11-15 15:52:29 +020015 bool default_per_cpu;
16 bool per_thread;
Namhyung Kim12864b32012-04-26 14:15:22 +090017};
18
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030019enum target_errno {
20 TARGET_ERRNO__SUCCESS = 0,
Namhyung Kim60bbdda2012-05-07 14:09:00 +090021
22 /*
23 * Choose an arbitrary negative big number not to clash with standard
24 * errno since SUS requires the errno has distinct positive values.
25 * See 'Issue 6' in the link below.
26 *
27 * http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/errno.h.html
28 */
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030029 __TARGET_ERRNO__START = -10000,
Namhyung Kim60bbdda2012-05-07 14:09:00 +090030
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030031 /* for target__validate() */
32 TARGET_ERRNO__PID_OVERRIDE_CPU = __TARGET_ERRNO__START,
33 TARGET_ERRNO__PID_OVERRIDE_UID,
34 TARGET_ERRNO__UID_OVERRIDE_CPU,
35 TARGET_ERRNO__PID_OVERRIDE_SYSTEM,
36 TARGET_ERRNO__UID_OVERRIDE_SYSTEM,
Adrian Hunter3aa59392013-11-15 15:52:29 +020037 TARGET_ERRNO__SYSTEM_OVERRIDE_THREAD,
Namhyung Kim60bbdda2012-05-07 14:09:00 +090038
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030039 /* for target__parse_uid() */
40 TARGET_ERRNO__INVALID_UID,
41 TARGET_ERRNO__USER_NOT_FOUND,
Namhyung Kim60bbdda2012-05-07 14:09:00 +090042
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030043 __TARGET_ERRNO__END,
Namhyung Kim60bbdda2012-05-07 14:09:00 +090044};
45
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030046enum target_errno target__validate(struct target *target);
47enum target_errno target__parse_uid(struct target *target);
Namhyung Kim12864b32012-04-26 14:15:22 +090048
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030049int target__strerror(struct target *target, int errnum, char *buf, size_t buflen);
Namhyung Kim16ad2ff2012-05-07 14:09:02 +090050
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030051static inline bool target__has_task(struct target *target)
Namhyung Kimd67356e2012-05-07 14:09:03 +090052{
Namhyung Kimaa22dd42012-05-16 18:45:47 +090053 return target->tid || target->pid || target->uid_str;
Namhyung Kimd67356e2012-05-07 14:09:03 +090054}
55
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030056static inline bool target__has_cpu(struct target *target)
Namhyung Kimd67356e2012-05-07 14:09:03 +090057{
Namhyung Kimaa22dd42012-05-16 18:45:47 +090058 return target->system_wide || target->cpu_list;
Namhyung Kimd67356e2012-05-07 14:09:03 +090059}
60
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030061static inline bool target__none(struct target *target)
Namhyung Kimd67356e2012-05-07 14:09:03 +090062{
Arnaldo Carvalho de Melo602ad872013-11-12 16:46:16 -030063 return !target__has_task(target) && !target__has_cpu(target);
Namhyung Kimd67356e2012-05-07 14:09:03 +090064}
65
Dongsheng Yang9c105fb2013-12-04 17:56:40 -050066static inline bool target__uses_dummy_map(struct target *target)
67{
68 bool use_dummy = false;
69
70 if (target->default_per_cpu)
71 use_dummy = target->per_thread ? true : false;
72 else if (target__has_task(target) ||
73 (!target__has_cpu(target) && !target->uses_mmap))
74 use_dummy = true;
75
76 return use_dummy;
77}
78
Namhyung Kim12864b32012-04-26 14:15:22 +090079#endif /* _PERF_TARGET_H */