Linux Perf
call-path.h
Go to the documentation of this file.
1 /*
2  * call-path.h: Manipulate a tree data structure containing function call paths
3  * Copyright (c) 2014, Intel Corporation.
4  *
5  * This program is free software; you can redistribute it and/or modify it
6  * under the terms and conditions of the GNU General Public License,
7  * version 2, as published by the Free Software Foundation.
8  *
9  * This program is distributed in the hope it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12  * more details.
13  *
14  */
15 
16 #ifndef __PERF_CALL_PATH_H
17 #define __PERF_CALL_PATH_H
18 
19 #include <sys/types.h>
20 
21 #include <linux/types.h>
22 #include <linux/rbtree.h>
23 
37 struct call_path {
38  struct call_path *parent;
39  struct symbol *sym;
40  u64 ip;
41  u64 db_id;
42  bool in_kernel;
43  struct rb_node rb_node;
44  struct rb_root children;
45 };
46 
47 #define CALL_PATH_BLOCK_SHIFT 8
48 #define CALL_PATH_BLOCK_SIZE (1 << CALL_PATH_BLOCK_SHIFT)
49 #define CALL_PATH_BLOCK_MASK (CALL_PATH_BLOCK_SIZE - 1)
50 
53  struct list_head node;
54 };
55 
65  struct list_head blocks;
66  size_t next;
67  size_t sz;
68 };
69 
71 void call_path_root__free(struct call_path_root *cpr);
72 
73 struct call_path *call_path__findnew(struct call_path_root *cpr,
74  struct call_path *parent,
75  struct symbol *sym, u64 ip, u64 ks);
76 
77 #endif
struct call_path * call_path__findnew(struct call_path_root *cpr, struct call_path *parent, struct symbol *sym, u64 ip, u64 ks)
Definition: call-path.c:85
struct call_path_root * call_path_root__new(void)
Definition: call-path.c:34
Definition: mem2node.c:7
struct rb_root children
Definition: call-path.h:44
struct rb_node rb_node
Definition: call-path.h:43
void call_path_root__free(struct call_path_root *cpr)
Definition: call-path.c:46
u64 db_id
Definition: call-path.h:41
struct call_path * parent
Definition: call-path.h:38
bool in_kernel
Definition: call-path.h:42
u64 blocks
Definition: block-range.c:7
size_t next
Definition: call-path.h:66
struct symbol * sym
Definition: call-path.h:39
Definition: symbol.h:55
#define CALL_PATH_BLOCK_SIZE
Definition: call-path.h:48
u64 ip
Definition: call-path.h:40