1@/***************************************************************************
2@ * Copyright (c) 2024 Microsoft Corporation
3@ *
4@ * This program and the accompanying materials are made available under the
5@ * terms of the MIT License which is available at
6@ * https://opensource.org/licenses/MIT.
7@ *
8@ * SPDX-License-Identifier: MIT
9@ **************************************************************************/
10@
11@
12@/**************************************************************************/
13@/**************************************************************************/
14@/**                                                                       */
15@/** ThreadX Component                                                     */
16@/**                                                                       */
17@/**   Thread                                                              */
18@/**                                                                       */
19@/**************************************************************************/
20@/**************************************************************************/
21#ifdef TX_INCLUDE_USER_DEFINE_FILE
22#include "tx_user.h"
23#endif
24
25#ifdef TX_ENABLE_FIQ_SUPPORT
26DISABLE_INTS    =       0xC0                    @ Disable IRQ/FIQ interrupts
27#else
28DISABLE_INTS    =       0x80                    @ Disable IRQ interrupts
29#endif
30MODE_MASK       =       0x1F                    @ Mode mask
31IRQ_MODE_BITS   =       0x12                    @ IRQ mode bits
32@
33@
34@/* No 16-bit Thumb mode veneer code is needed for _tx_thread_irq_nesting_end
35@   since it will never be called 16-bit mode.  */
36@
37    .arm
38    .text
39    .align 2
40@/**************************************************************************/
41@/*                                                                        */
42@/*  FUNCTION                                               RELEASE        */
43@/*                                                                        */
44@/*    _tx_thread_irq_nesting_end                           ARM9/GNU       */
45@/*                                                           6.2.1        */
46@/*  AUTHOR                                                                */
47@/*                                                                        */
48@/*    William E. Lamie, Microsoft Corporation                             */
49@/*                                                                        */
50@/*  DESCRIPTION                                                           */
51@/*                                                                        */
52@/*    This function is called by the application from IRQ mode after      */
53@/*    _tx_thread_irq_nesting_start has been called and switches the IRQ   */
54@/*    processing from system mode back to IRQ mode prior to the ISR       */
55@/*    calling _tx_thread_context_restore.  Note that this function        */
56@/*    assumes the system stack pointer is in the same position after      */
57@/*    nesting start function was called.                                  */
58@/*                                                                        */
59@/*    This function assumes that the system mode stack pointer was setup  */
60@/*    during low-level initialization (tx_initialize_low_level.s).        */
61@/*                                                                        */
62@/*    This function returns with IRQ interrupts disabled.                 */
63@/*                                                                        */
64@/*  INPUT                                                                 */
65@/*                                                                        */
66@/*    None                                                                */
67@/*                                                                        */
68@/*  OUTPUT                                                                */
69@/*                                                                        */
70@/*    None                                                                */
71@/*                                                                        */
72@/*  CALLS                                                                 */
73@/*                                                                        */
74@/*    None                                                                */
75@/*                                                                        */
76@/*  CALLED BY                                                             */
77@/*                                                                        */
78@/*    ISRs                                                                */
79@/*                                                                        */
80@/*  RELEASE HISTORY                                                       */
81@/*                                                                        */
82@/*    DATE              NAME                      DESCRIPTION             */
83@/*                                                                        */
84@/*  09-30-2020     William E. Lamie         Initial Version 6.1           */
85@/*  03-08-2023     Cindy Deng               Modified comment(s), added    */
86@/*                                            #include tx_user.h,         */
87@/*                                            resulting in version 6.2.1  */
88@/*                                                                        */
89@/**************************************************************************/
90@VOID   _tx_thread_irq_nesting_end(VOID)
91@{
92    .global  _tx_thread_irq_nesting_end
93    .type    _tx_thread_irq_nesting_end,function
94_tx_thread_irq_nesting_end:
95    MOV     r3,lr                               @ Save ISR return address
96    MRS     r0, CPSR                            @ Pickup the CPSR
97    ORR     r0, r0, #DISABLE_INTS               @ Build disable interrupt value
98    MSR     CPSR_cxsf, r0                       @ Disable interrupts
99    LDMIA   sp!, {r1, lr}                       @ Pickup saved lr (and r1 throw-away for
100                                                @   8-byte alignment logic)
101    BIC     r0, r0, #MODE_MASK                  @ Clear mode bits
102    ORR     r0, r0, #IRQ_MODE_BITS              @ Build IRQ mode CPSR
103    MSR     CPSR_cxsf, r0                       @ Reenter IRQ mode
104    MOV     pc, r3                              @ Return to caller
105@}
106
107