2010-05-20 03:35:17 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 1991, 1992 Linus Torvalds
|
|
|
|
* Copyright (C) 2000, 2001, 2002 Andi Kleen, SuSE Labs
|
|
|
|
*/
|
|
|
|
|
2008-10-23 13:26:29 +08:00
|
|
|
#ifndef _ASM_X86_STACKTRACE_H
|
|
|
|
#define _ASM_X86_STACKTRACE_H
|
2006-09-26 16:52:34 +08:00
|
|
|
|
2010-05-20 03:35:17 +08:00
|
|
|
#include <linux/uaccess.h>
|
|
|
|
|
2006-12-07 09:14:11 +08:00
|
|
|
extern int kstack_depth_to_print;
|
|
|
|
|
2009-12-17 12:40:33 +08:00
|
|
|
struct thread_info;
|
|
|
|
struct stacktrace_ops;
|
|
|
|
|
|
|
|
typedef unsigned long (*walk_stack_t)(struct thread_info *tinfo,
|
|
|
|
unsigned long *stack,
|
|
|
|
unsigned long bp,
|
|
|
|
const struct stacktrace_ops *ops,
|
|
|
|
void *data,
|
|
|
|
unsigned long *end,
|
|
|
|
int *graph);
|
|
|
|
|
|
|
|
extern unsigned long
|
|
|
|
print_context_stack(struct thread_info *tinfo,
|
|
|
|
unsigned long *stack, unsigned long bp,
|
|
|
|
const struct stacktrace_ops *ops, void *data,
|
|
|
|
unsigned long *end, int *graph);
|
|
|
|
|
2009-12-17 12:40:34 +08:00
|
|
|
extern unsigned long
|
|
|
|
print_context_stack_bp(struct thread_info *tinfo,
|
|
|
|
unsigned long *stack, unsigned long bp,
|
|
|
|
const struct stacktrace_ops *ops, void *data,
|
|
|
|
unsigned long *end, int *graph);
|
|
|
|
|
2006-09-26 16:52:34 +08:00
|
|
|
/* Generic stack tracer with callbacks */
|
|
|
|
|
|
|
|
struct stacktrace_ops {
|
|
|
|
void (*warning)(void *data, char *msg);
|
|
|
|
/* msg must contain %s for the symbol */
|
|
|
|
void (*warning_symbol)(void *data, char *msg, unsigned long symbol);
|
2008-01-30 20:33:07 +08:00
|
|
|
void (*address)(void *data, unsigned long address, int reliable);
|
2006-09-26 16:52:34 +08:00
|
|
|
/* On negative return stop dumping */
|
|
|
|
int (*stack)(void *data, char *name);
|
2009-12-17 12:40:33 +08:00
|
|
|
walk_stack_t walk_stack;
|
2006-09-26 16:52:34 +08:00
|
|
|
};
|
|
|
|
|
2008-01-30 20:33:07 +08:00
|
|
|
void dump_trace(struct task_struct *tsk, struct pt_regs *regs,
|
|
|
|
unsigned long *stack, unsigned long bp,
|
2007-10-18 00:04:37 +08:00
|
|
|
const struct stacktrace_ops *ops, void *data);
|
2006-09-26 16:52:34 +08:00
|
|
|
|
2010-05-20 03:35:17 +08:00
|
|
|
#ifdef CONFIG_X86_32
|
|
|
|
#define STACKSLOTS_PER_LINE 8
|
|
|
|
#define get_bp(bp) asm("movl %%ebp, %0" : "=r" (bp) :)
|
|
|
|
#else
|
|
|
|
#define STACKSLOTS_PER_LINE 4
|
|
|
|
#define get_bp(bp) asm("movq %%rbp, %0" : "=r" (bp) :)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
extern void
|
|
|
|
show_trace_log_lvl(struct task_struct *task, struct pt_regs *regs,
|
|
|
|
unsigned long *stack, unsigned long bp, char *log_lvl);
|
|
|
|
|
|
|
|
extern void
|
|
|
|
show_stack_log_lvl(struct task_struct *task, struct pt_regs *regs,
|
|
|
|
unsigned long *sp, unsigned long bp, char *log_lvl);
|
|
|
|
|
|
|
|
extern unsigned int code_bytes;
|
|
|
|
|
|
|
|
/* The form of the top of the frame on the stack */
|
|
|
|
struct stack_frame {
|
|
|
|
struct stack_frame *next_frame;
|
|
|
|
unsigned long return_address;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct stack_frame_ia32 {
|
|
|
|
u32 next_frame;
|
|
|
|
u32 return_address;
|
|
|
|
};
|
|
|
|
|
2010-05-20 13:47:21 +08:00
|
|
|
static inline unsigned long caller_frame_pointer(void)
|
2010-05-20 03:35:17 +08:00
|
|
|
{
|
|
|
|
struct stack_frame *frame;
|
|
|
|
|
|
|
|
get_bp(frame);
|
|
|
|
|
|
|
|
#ifdef CONFIG_FRAME_POINTER
|
2010-05-20 13:47:21 +08:00
|
|
|
frame = frame->next_frame;
|
2010-05-20 03:35:17 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
return (unsigned long)frame;
|
|
|
|
}
|
|
|
|
|
2008-10-23 13:26:29 +08:00
|
|
|
#endif /* _ASM_X86_STACKTRACE_H */
|