The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
Anna Bridge
Date:
Wed Jan 17 16:13:02 2018 +0000
Revision:
160:5571c4ff569f
mbed library. Release version 158

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Anna Bridge 160:5571c4ff569f 1 /**************************************************************************//**
Anna Bridge 160:5571c4ff569f 2 * @file core_cmSecureAccess.h
Anna Bridge 160:5571c4ff569f 3 * @brief CMSIS Cortex-M Core Secure Access Header File
Anna Bridge 160:5571c4ff569f 4 * @version XXX
Anna Bridge 160:5571c4ff569f 5 * @date 10. June 2016
Anna Bridge 160:5571c4ff569f 6 *
Anna Bridge 160:5571c4ff569f 7 * @note
Anna Bridge 160:5571c4ff569f 8 *
Anna Bridge 160:5571c4ff569f 9 ******************************************************************************/
Anna Bridge 160:5571c4ff569f 10 /* Copyright (c) 2016 ARM LIMITED
Anna Bridge 160:5571c4ff569f 11
Anna Bridge 160:5571c4ff569f 12 All rights reserved.
Anna Bridge 160:5571c4ff569f 13 Redistribution and use in source and binary forms, with or without
Anna Bridge 160:5571c4ff569f 14 modification, are permitted provided that the following conditions are met:
Anna Bridge 160:5571c4ff569f 15 - Redistributions of source code must retain the above copyright
Anna Bridge 160:5571c4ff569f 16 notice, this list of conditions and the following disclaimer.
Anna Bridge 160:5571c4ff569f 17 - Redistributions in binary form must reproduce the above copyright
Anna Bridge 160:5571c4ff569f 18 notice, this list of conditions and the following disclaimer in the
Anna Bridge 160:5571c4ff569f 19 documentation and/or other materials provided with the distribution.
Anna Bridge 160:5571c4ff569f 20 - Neither the name of ARM nor the names of its contributors may be used
Anna Bridge 160:5571c4ff569f 21 to endorse or promote products derived from this software without
Anna Bridge 160:5571c4ff569f 22 specific prior written permission.
Anna Bridge 160:5571c4ff569f 23 *
Anna Bridge 160:5571c4ff569f 24 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Anna Bridge 160:5571c4ff569f 25 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Anna Bridge 160:5571c4ff569f 26 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
Anna Bridge 160:5571c4ff569f 27 ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE
Anna Bridge 160:5571c4ff569f 28 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
Anna Bridge 160:5571c4ff569f 29 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
Anna Bridge 160:5571c4ff569f 30 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
Anna Bridge 160:5571c4ff569f 31 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
Anna Bridge 160:5571c4ff569f 32 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
Anna Bridge 160:5571c4ff569f 33 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
Anna Bridge 160:5571c4ff569f 34 POSSIBILITY OF SUCH DAMAGE.
Anna Bridge 160:5571c4ff569f 35 ---------------------------------------------------------------------------*/
Anna Bridge 160:5571c4ff569f 36
Anna Bridge 160:5571c4ff569f 37
Anna Bridge 160:5571c4ff569f 38 #ifndef __CORE_CM_SECURE_ACCESS_H
Anna Bridge 160:5571c4ff569f 39 #define __CORE_CM_SECURE_ACCESS_H
Anna Bridge 160:5571c4ff569f 40
Anna Bridge 160:5571c4ff569f 41
Anna Bridge 160:5571c4ff569f 42 /* ########################### Core Secure Access ########################### */
Anna Bridge 160:5571c4ff569f 43
Anna Bridge 160:5571c4ff569f 44 #ifdef FEATURE_UVISOR
Anna Bridge 160:5571c4ff569f 45 #include "uvisor-lib/uvisor-lib.h"
Anna Bridge 160:5571c4ff569f 46
Anna Bridge 160:5571c4ff569f 47 /* Secure uVisor implementation. */
Anna Bridge 160:5571c4ff569f 48
Anna Bridge 160:5571c4ff569f 49 /** Set the value at the target address.
Anna Bridge 160:5571c4ff569f 50 *
Anna Bridge 160:5571c4ff569f 51 * Equivalent to: `*address = value`.
Anna Bridge 160:5571c4ff569f 52 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 53 * @param value[in] Value to write at the address location.
Anna Bridge 160:5571c4ff569f 54 */
Anna Bridge 160:5571c4ff569f 55 #define SECURE_WRITE(address, value) \
Anna Bridge 160:5571c4ff569f 56 uvisor_write(public_box, UVISOR_RGW_SHARED, address, value, UVISOR_RGW_OP_WRITE, 0xFFFFFFFFUL)
Anna Bridge 160:5571c4ff569f 57
Anna Bridge 160:5571c4ff569f 58 /** Get the value at the target address.
Anna Bridge 160:5571c4ff569f 59 *
Anna Bridge 160:5571c4ff569f 60 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 61 * @returns The value `*address`.
Anna Bridge 160:5571c4ff569f 62 */
Anna Bridge 160:5571c4ff569f 63 #define SECURE_READ(address) \
Anna Bridge 160:5571c4ff569f 64 uvisor_read(public_box, UVISOR_RGW_SHARED, address, UVISOR_RGW_OP_READ, 0xFFFFFFFFUL)
Anna Bridge 160:5571c4ff569f 65
Anna Bridge 160:5571c4ff569f 66 /** Get the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 67 *
Anna Bridge 160:5571c4ff569f 68 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 69 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 70 * @returns The value `*address & mask`.
Anna Bridge 160:5571c4ff569f 71 */
Anna Bridge 160:5571c4ff569f 72 #define SECURE_BITS_GET(address, mask) \
Anna Bridge 160:5571c4ff569f 73 UVISOR_BITS_GET(public_box, UVISOR_RGW_SHARED, address, mask)
Anna Bridge 160:5571c4ff569f 74
Anna Bridge 160:5571c4ff569f 75 /** Check the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 76 *
Anna Bridge 160:5571c4ff569f 77 * @param address[in] Address at which to check the bits
Anna Bridge 160:5571c4ff569f 78 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 79 * @returns The value `((*address & mask) == mask)`.
Anna Bridge 160:5571c4ff569f 80 */
Anna Bridge 160:5571c4ff569f 81 #define SECURE_BITS_CHECK(address, mask) \
Anna Bridge 160:5571c4ff569f 82 UVISOR_BITS_CHECK(public_box, UVISOR_RGW_SHARED, address, mask)
Anna Bridge 160:5571c4ff569f 83
Anna Bridge 160:5571c4ff569f 84 /** Set the selected bits to 1 at the target address.
Anna Bridge 160:5571c4ff569f 85 *
Anna Bridge 160:5571c4ff569f 86 * Equivalent to: `*address |= mask`.
Anna Bridge 160:5571c4ff569f 87 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 88 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 89 */
Anna Bridge 160:5571c4ff569f 90 #define SECURE_BITS_SET(address, mask) \
Anna Bridge 160:5571c4ff569f 91 UVISOR_BITS_SET(public_box, UVISOR_RGW_SHARED, address, mask)
Anna Bridge 160:5571c4ff569f 92
Anna Bridge 160:5571c4ff569f 93 /** Clear the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 94 *
Anna Bridge 160:5571c4ff569f 95 * Equivalent to: `*address &= ~mask`.
Anna Bridge 160:5571c4ff569f 96 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 97 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 98 */
Anna Bridge 160:5571c4ff569f 99 #define SECURE_BITS_CLEAR(address, mask) \
Anna Bridge 160:5571c4ff569f 100 UVISOR_BITS_CLEAR(public_box, UVISOR_RGW_SHARED, address, mask)
Anna Bridge 160:5571c4ff569f 101
Anna Bridge 160:5571c4ff569f 102 /** Set the selected bits at the target address to the given value.
Anna Bridge 160:5571c4ff569f 103 *
Anna Bridge 160:5571c4ff569f 104 * Equivalent to: `*address = (*address & ~mask) | (value & mask)`.
Anna Bridge 160:5571c4ff569f 105 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 106 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 107 * @param value[in] Value to write at the address location. Note: The value
Anna Bridge 160:5571c4ff569f 108 * must be already shifted to the correct bit position
Anna Bridge 160:5571c4ff569f 109 */
Anna Bridge 160:5571c4ff569f 110 #define SECURE_BITS_SET_VALUE(address, mask, value) \
Anna Bridge 160:5571c4ff569f 111 UVISOR_BITS_SET_VALUE(public_box, UVISOR_RGW_SHARED, address, mask, value)
Anna Bridge 160:5571c4ff569f 112
Anna Bridge 160:5571c4ff569f 113 /** Toggle the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 114 *
Anna Bridge 160:5571c4ff569f 115 * Equivalent to: `*address ^= mask`.
Anna Bridge 160:5571c4ff569f 116 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 117 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 118 */
Anna Bridge 160:5571c4ff569f 119 #define SECURE_BITS_TOGGLE(address, mask) \
Anna Bridge 160:5571c4ff569f 120 UVISOR_BITS_TOGGLE(public_box, UVISOR_RGW_SHARED, address, mask)
Anna Bridge 160:5571c4ff569f 121
Anna Bridge 160:5571c4ff569f 122 #else
Anna Bridge 160:5571c4ff569f 123
Anna Bridge 160:5571c4ff569f 124 /* Insecure fallback implementation. */
Anna Bridge 160:5571c4ff569f 125
Anna Bridge 160:5571c4ff569f 126 /** Set the value at the target address.
Anna Bridge 160:5571c4ff569f 127 *
Anna Bridge 160:5571c4ff569f 128 * Equivalent to: `*address = value`.
Anna Bridge 160:5571c4ff569f 129 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 130 * @param value[in] Value to write at the address location.
Anna Bridge 160:5571c4ff569f 131 */
Anna Bridge 160:5571c4ff569f 132 #define SECURE_WRITE(address, value) \
Anna Bridge 160:5571c4ff569f 133 *(address) = (value)
Anna Bridge 160:5571c4ff569f 134
Anna Bridge 160:5571c4ff569f 135 /** Get the value at the target address.
Anna Bridge 160:5571c4ff569f 136 *
Anna Bridge 160:5571c4ff569f 137 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 138 * @returns The value `*address`.
Anna Bridge 160:5571c4ff569f 139 */
Anna Bridge 160:5571c4ff569f 140 #define SECURE_READ(address) \
Anna Bridge 160:5571c4ff569f 141 (*(address))
Anna Bridge 160:5571c4ff569f 142
Anna Bridge 160:5571c4ff569f 143 /** Get the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 144 *
Anna Bridge 160:5571c4ff569f 145 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 146 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 147 * @returns The value `*address & mask`.
Anna Bridge 160:5571c4ff569f 148 */
Anna Bridge 160:5571c4ff569f 149 #define SECURE_BITS_GET(address, mask) \
Anna Bridge 160:5571c4ff569f 150 (*(address) & (mask))
Anna Bridge 160:5571c4ff569f 151
Anna Bridge 160:5571c4ff569f 152 /** Check the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 153 *
Anna Bridge 160:5571c4ff569f 154 * @param address[in] Address at which to check the bits
Anna Bridge 160:5571c4ff569f 155 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 156 * @returns The value `((*address & mask) == mask)`.
Anna Bridge 160:5571c4ff569f 157 */
Anna Bridge 160:5571c4ff569f 158 #define SECURE_BITS_CHECK(address, mask) \
Anna Bridge 160:5571c4ff569f 159 ((*(address) & (mask)) == (mask))
Anna Bridge 160:5571c4ff569f 160
Anna Bridge 160:5571c4ff569f 161 /** Set the selected bits to 1 at the target address.
Anna Bridge 160:5571c4ff569f 162 *
Anna Bridge 160:5571c4ff569f 163 * Equivalent to: `*address |= mask`.
Anna Bridge 160:5571c4ff569f 164 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 165 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 166 */
Anna Bridge 160:5571c4ff569f 167 #define SECURE_BITS_SET(address, mask) \
Anna Bridge 160:5571c4ff569f 168 *(address) |= (mask)
Anna Bridge 160:5571c4ff569f 169
Anna Bridge 160:5571c4ff569f 170 /** Clear the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 171 *
Anna Bridge 160:5571c4ff569f 172 * Equivalent to: `*address &= ~mask`.
Anna Bridge 160:5571c4ff569f 173 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 174 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 175 */
Anna Bridge 160:5571c4ff569f 176 #define SECURE_BITS_CLEAR(address, mask) \
Anna Bridge 160:5571c4ff569f 177 *(address) &= ~(mask)
Anna Bridge 160:5571c4ff569f 178
Anna Bridge 160:5571c4ff569f 179 /** Set the selected bits at the target address to the given value.
Anna Bridge 160:5571c4ff569f 180 *
Anna Bridge 160:5571c4ff569f 181 * Equivalent to: `*address = (*address & ~mask) | (value & mask)`.
Anna Bridge 160:5571c4ff569f 182 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 183 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 184 * @param value[in] Value to write at the address location. Note: The value
Anna Bridge 160:5571c4ff569f 185 * must be already shifted to the correct bit position
Anna Bridge 160:5571c4ff569f 186 */
Anna Bridge 160:5571c4ff569f 187 #define SECURE_BITS_SET_VALUE(address, mask, value) \
Anna Bridge 160:5571c4ff569f 188 *(address) = (*(address) & ~(mask)) | ((value) & (mask))
Anna Bridge 160:5571c4ff569f 189
Anna Bridge 160:5571c4ff569f 190 /** Toggle the selected bits at the target address.
Anna Bridge 160:5571c4ff569f 191 *
Anna Bridge 160:5571c4ff569f 192 * Equivalent to: `*address ^= mask`.
Anna Bridge 160:5571c4ff569f 193 * @param address[in] Target address
Anna Bridge 160:5571c4ff569f 194 * @param mask[in] Bits to select out of the target address
Anna Bridge 160:5571c4ff569f 195 */
Anna Bridge 160:5571c4ff569f 196 #define SECURE_BITS_TOGGLE(address, mask) \
Anna Bridge 160:5571c4ff569f 197 *(address) ^= (mask)
Anna Bridge 160:5571c4ff569f 198
Anna Bridge 160:5571c4ff569f 199 #endif
Anna Bridge 160:5571c4ff569f 200
Anna Bridge 160:5571c4ff569f 201 #endif /* __CORE_CM_SECURE_ACCESS_H */