]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/ARM7_LPC2129_Keil_RVDS/serial/serialISR.s
Update version number in readiness for V10.3.0 release. Sync SVN with reviewed releas...
[freertos] / FreeRTOS / Demo / ARM7_LPC2129_Keil_RVDS / serial / serialISR.s
1 ;/*\r
2 ; * FreeRTOS Kernel V10.3.0\r
3 ; * Copyright (C) 2020 Amazon.com, Inc. or its affiliates.  All Rights Reserved.\r
4 ; *\r
5 ; * Permission is hereby granted, free of charge, to any person obtaining a copy of\r
6 ; * this software and associated documentation files (the "Software"), to deal in\r
7 ; * the Software without restriction, including without limitation the rights to\r
8 ; * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\r
9 ; * the Software, and to permit persons to whom the Software is furnished to do so,\r
10 ; * subject to the following conditions:\r
11 ; *\r
12 ; * The above copyright notice and this permission notice shall be included in all\r
13 ; * copies or substantial portions of the Software.\r
14 ; *\r
15 ; * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
16 ; * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\r
17 ; * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\r
18 ; * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\r
19 ; * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
20 ; * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r
21 ; *\r
22 ; * http://www.FreeRTOS.org\r
23 ; * http://aws.amazon.com/freertos\r
24 ; *\r
25 ; * 1 tab == 4 spaces!\r
26 ; */\r
27 \r
28         INCLUDE portmacro.inc\r
29 \r
30         ;The UART interrupt entry point is defined within an assembly wrapper\r
31         ;within this file.  This takes care of the task context saving before it\r
32         ;calls the main handler (vUART_ISRHandler()) which is written in C within\r
33         ;serial.c.  The execution of the handler can unblock tasks that were blocked\r
34         ;waiting for UART events.  Once the handler completes the asm wrapper\r
35         ;finishes off by        restoring the context of whichever task is now selected to\r
36         ;enter the RUNNING state (which might now be a different task to that which\r
37         ;was originally interrupted.\r
38         IMPORT vUART_ISRHandler\r
39         EXPORT vUART_ISREntry\r
40 \r
41         ;/* Interrupt entry must always be in ARM mode. */\r
42         ARM\r
43         AREA    |.text|, CODE, READONLY\r
44 \r
45 \r
46 vUART_ISREntry\r
47 \r
48         PRESERVE8\r
49 \r
50         ; Save the context of the interrupted task.\r
51         portSAVE_CONTEXT\r
52 \r
53         ; Call the C handler function - defined within serial.c.\r
54         LDR R0, =vUART_ISRHandler\r
55         MOV LR, PC\r
56         BX R0\r
57 \r
58         ; Finish off by restoring the context of the task that has been chosen to\r
59         ; run next - which might be a different task to that which was originally\r
60         ; interrupted.\r
61         portRESTORE_CONTEXT\r
62 \r
63         END\r