mirror of
				https://github.com/RT-Thread/rt-thread.git
				synced 2025-10-23 10:41:50 +08:00 
			
		
		
		
	 7c66501861
			
		
	
	7c66501861
	
	
	
		
			
			MIPS common code was highly duplicated, This commit is a attempt to clean-up and refine these code. The context and exception handle flow is mostly identical with Linux, but a notable difference is that when FPU enabled, we save FP registers in stackframe unconditionally. Signed-off-by: Jiaxun Yang <jiaxun.yang@flygoat.com>
		
			
				
	
	
		
			29 lines
		
	
	
		
			706 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
		
			706 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2006-2019, RT-Thread Development Team
 | |
|  *
 | |
|  * SPDX-License-Identifier: Apache-2.0
 | |
|  *
 | |
|  * Change Logs:
 | |
|  * Date           Author       Notes
 | |
|  * 2019-12-04     Jiaxun Yang  Initial version
 | |
|  */
 | |
| 
 | |
| #ifndef __EXCEPTION_H__
 | |
| #define __EXCEPTION_H__
 | |
| 
 | |
| #include "ptrace.h"
 | |
| 
 | |
| #ifndef __ASSEMBLY__
 | |
| 
 | |
| typedef void (* exception_func_t)(struct pt_regs *regs);
 | |
| 
 | |
| extern int rt_hw_exception_init(void);
 | |
| extern exception_func_t sys_exception_handlers[];
 | |
| extern void rt_do_mips_cpu_irq(rt_uint32_t ip);
 | |
| exception_func_t rt_set_except_vector(int n, exception_func_t func);
 | |
| extern void mips_mask_cpu_irq(rt_uint32_t irq);
 | |
| extern void mips_unmask_cpu_irq(rt_uint32_t irq);
 | |
| #endif
 | |
| 
 | |
| #endif /* end of __EXCEPTION_H__ */
 |