| /* |
| * call-path.h: Manipulate a tree data structure containing function call paths |
| * Copyright (c) 2014, Intel Corporation. |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms and conditions of the GNU General Public License, |
| * version 2, as published by the Free Software Foundation. |
| * |
| * This program is distributed in the hope it will be useful, but WITHOUT |
| * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
| * more details. |
| * |
| */ |
| |
| #ifndef __PERF_CALL_PATH_H |
| #define __PERF_CALL_PATH_H |
| |
| #include <sys/types.h> |
| |
| #include <linux/types.h> |
| #include <linux/rbtree.h> |
| |
| /** |
| * struct call_path - node in list of calls leading to a function call. |
| * @parent: call path to the parent function call |
| * @sym: symbol of function called |
| * @ip: only if sym is null, the ip of the function |
| * @db_id: id used for db-export |
| * @in_kernel: whether function is a in the kernel |
| * @rb_node: node in parent's tree of called functions |
| * @children: tree of call paths of functions called |
| * |
| * In combination with the call_return structure, the call_path structure |
| * defines a context-sensitve call-graph. |
| */ |
| struct call_path { |
| struct call_path *parent; |
| struct symbol *sym; |
| u64 ip; |
| u64 db_id; |
| bool in_kernel; |
| struct rb_node rb_node; |
| struct rb_root children; |
| }; |
| |
| #define CALL_PATH_BLOCK_SHIFT 8 |
| #define CALL_PATH_BLOCK_SIZE (1 << CALL_PATH_BLOCK_SHIFT) |
| #define CALL_PATH_BLOCK_MASK (CALL_PATH_BLOCK_SIZE - 1) |
| |
| struct call_path_block { |
| struct call_path cp[CALL_PATH_BLOCK_SIZE]; |
| struct list_head node; |
| }; |
| |
| /** |
| * struct call_path_root - root of all call paths. |
| * @call_path: root call path |
| * @blocks: list of blocks to store call paths |
| * @next: next free space |
| * @sz: number of spaces |
| */ |
| struct call_path_root { |
| struct call_path call_path; |
| struct list_head blocks; |
| size_t next; |
| size_t sz; |
| }; |
| |
| struct call_path_root *call_path_root__new(void); |
| void call_path_root__free(struct call_path_root *cpr); |
| |
| struct call_path *call_path__findnew(struct call_path_root *cpr, |
| struct call_path *parent, |
| struct symbol *sym, u64 ip, u64 ks); |
| |
| #endif |