| /* | 
 |  * 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 |