Helper to backtrace a user context
[akaros.git] / kern / include / kdebug.h
1 #ifndef ROS_KERN_KDEBUG_H
2 #define ROS_KERN_KDEBUG_H
3
4 #include <ros/common.h>
5 #include <ros/trapframe.h>
6 #include <arch/kdebug.h>
7
8 struct symtab_entry {
9         char *name;
10         uintptr_t addr;
11 };
12
13 void backtrace(void);
14 void backtrace_frame(uintptr_t pc, uintptr_t fp);
15 size_t backtrace_list(uintptr_t pc, uintptr_t fp, uintptr_t *pcs,
16                       size_t nr_slots);
17 void backtrace_kframe(struct hw_trapframe *hw_tf);
18 /* for includes */ struct proc;
19 void backtrace_user_ctx(struct proc *p, struct user_context *ctx);
20
21 /* Arch dependent, listed here for ease-of-use */
22 static inline uintptr_t get_caller_pc(void);
23
24 /* Returns a null-terminated string with the function name for a given PC /
25  * instruction pointer.  kfree() the result. */
26 char *get_fn_name(uintptr_t pc);
27
28 /* Returns the address of sym, or 0 if it does not exist */
29 uintptr_t get_symbol_addr(char *sym);
30
31 /* For a poor-mans function tracer (can add these with spatch) */
32 void __print_func_entry(const char *func, const char *file);
33 void __print_func_exit(const char *func, const char *file);
34 #define print_func_entry() __print_func_entry(__FUNCTION__, __FILE__)
35 #define print_func_exit() __print_func_exit(__FUNCTION__, __FILE__)
36 void hexdump(void *v, int length);
37 void pahexdump(uintptr_t pa, int length);
38 int printdump(char *buf, int buflen, uint8_t *data);
39
40 extern bool printx_on;
41 void set_printx(int mode);
42 #define printx(args...) if (printx_on) printk(args)
43 #define trace_printx(args...) if (printx_on) trace_printk(args)
44
45 #include <oprofile.h>
46 #define TRACEME() oprofile_add_backtrace(read_pc(), read_bp())
47
48 void debug_addr_proc(struct proc *p, unsigned long addr);
49 void debug_addr_pid(int pid, unsigned long addr);
50
51 #endif /* ROS_KERN_KDEBUG_H */