#ifndef __ASM_CSKY_PROCESSOR_H
#define __ASM_CSKY_PROCESSOR_H
#include <linux/bitops.h>
#include <linux/cache.h>
#include <asm/ptrace.h>
#include <asm/current.h>
#include <abi/reg_ops.h>
#include <abi/regdef.h>
#include <abi/switch_context.h>
#ifdef CONFIG_CPU_HAS_FPU
#include <abi/fpu.h>
#endif
struct cpuinfo_csky {
unsigned long asid_cache;
} __aligned(SMP_CACHE_BYTES);
extern struct cpuinfo_csky cpu_data[];
#define TASK_SIZE (PAGE_OFFSET - (PAGE_SIZE * 8))
#ifdef __KERNEL__
#define STACK_TOP TASK_SIZE
#define STACK_TOP_MAX STACK_TOP
#endif
#define TASK_UNMAPPED_BASE (TASK_SIZE / 3)
struct thread_struct {
unsigned long sp;
unsigned long trap_no;
struct user_fp __aligned(16) user_fp;
};
#define INIT_THREAD { \
.sp = sizeof(init_stack) + (unsigned long) &init_stack, \
}
#define start_thread(_regs, _pc, _usp) \
do { \
(_regs)->pc = (_pc); \
(_regs)->regs[1] = 0; \
(_regs)->regs[2] = 0; \
(_regs)->regs[3] = 0; \
(_regs)->sr &= ~PS_S; \
(_regs)->usp = (_usp); \
} while (0)
struct task_struct;
#define prepare_to_copy(tsk) do { } while (0)
unsigned long __get_wchan(struct task_struct *p);
#define KSTK_EIP(tsk) (task_pt_regs(tsk)->pc)
#define KSTK_ESP(tsk) (task_pt_regs(tsk)->usp)
#define task_pt_regs(p) \
((struct pt_regs *)(THREAD_SIZE + task_stack_page(p)) - 1)
#define cpu_relax() barrier()
register unsigned long current_stack_pointer __asm__("sp");
#endif