diff options
Diffstat (limited to 'arch/m68knommu/platform/coldfire/entry.S')
-rw-r--r-- | arch/m68knommu/platform/coldfire/entry.S | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/arch/m68knommu/platform/coldfire/entry.S b/arch/m68knommu/platform/coldfire/entry.S index 111b66dc737..1e3c0dcbd7a 100644 --- a/arch/m68knommu/platform/coldfire/entry.S +++ b/arch/m68knommu/platform/coldfire/entry.S | |||
@@ -103,9 +103,26 @@ ret_from_signal: | |||
103 | addql #4,%sp | 103 | addql #4,%sp |
104 | 104 | ||
105 | ret_from_exception: | 105 | ret_from_exception: |
106 | move #0x2700,%sr /* disable intrs */ | ||
106 | btst #5,%sp@(PT_SR) /* check if returning to kernel */ | 107 | btst #5,%sp@(PT_SR) /* check if returning to kernel */ |
107 | jeq Luser_return /* if so, skip resched, signals */ | 108 | jeq Luser_return /* if so, skip resched, signals */ |
108 | 109 | ||
110 | #ifdef CONFIG_PREEMPT | ||
111 | movel %sp,%d1 /* get thread_info pointer */ | ||
112 | andl #-THREAD_SIZE,%d1 /* at base of kernel stack */ | ||
113 | movel %d1,%a0 | ||
114 | movel %a0@(TI_FLAGS),%d1 /* get thread_info->flags */ | ||
115 | andl #_TIF_NEED_RESCHED,%d1 | ||
116 | jeq Lkernel_return | ||
117 | |||
118 | movel %a0@(TI_PREEMPTCOUNT),%d1 | ||
119 | cmpl #0,%d1 | ||
120 | jne Lkernel_return | ||
121 | |||
122 | pea Lkernel_return | ||
123 | jmp preempt_schedule_irq /* preempt the kernel */ | ||
124 | #endif | ||
125 | |||
109 | Lkernel_return: | 126 | Lkernel_return: |
110 | moveml %sp@,%d1-%d5/%a0-%a2 | 127 | moveml %sp@,%d1-%d5/%a0-%a2 |
111 | lea %sp@(32),%sp /* space for 8 regs */ | 128 | lea %sp@(32),%sp /* space for 8 regs */ |
@@ -140,6 +157,7 @@ Lreturn: | |||
140 | 157 | ||
141 | Lwork_to_do: | 158 | Lwork_to_do: |
142 | movel %a0@(TI_FLAGS),%d1 /* get thread_info->flags */ | 159 | movel %a0@(TI_FLAGS),%d1 /* get thread_info->flags */ |
160 | move #0x2000,%sr /* enable intrs again */ | ||
143 | btst #TIF_NEED_RESCHED,%d1 | 161 | btst #TIF_NEED_RESCHED,%d1 |
144 | jne reschedule | 162 | jne reschedule |
145 | 163 | ||