 79725df578
			
		
	
	
	79725df578
	
	
	
		
			
			This patch includes processor and system headers. System call interface is here. We used the syscall interface the same as asm-generic version. Signed-off-by: Guan Xuetao <gxt@mprc.pku.edu.cn> Reviewed-by: Arnd Bergmann <arnd@arndb.de>
		
			
				
	
	
		
			45 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * linux/arch/unicore32/include/asm/cpu-single.h
 | |
|  *
 | |
|  * Code specific to PKUnity SoC and UniCore ISA
 | |
|  *
 | |
|  * Copyright (C) 2001-2010 GUAN Xue-tao
 | |
|  *
 | |
|  * 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.
 | |
|  */
 | |
| #ifndef __UNICORE_CPU_SINGLE_H__
 | |
| #define __UNICORE_CPU_SINGLE_H__
 | |
| 
 | |
| #include <asm/page.h>
 | |
| #include <asm/memory.h>
 | |
| 
 | |
| #ifdef __KERNEL__
 | |
| #ifndef __ASSEMBLY__
 | |
| 
 | |
| #define cpu_switch_mm(pgd, mm) cpu_do_switch_mm(virt_to_phys(pgd), mm)
 | |
| 
 | |
| #define cpu_get_pgd()					\
 | |
| 	({						\
 | |
| 		unsigned long pg;			\
 | |
| 		__asm__("movc	%0, p0.c2, #0"		\
 | |
| 			 : "=r" (pg) : : "cc");		\
 | |
| 		pg &= ~0x0fff;				\
 | |
| 		(pgd_t *)phys_to_virt(pg);		\
 | |
| 	})
 | |
| 
 | |
| struct mm_struct;
 | |
| 
 | |
| /* declare all the functions as extern */
 | |
| extern void cpu_proc_fin(void);
 | |
| extern int cpu_do_idle(void);
 | |
| extern void cpu_dcache_clean_area(void *, int);
 | |
| extern void cpu_do_switch_mm(unsigned long pgd_phys, struct mm_struct *mm);
 | |
| extern void cpu_set_pte(pte_t *ptep, pte_t pte);
 | |
| extern void cpu_reset(unsigned long addr) __attribute__((noreturn));
 | |
| 
 | |
| #endif /* __ASSEMBLY__ */
 | |
| #endif /* __KERNEL__ */
 | |
| 
 | |
| #endif /* __UNICORE_CPU_SINGLE_H__ */
 |