]> git.sur5r.net Git - freertos/blob - Source/portable/Renesas/SH2A_FPU/portasm.src
Work in progress.
[freertos] / Source / portable / Renesas / SH2A_FPU / portasm.src
1 ;/*\r
2 ;    FreeRTOS V6.0.1 - Copyright (C) 2009 Real Time Engineers Ltd.\r
3 ;\r
4 ;    ***************************************************************************\r
5 ;    *                                                                         *\r
6 ;    * If you are:                                                             *\r
7 ;    *                                                                         *\r
8 ;    *    + New to FreeRTOS,                                                   *\r
9 ;    *    + Wanting to learn FreeRTOS or multitasking in general quickly       *\r
10 ;    *    + Looking for basic training,                                        *\r
11 ;    *    + Wanting to improve your FreeRTOS skills and productivity           *\r
12 ;    *                                                                         *\r
13 ;    * then take a look at the FreeRTOS eBook                                  *\r
14 ;    *                                                                         *\r
15 ;    *        "Using the FreeRTOS Real Time Kernel - a Practical Guide"        *\r
16 ;    *                  http://www.FreeRTOS.org/Documentation                  *\r
17 ;    *                                                                         *\r
18 ;    * A pdf reference manual is also available.  Both are usually delivered   *\r
19 ;    * to your inbox within 20 minutes to two hours when purchased between 8am *\r
20 ;    * and 8pm GMT (although please allow up to 24 hours in case of            *\r
21 ;    * exceptional circumstances).  Thank you for your support!                *\r
22 ;    *                                                                         *\r
23 ;    ***************************************************************************\r
24 ;\r
25 ;    This file is part of the FreeRTOS distribution.\r
26 ;\r
27 ;    FreeRTOS is free software; you can redistribute it and/or modify it under\r
28 ;    the terms of the GNU General Public License (version 2) as published by the\r
29 ;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.\r
30 ;    ***NOTE*** The exception to the GPL is included to allow you to distribute\r
31 ;    a combined work that includes FreeRTOS without being obliged to provide the\r
32 ;    source code for proprietary components outside of the FreeRTOS kernel.\r
33 ;    FreeRTOS is distributed in the hope that it will be useful, but WITHOUT\r
34 ;    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or\r
35 ;    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for\r
36 ;    more details. You should have received a copy of the GNU General Public \r
37 ;    License and the FreeRTOS license exception along with FreeRTOS; if not it \r
38 ;    can be viewed here: http://www.freertos.org/a00114.html and also obtained \r
39 ;    by writing to Richard Barry, contact details for whom are available on the\r
40 ;    FreeRTOS WEB site.\r
41 ;\r
42 ;    1 tab == 4 spaces!\r
43 ;\r
44 ;    http://www.FreeRTOS.org - Documentation, latest information, license and\r
45 ;    contact details.\r
46 ;\r
47 ;    http://www.SafeRTOS.com - A version that is certified for use in safety\r
48 ;    critical systems.\r
49 ;\r
50 ;    http://www.OpenRTOS.com - Commercial support, development, porting,\r
51 ;    licensing and training services.\r
52 ;*/\r
53 \r
54         .import _pxCurrentTCB\r
55         .import _vTaskSwitchContext\r
56 \r
57         .export _vPortStartFirstTask\r
58         .export _ulPortGetGBR\r
59         .export _vPortYield\r
60 \r
61     .section    P\r
62         \r
63 _vPortStartFirstTask:\r
64                 \r
65         ; Get the address of the pxCurrentTCB variable.\r
66         mov.l   #_pxCurrentTCB, r15\r
67 \r
68         ; Get the address of the task stack from pxCurrentTCB.\r
69         mov.l   @r15, r15\r
70 \r
71         ; Get the task stack itself into the stack pointer. \r
72         mov.l   @r15, r15               \r
73 \r
74         ; Restore r0 to PR (PR is used in place of r15).\r
75         movml.l @r15+, r15\r
76         \r
77         ; Restore system registers.\r
78         ldc.l   @r15+, gbr\r
79         lds.l   @r15+, mach\r
80         lds.l   @r15+, macl\r
81         \r
82         ; Pop the SR and PC to jump to the start of the task.\r
83         rte\r
84         nop\r
85 \r
86 _vPortYield:\r
87 \r
88         ; Save registers in the same order used by the CPU itself.\r
89         sts.l   macl, @-r15\r
90         sts.l   mach, @-r15\r
91         stc.l   gbr, @-r15\r
92         movml.l r15, @-r15\r
93         \r
94         ; Get the address of pxCurrentTCB\r
95         mov.l   #_pxCurrentTCB, r0\r
96         \r
97         ; Get the address of pxTopOfStack from the TCB.\r
98         mov.l   @r0, r0\r
99         \r
100         ; Save the stack pointer in pxTopOfStack.\r
101         mov.l   r15, @r0\r
102 \r
103         mov.l   #_vTaskSwitchContext, r0\r
104         jsr             @r0\r
105         nop\r
106 \r
107         ; Get the address of the pxCurrentTCB variable.\r
108         mov.l   #_pxCurrentTCB, r15\r
109 \r
110         ; Get the address of the task stack from pxCurrentTCB.\r
111         mov.l   @r15, r15\r
112 \r
113         ; Get the task stack itself into the stack pointer. \r
114         mov.l   @r15, r15               \r
115 \r
116         ; Restore r0 to PR (PR is used in place of r15).\r
117         movml.l @r15+, r15\r
118         \r
119         ; Restore system registers.\r
120         ldc.l   @r15+, gbr\r
121         lds.l   @r15+, mach\r
122         lds.l   @r15+, macl\r
123         \r
124         ; Pop the SR and PC to jump to the start of the task.\r
125         rte\r
126         nop\r
127 \r
128 \r
129 _ulPortGetGBR:\r
130 \r
131         stc.l   gbr, r0\r
132         rts\r
133         nop\r
134 \r
135         .end\r
136                 \r