1 #ifndef __ASM_ARM_SYSTEM_H
 
   2 #define __ASM_ARM_SYSTEM_H
 
   6 #include <linux/config.h>
 
   9  * This is used to ensure the compiler did actually allocate the register we
 
  10  * asked it for some inline assembly sequences.  Apparently we can't trust
 
  11  * the compiler from one version to another so a bit of paranoia won't hurt.
 
  12  * This string is meant to be concatenated with the inline asm string and
 
  13  * will cause compilation to stop on mismatch. (From ARM32 - may come in handy)
 
  15 #define __asmeq(x, y)  ".ifnc " x "," y " ; .err ; .endif\n\t"
 
  19 #include <linux/linkage.h>
 
  25 /* information about the system we're running on */
 
  26 extern unsigned int system_rev;
 
  27 extern unsigned int system_serial_low;
 
  28 extern unsigned int system_serial_high;
 
  29 extern unsigned int mem_fclk_21285;
 
  33  * We need to turn the caches off before calling the reset vector - RiscOS
 
  34  * messes up if we don't
 
  36 #define proc_hard_reset()       cpu_proc_fin()
 
  42 void die(const char *msg, struct pt_regs *regs, int err)
 
  43                 __attribute__((noreturn));
 
  45 void die_if_kernel(const char *str, struct pt_regs *regs, int err);
 
  47 void hook_fault_code(int nr, int (*fn)(unsigned long, unsigned int,
 
  49                      int sig, const char *name);
 
  51 #include <asm/proc-fns.h>
 
  54         ((__typeof__(*(ptr)))__xchg((unsigned long)(x),(ptr),sizeof(*(ptr))))
 
  56 #define tas(ptr) (xchg((ptr),1))
 
  58 extern asmlinkage void __backtrace(void);
 
  61         __asm__ __volatile__(                           \
 
  62         "mcr    p15, 0, %0, c1, c0, 0   @ set CR"       \
 
  68         __asm__ __volatile__(                           \
 
  69         "mrc    p15, 0, %0, c1, c0, 0   @ get CR"       \
 
  70         : "=r" (__val) : : "cc");                       \
 
  74 extern unsigned long cr_no_alignment;   /* defined in entry-armv.S */
 
  75 extern unsigned long cr_alignment;      /* defined in entry-armv.S */
 
  77 #define UDBG_UNDEFINED  (1 << 0)
 
  78 #define UDBG_SYSCALL    (1 << 1)
 
  79 #define UDBG_BADABORT   (1 << 2)
 
  80 #define UDBG_SEGV       (1 << 3)
 
  81 #define UDBG_BUS        (1 << 4)
 
  83 extern unsigned int user_debug;
 
  85 #define vectors_base()  (0)
 
  87 #define mb() __asm__ __volatile__ ("" : : : "memory")
 
  90 #define nop() __asm__ __volatile__("mov\tr0,r0\t@ nop\n\t");
 
  92 #define read_barrier_depends() do { } while(0)
 
  93 #define set_mb(var, value)  do { var = value; mb(); } while (0)
 
  94 #define set_wmb(var, value) do { var = value; wmb(); } while (0)
 
  97  * We assume knowledge of how
 
  98  * spin_unlock_irq() and friends are implemented.  This avoids
 
  99  * us needlessly decrementing and incrementing the preempt count.
 
 101 #define prepare_arch_switch(next)       local_irq_enable()
 
 102 #define finish_arch_switch(prev)        spin_unlock(&(rq)->lock)
 
 105  * switch_to(prev, next) should switch from task `prev' to `next'
 
 106  * `prev' will never be the same as `next'.  schedule() itself
 
 107  * contains the memory barrier to tell GCC not to cache `current'.
 
 109 extern struct task_struct *__switch_to(struct task_struct *, struct thread_info *, struct thread_info *);
 
 111 #define switch_to(prev,next,last)                                       \
 
 113         last = __switch_to(prev,task_thread_info(prev),task_thread_info(next)); \
 
 117  * On SMP systems, when the scheduler does migration-cost autodetection,
 
 118  * it needs a way to flush as much of the CPU's caches as possible.
 
 120  * TODO: fill this in!
 
 122 static inline void sched_cacheflush(void)
 
 127  * Save the current interrupt enable state & disable IRQs
 
 129 #define local_irq_save(x)                               \
 
 131           unsigned long temp;                           \
 
 132           __asm__ __volatile__(                         \
 
 133 "       mov     %0, pc          @ save_flags_cli\n"     \
 
 134 "       orr     %1, %0, #0x08000000\n"                  \
 
 135 "       and     %0, %0, #0x0c000000\n"                  \
 
 137           : "=r" (x), "=r" (temp)                       \
 
 145 #define local_irq_enable()                                      \
 
 147           unsigned long temp;                   \
 
 148           __asm__ __volatile__(                 \
 
 149 "       mov     %0, pc          @ sti\n"        \
 
 150 "       bic     %0, %0, #0x08000000\n"          \
 
 160 #define local_irq_disable()                                     \
 
 162           unsigned long temp;                   \
 
 163           __asm__ __volatile__(                 \
 
 164 "       mov     %0, pc          @ cli\n"        \
 
 165 "       orr     %0, %0, #0x08000000\n"          \
 
 172 /* Enable FIQs (stf) */
 
 174 #define __stf() do {                            \
 
 175         unsigned long temp;                     \
 
 176         __asm__ __volatile__(                   \
 
 177 "       mov     %0, pc          @ stf\n"        \
 
 178 "       bic     %0, %0, #0x04000000\n"          \
 
 183 /* Disable FIQs  (clf) */
 
 185 #define __clf() do {                            \
 
 186         unsigned long temp;                     \
 
 187         __asm__ __volatile__(                   \
 
 188 "       mov     %0, pc          @ clf\n"        \
 
 189 "       orr     %0, %0, #0x04000000\n"          \
 
 196  * Save the current interrupt enable state.
 
 198 #define local_save_flags(x)                             \
 
 200           __asm__ __volatile__(                 \
 
 201 "       mov     %0, pc          @ save_flags\n" \
 
 202 "       and     %0, %0, #0x0c000000\n"          \
 
 208  * restore saved IRQ & FIQ state
 
 210 #define local_irq_restore(x)                            \
 
 212           unsigned long temp;                           \
 
 213           __asm__ __volatile__(                         \
 
 214 "       mov     %0, pc          @ restore_flags\n"      \
 
 215 "       bic     %0, %0, #0x0c000000\n"                  \
 
 216 "       orr     %0, %0, %1\n"                           \
 
 225 #error SMP not supported
 
 228 #define smp_mb()                barrier()
 
 229 #define smp_rmb()               barrier()
 
 230 #define smp_wmb()               barrier()
 
 231 #define smp_read_barrier_depends()              do { } while(0)
 
 233 #define clf()                   __clf()
 
 234 #define stf()                   __stf()
 
 236 #define irqs_disabled()                 \
 
 238         unsigned long flags;            \
 
 239         local_save_flags(flags);        \
 
 243 static inline unsigned long __xchg(unsigned long x, volatile void *ptr, int size)
 
 245         extern void __bad_xchg(volatile void *, int);
 
 248                 case 1: return cpu_xchg_1(x, ptr);
 
 249                 case 4: return cpu_xchg_4(x, ptr);
 
 250                 default: __bad_xchg(ptr, size);
 
 255 #endif /* __ASSEMBLY__ */
 
 257 #define arch_align_stack(x) (x)
 
 259 #endif /* __KERNEL__ */