~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/tools/perf/util/target.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef _PERF_TARGET_H
  3 #define _PERF_TARGET_H
  4 
  5 #include <stdbool.h>
  6 #include <sys/types.h>
  7 
  8 struct target {
  9         const char   *pid;
 10         const char   *tid;
 11         const char   *cpu_list;
 12         const char   *uid_str;
 13         const char   *bpf_str;
 14         uid_t        uid;
 15         bool         system_wide;
 16         bool         uses_mmap;
 17         bool         default_per_cpu;
 18         bool         per_thread;
 19         bool         use_bpf;
 20         int          initial_delay;
 21         const char   *attr_map;
 22 };
 23 
 24 enum target_errno {
 25         TARGET_ERRNO__SUCCESS           = 0,
 26 
 27         /*
 28          * Choose an arbitrary negative big number not to clash with standard
 29          * errno since SUS requires the errno has distinct positive values.
 30          * See 'Issue 6' in the link below.
 31          *
 32          * http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/errno.h.html
 33          */
 34         __TARGET_ERRNO__START           = -10000,
 35 
 36         /* for target__validate() */
 37         TARGET_ERRNO__PID_OVERRIDE_CPU  = __TARGET_ERRNO__START,
 38         TARGET_ERRNO__PID_OVERRIDE_UID,
 39         TARGET_ERRNO__UID_OVERRIDE_CPU,
 40         TARGET_ERRNO__PID_OVERRIDE_SYSTEM,
 41         TARGET_ERRNO__UID_OVERRIDE_SYSTEM,
 42         TARGET_ERRNO__SYSTEM_OVERRIDE_THREAD,
 43         TARGET_ERRNO__BPF_OVERRIDE_CPU,
 44         TARGET_ERRNO__BPF_OVERRIDE_PID,
 45         TARGET_ERRNO__BPF_OVERRIDE_UID,
 46         TARGET_ERRNO__BPF_OVERRIDE_THREAD,
 47 
 48         /* for target__parse_uid() */
 49         TARGET_ERRNO__INVALID_UID,
 50         TARGET_ERRNO__USER_NOT_FOUND,
 51 
 52         __TARGET_ERRNO__END,
 53 };
 54 
 55 enum target_errno target__validate(struct target *target);
 56 enum target_errno target__parse_uid(struct target *target);
 57 
 58 int target__strerror(struct target *target, int errnum, char *buf, size_t buflen);
 59 
 60 static inline bool target__has_task(struct target *target)
 61 {
 62         return target->tid || target->pid || target->uid_str;
 63 }
 64 
 65 static inline bool target__has_cpu(struct target *target)
 66 {
 67         return target->system_wide || target->cpu_list;
 68 }
 69 
 70 static inline bool target__none(struct target *target)
 71 {
 72         return !target__has_task(target) && !target__has_cpu(target);
 73 }
 74 
 75 static inline bool target__enable_on_exec(struct target *target)
 76 {
 77         /*
 78          * Normally enable_on_exec should be set if:
 79          *  1) The tracee process is forked (not attaching to existed task or cpu).
 80          *  2) And initial_delay is not configured.
 81          * Otherwise, we enable tracee events manually.
 82          */
 83         return target__none(target) && !target->initial_delay;
 84 }
 85 
 86 static inline bool target__has_per_thread(struct target *target)
 87 {
 88         return target->system_wide && target->per_thread;
 89 }
 90 
 91 static inline bool target__uses_dummy_map(struct target *target)
 92 {
 93         bool use_dummy = false;
 94 
 95         if (target->default_per_cpu)
 96                 use_dummy = target->per_thread ? true : false;
 97         else if (target__has_task(target) ||
 98                  (!target__has_cpu(target) && !target->uses_mmap))
 99                 use_dummy = true;
100         else if (target__has_per_thread(target))
101                 use_dummy = true;
102 
103         return use_dummy;
104 }
105 
106 #endif /* _PERF_TARGET_H */
107 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php