mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Thu Sep 06 13:40:20 2018 +0100
Revision:
187:0387e8f68319
Parent:
184:08ed48f1de7f
Child:
189:f392fc9709a3
mbed-dev library. Release version 163

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 184:08ed48f1de7f 1 /** \addtogroup hal */
AnnaBridge 184:08ed48f1de7f 2 /** @{*/
AnnaBridge 184:08ed48f1de7f 3 /* mbed Microcontroller Library
AnnaBridge 184:08ed48f1de7f 4 * Copyright (c) 2017 ARM Limited
AnnaBridge 184:08ed48f1de7f 5 *
AnnaBridge 184:08ed48f1de7f 6 * Licensed under the Apache License, Version 2.0 (the "License");
AnnaBridge 184:08ed48f1de7f 7 * you may not use this file except in compliance with the License.
AnnaBridge 184:08ed48f1de7f 8 * You may obtain a copy of the License at
AnnaBridge 184:08ed48f1de7f 9 *
AnnaBridge 184:08ed48f1de7f 10 * http://www.apache.org/licenses/LICENSE-2.0
AnnaBridge 184:08ed48f1de7f 11 *
AnnaBridge 184:08ed48f1de7f 12 * Unless required by applicable law or agreed to in writing, software
AnnaBridge 184:08ed48f1de7f 13 * distributed under the License is distributed on an "AS IS" BASIS,
AnnaBridge 184:08ed48f1de7f 14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
AnnaBridge 184:08ed48f1de7f 15 * See the License for the specific language governing permissions and
AnnaBridge 184:08ed48f1de7f 16 * limitations under the License.
AnnaBridge 184:08ed48f1de7f 17 */
AnnaBridge 184:08ed48f1de7f 18
AnnaBridge 184:08ed48f1de7f 19 #ifndef MBED_ITM_API_H
AnnaBridge 184:08ed48f1de7f 20 #define MBED_ITM_API_H
AnnaBridge 184:08ed48f1de7f 21
AnnaBridge 184:08ed48f1de7f 22 #if defined(DEVICE_ITM)
AnnaBridge 184:08ed48f1de7f 23
AnnaBridge 184:08ed48f1de7f 24 #include <stdint.h>
AnnaBridge 187:0387e8f68319 25 #include <stddef.h>
AnnaBridge 184:08ed48f1de7f 26
AnnaBridge 184:08ed48f1de7f 27 #ifdef __cplusplus
AnnaBridge 184:08ed48f1de7f 28 extern "C" {
AnnaBridge 184:08ed48f1de7f 29 #endif
AnnaBridge 184:08ed48f1de7f 30
AnnaBridge 184:08ed48f1de7f 31 /**
AnnaBridge 184:08ed48f1de7f 32 * \defgroup itm_hal Instrumented Trace Macrocell HAL API
AnnaBridge 184:08ed48f1de7f 33 * @{
AnnaBridge 184:08ed48f1de7f 34 */
AnnaBridge 184:08ed48f1de7f 35
AnnaBridge 184:08ed48f1de7f 36 enum {
AnnaBridge 184:08ed48f1de7f 37 ITM_PORT_SWO = 0
AnnaBridge 184:08ed48f1de7f 38 };
AnnaBridge 184:08ed48f1de7f 39
AnnaBridge 184:08ed48f1de7f 40 /**
AnnaBridge 184:08ed48f1de7f 41 * @brief Target specific initialization function.
AnnaBridge 187:0387e8f68319 42 * This function is responsible for initializing and configuring
AnnaBridge 187:0387e8f68319 43 * the debug clock for the ITM and setting up the SWO pin for
AnnaBridge 184:08ed48f1de7f 44 * debug output.
AnnaBridge 187:0387e8f68319 45 *
AnnaBridge 184:08ed48f1de7f 46 * The only Cortex-M register that should be modified is the clock
AnnaBridge 184:08ed48f1de7f 47 * prescaler in TPI->ACPR.
AnnaBridge 187:0387e8f68319 48 *
AnnaBridge 187:0387e8f68319 49 * The generic mbed_itm_init initialization function will setup:
AnnaBridge 187:0387e8f68319 50 *
AnnaBridge 184:08ed48f1de7f 51 * ITM->LAR
AnnaBridge 184:08ed48f1de7f 52 * ITM->TPR
AnnaBridge 184:08ed48f1de7f 53 * ITM->TCR
AnnaBridge 184:08ed48f1de7f 54 * ITM->TER
AnnaBridge 184:08ed48f1de7f 55 * TPI->SPPR
AnnaBridge 184:08ed48f1de7f 56 * TPI->FFCR
AnnaBridge 184:08ed48f1de7f 57 * DWT->CTRL
AnnaBridge 187:0387e8f68319 58 *
AnnaBridge 184:08ed48f1de7f 59 * for SWO output on stimulus port 0.
AnnaBridge 184:08ed48f1de7f 60 */
AnnaBridge 184:08ed48f1de7f 61 void itm_init(void);
AnnaBridge 184:08ed48f1de7f 62
AnnaBridge 184:08ed48f1de7f 63 /**
AnnaBridge 184:08ed48f1de7f 64 * @brief Initialization function for both generic registers and target specific clock and pin.
AnnaBridge 184:08ed48f1de7f 65 */
AnnaBridge 184:08ed48f1de7f 66 void mbed_itm_init(void);
AnnaBridge 184:08ed48f1de7f 67
AnnaBridge 184:08ed48f1de7f 68 /**
AnnaBridge 184:08ed48f1de7f 69 * @brief Send data over ITM stimulus port.
AnnaBridge 184:08ed48f1de7f 70 *
AnnaBridge 184:08ed48f1de7f 71 * @param[in] port The stimulus port to send data over.
AnnaBridge 187:0387e8f68319 72 * @param[in] data The 32-bit data to send.
AnnaBridge 187:0387e8f68319 73 *
AnnaBridge 187:0387e8f68319 74 * The data is written as a single 32-bit write to the port.
AnnaBridge 184:08ed48f1de7f 75 *
AnnaBridge 184:08ed48f1de7f 76 * @return value of data sent.
AnnaBridge 184:08ed48f1de7f 77 */
AnnaBridge 184:08ed48f1de7f 78 uint32_t mbed_itm_send(uint32_t port, uint32_t data);
AnnaBridge 184:08ed48f1de7f 79
AnnaBridge 187:0387e8f68319 80 /**
AnnaBridge 187:0387e8f68319 81 * @brief Send a block of data over ITM stimulus port.
AnnaBridge 187:0387e8f68319 82 *
AnnaBridge 187:0387e8f68319 83 * @param[in] port The stimulus port to send data over.
AnnaBridge 187:0387e8f68319 84 * @param[in] data The block of data to send.
AnnaBridge 187:0387e8f68319 85 * @param[in] len The number of bytes of data to send.
AnnaBridge 187:0387e8f68319 86 *
AnnaBridge 187:0387e8f68319 87 * The data is written using multiple appropriately-sized port accesses for
AnnaBridge 187:0387e8f68319 88 * efficient transfer.
AnnaBridge 187:0387e8f68319 89 */
AnnaBridge 187:0387e8f68319 90 void mbed_itm_send_block(uint32_t port, const void *data, size_t len);
AnnaBridge 187:0387e8f68319 91
AnnaBridge 184:08ed48f1de7f 92 /**@}*/
AnnaBridge 184:08ed48f1de7f 93
AnnaBridge 184:08ed48f1de7f 94 #ifdef __cplusplus
AnnaBridge 184:08ed48f1de7f 95 }
AnnaBridge 184:08ed48f1de7f 96 #endif
AnnaBridge 184:08ed48f1de7f 97
AnnaBridge 184:08ed48f1de7f 98 #endif
AnnaBridge 184:08ed48f1de7f 99
AnnaBridge 184:08ed48f1de7f 100 #endif /* MBED_ITM_API_H */
AnnaBridge 184:08ed48f1de7f 101
AnnaBridge 184:08ed48f1de7f 102 /**@}*/