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