1;/*
2; * FreeRTOS Kernel V11.1.0
3; * Copyright (C) 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
4; *
5; * SPDX-License-Identifier: MIT
6; *
7; * Permission is hereby granted, free of charge, to any person obtaining a copy of
8; * this software and associated documentation files (the "Software"), to deal in
9; * the Software without restriction, including without limitation the rights to
10; * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
11; * the Software, and to permit persons to whom the Software is furnished to do so,
12; * subject to the following conditions:
13; *
14; * The above copyright notice and this permission notice shall be included in all
15; * copies or substantial portions of the Software.
16; *
17; * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18; * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
19; * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
20; * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
21; * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22; * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23; *
24; * https://www.FreeRTOS.org
25; * https://github.com/FreeRTOS
26; *
27; */
28
29    .import _pxCurrentTCB
30    .import _vTaskSwitchContext
31    .import _xTaskIncrementTick
32
33    .export _vPortStartFirstTask
34    .export _ulPortGetGBR
35    .export _vPortYieldHandler
36    .export _vPortPreemptiveTick
37    .export _vPortCooperativeTick
38    .export _vPortSaveFlopRegisters
39    .export _vPortRestoreFlopRegisters
40
41    .section    P
42
43    .INCLUDE "ISR_Support.inc"
44
45_vPortStartFirstTask:
46
47    portRESTORE_CONTEXT
48
49;-----------------------------------------------------------
50
51_vPortYieldHandler:
52
53    portSAVE_CONTEXT
54
55    mov.l   #_vTaskSwitchContext, r0
56    jsr     @r0
57    nop
58
59    portRESTORE_CONTEXT
60
61;-----------------------------------------------------------
62
63_vPortPreemptiveTick
64
65    portSAVE_CONTEXT
66
67    mov.l   #_xTaskIncrementTick, r0
68    jsr     @r0
69    nop
70
71    mov.l   #_vTaskSwitchContext, r0
72    jsr     @r0
73    nop
74
75    portRESTORE_CONTEXT
76
77;-----------------------------------------------------------
78
79_vPortCooperativeTick
80
81    portSAVE_CONTEXT
82
83    mov.l   #_xTaskIncrementTick, r0
84    jsr     @r0
85    nop
86
87    portRESTORE_CONTEXT
88
89;-----------------------------------------------------------
90
91_ulPortGetGBR:
92
93    stc.l   gbr, r0
94    rts
95    nop
96
97;-----------------------------------------------------------
98
99_vPortSaveFlopRegisters:
100
101    fmov.s  fr0, @-r4
102    fmov.s  fr1, @-r4
103    fmov.s  fr2, @-r4
104    fmov.s  fr3, @-r4
105    fmov.s  fr4, @-r4
106    fmov.s  fr5, @-r4
107    fmov.s  fr6, @-r4
108    fmov.s  fr7, @-r4
109    fmov.s  fr8, @-r4
110    fmov.s  fr9, @-r4
111    fmov.s  fr10, @-r4
112    fmov.s  fr11, @-r4
113    fmov.s  fr12, @-r4
114    fmov.s  fr13, @-r4
115    fmov.s  fr14, @-r4
116    fmov.s  fr15, @-r4
117    sts.l   fpul, @-r4
118    sts.l   fpscr, @-r4
119
120    rts
121    nop
122
123;-----------------------------------------------------------
124
125_vPortRestoreFlopRegisters:
126
127    add.l  #-72, r4
128    lds.l  @r4+, fpscr
129    lds.l  @r4+, fpul
130    fmov.s @r4+, fr15
131    fmov.s @r4+, fr14
132    fmov.s @r4+, fr13
133    fmov.s @r4+, fr12
134    fmov.s @r4+, fr11
135    fmov.s @r4+, fr10
136    fmov.s @r4+, fr9
137    fmov.s @r4+, fr8
138    fmov.s @r4+, fr7
139    fmov.s @r4+, fr6
140    fmov.s @r4+, fr5
141    fmov.s @r4+, fr4
142    fmov.s @r4+, fr3
143    fmov.s @r4+, fr2
144    fmov.s @r4+, fr1
145    fmov.s @r4+, fr0
146
147    rts
148    nop
149
150    .end
151