hc
2023-11-07 f45e756958099c35d6afb746df1d40a1c6302cfc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __PERF_THREAD_MAP_H
#define __PERF_THREAD_MAP_H
 
#include <sys/types.h>
#include <stdio.h>
#include <linux/refcount.h>
 
struct thread_map_data {
   pid_t    pid;
   char    *comm;
};
 
struct thread_map {
   refcount_t refcnt;
   int nr;
   int err_thread;
   struct thread_map_data map[];
};
 
struct thread_map_event;
 
struct thread_map *thread_map__new_dummy(void);
struct thread_map *thread_map__new_by_pid(pid_t pid);
struct thread_map *thread_map__new_by_tid(pid_t tid);
struct thread_map *thread_map__new_by_uid(uid_t uid);
struct thread_map *thread_map__new_all_cpus(void);
struct thread_map *thread_map__new(pid_t pid, pid_t tid, uid_t uid);
struct thread_map *thread_map__new_event(struct thread_map_event *event);
 
struct thread_map *thread_map__get(struct thread_map *map);
void thread_map__put(struct thread_map *map);
 
struct thread_map *thread_map__new_str(const char *pid,
       const char *tid, uid_t uid, bool all_threads);
 
struct thread_map *thread_map__new_by_tid_str(const char *tid_str);
 
size_t thread_map__fprintf(struct thread_map *threads, FILE *fp);
 
static inline int thread_map__nr(struct thread_map *threads)
{
   return threads ? threads->nr : 1;
}
 
static inline pid_t thread_map__pid(struct thread_map *map, int thread)
{
   return map->map[thread].pid;
}
 
static inline void
thread_map__set_pid(struct thread_map *map, int thread, pid_t pid)
{
   map->map[thread].pid = pid;
}
 
static inline char *thread_map__comm(struct thread_map *map, int thread)
{
   return map->map[thread].comm;
}
 
void thread_map__read_comms(struct thread_map *threads);
bool thread_map__has(struct thread_map *threads, pid_t pid);
int thread_map__remove(struct thread_map *threads, int idx);
#endif    /* __PERF_THREAD_MAP_H */