mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 05:51:29 +01:00 
			
		
		
		
	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>
		
	
			
		
			
				
	
	
		
			75 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			75 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
 |