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.
TARGET_ARM_BEETLE_SOC/TOOLCHAIN_ARM_STD/drv_console.h@172:65be27845400, 2019-02-20 (annotated)
- Committer:
- AnnaBridge
- Date:
- Wed Feb 20 20:53:29 2019 +0000
- Revision:
- 172:65be27845400
- Parent:
- 171:3a7713b1edbc
mbed library release version 165
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
AnnaBridge | 171:3a7713b1edbc | 1 | /*************************************************************************************************/ |
AnnaBridge | 171:3a7713b1edbc | 2 | /*! |
AnnaBridge | 171:3a7713b1edbc | 3 | * \file drv_console.h |
AnnaBridge | 171:3a7713b1edbc | 4 | * |
AnnaBridge | 171:3a7713b1edbc | 5 | * \brief Upper-layer UART driver. |
AnnaBridge | 171:3a7713b1edbc | 6 | * |
AnnaBridge | 171:3a7713b1edbc | 7 | * Copyright (c) 2015 ARM, Ltd., all rights reserved. |
AnnaBridge | 171:3a7713b1edbc | 8 | * ARM confidential and proprietary. |
AnnaBridge | 171:3a7713b1edbc | 9 | * |
AnnaBridge | 171:3a7713b1edbc | 10 | * IMPORTANT. Your use of this file is governed by a Software License Agreement |
AnnaBridge | 171:3a7713b1edbc | 11 | * ("Agreement") that must be accepted in order to download or otherwise receive a |
AnnaBridge | 171:3a7713b1edbc | 12 | * copy of this file. You may not use or copy this file for any purpose other than |
AnnaBridge | 171:3a7713b1edbc | 13 | * as described in the Agreement. If you do not agree to all of the terms of the |
AnnaBridge | 171:3a7713b1edbc | 14 | * Agreement do not use this file and delete all copies in your possession or control; |
AnnaBridge | 171:3a7713b1edbc | 15 | * if you do not have a copy of the Agreement, you must contact ARM, Ltd. prior |
AnnaBridge | 171:3a7713b1edbc | 16 | * to any use, copying or further distribution of this software. |
AnnaBridge | 171:3a7713b1edbc | 17 | */ |
AnnaBridge | 171:3a7713b1edbc | 18 | /*************************************************************************************************/ |
AnnaBridge | 171:3a7713b1edbc | 19 | |
AnnaBridge | 171:3a7713b1edbc | 20 | #ifndef __DRV_CONSOLE_H |
AnnaBridge | 171:3a7713b1edbc | 21 | #define __DRV_CONSOLE_H |
AnnaBridge | 171:3a7713b1edbc | 22 | |
AnnaBridge | 171:3a7713b1edbc | 23 | #ifdef __cplusplus |
AnnaBridge | 171:3a7713b1edbc | 24 | extern "C" { |
AnnaBridge | 171:3a7713b1edbc | 25 | #endif |
AnnaBridge | 171:3a7713b1edbc | 26 | |
AnnaBridge | 171:3a7713b1edbc | 27 | /*************************************************************************************************** |
AnnaBridge | 171:3a7713b1edbc | 28 | ** INCLUDES |
AnnaBridge | 171:3a7713b1edbc | 29 | ***************************************************************************************************/ |
AnnaBridge | 171:3a7713b1edbc | 30 | |
AnnaBridge | 171:3a7713b1edbc | 31 | #include "chip.h" |
AnnaBridge | 171:3a7713b1edbc | 32 | #include "board.h" |
AnnaBridge | 171:3a7713b1edbc | 33 | |
AnnaBridge | 171:3a7713b1edbc | 34 | /*************************************************************************************************** |
AnnaBridge | 171:3a7713b1edbc | 35 | ** DEFINES |
AnnaBridge | 171:3a7713b1edbc | 36 | ***************************************************************************************************/ |
AnnaBridge | 171:3a7713b1edbc | 37 | |
AnnaBridge | 171:3a7713b1edbc | 38 | /*-------------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 39 | ** ENABLE/DISABLE, ON/OFF DEFINES |
AnnaBridge | 171:3a7713b1edbc | 40 | ** |
AnnaBridge | 171:3a7713b1edbc | 41 | ** DESCRIPTION: For clarity in enable parameters. |
AnnaBridge | 171:3a7713b1edbc | 42 | --------------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 43 | |
AnnaBridge | 171:3a7713b1edbc | 44 | #ifndef DRV_ENABLE |
AnnaBridge | 171:3a7713b1edbc | 45 | #define DRV_ENABLE 1 |
AnnaBridge | 171:3a7713b1edbc | 46 | #endif |
AnnaBridge | 171:3a7713b1edbc | 47 | |
AnnaBridge | 171:3a7713b1edbc | 48 | #ifndef DRV_DISABLE |
AnnaBridge | 171:3a7713b1edbc | 49 | #define DRV_DISABLE 0 |
AnnaBridge | 171:3a7713b1edbc | 50 | #endif |
AnnaBridge | 171:3a7713b1edbc | 51 | |
AnnaBridge | 171:3a7713b1edbc | 52 | #ifndef DRV_ON |
AnnaBridge | 171:3a7713b1edbc | 53 | #define DRV_ON 1 |
AnnaBridge | 171:3a7713b1edbc | 54 | #endif |
AnnaBridge | 171:3a7713b1edbc | 55 | |
AnnaBridge | 171:3a7713b1edbc | 56 | #ifndef DRV_OFF |
AnnaBridge | 171:3a7713b1edbc | 57 | #define DRV_OFF 0 |
AnnaBridge | 171:3a7713b1edbc | 58 | #endif |
AnnaBridge | 171:3a7713b1edbc | 59 | |
AnnaBridge | 171:3a7713b1edbc | 60 | /*-------------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 61 | ** TX/RX DEFINES |
AnnaBridge | 171:3a7713b1edbc | 62 | ** |
AnnaBridge | 171:3a7713b1edbc | 63 | ** DESCRIPTION: For tx/rx argument of driver functions. |
AnnaBridge | 171:3a7713b1edbc | 64 | --------------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 65 | |
AnnaBridge | 171:3a7713b1edbc | 66 | #define DRV_CONSOLE_TX (1u << 0) |
AnnaBridge | 171:3a7713b1edbc | 67 | #define DRV_CONSOLE_RX (1u << 1) |
AnnaBridge | 171:3a7713b1edbc | 68 | |
AnnaBridge | 171:3a7713b1edbc | 69 | /*-------------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 70 | ** DRV_CONSOLE_BUF_LEN |
AnnaBridge | 171:3a7713b1edbc | 71 | ** |
AnnaBridge | 171:3a7713b1edbc | 72 | ** DESCRIPTION: The maximum length of printed strings. |
AnnaBridge | 171:3a7713b1edbc | 73 | **------------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 74 | #define DRV_CONSOLE_BUF_LEN 128u |
AnnaBridge | 171:3a7713b1edbc | 75 | |
AnnaBridge | 171:3a7713b1edbc | 76 | /*************************************************************************************************** |
AnnaBridge | 171:3a7713b1edbc | 77 | ** TYPES |
AnnaBridge | 171:3a7713b1edbc | 78 | ***************************************************************************************************/ |
AnnaBridge | 171:3a7713b1edbc | 79 | |
AnnaBridge | 171:3a7713b1edbc | 80 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 81 | ** DRV_CONSOLE_RX_CALLBACK_t() |
AnnaBridge | 171:3a7713b1edbc | 82 | ** |
AnnaBridge | 171:3a7713b1edbc | 83 | ** DESCRIPTION: Callback for received byte. |
AnnaBridge | 171:3a7713b1edbc | 84 | ** |
AnnaBridge | 171:3a7713b1edbc | 85 | ** PARAMETERS: c Received byte |
AnnaBridge | 171:3a7713b1edbc | 86 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 87 | |
AnnaBridge | 171:3a7713b1edbc | 88 | typedef void (*DRV_CONSOLE_RX_CALLBACK_t)(uint8_t c); |
AnnaBridge | 171:3a7713b1edbc | 89 | |
AnnaBridge | 171:3a7713b1edbc | 90 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 91 | ** DRV_CONSOLE_TX_COMPLETE_CALLBACK_t() |
AnnaBridge | 171:3a7713b1edbc | 92 | ** |
AnnaBridge | 171:3a7713b1edbc | 93 | ** DESCRIPTION: Callback for transmission completion. |
AnnaBridge | 171:3a7713b1edbc | 94 | ** |
AnnaBridge | 171:3a7713b1edbc | 95 | ** PARAMETERS: buf Pointer to buffer that was transmitted |
AnnaBridge | 171:3a7713b1edbc | 96 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 97 | |
AnnaBridge | 171:3a7713b1edbc | 98 | typedef void (*DRV_CONSOLE_TX_COMPLETE_CALLBACK_t)(const uint8_t *buf); |
AnnaBridge | 171:3a7713b1edbc | 99 | |
AnnaBridge | 171:3a7713b1edbc | 100 | /*-------------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 101 | ** struct drv_console |
AnnaBridge | 171:3a7713b1edbc | 102 | ** |
AnnaBridge | 171:3a7713b1edbc | 103 | ** DESCRIPTION: Access structure of driver. |
AnnaBridge | 171:3a7713b1edbc | 104 | --------------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 105 | |
AnnaBridge | 171:3a7713b1edbc | 106 | struct drv_console { |
AnnaBridge | 171:3a7713b1edbc | 107 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 108 | ** Initialize() |
AnnaBridge | 171:3a7713b1edbc | 109 | ** |
AnnaBridge | 171:3a7713b1edbc | 110 | ** DESCRIPTION: Initialize console. |
AnnaBridge | 171:3a7713b1edbc | 111 | ** |
AnnaBridge | 171:3a7713b1edbc | 112 | ** PARAMETERS: baud Baud rate |
AnnaBridge | 171:3a7713b1edbc | 113 | ** rx_tx Indicates allowed modes of driver (DRV_CONSOLE_RX &/| DRV_CONSOLE_TX). |
AnnaBridge | 171:3a7713b1edbc | 114 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 115 | void (*Initialize)(uint32_t baud, uint32_t rx_tx); |
AnnaBridge | 171:3a7713b1edbc | 116 | |
AnnaBridge | 171:3a7713b1edbc | 117 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 118 | ** Receive() |
AnnaBridge | 171:3a7713b1edbc | 119 | ** |
AnnaBridge | 171:3a7713b1edbc | 120 | ** DESCRIPTION: Receive data. |
AnnaBridge | 171:3a7713b1edbc | 121 | ** |
AnnaBridge | 171:3a7713b1edbc | 122 | ** PARAMETERS: buf Pointer to buffer that will receive data |
AnnaBridge | 171:3a7713b1edbc | 123 | ** len Number of data bytes to data |
AnnaBridge | 171:3a7713b1edbc | 124 | ** |
AnnaBridge | 171:3a7713b1edbc | 125 | ** RETURNS: Number of bytes received |
AnnaBridge | 171:3a7713b1edbc | 126 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 127 | int32_t (*Receive)(uint8_t *buf, uint32_t len); |
AnnaBridge | 171:3a7713b1edbc | 128 | |
AnnaBridge | 171:3a7713b1edbc | 129 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 130 | ** ReceiveAsyncStart() |
AnnaBridge | 171:3a7713b1edbc | 131 | ** |
AnnaBridge | 171:3a7713b1edbc | 132 | ** DESCRIPTION: Start receiving data asynchronously. |
AnnaBridge | 171:3a7713b1edbc | 133 | ** |
AnnaBridge | 171:3a7713b1edbc | 134 | ** PARAMETERS: cb Callback for receive events |
AnnaBridge | 171:3a7713b1edbc | 135 | ** |
AnnaBridge | 171:3a7713b1edbc | 136 | ** RETURNS: 0 or error (if not zero) |
AnnaBridge | 171:3a7713b1edbc | 137 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 138 | int32_t (*ReceiveAsyncStart)(DRV_UART_RX_CALLBACK_t cb); |
AnnaBridge | 171:3a7713b1edbc | 139 | |
AnnaBridge | 171:3a7713b1edbc | 140 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 141 | ** ReceiveAsyncStart() |
AnnaBridge | 171:3a7713b1edbc | 142 | ** |
AnnaBridge | 171:3a7713b1edbc | 143 | ** DESCRIPTION: Stop receiving data asynchronously. |
AnnaBridge | 171:3a7713b1edbc | 144 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 145 | void (*ReceiveAsyncStop)(void); |
AnnaBridge | 171:3a7713b1edbc | 146 | |
AnnaBridge | 171:3a7713b1edbc | 147 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 148 | ** Transmit() |
AnnaBridge | 171:3a7713b1edbc | 149 | ** |
AnnaBridge | 171:3a7713b1edbc | 150 | ** DESCRIPTION: Transmit buffer synchronously, waiting for any active transmission to finish. |
AnnaBridge | 171:3a7713b1edbc | 151 | ** |
AnnaBridge | 171:3a7713b1edbc | 152 | ** PARAMETERS: buf Pointer to buffer of data to transmit |
AnnaBridge | 171:3a7713b1edbc | 153 | ** len Number of data bytes to transmit |
AnnaBridge | 171:3a7713b1edbc | 154 | ** |
AnnaBridge | 171:3a7713b1edbc | 155 | ** RETURNS: Number of bytes transmitted |
AnnaBridge | 171:3a7713b1edbc | 156 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 157 | int32_t (*Transmit)(const uint8_t *buf, uint32_t len); |
AnnaBridge | 171:3a7713b1edbc | 158 | |
AnnaBridge | 171:3a7713b1edbc | 159 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 160 | ** TransmitAsync() |
AnnaBridge | 171:3a7713b1edbc | 161 | ** |
AnnaBridge | 171:3a7713b1edbc | 162 | ** DESCRIPTION: Transmit buffer asynchronously, waiting for any active transmission to finish. |
AnnaBridge | 171:3a7713b1edbc | 163 | ** |
AnnaBridge | 171:3a7713b1edbc | 164 | ** PARAMETERS: buf Pointer to buffer of data to transmit |
AnnaBridge | 171:3a7713b1edbc | 165 | ** len Number of data bytes to transmit |
AnnaBridge | 171:3a7713b1edbc | 166 | ** cb Pointer to completion callback |
AnnaBridge | 171:3a7713b1edbc | 167 | ** |
AnnaBridge | 171:3a7713b1edbc | 168 | ** RETURNS: 0 or error (if not zero) |
AnnaBridge | 171:3a7713b1edbc | 169 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 170 | int32_t (*TransmitAsync)(const uint8_t *buf, uint32_t len, DRV_CONSOLE_TX_COMPLETE_CALLBACK_t cb); |
AnnaBridge | 171:3a7713b1edbc | 171 | |
AnnaBridge | 171:3a7713b1edbc | 172 | /*---------------------------------------------------------------------------------------------- |
AnnaBridge | 171:3a7713b1edbc | 173 | ** GetUART() |
AnnaBridge | 171:3a7713b1edbc | 174 | ** |
AnnaBridge | 171:3a7713b1edbc | 175 | ** DESCRIPTION: Get UART associated with this console. |
AnnaBridge | 171:3a7713b1edbc | 176 | ** |
AnnaBridge | 171:3a7713b1edbc | 177 | ** RETURNS: Pointer to UART |
AnnaBridge | 171:3a7713b1edbc | 178 | **--------------------------------------------------------------------------------------------*/ |
AnnaBridge | 171:3a7713b1edbc | 179 | const struct drv_uart *(*GetUART)(void); |
AnnaBridge | 171:3a7713b1edbc | 180 | }; |
AnnaBridge | 171:3a7713b1edbc | 181 | |
AnnaBridge | 171:3a7713b1edbc | 182 | #ifdef __cplusplus |
AnnaBridge | 171:3a7713b1edbc | 183 | } |
AnnaBridge | 171:3a7713b1edbc | 184 | #endif |
AnnaBridge | 171:3a7713b1edbc | 185 | |
AnnaBridge | 171:3a7713b1edbc | 186 | #endif /* __DRV_CONSOLE_H */ |