aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arc/include/asm/processor.h
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2014-06-09 21:05:11 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2014-06-09 21:05:11 -0400
commit9b651cc2277b5e4883012ebab0fea2bcda4cbafa (patch)
treedd6744f80a07f72876e9307d854700019255218e /arch/arc/include/asm/processor.h
parent214b93132023cc9305d5801add812515bea4d7d0 (diff)
parentef680cdc24376f394841a3f19b3a7ef6d57a009d (diff)
Merge tag 'arc-v3.16-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/vgupta/arc
Pull ARC updates from Vineet Gupta: "Nothing too exciting here, just minor fixes/cleanup. Only noteworthy ones are: - Moving cache disabling to early boot - ARC UART enabled only if earlyprintk setup in cmdline" * tag 'arc-v3.16-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/vgupta/arc: ARC: Disable caches in early boot if so configured ARC: [arcfpga] Early ARC UART to be only activated by cmdline ARC: [arcfpga] Get rid of legacy BVCI latency unit support ARC: remove duplicate header exports ARC: arc_local_timer_setup() need not pass own cpu id ARC: Fixed spelling errors within comments ARC: make start_thread() out-of-line ARC: fix mmuv2 warning ARC: [SMP] ISS SMP extension bitrot
Diffstat (limited to 'arch/arc/include/asm/processor.h')
-rw-r--r--arch/arc/include/asm/processor.h29
1 files changed, 4 insertions, 25 deletions
diff --git a/arch/arc/include/asm/processor.h b/arch/arc/include/asm/processor.h
index 15334ab66b56..d99f9b37cd15 100644
--- a/arch/arc/include/asm/processor.h
+++ b/arch/arc/include/asm/processor.h
@@ -18,7 +18,6 @@
18 18
19#ifndef __ASSEMBLY__ 19#ifndef __ASSEMBLY__
20 20
21#include <asm/arcregs.h> /* for STATUS_E1_MASK et all */
22#include <asm/ptrace.h> 21#include <asm/ptrace.h>
23 22
24/* Arch specific stuff which needs to be saved per task. 23/* Arch specific stuff which needs to be saved per task.
@@ -41,15 +40,13 @@ struct thread_struct {
41/* Forward declaration, a strange C thing */ 40/* Forward declaration, a strange C thing */
42struct task_struct; 41struct task_struct;
43 42
44/* 43/* Return saved PC of a blocked thread */
45 * Return saved PC of a blocked thread.
46 */
47unsigned long thread_saved_pc(struct task_struct *t); 44unsigned long thread_saved_pc(struct task_struct *t);
48 45
49#define task_pt_regs(p) \ 46#define task_pt_regs(p) \
50 ((struct pt_regs *)(THREAD_SIZE + (void *)task_stack_page(p)) - 1) 47 ((struct pt_regs *)(THREAD_SIZE + (void *)task_stack_page(p)) - 1)
51 48
52/* Free all resources held by a thread. */ 49/* Free all resources held by a thread */
53#define release_thread(thread) do { } while (0) 50#define release_thread(thread) do { } while (0)
54 51
55/* Prepare to copy thread state - unlazy all lazy status */ 52/* Prepare to copy thread state - unlazy all lazy status */
@@ -82,26 +79,8 @@ unsigned long thread_saved_pc(struct task_struct *t);
82#define KSTK_BLINK(tsk) KSTK_REG(tsk, 4) 79#define KSTK_BLINK(tsk) KSTK_REG(tsk, 4)
83#define KSTK_FP(tsk) KSTK_REG(tsk, 0) 80#define KSTK_FP(tsk) KSTK_REG(tsk, 0)
84 81
85/* 82extern void start_thread(struct pt_regs * regs, unsigned long pc,
86 * Do necessary setup to start up a newly executed thread. 83 unsigned long usp);
87 *
88 * E1,E2 so that Interrupts are enabled in user mode
89 * L set, so Loop inhibited to begin with
90 * lp_start and lp_end seeded with bogus non-zero values so to easily catch
91 * the ARC700 sr to lp_start hardware bug
92 */
93#define start_thread(_regs, _pc, _usp) \
94do { \
95 set_fs(USER_DS); /* reads from user space */ \
96 (_regs)->ret = (_pc); \
97 /* Interrupts enabled in User Mode */ \
98 (_regs)->status32 = STATUS_U_MASK | STATUS_L_MASK \
99 | STATUS_E1_MASK | STATUS_E2_MASK; \
100 (_regs)->sp = (_usp); \
101 /* bogus seed values for debugging */ \
102 (_regs)->lp_start = 0x10; \
103 (_regs)->lp_end = 0x80; \
104} while (0)
105 84
106extern unsigned int get_wchan(struct task_struct *p); 85extern unsigned int get_wchan(struct task_struct *p);
107 86