blob: 20b96b5d1f1593117225ec93c376596377e38e17 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
John Kacur8b40f522009-09-24 18:02:18 +02002#ifndef __PERF_THREAD_H
3#define __PERF_THREAD_H
4
Elena Reshetovae34f5b12017-02-21 17:35:02 +02005#include <linux/refcount.h>
Frederic Weisbecker6baa0a52009-08-14 12:21:53 +02006#include <linux/rbtree.h>
Frederic Weisbecker1902efe2013-09-11 16:56:44 +02007#include <linux/list.h>
Arnaldo Carvalho de Meloe22c1c72019-01-28 00:07:40 +01008#include <stdio.h>
Frederic Weisbecker6baa0a52009-08-14 12:21:53 +02009#include <unistd.h>
Arnaldo Carvalho de Melo9d2f8e22012-10-06 15:43:20 -030010#include <sys/types.h>
Arnaldo Carvalho de Melo4fed0722019-01-27 11:31:39 +010011#include "srccode.h"
Arnaldo Carvalho de Meloe22c1c72019-01-28 00:07:40 +010012#include "symbol_conf.h"
David Ahern1f3878c2013-11-18 13:32:47 -070013#include <strlist.h>
David Aherne03eaa42015-03-24 09:52:41 -060014#include <intlist.h>
Kan Liangb32ee9e2017-09-29 07:47:52 -070015#include "rwsem.h"
Frederic Weisbecker6baa0a52009-08-14 12:21:53 +020016
Arnaldo Carvalho de Meloe22c1c72019-01-28 00:07:40 +010017struct addr_location;
18struct map;
Arnaldo Carvalho de Melo69d81f02019-08-26 19:02:31 -030019struct perf_record_namespaces;
Adrian Hunter00447cc2014-10-30 16:09:42 +020020struct thread_stack;
He Kuangf83c0412016-06-03 03:33:12 +000021struct unwind_libunwind_ops;
Adrian Hunter00447cc2014-10-30 16:09:42 +020022
Arnaldo Carvalho de Melo9958e1f2009-12-11 14:50:36 -020023struct thread {
Arnaldo Carvalho de Melo720a3ae2010-06-17 08:37:44 -030024 union {
25 struct rb_node rb_node;
26 struct list_head node;
27 };
Arnaldo Carvalho de Melofe877972019-11-25 22:07:43 -030028 struct maps *maps;
Adrian Hunter99d725f2013-08-26 16:00:19 +030029 pid_t pid_; /* Not all tools update this */
Adrian Hunter38051232013-07-04 16:20:31 +030030 pid_t tid;
David Ahern70c57ef2013-05-25 22:47:10 -060031 pid_t ppid;
Adrian Hunterbf49c352014-07-22 16:17:24 +030032 int cpu;
Elena Reshetovae34f5b12017-02-21 17:35:02 +020033 refcount_t refcnt;
Arnaldo Carvalho de Melofaa5c5c2010-02-19 23:02:07 -020034 bool comm_set;
Arnaldo Carvalho de Melo86066062015-05-15 17:29:56 -030035 int comm_len;
David Ahern236a3bb2013-08-14 08:49:27 -060036 bool dead; /* if set thread has exited */
Hari Bathinif3b36142017-03-08 02:11:43 +053037 struct list_head namespaces_list;
Kan Liangb32ee9e2017-09-29 07:47:52 -070038 struct rw_semaphore namespaces_lock;
Frederic Weisbecker1902efe2013-09-11 16:56:44 +020039 struct list_head comm_list;
Kan Liangb32ee9e2017-09-29 07:47:52 -070040 struct rw_semaphore comm_lock;
Adrian Hunter0db15b12014-10-23 13:45:13 +030041 u64 db_id;
Xiao Guangrongbcf6edc2012-09-17 16:31:15 +080042
43 void *priv;
Adrian Hunter00447cc2014-10-30 16:09:42 +020044 struct thread_stack *ts;
Krister Johansen843ff372017-07-05 18:48:08 -070045 struct nsinfo *nsinfo;
Andi Kleendd2e18e2018-12-03 16:18:48 -080046 struct srccode_state srccode_state;
Andi Kleen99f753f2018-09-20 11:05:39 -070047 bool filter;
48 int filter_entry_depth;
Frederic Weisbecker6baa0a52009-08-14 12:21:53 +020049};
50
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -020051struct machine;
Hari Bathinif3b36142017-03-08 02:11:43 +053052struct namespaces;
Namhyung Kim4dfced32013-09-13 16:28:57 +090053struct comm;
Arnaldo Carvalho de Melo4b8cf842010-03-25 19:58:58 -030054
Adrian Hunter99d725f2013-08-26 16:00:19 +030055struct thread *thread__new(pid_t pid, pid_t tid);
Arnaldo Carvalho de Melo79b6bb72019-11-25 21:58:33 -030056int thread__init_maps(struct thread *thread, struct machine *machine);
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030057void thread__delete(struct thread *thread);
Arnaldo Carvalho de Melof3b623b2015-03-02 22:21:35 -030058
59struct thread *thread__get(struct thread *thread);
60void thread__put(struct thread *thread);
61
62static inline void __thread__zput(struct thread **thread)
63{
64 thread__put(*thread);
65 *thread = NULL;
66}
67
68#define thread__zput(thread) __thread__zput(&thread)
69
David Ahern236a3bb2013-08-14 08:49:27 -060070static inline void thread__exited(struct thread *thread)
71{
72 thread->dead = true;
73}
Arnaldo Carvalho de Melo591765f2010-07-30 18:28:42 -030074
Namhyung Kim7cb10a082019-05-27 15:11:49 +090075struct namespaces *thread__namespaces(struct thread *thread);
Hari Bathinif3b36142017-03-08 02:11:43 +053076int thread__set_namespaces(struct thread *thread, u64 timestamp,
Arnaldo Carvalho de Melo69d81f02019-08-26 19:02:31 -030077 struct perf_record_namespaces *event);
Hari Bathinif3b36142017-03-08 02:11:43 +053078
Adrian Hunter65de51f2014-07-31 09:00:44 +030079int __thread__set_comm(struct thread *thread, const char *comm, u64 timestamp,
80 bool exec);
81static inline int thread__set_comm(struct thread *thread, const char *comm,
82 u64 timestamp)
83{
84 return __thread__set_comm(thread, comm, timestamp, false);
85}
86
Arnaldo Carvalho de Melo2f3027a2016-04-26 12:32:50 -030087int thread__set_comm_from_proc(struct thread *thread);
88
Arnaldo Carvalho de Melo316c7132013-11-05 15:32:36 -030089int thread__comm_len(struct thread *thread);
Namhyung Kim4dfced32013-09-13 16:28:57 +090090struct comm *thread__comm(const struct thread *thread);
Adrian Hunter65de51f2014-07-31 09:00:44 +030091struct comm *thread__exec_comm(const struct thread *thread);
Namhyung Kim7cb10a082019-05-27 15:11:49 +090092const char *thread__comm_str(struct thread *thread);
He Kuang8132a2a2016-06-03 03:33:13 +000093int thread__insert_map(struct thread *thread, struct map *map);
David Miller4f8f3822018-10-30 22:24:04 -070094int thread__fork(struct thread *thread, struct thread *parent, u64 timestamp, bool do_maps_clone);
Arnaldo Carvalho de Melo3f067dc2012-12-07 17:39:39 -030095size_t thread__fprintf(struct thread *thread, FILE *fp);
John Kacur8b40f522009-09-24 18:02:18 +020096
Andi Kleen480ca352016-05-23 17:52:24 -070097struct thread *thread__main_thread(struct machine *machine, struct thread *thread);
98
Arnaldo Carvalho de Melo404eb5a2018-04-26 09:34:37 -030099struct map *thread__find_map(struct thread *thread, u8 cpumode, u64 addr,
100 struct addr_location *al);
Adrian Hunter8e80ad92018-11-06 23:07:10 +0200101struct map *thread__find_map_fb(struct thread *thread, u8 cpumode, u64 addr,
102 struct addr_location *al);
Arnaldo Carvalho de Melo59ee68e2010-01-14 23:45:29 -0200103
Arnaldo Carvalho de Melo117d3c22018-04-25 18:16:53 -0300104struct symbol *thread__find_symbol(struct thread *thread, u8 cpumode,
105 u64 addr, struct addr_location *al);
Adrian Hunter8e80ad92018-11-06 23:07:10 +0200106struct symbol *thread__find_symbol_fb(struct thread *thread, u8 cpumode,
107 u64 addr, struct addr_location *al);
David Ahernba580412013-06-07 16:22:12 -0600108
Arnaldo Carvalho de Melo26bd9332018-04-25 17:58:03 -0300109void thread__find_cpumode_addr_location(struct thread *thread, u64 addr,
Arnaldo Carvalho de Melo52a3cb82014-03-11 16:16:49 -0300110 struct addr_location *al);
111
Andi Kleen15325932019-03-06 17:55:35 -0300112int thread__memcpy(struct thread *thread, struct machine *machine,
113 void *buf, u64 ip, int len, bool *is64bit);
114
David Ahernba580412013-06-07 16:22:12 -0600115static inline void *thread__priv(struct thread *thread)
116{
117 return thread->priv;
118}
119
120static inline void thread__set_priv(struct thread *thread, void *p)
121{
122 thread->priv = p;
123}
David Ahern1f3878c2013-11-18 13:32:47 -0700124
125static inline bool thread__is_filtered(struct thread *thread)
126{
127 if (symbol_conf.comm_list &&
128 !strlist__has_entry(symbol_conf.comm_list, thread__comm_str(thread))) {
129 return true;
130 }
131
David Aherne03eaa42015-03-24 09:52:41 -0600132 if (symbol_conf.pid_list &&
133 !intlist__has_entry(symbol_conf.pid_list, thread->pid_)) {
134 return true;
135 }
136
137 if (symbol_conf.tid_list &&
138 !intlist__has_entry(symbol_conf.tid_list, thread->tid)) {
139 return true;
140 }
141
David Ahern1f3878c2013-11-18 13:32:47 -0700142 return false;
143}
144
John Kacur8b40f522009-09-24 18:02:18 +0200145#endif /* __PERF_THREAD_H */