]> git.sur5r.net Git - freertos/blob - Demo/ARM7_LPC2129_Keil_RVDS/serial/serialISR.s
Remove unnecessary use of portLONG, portCHAR and portSHORT.
[freertos] / Demo / ARM7_LPC2129_Keil_RVDS / serial / serialISR.s
1 ;/*\r
2 ;    FreeRTOS V6.0.0 - Copyright (C) 2009 Real Time Engineers Ltd.\r
3 ;\r
4 ;    This file is part of the FreeRTOS distribution.\r
5 ;\r
6 ;    FreeRTOS is free software; you can redistribute it and/or modify it    under\r
7 ;    the terms of the GNU General Public License (version 2) as published by the\r
8 ;    Free Software Foundation and modified by the FreeRTOS exception.\r
9 ;    **NOTE** The exception to the GPL is included to allow you to distribute a\r
10 ;    combined work that includes FreeRTOS without being obliged to provide the\r
11 ;    source code for proprietary components outside of the FreeRTOS kernel.\r
12 ;    Alternative commercial license and support terms are also available upon\r
13 ;    request.  See the licensing section of http://www.FreeRTOS.org for full\r
14 ;    license details.\r
15 ;\r
16 ;    FreeRTOS is distributed in the hope that it will be useful,    but WITHOUT\r
17 ;    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or\r
18 ;    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for\r
19 ;    more details.\r
20 ;\r
21 ;    You should have received a copy of the GNU General Public License along\r
22 ;    with FreeRTOS; if not, write to the Free Software Foundation, Inc., 59\r
23 ;    Temple Place, Suite 330, Boston, MA  02111-1307  USA.\r
24 ;\r
25 ;\r
26 ;    ***************************************************************************\r
27 ;    *                                                                         *\r
28 ;    * The FreeRTOS eBook and reference manual are available to purchase for a *\r
29 ;    * small fee. Help yourself get started quickly while also helping the     *\r
30 ;    * FreeRTOS project! See http://www.FreeRTOS.org/Documentation for details *\r
31 ;    *                                                                         *\r
32 ;    ***************************************************************************\r
33 ;\r
34 ;    1 tab == 4 spaces!\r
35 ;\r
36 ;    Please ensure to read the configuration and relevant port sections of the\r
37 ;    online documentation.\r
38 ;\r
39 ;    http://www.FreeRTOS.org - Documentation, latest information, license and\r
40 ;    contact details.\r
41 ;\r
42 ;    http://www.SafeRTOS.com - A version that is certified for use in safety\r
43 ;    critical systems.\r
44 ;\r
45 ;    http://www.OpenRTOS.com - Commercial support, development, porting,\r
46 ;    licensing and training services.\r
47 ;*/\r
48                 \r
49         INCLUDE portmacro.inc\r
50         \r
51         ;The UART interrupt entry point is defined within an assembly wrapper\r
52         ;within this file.  This takes care of the task context saving before it\r
53         ;calls the main handler (vUART_ISRHandler()) which is written in C within\r
54         ;serial.c.  The execution of the handler can unblock tasks that were blocked\r
55         ;waiting for UART events.  Once the handler completes the asm wrapper \r
56         ;finishes off by        restoring the context of whichever task is now selected to \r
57         ;enter the RUNNING state (which might now be a different task to that which\r
58         ;was originally interrupted.\r
59         IMPORT vUART_ISRHandler\r
60         EXPORT vUART_ISREntry\r
61 \r
62         ;/* Interrupt entry must always be in ARM mode. */\r
63         ARM\r
64         AREA    |.text|, CODE, READONLY\r
65 \r
66 \r
67 vUART_ISREntry\r
68 \r
69         PRESERVE8\r
70 \r
71         ; Save the context of the interrupted task.\r
72         portSAVE_CONTEXT                        \r
73 \r
74         ; Call the C handler function - defined within serial.c.\r
75         LDR R0, =vUART_ISRHandler\r
76         MOV LR, PC                              \r
77         BX R0\r
78 \r
79         ; Finish off by restoring the context of the task that has been chosen to \r
80         ; run next - which might be a different task to that which was originally\r
81         ; interrupted.\r
82         portRESTORE_CONTEXT\r
83 \r
84         END\r