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;
22;#define TX_SOURCE_CODE
23;
24;
25;/* Include necessary system files.  */
26;
27;#include "tx_api.h"
28;#include "tx_thread.h"
29;
30;
31#ifdef TX_ENABLE_FIQ_SUPPORT
32INT_MASK        DEFINE      0xC0                ; Interrupt bit mask
33#else
34INT_MASK        DEFINE      0x80                ; Interrupt bit mask
35#endif
36;
37;
38;/**************************************************************************/
39;/*                                                                        */
40;/*  FUNCTION                                               RELEASE        */
41;/*                                                                        */
42;/*    _tx_thread_interrupt_control                        ARM11/IAR       */
43;/*                                                            6.1         */
44;/*  AUTHOR                                                                */
45;/*                                                                        */
46;/*    William E. Lamie, Microsoft Corporation                             */
47;/*                                                                        */
48;/*  DESCRIPTION                                                           */
49;/*                                                                        */
50;/*    This function is responsible for changing the interrupt lockout     */
51;/*    posture of the system.                                              */
52;/*                                                                        */
53;/*  INPUT                                                                 */
54;/*                                                                        */
55;/*    new_posture                           New interrupt lockout posture */
56;/*                                                                        */
57;/*  OUTPUT                                                                */
58;/*                                                                        */
59;/*    old_posture                           Old interrupt lockout posture */
60;/*                                                                        */
61;/*  CALLS                                                                 */
62;/*                                                                        */
63;/*    None                                                                */
64;/*                                                                        */
65;/*  CALLED BY                                                             */
66;/*                                                                        */
67;/*    Application Code                                                    */
68;/*                                                                        */
69;/*  RELEASE HISTORY                                                       */
70;/*                                                                        */
71;/*    DATE              NAME                      DESCRIPTION             */
72;/*                                                                        */
73;/*  09-30-2020     William E. Lamie         Initial Version 6.1           */
74;/*                                                                        */
75;/**************************************************************************/
76;UINT   _tx_thread_interrupt_control(UINT new_posture)
77;{
78    RSEG    .text:CODE:NOROOT(2)
79    PUBLIC  _tx_thread_interrupt_control
80    CODE32
81_tx_thread_interrupt_control
82;
83;    /* Pickup current interrupt lockout posture.  */
84;
85    MRS     r3, CPSR                            ; Pickup current CPSR
86    BIC     r1, r3, #INT_MASK                   ; Clear interrupt lockout bits
87    ORR     r1, r1, r0                          ; Or-in new interrupt lockout bits
88;
89;    /* Apply the new interrupt posture.  */
90;
91    MSR     CPSR_cxsf, r1                       ; Setup new CPSR
92    AND     r0, r3, #INT_MASK                   ; Return previous interrupt mask
93#ifdef TX_THUMB
94    BX      lr                                  ; Return to caller
95#else
96    MOV     pc, lr                              ; Return to caller
97#endif
98;
99;}
100;
101;
102    END
103