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