提交 dc66ff62 编写于 作者: R Roel Kluin 提交者: Paul Mundt

SH: fix start_thread and user_stack_pointer macros

Fix macros start_thread and user_stack_pointer.
When these macros aren't called with a variable named regs as second
argument, this will result in a build failure.
Signed-off-by: NRoel Kluin <roel.kluin@gmail.com>
Signed-off-by: NPaul Mundt <lethal@linux-sh.org>
上级 84fdf6cd
...@@ -16,7 +16,7 @@ typedef u16 kprobe_opcode_t; ...@@ -16,7 +16,7 @@ typedef u16 kprobe_opcode_t;
? (MAX_STACK_SIZE) \ ? (MAX_STACK_SIZE) \
: (((unsigned long)current_thread_info()) + THREAD_SIZE - (ADDR))) : (((unsigned long)current_thread_info()) + THREAD_SIZE - (ADDR)))
#define regs_return_value(regs) ((regs)->regs[0]) #define regs_return_value(_regs) ((_regs)->regs[0])
#define flush_insn_slot(p) do { } while (0) #define flush_insn_slot(p) do { } while (0)
#define kretprobe_blacklist_size 0 #define kretprobe_blacklist_size 0
......
...@@ -108,12 +108,12 @@ extern int ubc_usercnt; ...@@ -108,12 +108,12 @@ extern int ubc_usercnt;
/* /*
* Do necessary setup to start up a newly executed thread. * Do necessary setup to start up a newly executed thread.
*/ */
#define start_thread(regs, new_pc, new_sp) \ #define start_thread(_regs, new_pc, new_sp) \
set_fs(USER_DS); \ set_fs(USER_DS); \
regs->pr = 0; \ _regs->pr = 0; \
regs->sr = SR_FD; /* User mode. */ \ _regs->sr = SR_FD; /* User mode. */ \
regs->pc = new_pc; \ _regs->pc = new_pc; \
regs->regs[15] = new_sp _regs->regs[15] = new_sp
/* Forward declaration, a strange C thing */ /* Forward declaration, a strange C thing */
struct task_struct; struct task_struct;
...@@ -189,7 +189,7 @@ extern unsigned long get_wchan(struct task_struct *p); ...@@ -189,7 +189,7 @@ extern unsigned long get_wchan(struct task_struct *p);
#define KSTK_EIP(tsk) (task_pt_regs(tsk)->pc) #define KSTK_EIP(tsk) (task_pt_regs(tsk)->pc)
#define KSTK_ESP(tsk) (task_pt_regs(tsk)->regs[15]) #define KSTK_ESP(tsk) (task_pt_regs(tsk)->regs[15])
#define user_stack_pointer(regs) ((regs)->regs[15]) #define user_stack_pointer(_regs) ((_regs)->regs[15])
#if defined(CONFIG_CPU_SH2A) || defined(CONFIG_CPU_SH3) || \ #if defined(CONFIG_CPU_SH2A) || defined(CONFIG_CPU_SH3) || \
defined(CONFIG_CPU_SH4) defined(CONFIG_CPU_SH4)
......
...@@ -145,13 +145,13 @@ struct thread_struct { ...@@ -145,13 +145,13 @@ struct thread_struct {
*/ */
#define SR_USER (SR_MMU | SR_FD) #define SR_USER (SR_MMU | SR_FD)
#define start_thread(regs, new_pc, new_sp) \ #define start_thread(_regs, new_pc, new_sp) \
set_fs(USER_DS); \ set_fs(USER_DS); \
regs->sr = SR_USER; /* User mode. */ \ _regs->sr = SR_USER; /* User mode. */ \
regs->pc = new_pc - 4; /* Compensate syscall exit */ \ _regs->pc = new_pc - 4; /* Compensate syscall exit */ \
regs->pc |= 1; /* Set SHmedia ! */ \ _regs->pc |= 1; /* Set SHmedia ! */ \
regs->regs[18] = 0; \ _regs->regs[18] = 0; \
regs->regs[15] = new_sp _regs->regs[15] = new_sp
/* Forward declaration, a strange C thing */ /* Forward declaration, a strange C thing */
struct task_struct; struct task_struct;
...@@ -226,7 +226,7 @@ extern unsigned long get_wchan(struct task_struct *p); ...@@ -226,7 +226,7 @@ extern unsigned long get_wchan(struct task_struct *p);
#define KSTK_EIP(tsk) ((tsk)->thread.pc) #define KSTK_EIP(tsk) ((tsk)->thread.pc)
#define KSTK_ESP(tsk) ((tsk)->thread.sp) #define KSTK_ESP(tsk) ((tsk)->thread.sp)
#define user_stack_pointer(regs) ((regs)->regs[15]) #define user_stack_pointer(_regs) ((_regs)->regs[15])
#endif /* __ASSEMBLY__ */ #endif /* __ASSEMBLY__ */
#endif /* __ASM_SH_PROCESSOR_64_H */ #endif /* __ASM_SH_PROCESSOR_64_H */
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册