]> git.sur5r.net Git - freertos/blob - Demo/ARM7_LPC2129_Keil_RVDS/serial/serialISR.s
Update ready for V5.1.0 release.
[freertos] / Demo / ARM7_LPC2129_Keil_RVDS / serial / serialISR.s
1 ;/*\r
2 ;       FreeRTOS.org V5.1.0 - Copyright (C) 2003-2008 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\r
7 ;       it under the terms of the GNU General Public License as published by\r
8 ;       the Free Software Foundation; either version 2 of the License, or\r
9 ;       (at your option) any later version.\r
10\r
11 ;       FreeRTOS.org is distributed in the hope that it will be useful,\r
12 ;       but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13 ;       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14 ;       GNU General Public License for more details.\r
15 ;\r
16 ;       You should have received a copy of the GNU General Public License\r
17 ;       along with FreeRTOS.org; if not, write to the Free Software\r
18 ;       Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
19 ;\r
20 ;       A special exception to the GPL can be applied should you wish to distribute\r
21 ;       a combined work that includes FreeRTOS.org, without being obliged to provide\r
22 ;       the source code for any proprietary components.  See the licensing section \r
23 ;       of http://www.FreeRTOS.org for full details of how and when the exception\r
24 ;       can be applied.\r
25 ;\r
26 ;   ***************************************************************************\r
27 ;   ***************************************************************************\r
28 ;   *                                                                         *\r
29 ;   * SAVE TIME AND MONEY!  We can port FreeRTOS.org to your own hardware,    *\r
30 ;   * and even write all or part of your application on your behalf.          *\r
31 ;   * See http://www.OpenRTOS.com for details of the services we provide to   *\r
32 ;   * expedite your project.                                                  *\r
33 ;   *                                                                         *\r
34 ;   ***************************************************************************\r
35 ;   ***************************************************************************\r
36 ;\r
37 ;       Please ensure to read the configuration and relevant port sections of the\r
38 ;       online documentation.\r
39 ;\r
40 ;       http://www.FreeRTOS.org - Documentation, latest information, license and \r
41 ;       contact details.\r
42 ;\r
43 ;       http://www.SafeRTOS.com - A version that is certified for use in safety \r
44 ;       critical systems.\r
45 ;\r
46 ;       http://www.OpenRTOS.com - Commercial support, development, porting, \r
47 ;       licensing and training services.\r
48 ;*/             \r
49                 \r
50         INCLUDE portmacro.inc\r
51         \r
52         ;The UART interrupt entry point is defined within an assembly wrapper\r
53         ;within this file.  This takes care of the task context saving before it\r
54         ;calls the main handler (vUART_ISRHandler()) which is written in C within\r
55         ;serial.c.  The execution of the handler can unblock tasks that were blocked\r
56         ;waiting for UART events.  Once the handler completes the asm wrapper \r
57         ;finishes off by        restoring the context of whichever task is now selected to \r
58         ;enter the RUNNING state (which might now be a different task to that which\r
59         ;was originally interrupted.\r
60         IMPORT vUART_ISRHandler\r
61         EXPORT vUART_ISREntry\r
62 \r
63         ;/* Interrupt entry must always be in ARM mode. */\r
64         ARM\r
65         AREA    |.text|, CODE, READONLY\r
66 \r
67 \r
68 vUART_ISREntry\r
69 \r
70         PRESERVE8\r
71 \r
72         ; Save the context of the interrupted task.\r
73         portSAVE_CONTEXT                        \r
74 \r
75         ; Call the C handler function - defined within serial.c.\r
76         LDR R0, =vUART_ISRHandler\r
77         MOV LR, PC                              \r
78         BX R0\r
79 \r
80         ; Finish off by restoring the context of the task that has been chosen to \r
81         ; run next - which might be a different task to that which was originally\r
82         ; interrupted.\r
83         portRESTORE_CONTEXT\r
84 \r
85         END\r