1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef __PERF_THREAD_H
3 #define __PERF_THREAD_H
5 #include <linux/refcount.h>
6 #include <linux/rbtree.h>
7 #include <linux/list.h>
10 #include <sys/types.h>
12 #include "symbol_conf.h"
17 #include "callchain.h"
21 struct perf_record_namespaces
;
23 struct unwind_libunwind_ops
;
26 struct list_head lists
;
27 struct list_head free_lists
;
28 struct perf_sample prev_sample
;
29 struct callchain_cursor_node
*prev_lbr_cursor
;
34 struct rb_node rb_node
;
35 struct list_head node
;
38 pid_t pid_
; /* Not all tools update this */
45 bool dead
; /* if set thread has exited */
46 struct list_head namespaces_list
;
47 struct rw_semaphore namespaces_lock
;
48 struct list_head comm_list
;
49 struct rw_semaphore comm_lock
;
53 struct thread_stack
*ts
;
54 struct nsinfo
*nsinfo
;
55 struct srccode_state srccode_state
;
57 int filter_entry_depth
;
59 /* LBR call stack stitch */
60 bool lbr_stitch_enable
;
61 struct lbr_stitch
*lbr_stitch
;
68 struct thread
*thread__new(pid_t pid
, pid_t tid
);
69 int thread__init_maps(struct thread
*thread
, struct machine
*machine
);
70 void thread__delete(struct thread
*thread
);
72 struct thread
*thread__get(struct thread
*thread
);
73 void thread__put(struct thread
*thread
);
75 static inline void __thread__zput(struct thread
**thread
)
81 #define thread__zput(thread) __thread__zput(&thread)
83 static inline void thread__exited(struct thread
*thread
)
88 struct namespaces
*thread__namespaces(struct thread
*thread
);
89 int thread__set_namespaces(struct thread
*thread
, u64 timestamp
,
90 struct perf_record_namespaces
*event
);
92 int __thread__set_comm(struct thread
*thread
, const char *comm
, u64 timestamp
,
94 static inline int thread__set_comm(struct thread
*thread
, const char *comm
,
97 return __thread__set_comm(thread
, comm
, timestamp
, false);
100 int thread__set_comm_from_proc(struct thread
*thread
);
102 int thread__comm_len(struct thread
*thread
);
103 struct comm
*thread__comm(const struct thread
*thread
);
104 struct comm
*thread__exec_comm(const struct thread
*thread
);
105 const char *thread__comm_str(struct thread
*thread
);
106 int thread__insert_map(struct thread
*thread
, struct map
*map
);
107 int thread__fork(struct thread
*thread
, struct thread
*parent
, u64 timestamp
, bool do_maps_clone
);
108 size_t thread__fprintf(struct thread
*thread
, FILE *fp
);
110 struct thread
*thread__main_thread(struct machine
*machine
, struct thread
*thread
);
112 struct map
*thread__find_map(struct thread
*thread
, u8 cpumode
, u64 addr
,
113 struct addr_location
*al
);
114 struct map
*thread__find_map_fb(struct thread
*thread
, u8 cpumode
, u64 addr
,
115 struct addr_location
*al
);
117 struct symbol
*thread__find_symbol(struct thread
*thread
, u8 cpumode
,
118 u64 addr
, struct addr_location
*al
);
119 struct symbol
*thread__find_symbol_fb(struct thread
*thread
, u8 cpumode
,
120 u64 addr
, struct addr_location
*al
);
122 void thread__find_cpumode_addr_location(struct thread
*thread
, u64 addr
,
123 struct addr_location
*al
);
125 int thread__memcpy(struct thread
*thread
, struct machine
*machine
,
126 void *buf
, u64 ip
, int len
, bool *is64bit
);
128 static inline void *thread__priv(struct thread
*thread
)
133 static inline void thread__set_priv(struct thread
*thread
, void *p
)
138 static inline bool thread__is_filtered(struct thread
*thread
)
140 if (symbol_conf
.comm_list
&&
141 !strlist__has_entry(symbol_conf
.comm_list
, thread__comm_str(thread
))) {
145 if (symbol_conf
.pid_list
&&
146 !intlist__has_entry(symbol_conf
.pid_list
, thread
->pid_
)) {
150 if (symbol_conf
.tid_list
&&
151 !intlist__has_entry(symbol_conf
.tid_list
, thread
->tid
)) {
158 void thread__free_stitch_list(struct thread
*thread
);
160 #endif /* __PERF_THREAD_H */