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:
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?

UserRevisionLine numberNew contents of line
AnnaBridge 145:64910690c574 1 /*
AnnaBridge 145:64910690c574 2 * Copyright (c) 2015, Freescale Semiconductor, Inc.
AnnaBridge 145:64910690c574 3 * All rights reserved.
AnnaBridge 145:64910690c574 4 *
AnnaBridge 145:64910690c574 5 * Redistribution and use in source and binary forms, with or without modification,
AnnaBridge 145:64910690c574 6 * are permitted provided that the following conditions are met:
AnnaBridge 145:64910690c574 7 *
AnnaBridge 145:64910690c574 8 * o Redistributions of source code must retain the above copyright notice, this list
AnnaBridge 145:64910690c574 9 * of conditions and the following disclaimer.
AnnaBridge 145:64910690c574 10 *
AnnaBridge 145:64910690c574 11 * o Redistributions in binary form must reproduce the above copyright notice, this
AnnaBridge 145:64910690c574 12 * list of conditions and the following disclaimer in the documentation and/or
AnnaBridge 145:64910690c574 13 * other materials provided with the distribution.
AnnaBridge 145:64910690c574 14 *
AnnaBridge 145:64910690c574 15 * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
AnnaBridge 145:64910690c574 16 * contributors may be used to endorse or promote products derived from this
AnnaBridge 145:64910690c574 17 * software without specific prior written permission.
AnnaBridge 145:64910690c574 18 *
AnnaBridge 145:64910690c574 19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
AnnaBridge 145:64910690c574 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
AnnaBridge 145:64910690c574 21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
AnnaBridge 145:64910690c574 22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
AnnaBridge 145:64910690c574 23 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
AnnaBridge 145:64910690c574 24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
AnnaBridge 145:64910690c574 25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
AnnaBridge 145:64910690c574 26 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
AnnaBridge 145:64910690c574 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
AnnaBridge 145:64910690c574 28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
AnnaBridge 145:64910690c574 29 */
AnnaBridge 145:64910690c574 30
AnnaBridge 145:64910690c574 31 #ifndef _FSL_FLEXIO_CAMERA_H_
AnnaBridge 145:64910690c574 32 #define _FSL_FLEXIO_CAMERA_H_
AnnaBridge 145:64910690c574 33
AnnaBridge 145:64910690c574 34 #include "fsl_common.h"
AnnaBridge 145:64910690c574 35 #include "fsl_flexio.h"
AnnaBridge 145:64910690c574 36
AnnaBridge 145:64910690c574 37 /*!
AnnaBridge 145:64910690c574 38 * @addtogroup flexio_camera
AnnaBridge 145:64910690c574 39 * @{
AnnaBridge 145:64910690c574 40 */
AnnaBridge 145:64910690c574 41
AnnaBridge 145:64910690c574 42
AnnaBridge 145:64910690c574 43 /*******************************************************************************
AnnaBridge 145:64910690c574 44 * Definitions
AnnaBridge 145:64910690c574 45 ******************************************************************************/
AnnaBridge 145:64910690c574 46
AnnaBridge 145:64910690c574 47 /*! @name Driver version */
AnnaBridge 145:64910690c574 48 /*@{*/
AnnaBridge 145:64910690c574 49 /*! @brief FlexIO Camera driver version 2.1.0. */
AnnaBridge 145:64910690c574 50 #define FSL_FLEXIO_CAMERA_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))
AnnaBridge 145:64910690c574 51 /*@}*/
AnnaBridge 145:64910690c574 52
AnnaBridge 145:64910690c574 53 /*! @brief Define the Camera CPI interface is constantly 8-bit width. */
AnnaBridge 145:64910690c574 54 #define FLEXIO_CAMERA_PARALLEL_DATA_WIDTH (8U)
AnnaBridge 145:64910690c574 55
AnnaBridge 145:64910690c574 56 /*! @brief Error codes for the Camera driver. */
AnnaBridge 145:64910690c574 57 enum _flexio_camera_status
AnnaBridge 145:64910690c574 58 {
AnnaBridge 145:64910690c574 59 kStatus_FLEXIO_CAMERA_RxBusy = MAKE_STATUS(kStatusGroup_FLEXIO_CAMERA, 0), /*!< Receiver is busy. */
AnnaBridge 145:64910690c574 60 kStatus_FLEXIO_CAMERA_RxIdle = MAKE_STATUS(kStatusGroup_FLEXIO_CAMERA, 1), /*!< Camera receiver is idle. */
AnnaBridge 145:64910690c574 61 };
AnnaBridge 145:64910690c574 62
AnnaBridge 145:64910690c574 63 /*! @brief Define FlexIO Camera status mask. */
AnnaBridge 145:64910690c574 64 enum _flexio_camera_status_flags
AnnaBridge 145:64910690c574 65 {
AnnaBridge 145:64910690c574 66 kFLEXIO_CAMERA_RxDataRegFullFlag = 0x1U, /*!< Receive buffer full flag. */
AnnaBridge 145:64910690c574 67 kFLEXIO_CAMERA_RxErrorFlag = 0x2U, /*!< Receive buffer error flag. */
AnnaBridge 145:64910690c574 68 };
AnnaBridge 145:64910690c574 69
AnnaBridge 145:64910690c574 70 /*!
AnnaBridge 145:64910690c574 71 * @brief Define structure of configuring the FlexIO Camera device.
AnnaBridge 145:64910690c574 72 */
AnnaBridge 145:64910690c574 73 typedef struct _flexio_camera_type
AnnaBridge 145:64910690c574 74 {
AnnaBridge 145:64910690c574 75 FLEXIO_Type *flexioBase; /*!< FlexIO module base address. */
AnnaBridge 145:64910690c574 76 uint32_t datPinStartIdx; /*!< First data pin (D0) index for flexio_camera.
AnnaBridge 145:64910690c574 77 Then the successive following FLEXIO_CAMERA_DATA_WIDTH-1 pins
AnnaBridge 145:64910690c574 78 are used as D1-D7.*/
AnnaBridge 145:64910690c574 79 uint32_t pclkPinIdx; /*!< Pixel clock pin (PCLK) index for flexio_camera. */
AnnaBridge 145:64910690c574 80 uint32_t hrefPinIdx; /*!< Horizontal sync pin (HREF) index for flexio_camera. */
AnnaBridge 145:64910690c574 81
AnnaBridge 145:64910690c574 82 uint32_t shifterStartIdx; /*!< First shifter index used for flexio_camera data FIFO. */
AnnaBridge 145:64910690c574 83 uint32_t shifterCount; /*!< The count of shifters that are used as flexio_camera data FIFO. */
AnnaBridge 145:64910690c574 84 uint32_t timerIdx; /*!< Timer index used for flexio_camera in FlexIO. */
AnnaBridge 145:64910690c574 85 } FLEXIO_CAMERA_Type;
AnnaBridge 145:64910690c574 86
AnnaBridge 145:64910690c574 87 /*! @brief Define FlexIO Camera user configuration structure. */
AnnaBridge 145:64910690c574 88 typedef struct _flexio_camera_config
AnnaBridge 145:64910690c574 89 {
AnnaBridge 145:64910690c574 90 bool enablecamera; /*!< Enable/disable FlexIO Camera TX & RX. */
AnnaBridge 145:64910690c574 91 bool enableInDoze; /*!< Enable/disable FlexIO operation in doze mode*/
AnnaBridge 145:64910690c574 92 bool enableInDebug; /*!< Enable/disable FlexIO operation in debug mode*/
AnnaBridge 145:64910690c574 93 bool enableFastAccess; /*!< Enable/disable fast access to FlexIO registers,
AnnaBridge 145:64910690c574 94 fast access requires the FlexIO clock to be at least
AnnaBridge 145:64910690c574 95 twice the frequency of the bus clock. */
AnnaBridge 145:64910690c574 96 } flexio_camera_config_t;
AnnaBridge 145:64910690c574 97
AnnaBridge 145:64910690c574 98 /*! @brief Define FlexIO Camera transfer structure. */
AnnaBridge 145:64910690c574 99 typedef struct _flexio_camera_transfer
AnnaBridge 145:64910690c574 100 {
AnnaBridge 145:64910690c574 101 uint32_t dataAddress; /*!< Transfer buffer*/
AnnaBridge 145:64910690c574 102 uint32_t dataNum; /*!< Transfer num*/
AnnaBridge 145:64910690c574 103 } flexio_camera_transfer_t;
AnnaBridge 145:64910690c574 104
AnnaBridge 145:64910690c574 105 /*******************************************************************************
AnnaBridge 145:64910690c574 106 * API
AnnaBridge 145:64910690c574 107 ******************************************************************************/
AnnaBridge 145:64910690c574 108
AnnaBridge 145:64910690c574 109 #if defined(__cplusplus)
AnnaBridge 145:64910690c574 110 extern "C" {
AnnaBridge 145:64910690c574 111 #endif /*_cplusplus*/
AnnaBridge 145:64910690c574 112
AnnaBridge 145:64910690c574 113 /*!
AnnaBridge 145:64910690c574 114 * @name Initialization and configuration
AnnaBridge 145:64910690c574 115 * @{
AnnaBridge 145:64910690c574 116 */
AnnaBridge 145:64910690c574 117
AnnaBridge 145:64910690c574 118 /*!
AnnaBridge 145:64910690c574 119 * @brief Ungates the FlexIO clock, resets the FlexIO module, and configures the FlexIO Camera.
AnnaBridge 145:64910690c574 120 *
AnnaBridge 145:64910690c574 121 * @param base Pointer to FLEXIO_CAMERA_Type structure
AnnaBridge 145:64910690c574 122 * @param config Pointer to flexio_camera_config_t structure
AnnaBridge 145:64910690c574 123 */
AnnaBridge 145:64910690c574 124 void FLEXIO_CAMERA_Init(FLEXIO_CAMERA_Type *base, const flexio_camera_config_t *config);
AnnaBridge 145:64910690c574 125
AnnaBridge 145:64910690c574 126 /*!
AnnaBridge 145:64910690c574 127 * @brief Disables the FlexIO Camera and gates the FlexIO clock.
AnnaBridge 145:64910690c574 128 *
AnnaBridge 145:64910690c574 129 * @note After calling this API, call FLEXO_CAMERA_Init to use the FlexIO Camera module.
AnnaBridge 145:64910690c574 130 *
AnnaBridge 145:64910690c574 131 * @param base Pointer to FLEXIO_CAMERA_Type structure
AnnaBridge 145:64910690c574 132 */
AnnaBridge 145:64910690c574 133 void FLEXIO_CAMERA_Deinit(FLEXIO_CAMERA_Type *base);
AnnaBridge 145:64910690c574 134
AnnaBridge 145:64910690c574 135 /*!
AnnaBridge 145:64910690c574 136 * @brief Gets the default configuration to configure the FlexIO Camera. The configuration
AnnaBridge 145:64910690c574 137 * can be used directly for calling the FLEXIO_CAMERA_Init().
AnnaBridge 145:64910690c574 138 * Example:
AnnaBridge 145:64910690c574 139 @code
AnnaBridge 145:64910690c574 140 flexio_camera_config_t config;
AnnaBridge 145:64910690c574 141 FLEXIO_CAMERA_GetDefaultConfig(&userConfig);
AnnaBridge 145:64910690c574 142 @endcode
AnnaBridge 145:64910690c574 143 * @param config Pointer to the flexio_camera_config_t structure
AnnaBridge 145:64910690c574 144 */
AnnaBridge 145:64910690c574 145 void FLEXIO_CAMERA_GetDefaultConfig(flexio_camera_config_t *config);
AnnaBridge 145:64910690c574 146
AnnaBridge 145:64910690c574 147 /*!
AnnaBridge 145:64910690c574 148 * @brief Enables/disables the FlexIO Camera module operation.
AnnaBridge 145:64910690c574 149 *
AnnaBridge 145:64910690c574 150 * @param base Pointer to the FLEXIO_CAMERA_Type
AnnaBridge 145:64910690c574 151 * @param enable True to enable, false to disable.
AnnaBridge 145:64910690c574 152 */
AnnaBridge 145:64910690c574 153 static inline void FLEXIO_CAMERA_Enable(FLEXIO_CAMERA_Type *base, bool enable)
AnnaBridge 145:64910690c574 154 {
AnnaBridge 145:64910690c574 155 if (enable)
AnnaBridge 145:64910690c574 156 {
AnnaBridge 145:64910690c574 157 base->flexioBase->CTRL |= FLEXIO_CTRL_FLEXEN_MASK;
AnnaBridge 145:64910690c574 158 }
AnnaBridge 145:64910690c574 159 else
AnnaBridge 145:64910690c574 160 {
AnnaBridge 145:64910690c574 161 base->flexioBase->CTRL &= ~FLEXIO_CTRL_FLEXEN_MASK;
AnnaBridge 145:64910690c574 162 }
AnnaBridge 145:64910690c574 163 }
AnnaBridge 145:64910690c574 164
AnnaBridge 145:64910690c574 165 /*! @} */
AnnaBridge 145:64910690c574 166
AnnaBridge 145:64910690c574 167 /*!
AnnaBridge 145:64910690c574 168 * @name Status
AnnaBridge 145:64910690c574 169 * @{
AnnaBridge 145:64910690c574 170 */
AnnaBridge 145:64910690c574 171
AnnaBridge 145:64910690c574 172 /*!
AnnaBridge 145:64910690c574 173 * @brief Gets the FlexIO Camera status flags.
AnnaBridge 145:64910690c574 174 *
AnnaBridge 145:64910690c574 175 * @param base Pointer to FLEXIO_CAMERA_Type structure
AnnaBridge 145:64910690c574 176 * @return FlexIO shifter status flags
AnnaBridge 145:64910690c574 177 * @arg FLEXIO_SHIFTSTAT_SSF_MASK
AnnaBridge 145:64910690c574 178 * @arg 0
AnnaBridge 145:64910690c574 179 */
AnnaBridge 145:64910690c574 180 uint32_t FLEXIO_CAMERA_GetStatusFlags(FLEXIO_CAMERA_Type *base);
AnnaBridge 145:64910690c574 181
AnnaBridge 145:64910690c574 182 /*!
AnnaBridge 145:64910690c574 183 * @brief Clears the receive buffer full flag manually.
AnnaBridge 145:64910690c574 184 *
AnnaBridge 145:64910690c574 185 * @param base Pointer to the device.
AnnaBridge 145:64910690c574 186 * @param mask status flag
AnnaBridge 145:64910690c574 187 * The parameter can be any combination of the following values:
AnnaBridge 145:64910690c574 188 * @arg kFLEXIO_CAMERA_RxDataRegFullFlag
AnnaBridge 145:64910690c574 189 * @arg kFLEXIO_CAMERA_RxErrorFlag
AnnaBridge 145:64910690c574 190 */
AnnaBridge 145:64910690c574 191 void FLEXIO_CAMERA_ClearStatusFlags(FLEXIO_CAMERA_Type *base, uint32_t mask);
AnnaBridge 145:64910690c574 192
AnnaBridge 145:64910690c574 193 /* @} */
AnnaBridge 145:64910690c574 194
AnnaBridge 145:64910690c574 195 /*!
AnnaBridge 145:64910690c574 196 * @name Interrupts
AnnaBridge 145:64910690c574 197 * @{
AnnaBridge 145:64910690c574 198 */
AnnaBridge 145:64910690c574 199
AnnaBridge 145:64910690c574 200 /*!
AnnaBridge 145:64910690c574 201 * @brief Switches on the interrupt for receive buffer full event.
AnnaBridge 145:64910690c574 202 *
AnnaBridge 145:64910690c574 203 * @param base Pointer to the device.
AnnaBridge 145:64910690c574 204 */
AnnaBridge 145:64910690c574 205 void FLEXIO_CAMERA_EnableInterrupt(FLEXIO_CAMERA_Type *base);
AnnaBridge 145:64910690c574 206
AnnaBridge 145:64910690c574 207 /*!
AnnaBridge 145:64910690c574 208 * @brief Switches off the interrupt for receive buffer full event.
AnnaBridge 145:64910690c574 209 *
AnnaBridge 145:64910690c574 210 * @param base Pointer to the device.
AnnaBridge 145:64910690c574 211 *
AnnaBridge 145:64910690c574 212 */
AnnaBridge 145:64910690c574 213 void FLEXIO_CAMERA_DisableInterrupt(FLEXIO_CAMERA_Type *base);
AnnaBridge 145:64910690c574 214
AnnaBridge 145:64910690c574 215 /*! @} */
AnnaBridge 145:64910690c574 216
AnnaBridge 145:64910690c574 217 /*!
AnnaBridge 145:64910690c574 218 * @name DMA support
AnnaBridge 145:64910690c574 219 * @{
AnnaBridge 145:64910690c574 220 */
AnnaBridge 145:64910690c574 221
AnnaBridge 145:64910690c574 222 /*!
AnnaBridge 145:64910690c574 223 * @brief Enables/disables the FlexIO Camera receive DMA.
AnnaBridge 145:64910690c574 224 *
AnnaBridge 145:64910690c574 225 * @param base Pointer to FLEXIO_CAMERA_Type structure
AnnaBridge 145:64910690c574 226 * @param enable True to enable, false to disable.
AnnaBridge 145:64910690c574 227 *
AnnaBridge 145:64910690c574 228 * The FlexIO Camera mode can't work without the DMA or eDMA support,
AnnaBridge 145:64910690c574 229 * Usually, it needs at least two DMA or eDMA channels, one for transferring data from
AnnaBridge 145:64910690c574 230 * Camera, such as 0V7670 to FlexIO buffer, another is for transferring data from FlexIO
AnnaBridge 145:64910690c574 231 * buffer to LCD.
AnnaBridge 145:64910690c574 232 *
AnnaBridge 145:64910690c574 233 */
AnnaBridge 145:64910690c574 234 static inline void FLEXIO_CAMERA_EnableRxDMA(FLEXIO_CAMERA_Type *base, bool enable)
AnnaBridge 145:64910690c574 235 {
AnnaBridge 145:64910690c574 236 FLEXIO_EnableShifterStatusDMA(base->flexioBase, 1 << base->shifterStartIdx, enable);
AnnaBridge 145:64910690c574 237 }
AnnaBridge 145:64910690c574 238
AnnaBridge 145:64910690c574 239 /*!
AnnaBridge 145:64910690c574 240 * @brief Gets the data from the receive buffer.
AnnaBridge 145:64910690c574 241 *
AnnaBridge 145:64910690c574 242 * @param base Pointer to the device.
AnnaBridge 145:64910690c574 243 * @return data Pointer to the buffer that keeps the data with count of base->shifterCount .
AnnaBridge 145:64910690c574 244 */
AnnaBridge 145:64910690c574 245 static inline uint32_t FLEXIO_CAMERA_GetRxBufferAddress(FLEXIO_CAMERA_Type *base)
AnnaBridge 145:64910690c574 246 {
AnnaBridge 145:64910690c574 247 return FLEXIO_GetShifterBufferAddress(base->flexioBase, kFLEXIO_ShifterBuffer, base->shifterStartIdx);
AnnaBridge 145:64910690c574 248 }
AnnaBridge 145:64910690c574 249
AnnaBridge 145:64910690c574 250 /*! @} */
AnnaBridge 145:64910690c574 251
AnnaBridge 145:64910690c574 252 #if defined(__cplusplus)
AnnaBridge 145:64910690c574 253 }
AnnaBridge 145:64910690c574 254 #endif /*_cplusplus*/
AnnaBridge 145:64910690c574 255
AnnaBridge 145:64910690c574 256 /*@}*/
AnnaBridge 145:64910690c574 257
AnnaBridge 145:64910690c574 258 #endif /*_FSL_FLEXIO_CAMERA_H_*/