2 * FreeRTOS Kernel <DEVELOPMENT BRANCH>
3 * Copyright (C) 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
5 * SPDX-License-Identifier: MIT
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:
14 * The above copyright notice and this permission notice shall be included in all
15 * copies or substantial portions of the Software.
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.
24 * https://www.FreeRTOS.org
25 * https://github.com/FreeRTOS
29 /* Variables used by scheduler */
31 .extern _usCriticalNesting
34 * portSAVE_CONTEXT MACRO
35 * Saves the context of the general purpose registers, CS and ES (only in far
36 * memory mode) registers the usCriticalNesting Value and the Stack Pointer
37 * of the active Task onto the task stack
39 .macro portSAVE_CONTEXT
43 /* Save AX Register to stack. */
46 /* Save CS register. */
49 /* Save ES register. */
52 /* Save the remaining general purpose registers from bank 0. */
55 /* Save the other register banks - only necessary in the GCC port. */
66 /* Registers in bank 3 are for ISR use only so don't need saving. */
68 /* Save the usCriticalNesting value. */
69 MOVW AX, !_usCriticalNesting
71 /* Save the Stack pointer. */
72 MOVW AX, !_pxCurrentTCB
76 /* Switch stack pointers. */
77 movw sp, # _stack /* Set stack pointer */
83 * portRESTORE_CONTEXT MACRO
84 * Restores the task Stack Pointer then use this to restore usCriticalNesting,
85 * general purpose registers and the CS and ES (only in far memory mode)
86 * of the selected task from the task stack
88 .macro portRESTORE_CONTEXT MACRO
90 /* Restore the Stack pointer. */
91 MOVW AX, !_pxCurrentTCB
95 /* Restore usCriticalNesting value. */
97 MOVW !_usCriticalNesting, AX
99 /* Restore the alternative register banks - only necessary in the GCC
100 * port. Register bank 3 is dedicated for interrupts use so is not saved or
113 /* Restore the necessary general purpose registers. */
116 /* Restore the ES register. */
119 /* Restore the CS register. */
122 /* Restore general purpose register HL. */