162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci 362306a36Sopenharmony_ci#ifndef __ASM_CSKY_PROCESSOR_H 462306a36Sopenharmony_ci#define __ASM_CSKY_PROCESSOR_H 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include <linux/bitops.h> 762306a36Sopenharmony_ci#include <linux/cache.h> 862306a36Sopenharmony_ci#include <asm/ptrace.h> 962306a36Sopenharmony_ci#include <asm/current.h> 1062306a36Sopenharmony_ci#include <abi/reg_ops.h> 1162306a36Sopenharmony_ci#include <abi/regdef.h> 1262306a36Sopenharmony_ci#include <abi/switch_context.h> 1362306a36Sopenharmony_ci#ifdef CONFIG_CPU_HAS_FPU 1462306a36Sopenharmony_ci#include <abi/fpu.h> 1562306a36Sopenharmony_ci#endif 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_cistruct cpuinfo_csky { 1862306a36Sopenharmony_ci unsigned long asid_cache; 1962306a36Sopenharmony_ci} __aligned(SMP_CACHE_BYTES); 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ciextern struct cpuinfo_csky cpu_data[]; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci/* 2462306a36Sopenharmony_ci * User space process size: 2GB. This is hardcoded into a few places, 2562306a36Sopenharmony_ci * so don't change it unless you know what you are doing. TASK_SIZE 2662306a36Sopenharmony_ci * for a 64 bit kernel expandable to 8192EB, of which the current CSKY 2762306a36Sopenharmony_ci * implementations will "only" be able to use 1TB ... 2862306a36Sopenharmony_ci */ 2962306a36Sopenharmony_ci#define TASK_SIZE (PAGE_OFFSET - (PAGE_SIZE * 8)) 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci#ifdef __KERNEL__ 3262306a36Sopenharmony_ci#define STACK_TOP TASK_SIZE 3362306a36Sopenharmony_ci#define STACK_TOP_MAX STACK_TOP 3462306a36Sopenharmony_ci#endif 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci/* This decides where the kernel will search for a free chunk of vm 3762306a36Sopenharmony_ci * space during mmap's. 3862306a36Sopenharmony_ci */ 3962306a36Sopenharmony_ci#define TASK_UNMAPPED_BASE (TASK_SIZE / 3) 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistruct thread_struct { 4262306a36Sopenharmony_ci unsigned long sp; /* kernel stack pointer */ 4362306a36Sopenharmony_ci unsigned long trap_no; /* saved status register */ 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci /* FPU regs */ 4662306a36Sopenharmony_ci struct user_fp __aligned(16) user_fp; 4762306a36Sopenharmony_ci}; 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci#define INIT_THREAD { \ 5062306a36Sopenharmony_ci .sp = sizeof(init_stack) + (unsigned long) &init_stack, \ 5162306a36Sopenharmony_ci} 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci/* 5462306a36Sopenharmony_ci * Do necessary setup to start up a newly executed thread. 5562306a36Sopenharmony_ci * 5662306a36Sopenharmony_ci * pass the data segment into user programs if it exists, 5762306a36Sopenharmony_ci * it can't hurt anything as far as I can tell 5862306a36Sopenharmony_ci */ 5962306a36Sopenharmony_ci#define start_thread(_regs, _pc, _usp) \ 6062306a36Sopenharmony_cido { \ 6162306a36Sopenharmony_ci (_regs)->pc = (_pc); \ 6262306a36Sopenharmony_ci (_regs)->regs[1] = 0; /* ABIV1 is R7, uClibc_main rtdl arg */ \ 6362306a36Sopenharmony_ci (_regs)->regs[2] = 0; \ 6462306a36Sopenharmony_ci (_regs)->regs[3] = 0; /* ABIV2 is R7, use it? */ \ 6562306a36Sopenharmony_ci (_regs)->sr &= ~PS_S; \ 6662306a36Sopenharmony_ci (_regs)->usp = (_usp); \ 6762306a36Sopenharmony_ci} while (0) 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_ci/* Forward declaration, a strange C thing */ 7062306a36Sopenharmony_cistruct task_struct; 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_ci/* Prepare to copy thread state - unlazy all lazy status */ 7362306a36Sopenharmony_ci#define prepare_to_copy(tsk) do { } while (0) 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ciunsigned long __get_wchan(struct task_struct *p); 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci#define KSTK_EIP(tsk) (task_pt_regs(tsk)->pc) 7862306a36Sopenharmony_ci#define KSTK_ESP(tsk) (task_pt_regs(tsk)->usp) 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci#define task_pt_regs(p) \ 8162306a36Sopenharmony_ci ((struct pt_regs *)(THREAD_SIZE + task_stack_page(p)) - 1) 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_ci#define cpu_relax() barrier() 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ciregister unsigned long current_stack_pointer __asm__("sp"); 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ci#endif /* __ASM_CSKY_PROCESSOR_H */ 88