-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCortexM.h
112 lines (93 loc) · 3.79 KB
/
CortexM.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#ifndef _CORTEXM_
#define _CORTEXM_
/**
* @file CortexM.h
* @brief Basic functions used in these labs
* @details Used for enabling and disabling interrupts
* @version V1.0
* @author Valvano
* @copyright Copyright 2017 by Jonathan W. Valvano, [email protected],
* @warning AS-IS
* @note For more information see http://users.ece.utexas.edu/~valvano/
* @date February 18, 2017
******************************************************************************/
/* This example accompanies the books
"Embedded Systems: Introduction to the MSP432 Microcontroller",
ISBN: 978-1512185676, Jonathan Valvano, copyright (c) 2017
"Embedded Systems: Real-Time Interfacing to the MSP432 Microcontroller",
ISBN: 978-1514676585, Jonathan Valvano, copyright (c) 2017
"Embedded Systems: Real-Time Operating Systems for ARM Cortex-M Microcontrollers",
ISBN: 978-1466468863, , Jonathan Valvano, copyright (c) 2017
For more information about my classes, my research, and my books, see
http://users.ece.utexas.edu/~valvano/
Simplified BSD License (FreeBSD License)
Copyright (c) 2017, Jonathan Valvano, All rights reserved.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
The views and conclusions contained in the software and documentation are
those of the authors and should not be interpreted as representing official
policies, either expressed or implied, of the FreeBSD Project.
*/
/**
* Disables Interrupts
*
* @param none
* @return none
*
* @brief Sets the I bit in the PRIMASK to disable interrupts.
*/
void DisableInterrupts(void); // Disable interrupts
/**
* Enables Interrupts
*
* @param none
* @return none
*
* @brief clears the I bit in the PRIMASK to enable interrupts
*/
void EnableInterrupts(void); // Enable interrupts
/**
* Start a critical section. Code between StartCritical and EndCritical is run atomically
*
* @param none
* @return copy of the PRIMASK (I bit) before StartCritical called
*
* @brief Saves a copy of PRIMASK and disables interrupts
*/
long StartCritical(void);
/**
* End a critical section. Code between StartCritical and EndCritical is run atomically
*
* @param sr is PRIMASK (I bit) before StartCritical called
* @return none
*
* @brief Sets PRIMASK with value passed in
*/
void EndCritical(long sr); // restore I bit to previous value
/**
* Enters low power sleep mode waiting for interrupt (WFI instruction)
* processor sleeps until next hardware interrupt
* returns after ISR has been run
*
* @param none
* @return none
*
* @brief Enters low power sleep mode waiting for interrupt
*/
void WaitForInterrupt(void);
#endif