You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							100 lines
						
					
					
						
							3.4 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							100 lines
						
					
					
						
							3.4 KiB
						
					
					
				| /* | |
|  * File      : cpuport.c | |
|  * This file is part of RT-Thread RTOS | |
|  * COPYRIGHT (C) 2009 - 2012, RT-Thread Development Team | |
|  * | |
|  * The license and distribution terms for this file may be | |
|  * found in the file LICENSE in this distribution or at | |
|  * http://www.rt-thread.org/license/LICENSE | |
|  * | |
|  * Change Logs: | |
|  * Date           Author       Notes | |
|  * 2011-02-23     Bernard      the first version | |
|  * 2012-09-23     lgnq         set the texit to R31 | |
|  */ | |
| 
 | |
| #include <rtthread.h> | |
|  | |
| extern volatile rt_uint8_t rt_interrupt_nest; | |
| 
 | |
| /* switch flag on interrupt and thread pointer to save switch record */ | |
| rt_uint32_t rt_interrupt_from_thread; | |
| rt_uint32_t rt_interrupt_to_thread; | |
| rt_uint32_t rt_thread_switch_interrupt_flag; | |
| 
 | |
| /** | |
|  * This function will initialize hardware interrupt | |
|  */ | |
| void rt_hw_interrupt_init(void) | |
| { | |
|     /* init interrupt nest, and context in thread sp */ | |
|     rt_interrupt_nest               = 0; | |
|     rt_interrupt_from_thread        = 0; | |
|     rt_interrupt_to_thread          = 0; | |
|     rt_thread_switch_interrupt_flag = 0; | |
| } | |
| 
 | |
| /** | |
|  * This function will initialize thread stack | |
|  * | |
|  * @param tentry the entry of thread | |
|  * @param parameter the parameter of entry | |
|  * @param stack_addr the beginning stack address | |
|  * @param texit the function will be called when thread exit | |
|  * | |
|  * @return stack address | |
|  */ | |
| rt_uint8_t *rt_hw_stack_init(void       *tentry, | |
|                              void       *parameter, | |
|                              rt_uint8_t *stack_addr, | |
|                              void       *texit) | |
| { | |
|     rt_uint32_t *stk; | |
| 
 | |
|     stk      = (rt_uint32_t *)stack_addr;    /* Load stack pointer */ | |
| 
 | |
|     *(--stk) = (rt_uint32_t)0x23232323;      /* r23 */ | |
|     *(--stk) = (rt_uint32_t)0x24242424;      /* r24 */ | |
|     *(--stk) = (rt_uint32_t)0x25252525;      /* r25 */ | |
|     *(--stk) = (rt_uint32_t)0x26262626;      /* r26 */ | |
|     *(--stk) = (rt_uint32_t)0x27272727;      /* r27 */ | |
|     *(--stk) = (rt_uint32_t)0x28282828;      /* r28 */ | |
|     *(--stk) = (rt_uint32_t)0x29292929;      /* r29 */ | |
|     *(--stk) = (rt_uint32_t)0x30303030;      /* r30 */ | |
|     *(--stk) = (rt_uint32_t)texit;           /* r31 */ | |
|     *(--stk) = (rt_uint32_t)0x00000000;      /* Task PSW = Interrupts enabled */ | |
|     *(--stk) = (rt_uint32_t)tentry;          /* Task's PC */ | |
|     *(--stk) = (rt_uint32_t)0x16161616;      /* r16 */ | |
|     *(--stk) = (rt_uint32_t)0x15151515;      /* r15 */ | |
|     *(--stk) = (rt_uint32_t)0x14141414;      /* r14 */ | |
|     *(--stk) = (rt_uint32_t)0x13131313;      /* r13 */ | |
|     *(--stk) = (rt_uint32_t)0x12121212;      /* r12 */ | |
|     *(--stk) = (rt_uint32_t)0x11111111;      /* r11 */ | |
|     *(--stk) = (rt_uint32_t)0x10101010;      /* r10 */ | |
|     *(--stk) = (rt_uint32_t)0x09090909;      /* r9 */ | |
|     *(--stk) = (rt_uint32_t)0x08080808;      /* r8 */ | |
|     *(--stk) = (rt_uint32_t)0x07070707;      /* r7 */ | |
|     *(--stk) = (rt_uint32_t)0x06060606;      /* r6 */ | |
|     *(--stk) = (rt_uint32_t)0x05050505;      /* r5 */ | |
|     *(--stk) = (rt_uint32_t)0x02020202;      /* r2 */ | |
|     *(--stk) = (rt_uint32_t)parameter;       /* r1 */ | |
| 
 | |
|     return ((rt_uint8_t *)stk); | |
| } | |
| 
 | |
| void rt_hw_context_switch(rt_uint32_t from, rt_uint32_t to) | |
| { | |
|     rt_interrupt_from_thread = from; | |
|     rt_interrupt_to_thread = to; | |
|     asm("trap 0x10"); | |
| } | |
| 
 | |
| void rt_hw_context_switch_interrupt(rt_uint32_t from, rt_uint32_t to) | |
| { | |
|     if (rt_thread_switch_interrupt_flag != 1) | |
|     { | |
|         rt_thread_switch_interrupt_flag = 1; | |
|         rt_interrupt_from_thread = from; | |
|     } | |
|     rt_interrupt_to_thread = to; | |
| }
 | |
| 
 |