-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6: sparc64: Handle stack trace attempts before irqstacks are setup. sparc64: Implement IRQ stacks. sparc: remove include of linux/of_device.h from asm/of_device.h sparc64: Fix recursion in stack overflow detection handling. sparc/drivers: use linux/of_device.h instead of asm/of_device.h sparc64: Don't MAGIC_SYSRQ ifdef smp_fetch_global_regs and support code.
- Loading branch information
Showing
17 changed files
with
186 additions
and
49 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
#ifndef _KSTACK_H | ||
#define _KSTACK_H | ||
|
||
#include <linux/thread_info.h> | ||
#include <linux/sched.h> | ||
#include <asm/ptrace.h> | ||
#include <asm/irq.h> | ||
|
||
/* SP must be STACK_BIAS adjusted already. */ | ||
static inline bool kstack_valid(struct thread_info *tp, unsigned long sp) | ||
{ | ||
unsigned long base = (unsigned long) tp; | ||
|
||
if (sp >= (base + sizeof(struct thread_info)) && | ||
sp <= (base + THREAD_SIZE - sizeof(struct sparc_stackf))) | ||
return true; | ||
|
||
if (hardirq_stack[tp->cpu]) { | ||
base = (unsigned long) hardirq_stack[tp->cpu]; | ||
if (sp >= base && | ||
sp <= (base + THREAD_SIZE - sizeof(struct sparc_stackf))) | ||
return true; | ||
base = (unsigned long) softirq_stack[tp->cpu]; | ||
if (sp >= base && | ||
sp <= (base + THREAD_SIZE - sizeof(struct sparc_stackf))) | ||
return true; | ||
} | ||
return false; | ||
} | ||
|
||
/* Does "regs" point to a valid pt_regs trap frame? */ | ||
static inline bool kstack_is_trap_frame(struct thread_info *tp, struct pt_regs *regs) | ||
{ | ||
unsigned long base = (unsigned long) tp; | ||
unsigned long addr = (unsigned long) regs; | ||
|
||
if (addr >= base && | ||
addr <= (base + THREAD_SIZE - sizeof(*regs))) | ||
goto check_magic; | ||
|
||
if (hardirq_stack[tp->cpu]) { | ||
base = (unsigned long) hardirq_stack[tp->cpu]; | ||
if (addr >= base && | ||
addr <= (base + THREAD_SIZE - sizeof(*regs))) | ||
goto check_magic; | ||
base = (unsigned long) softirq_stack[tp->cpu]; | ||
if (addr >= base && | ||
addr <= (base + THREAD_SIZE - sizeof(*regs))) | ||
goto check_magic; | ||
} | ||
return false; | ||
|
||
check_magic: | ||
if ((regs->magic & ~0x1ff) == PT_REGS_MAGIC) | ||
return true; | ||
return false; | ||
|
||
} | ||
|
||
#endif /* _KSTACK_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.