]> git.sur5r.net Git - freertos/blob - FreeRTOS/Source/portable/RVDS/ARM7_LPC21xx/portmacro.inc
Update to MIT licensed FreeRTOS V10.0.0 - see https://www.freertos.org/History.txt
[freertos] / FreeRTOS / Source / portable / RVDS / ARM7_LPC21xx / portmacro.inc
1 ;/*\r
2 ; * FreeRTOS Kernel V10.0.0\r
3 ; * Copyright (C) 2017 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. If you wish to use our Amazon\r
14 ; * FreeRTOS name, please do so in a fair use way that does not cause confusion.\r
15 ; *\r
16 ; * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
17 ; * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\r
18 ; * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\r
19 ; * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\r
20 ; * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
21 ; * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r
22 ; *\r
23 ; * http://www.FreeRTOS.org\r
24 ; * http://aws.amazon.com/freertos\r
25 ; *\r
26 ; * 1 tab == 4 spaces!\r
27 ; */\r
28 \r
29         IMPORT  ulCriticalNesting               ;\r
30         IMPORT  pxCurrentTCB                    ;\r
31 \r
32 \r
33         MACRO\r
34         portRESTORE_CONTEXT\r
35 \r
36 \r
37         LDR             R0, =pxCurrentTCB               ; Set the LR to the task stack.  The location was...\r
38         LDR             R0, [R0]                                ; ... stored in pxCurrentTCB\r
39         LDR             LR, [R0]\r
40 \r
41         LDR             R0, =ulCriticalNesting  ; The critical nesting depth is the first item on...\r
42         LDMFD   LR!, {R1}                               ; ...the stack.  Load it into the ulCriticalNesting var.\r
43         STR             R1, [R0]                                ;\r
44 \r
45         LDMFD   LR!, {R0}                               ; Get the SPSR from the stack.\r
46         MSR             SPSR_cxsf, R0                   ;\r
47 \r
48         LDMFD   LR, {R0-R14}^                   ; Restore all system mode registers for the task.\r
49         NOP                                                             ;\r
50 \r
51         LDR             LR, [LR, #+60]                  ; Restore the return address\r
52 \r
53                                                                         ; And return - correcting the offset in the LR to obtain ...\r
54         SUBS    PC, LR, #4                              ; ...the correct address.\r
55 \r
56         MEND\r
57 \r
58 ; /**********************************************************************/\r
59 \r
60         MACRO\r
61         portSAVE_CONTEXT\r
62 \r
63 \r
64         STMDB   SP!, {R0}                               ; Store R0 first as we need to use it.\r
65 \r
66         STMDB   SP,{SP}^                                ; Set R0 to point to the task stack pointer.\r
67         NOP                                                             ;\r
68         SUB             SP, SP, #4                              ;\r
69         LDMIA   SP!,{R0}                                ;\r
70 \r
71         STMDB   R0!, {LR}                               ; Push the return address onto the stack.\r
72         MOV             LR, R0                                  ; Now we have saved LR we can use it instead of R0.\r
73         LDMIA   SP!, {R0}                               ; Pop R0 so we can save it onto the system mode stack.\r
74 \r
75         STMDB   LR,{R0-LR}^                             ; Push all the system mode registers onto the task stack.\r
76         NOP                                                             ;\r
77         SUB             LR, LR, #60                             ;\r
78 \r
79         MRS             R0, SPSR                                ; Push the SPSR onto the task stack.\r
80         STMDB   LR!, {R0}                               ;\r
81 \r
82         LDR             R0, =ulCriticalNesting  ;\r
83         LDR             R0, [R0]                                ;\r
84         STMDB   LR!, {R0}                               ;\r
85 \r
86         LDR             R0, =pxCurrentTCB               ; Store the new top of stack for the task.\r
87         LDR             R1, [R0]                                ;\r
88         STR             LR, [R1]                                ;\r
89 \r
90         MEND\r
91 \r
92         END\r