mbed library sources. Supersedes mbed-src.
Fork of mbed-dev by
targets/TARGET_NUVOTON/TARGET_NUC472/device/StdDriver/nuc472_cap.h@149:156823d33999, 2016-10-28 (annotated)
- Committer:
- <>
- Date:
- Fri Oct 28 11:17:30 2016 +0100
- Revision:
- 149:156823d33999
- Parent:
- targets/cmsis/TARGET_NUVOTON/TARGET_NUC472/StdDriver/nuc472_cap.h@144:ef7eb2e8f9f7
This updates the lib to the mbed lib v128
NOTE: This release includes a restructuring of the file and directory locations and thus some
include paths in your code may need updating accordingly.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
<> | 144:ef7eb2e8f9f7 | 1 | /**************************************************************************//** |
<> | 144:ef7eb2e8f9f7 | 2 | * @file cap.h |
<> | 144:ef7eb2e8f9f7 | 3 | * @version V0.10 |
<> | 144:ef7eb2e8f9f7 | 4 | * $Revision: 16 $ |
<> | 144:ef7eb2e8f9f7 | 5 | * $Date: 14/05/29 1:13p $ |
<> | 144:ef7eb2e8f9f7 | 6 | * @brief NUC470 series Image Capture Driver Header File |
<> | 144:ef7eb2e8f9f7 | 7 | * |
<> | 144:ef7eb2e8f9f7 | 8 | * @note |
<> | 144:ef7eb2e8f9f7 | 9 | * Copyright (C) 2013 Nuvoton Technology Corp. All rights reserved. |
<> | 144:ef7eb2e8f9f7 | 10 | * |
<> | 144:ef7eb2e8f9f7 | 11 | ******************************************************************************/ |
<> | 144:ef7eb2e8f9f7 | 12 | #ifndef __CAP_H__ |
<> | 144:ef7eb2e8f9f7 | 13 | #define __CAP_H__ |
<> | 144:ef7eb2e8f9f7 | 14 | |
<> | 144:ef7eb2e8f9f7 | 15 | #ifdef __cplusplus |
<> | 144:ef7eb2e8f9f7 | 16 | extern "C" |
<> | 144:ef7eb2e8f9f7 | 17 | { |
<> | 144:ef7eb2e8f9f7 | 18 | #endif |
<> | 144:ef7eb2e8f9f7 | 19 | |
<> | 144:ef7eb2e8f9f7 | 20 | /** @addtogroup NUC472_442_Device_Driver NUC472/NUC442 Device Driver |
<> | 144:ef7eb2e8f9f7 | 21 | @{ |
<> | 144:ef7eb2e8f9f7 | 22 | */ |
<> | 144:ef7eb2e8f9f7 | 23 | |
<> | 144:ef7eb2e8f9f7 | 24 | /** @addtogroup NUC472_442_CAP_Driver CAP Driver |
<> | 144:ef7eb2e8f9f7 | 25 | @{ |
<> | 144:ef7eb2e8f9f7 | 26 | */ |
<> | 144:ef7eb2e8f9f7 | 27 | |
<> | 144:ef7eb2e8f9f7 | 28 | /** @addtogroup NUC472_442_CAP_EXPORTED_CONSTANTS CAP Exported Constants |
<> | 144:ef7eb2e8f9f7 | 29 | @{ |
<> | 144:ef7eb2e8f9f7 | 30 | */ |
<> | 144:ef7eb2e8f9f7 | 31 | |
<> | 144:ef7eb2e8f9f7 | 32 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 33 | /* VINCTRL constant definitions */ |
<> | 144:ef7eb2e8f9f7 | 34 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 35 | #define CAP_CTL_CAPEN (1ul<<CAP_CTL_CAPEN_Pos) /*!< CAP CTL setting for enabling capture engine mode \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 36 | #define CAP_CTL_ADDRSW (1ul<<CAP_CTL_ADDRSW_Pos) /*!< CAP CTL setting for packet buffer address switch \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 37 | #define CAP_CTL_PKTEN (1ul<<CAP_CTL_PKTEN_Pos) /*!< CAP CTL setting for enabling packet output mode \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 38 | #define CAP_CTL_PLNEN (1ul<<CAP_CTL_PLNEN_Pos) /*!< CAP CTL setting for enabling planar output mode \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 39 | #define CAP_CTL_SHUTTER (1ul<<CAP_CTL_SHUTTER_Pos) /*!< CAP CTL setting for enabling shutter mode \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 40 | #define CAP_CTL_UPDATE (1ul<<CAP_CTL_UPDATE_Pos) /*!< CAP CTL setting for enabling update register at new frame \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 41 | #define CAP_CTL_RESET (1ul<<CAP_CTL_VPRST_Pos) /*!< CAP CTL setting for capture reset \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 42 | |
<> | 144:ef7eb2e8f9f7 | 43 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 44 | /* CAPPAR constant definitions */ |
<> | 144:ef7eb2e8f9f7 | 45 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 46 | #define CAP_PAR_INFMT_YUV422 (0ul<<CAP_PAR_INFMT_Pos) /*!< CAP PAR setting for Sensor Input Data YUV422 Format \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 47 | #define CAP_PAR_INFMT_RGB565 (1ul<<CAP_PAR_INFMT_Pos) /*!< CAP PAR setting for Sensor Input Data RGB565 Format \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 48 | |
<> | 144:ef7eb2e8f9f7 | 49 | #define CAP_PAR_SENTYPE_CCIR601 (0ul<<CAP_PAR_SENTYPE_Pos) /*!< CAP PAR setting for Sensor Input CCIR601 Type \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 50 | #define CAP_PAR_SENTYPE_CCIR656 (1ul<<CAP_PAR_SENTYPE_Pos) /*!< CAP PAR setting for Sensor Input CCIR656 Type \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 51 | |
<> | 144:ef7eb2e8f9f7 | 52 | #define CAP_PAR_INDATORD_YUYV (0x0ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, YUYV \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 53 | #define CAP_PAR_INDATORD_YVYU (0x1ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, YVYU \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 54 | #define CAP_PAR_INDATORD_UYVY (0x2ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, UYVY \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 55 | #define CAP_PAR_INDATORD_VYUY (0x3ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, VYUY \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 56 | |
<> | 144:ef7eb2e8f9f7 | 57 | #define CAP_PAR_INDATORD_RGGB (0x0ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, 0byte: R[0:4] G[5:8], 1byte G[0:2] R[3:8] \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 58 | #define CAP_PAR_INDATORD_BGGR (0x1ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, 0byte: b[0:4] G[5:8], 1byte G[0:2] R[3:8] \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 59 | #define CAP_PAR_INDATORD_GBRG (0x2ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, 0byte: G[0:3] G[4:8], 1byte G[0:4] G[5:8] \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 60 | #define CAP_PAR_INDATORD_GRBG (0x3ul<<CAP_PAR_INDATORD_Pos) /*!< CAP PAR setting for Sensor Input Data Order, 0byte: G[0:3] G[4:8], 1byte G[0:4] G[5:8] \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 61 | |
<> | 144:ef7eb2e8f9f7 | 62 | #define CAP_PAR_OUTFMT_YUV422 (0x0ul<<CAP_PAR_OUTFMT_Pos) /*!< CAP PAR setting for Image Data YUV422 Format Output to System Memory \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 63 | #define CAP_PAR_OUTFMT_ONLY_Y (0x1ul<<CAP_PAR_OUTFMT_Pos) /*!< CAP PAR setting for Image Data ONLY_Y Format Output to System Memory \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 64 | #define CAP_PAR_OUTFMT_RGB555 (0x2ul<<CAP_PAR_OUTFMT_Pos) /*!< CAP PAR setting for Image Data RGB555 Format Output to System Memory \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 65 | #define CAP_PAR_OUTFMT_RGB565 (0x3ul<<CAP_PAR_OUTFMT_Pos) /*!< CAP PAR setting for Image Data RGB565 Format Output to System Memory \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 66 | |
<> | 144:ef7eb2e8f9f7 | 67 | #define CAP_PAR_PLNFMT_YUV422 (0x0ul<<CAP_PAR_PLNFMT_Pos) /*!< CAP PAR setting for Planar Output YUV422 Format \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 68 | #define CAP_PAR_PLNFMT_YUV420 (0x1ul<<CAP_PAR_PLNFMT_Pos) /*!< CAP PAR setting for Planar Output YUV420 Format \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 69 | |
<> | 144:ef7eb2e8f9f7 | 70 | #define CAP_PAR_VSP_LOW (0x0ul<<CAP_PAR_VSP_Pos) /*!< CAP PAR setting for Sensor Vsync Polarity \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 71 | #define CAP_PAR_VSP_HIGH (0x1ul<<CAP_PAR_VSP_Pos) /*!< CAP PAR setting for Sensor Vsync Polarity \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 72 | #define CAP_PAR_HSP_LOW (0x0ul<<CAP_PAR_HSP_Pos) /*!< CAP PAR setting for Sensor Hsync Polarity \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 73 | #define CAP_PAR_HSP_HIGH (0x1ul<<CAP_PAR_HSP_Pos) /*!< CAP PAR setting for Sensor Hsync Polarity \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 74 | #define CAP_PAR_PCLKP_LOW (0x0ul<<CAP_PAR_PCLKP_Pos) /*!< CAP PAR setting for Sensor Pixel Clock Polarity \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 75 | #define CAP_PAR_PCLKP_HIGH (0x1ul<<CAP_PAR_PCLKP_Pos) /*!< CAP PAR setting for Sensor Pixel Clock Polarity \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 76 | |
<> | 144:ef7eb2e8f9f7 | 77 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 78 | /* VININT constant definitions */ |
<> | 144:ef7eb2e8f9f7 | 79 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 80 | #define CAP_INT_VIEN_ENABLE (0x1ul<<CAP_INT_VIEN_Pos) /*!< VININT setting for Frame End Interrupt enable \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 81 | #define CAP_INT_MEIEN_ENABLE (0x1ul<<CAP_INT_MEIEN_Pos) /*!< VININT setting for Bus Master Transfer Error Interrupt enable \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 82 | #define CAP_INT_ADDRMIEN_ENABLE (0x1ul<<CAP_INT_ADDRMIEN_Pos) /*!< VININT setting for Memory Address Match Interrupt enable \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 83 | #define CAP_INT_MDIEN_ENABLE (0x1ul<<CAP_INT_MDIEN_Pos) /*!< VININT setting for Motion Detection Output Finish Interrupt Enable enable \hideinitializer */ |
<> | 144:ef7eb2e8f9f7 | 84 | |
<> | 144:ef7eb2e8f9f7 | 85 | |
<> | 144:ef7eb2e8f9f7 | 86 | static uint32_t u32EscapeFrame = 0; |
<> | 144:ef7eb2e8f9f7 | 87 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 88 | /* Define Error Code */ |
<> | 144:ef7eb2e8f9f7 | 89 | /*---------------------------------------------------------------------------------------------------------*/ |
<> | 144:ef7eb2e8f9f7 | 90 | #define CAP_INVALID_INT ((int32_t)(0xFFFFFFFF-1)) |
<> | 144:ef7eb2e8f9f7 | 91 | #define CAP_INVALID_BUF ((int32_t)(0xFFFFFFFF-2)) |
<> | 144:ef7eb2e8f9f7 | 92 | #define CAP_INVALID_PIPE ((int32_t)(0xFFFFFFFF-3)) |
<> | 144:ef7eb2e8f9f7 | 93 | |
<> | 144:ef7eb2e8f9f7 | 94 | |
<> | 144:ef7eb2e8f9f7 | 95 | /*@}*/ /* end of group NUC472_442_CAP_EXPORTED_CONSTANTS */ |
<> | 144:ef7eb2e8f9f7 | 96 | |
<> | 144:ef7eb2e8f9f7 | 97 | |
<> | 144:ef7eb2e8f9f7 | 98 | |
<> | 144:ef7eb2e8f9f7 | 99 | /** @addtogroup NUC472_442_CAP_EXPORTED_FUNCTIONS CAP Exported Functions |
<> | 144:ef7eb2e8f9f7 | 100 | @{ |
<> | 144:ef7eb2e8f9f7 | 101 | */ |
<> | 144:ef7eb2e8f9f7 | 102 | |
<> | 144:ef7eb2e8f9f7 | 103 | /** |
<> | 144:ef7eb2e8f9f7 | 104 | * @brief Is CAP module Enable |
<> | 144:ef7eb2e8f9f7 | 105 | * |
<> | 144:ef7eb2e8f9f7 | 106 | * @return FALSE(Enable) or TRUE(Disable) |
<> | 144:ef7eb2e8f9f7 | 107 | * |
<> | 144:ef7eb2e8f9f7 | 108 | * @details Check Image Capture Interface module Enable or Disable |
<> | 144:ef7eb2e8f9f7 | 109 | * \hideinitializer |
<> | 144:ef7eb2e8f9f7 | 110 | */ |
<> | 144:ef7eb2e8f9f7 | 111 | #define CAP_IS_STOPPED() ((ICAP->CTL & CAP_CTL_CAPEN_Msk)?0:1) |
<> | 144:ef7eb2e8f9f7 | 112 | |
<> | 144:ef7eb2e8f9f7 | 113 | /** |
<> | 144:ef7eb2e8f9f7 | 114 | * @brief Clear CAP flag |
<> | 144:ef7eb2e8f9f7 | 115 | * |
<> | 144:ef7eb2e8f9f7 | 116 | * @param[in] u32IntMask interrupt flags settings. It could be |
<> | 144:ef7eb2e8f9f7 | 117 | * - \ref CAP_INT_VINTF_Msk |
<> | 144:ef7eb2e8f9f7 | 118 | * - \ref CAP_INT_MEINTF_Msk |
<> | 144:ef7eb2e8f9f7 | 119 | * - \ref CAP_INT_ADDRMINTF_Msk |
<> | 144:ef7eb2e8f9f7 | 120 | * - \ref CAP_INT_MDINTF_Msk |
<> | 144:ef7eb2e8f9f7 | 121 | * |
<> | 144:ef7eb2e8f9f7 | 122 | * @return TRUE(Enable) or FALSE(Disable) |
<> | 144:ef7eb2e8f9f7 | 123 | * |
<> | 144:ef7eb2e8f9f7 | 124 | * @details Clear Image Capture Interface interrupt flag |
<> | 144:ef7eb2e8f9f7 | 125 | * \hideinitializer |
<> | 144:ef7eb2e8f9f7 | 126 | */ |
<> | 144:ef7eb2e8f9f7 | 127 | #define CAP_CLR_INT_FLAG(u32IntMask) (CAP->CAPINT |=u32IntMask) |
<> | 144:ef7eb2e8f9f7 | 128 | |
<> | 144:ef7eb2e8f9f7 | 129 | /** |
<> | 144:ef7eb2e8f9f7 | 130 | * @brief Get CAP Interrupt status |
<> | 144:ef7eb2e8f9f7 | 131 | * |
<> | 144:ef7eb2e8f9f7 | 132 | * @return TRUE(Enable) or FALSE(Disable) |
<> | 144:ef7eb2e8f9f7 | 133 | * |
<> | 144:ef7eb2e8f9f7 | 134 | * @details Get Image Capture Interface interrupt status. |
<> | 144:ef7eb2e8f9f7 | 135 | * \hideinitializer |
<> | 144:ef7eb2e8f9f7 | 136 | */ |
<> | 144:ef7eb2e8f9f7 | 137 | #define CAP_GET_INT_STS() (CAP->CAPINT) |
<> | 144:ef7eb2e8f9f7 | 138 | |
<> | 144:ef7eb2e8f9f7 | 139 | void CAP_Open(uint32_t u32InFormat, uint32_t u32OutFormet); |
<> | 144:ef7eb2e8f9f7 | 140 | void CAP_SetCroppingWindow(uint32_t u32VStart,uint32_t u32HStart, uint32_t u32Height, uint32_t u32Width); |
<> | 144:ef7eb2e8f9f7 | 141 | void CAP_SetPacketBuf(uint32_t u32Address ); |
<> | 144:ef7eb2e8f9f7 | 142 | void CAP_SetPlanarBuf(uint32_t u32YAddr, uint32_t u32UAddr, uint32_t u32VAddr); |
<> | 144:ef7eb2e8f9f7 | 143 | void CAP_Close(void); |
<> | 144:ef7eb2e8f9f7 | 144 | void CAP_EnableInt(uint32_t u32IntMask); |
<> | 144:ef7eb2e8f9f7 | 145 | void CAP_DisableInt(uint32_t u32IntMask); |
<> | 144:ef7eb2e8f9f7 | 146 | void CAP_Start(void); |
<> | 144:ef7eb2e8f9f7 | 147 | void CAP_Stop(uint32_t u32FrameComplete); |
<> | 144:ef7eb2e8f9f7 | 148 | void CAP_SetPacketScaling(uint32_t u32VNumerator, uint32_t u32VDenominator, uint32_t u32HNumerator, uint32_t u32HDenominator); |
<> | 144:ef7eb2e8f9f7 | 149 | void CAP_SetPlanarScaling(uint32_t u32VNumerator, uint32_t u32VDenominator, uint32_t u32HNumerator, uint32_t u32HDenominator); |
<> | 144:ef7eb2e8f9f7 | 150 | void CAP_SetPacketStride(uint32_t u32Stride ); |
<> | 144:ef7eb2e8f9f7 | 151 | void CAP_SetPlanarStride(uint32_t u32Stride ); |
<> | 144:ef7eb2e8f9f7 | 152 | void CAP_EnableMotionDet(uint32_t u32Freq, uint32_t u32BlockSize, uint32_t u32Format, uint32_t u32Threshold, uint32_t u32YDetAddr, uint32_t u32DetAddr); |
<> | 144:ef7eb2e8f9f7 | 153 | void CAP_DisableMotionDet(void); |
<> | 144:ef7eb2e8f9f7 | 154 | |
<> | 144:ef7eb2e8f9f7 | 155 | /*@}*/ /* end of group NUC472_442_CAP_EXPORTED_FUNCTIONS */ |
<> | 144:ef7eb2e8f9f7 | 156 | |
<> | 144:ef7eb2e8f9f7 | 157 | |
<> | 144:ef7eb2e8f9f7 | 158 | |
<> | 144:ef7eb2e8f9f7 | 159 | /*@}*/ /* end of group NUC472_442_CAP_Driver */ |
<> | 144:ef7eb2e8f9f7 | 160 | |
<> | 144:ef7eb2e8f9f7 | 161 | /*@}*/ /* end of group NUC472_442_Device_Driver */ |
<> | 144:ef7eb2e8f9f7 | 162 | |
<> | 144:ef7eb2e8f9f7 | 163 | #ifdef __cplusplus |
<> | 144:ef7eb2e8f9f7 | 164 | } |
<> | 144:ef7eb2e8f9f7 | 165 | #endif |
<> | 144:ef7eb2e8f9f7 | 166 | |
<> | 144:ef7eb2e8f9f7 | 167 | #endif //__CAP_H__ |
<> | 144:ef7eb2e8f9f7 | 168 | |
<> | 144:ef7eb2e8f9f7 | 169 | /*** (C) COPYRIGHT 2013 Nuvoton Technology Corp. ***/ |