mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-18 18:59:44 +00:00
7d89982b7a
mkconfig links ${objtree}/include/asm/proc/ to ${srctree}/arch/${arch}/include/asm/proc-armv/. This seems to be a remnant from the past. Ever since its introduction in 2003 it is used only in ARM build and always links to same place, so let's simplify the code, remove it and reference directly where needed. Successful MAKEALL for ARM and PowerPC verified on Linux. Signed-off-by: Vasili Galka <vvv444@gmail.com>
74 lines
2.2 KiB
C
74 lines
2.2 KiB
C
/*
|
|
* linux/include/asm-arm/proc-armv/processor.h
|
|
*
|
|
* Copyright (C) 1996-1999 Russell King.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* Changelog:
|
|
* 20-09-1996 RMK Created
|
|
* 26-09-1996 RMK Added 'EXTRA_THREAD_STRUCT*'
|
|
* 28-09-1996 RMK Moved start_thread into the processor dependencies
|
|
* 09-09-1998 PJB Delete redundant `wp_works_ok'
|
|
* 30-05-1999 PJB Save sl across context switches
|
|
* 31-07-1999 RMK Added 'domain' stuff
|
|
*/
|
|
#ifndef __ASM_PROC_PROCESSOR_H
|
|
#define __ASM_PROC_PROCESSOR_H
|
|
|
|
#include <asm/proc-armv/domain.h>
|
|
|
|
#define KERNEL_STACK_SIZE PAGE_SIZE
|
|
|
|
struct context_save_struct {
|
|
unsigned long cpsr;
|
|
unsigned long r4;
|
|
unsigned long r5;
|
|
unsigned long r6;
|
|
unsigned long r7;
|
|
unsigned long r8;
|
|
unsigned long r9;
|
|
unsigned long sl;
|
|
unsigned long fp;
|
|
unsigned long pc;
|
|
};
|
|
|
|
#define INIT_CSS (struct context_save_struct){ SVC_MODE, 0, 0, 0, 0, 0, 0, 0, 0, 0 }
|
|
|
|
#define EXTRA_THREAD_STRUCT \
|
|
unsigned int domain;
|
|
|
|
#define EXTRA_THREAD_STRUCT_INIT \
|
|
domain: domain_val(DOMAIN_USER, DOMAIN_CLIENT) | \
|
|
domain_val(DOMAIN_KERNEL, DOMAIN_MANAGER) | \
|
|
domain_val(DOMAIN_IO, DOMAIN_CLIENT)
|
|
|
|
#define start_thread(regs,pc,sp) \
|
|
({ \
|
|
unsigned long *stack = (unsigned long *)sp; \
|
|
set_fs(USER_DS); \
|
|
memzero(regs->uregs, sizeof(regs->uregs)); \
|
|
if (current->personality & ADDR_LIMIT_32BIT) \
|
|
regs->ARM_cpsr = USR_MODE; \
|
|
else \
|
|
regs->ARM_cpsr = USR26_MODE; \
|
|
regs->ARM_pc = pc; /* pc */ \
|
|
regs->ARM_sp = sp; /* sp */ \
|
|
regs->ARM_r2 = stack[2]; /* r2 (envp) */ \
|
|
regs->ARM_r1 = stack[1]; /* r1 (argv) */ \
|
|
regs->ARM_r0 = stack[0]; /* r0 (argc) */ \
|
|
})
|
|
|
|
#define KSTK_EIP(tsk) (((unsigned long *)(4096+(unsigned long)(tsk)))[1019])
|
|
#define KSTK_ESP(tsk) (((unsigned long *)(4096+(unsigned long)(tsk)))[1017])
|
|
|
|
/* Allocation and freeing of basic task resources. */
|
|
/*
|
|
* NOTE! The task struct and the stack go together
|
|
*/
|
|
#define ll_alloc_task_struct() ((struct task_struct *) __get_free_pages(GFP_KERNEL,1))
|
|
#define ll_free_task_struct(p) free_pages((unsigned long)(p),1)
|
|
|
|
#endif
|