test
Fork of mbed-dev by
targets/TARGET_Realtek/TARGET_AMEBA/analogin_api.c@178:d650f5d4c87a, 2017-11-08 (annotated)
- Committer:
- AnnaBridge
- Date:
- Wed Nov 08 13:50:44 2017 +0000
- Revision:
- 178:d650f5d4c87a
- Parent:
- 174:e131a1973e81
This updates the lib to the mbed lib v 155
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
AnnaBridge | 168:e84263d55307 | 1 | /* mbed Microcontroller Library |
AnnaBridge | 168:e84263d55307 | 2 | * Copyright (c) 2013-2016 Realtek Semiconductor Corp. |
AnnaBridge | 168:e84263d55307 | 3 | * |
AnnaBridge | 168:e84263d55307 | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
AnnaBridge | 168:e84263d55307 | 5 | * you may not use this file except in compliance with the License. |
AnnaBridge | 168:e84263d55307 | 6 | * You may obtain a copy of the License at |
AnnaBridge | 168:e84263d55307 | 7 | * |
AnnaBridge | 168:e84263d55307 | 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
AnnaBridge | 168:e84263d55307 | 9 | * |
AnnaBridge | 168:e84263d55307 | 10 | * Unless required by applicable law or agreed to in writing, software |
AnnaBridge | 168:e84263d55307 | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
AnnaBridge | 168:e84263d55307 | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
AnnaBridge | 168:e84263d55307 | 13 | * See the License for the specific language governing permissions and |
AnnaBridge | 168:e84263d55307 | 14 | * limitations under the License. |
AnnaBridge | 168:e84263d55307 | 15 | */ |
AnnaBridge | 168:e84263d55307 | 16 | |
AnnaBridge | 168:e84263d55307 | 17 | #include "objects.h" |
AnnaBridge | 168:e84263d55307 | 18 | #include "PinNames.h" |
AnnaBridge | 168:e84263d55307 | 19 | #include "hal_adc.h" |
AnnaBridge | 168:e84263d55307 | 20 | #include "analogin_api.h" |
AnnaBridge | 168:e84263d55307 | 21 | |
AnnaBridge | 168:e84263d55307 | 22 | |
AnnaBridge | 168:e84263d55307 | 23 | |
AnnaBridge | 168:e84263d55307 | 24 | #if CONFIG_ADC_EN |
AnnaBridge | 168:e84263d55307 | 25 | #include "pinmap.h" |
AnnaBridge | 168:e84263d55307 | 26 | |
AnnaBridge | 168:e84263d55307 | 27 | |
AnnaBridge | 168:e84263d55307 | 28 | extern u32 ConfigDebugErr; |
AnnaBridge | 168:e84263d55307 | 29 | extern u32 ConfigDebuginfo; |
AnnaBridge | 168:e84263d55307 | 30 | |
AnnaBridge | 168:e84263d55307 | 31 | |
AnnaBridge | 168:e84263d55307 | 32 | void analogin_init (analogin_t *obj, PinName pin) |
AnnaBridge | 168:e84263d55307 | 33 | { |
AnnaBridge | 168:e84263d55307 | 34 | uint32_t adc_idx; |
AnnaBridge | 168:e84263d55307 | 35 | PSAL_ADC_MNGT_ADPT pSalADCMngtAdpt = NULL; |
AnnaBridge | 168:e84263d55307 | 36 | PSAL_ADC_USERCB_ADPT pSalADCUserCBAdpt = NULL; |
AnnaBridge | 168:e84263d55307 | 37 | PSAL_ADC_HND pSalADCHND = NULL; |
AnnaBridge | 168:e84263d55307 | 38 | |
AnnaBridge | 168:e84263d55307 | 39 | HAL_ADC_INIT_DAT HalADCInitDataTmp; |
AnnaBridge | 168:e84263d55307 | 40 | PHAL_ADC_INIT_DAT pHalADCInitDataTmp = &HalADCInitDataTmp; |
AnnaBridge | 168:e84263d55307 | 41 | /* To backup user config first */ |
AnnaBridge | 168:e84263d55307 | 42 | |
AnnaBridge | 168:e84263d55307 | 43 | _memset(&(obj->HalADCInitData), 0, sizeof(HAL_ADC_INIT_DAT)); |
AnnaBridge | 168:e84263d55307 | 44 | _memcpy(pHalADCInitDataTmp, &(obj->HalADCInitData), sizeof(HAL_ADC_INIT_DAT)); |
AnnaBridge | 168:e84263d55307 | 45 | _memset(obj, 0x00, sizeof(analogin_t)); |
AnnaBridge | 168:e84263d55307 | 46 | |
AnnaBridge | 168:e84263d55307 | 47 | ConfigDebugErr &= (~(_DBG_ADC_|_DBG_GDMA_)); |
AnnaBridge | 168:e84263d55307 | 48 | ConfigDebugInfo&= (~(_DBG_ADC_|_DBG_GDMA_)); |
AnnaBridge | 168:e84263d55307 | 49 | |
AnnaBridge | 168:e84263d55307 | 50 | adc_idx = pin & 0x0F; |
AnnaBridge | 168:e84263d55307 | 51 | |
AnnaBridge | 168:e84263d55307 | 52 | /* Get I2C device handler */ |
AnnaBridge | 168:e84263d55307 | 53 | pSalADCMngtAdpt = &(obj->SalADCMngtAdpt); |
AnnaBridge | 168:e84263d55307 | 54 | pSalADCUserCBAdpt = (PSAL_ADC_USERCB_ADPT)&(obj->SalADCUserCBAdpt); |
AnnaBridge | 168:e84263d55307 | 55 | |
AnnaBridge | 168:e84263d55307 | 56 | /*To assign the rest pointers*/ |
AnnaBridge | 168:e84263d55307 | 57 | pSalADCMngtAdpt->pSalHndPriv = &(obj->SalADCHndPriv); |
AnnaBridge | 168:e84263d55307 | 58 | pSalADCMngtAdpt->pSalHndPriv->ppSalADCHnd = (void**)&(pSalADCMngtAdpt->pSalHndPriv); |
AnnaBridge | 168:e84263d55307 | 59 | |
AnnaBridge | 168:e84263d55307 | 60 | /* To assign the default (ROM) HAL OP initialization function */ |
AnnaBridge | 168:e84263d55307 | 61 | pSalADCMngtAdpt->pHalOpInit = &HalADCOpInit; |
AnnaBridge | 168:e84263d55307 | 62 | |
AnnaBridge | 168:e84263d55307 | 63 | /* To assign the default (ROM) HAL GDMA OP initialization function */ |
AnnaBridge | 168:e84263d55307 | 64 | pSalADCMngtAdpt->pHalGdmaOpInit = &HalGdmaOpInit; |
AnnaBridge | 168:e84263d55307 | 65 | |
AnnaBridge | 168:e84263d55307 | 66 | /* To assign the default (ROM) SAL interrupt function */ |
AnnaBridge | 168:e84263d55307 | 67 | pSalADCMngtAdpt->pSalIrqFunc = &ADCISRHandle; |
AnnaBridge | 168:e84263d55307 | 68 | |
AnnaBridge | 168:e84263d55307 | 69 | /* To assign the default (ROM) SAL DMA TX interrupt function */ |
AnnaBridge | 168:e84263d55307 | 70 | pSalADCMngtAdpt->pSalDMAIrqFunc = &ADCGDMAISRHandle; |
AnnaBridge | 168:e84263d55307 | 71 | |
AnnaBridge | 168:e84263d55307 | 72 | /* To backup user config first */ |
AnnaBridge | 168:e84263d55307 | 73 | //_memcpy(pHalADCInitDataTmp, &(obj->HalADCInitData), sizeof(HAL_ADC_INIT_DAT)); |
AnnaBridge | 168:e84263d55307 | 74 | |
AnnaBridge | 168:e84263d55307 | 75 | pSalADCMngtAdpt->pHalInitDat = &(obj->HalADCInitData); |
AnnaBridge | 168:e84263d55307 | 76 | pSalADCMngtAdpt->pHalOp = &(obj->HalADCOp); |
AnnaBridge | 168:e84263d55307 | 77 | pSalADCMngtAdpt->pIrqHnd = &(obj->ADCIrqHandleDat); |
AnnaBridge | 168:e84263d55307 | 78 | pSalADCMngtAdpt->pHalGdmaAdp = &(obj->HalADCGdmaAdpt); |
AnnaBridge | 168:e84263d55307 | 79 | pSalADCMngtAdpt->pHalGdmaOp = &(obj->HalADCGdmaOp); |
AnnaBridge | 168:e84263d55307 | 80 | pSalADCMngtAdpt->pIrqGdmaHnd = &(obj->ADCGdmaIrqHandleDat); |
AnnaBridge | 168:e84263d55307 | 81 | pSalADCMngtAdpt->pUserCB = &(obj->SalADCUserCB); |
AnnaBridge | 168:e84263d55307 | 82 | |
AnnaBridge | 168:e84263d55307 | 83 | /* Assign the private SAL handle to public SAL handle */ |
AnnaBridge | 168:e84263d55307 | 84 | pSalADCHND = &(pSalADCMngtAdpt->pSalHndPriv->SalADCHndPriv); |
AnnaBridge | 168:e84263d55307 | 85 | |
AnnaBridge | 168:e84263d55307 | 86 | /* Assign the internal HAL initial data pointer to the SAL handle */ |
AnnaBridge | 168:e84263d55307 | 87 | pSalADCHND->pInitDat = pSalADCMngtAdpt->pHalInitDat; |
AnnaBridge | 168:e84263d55307 | 88 | |
AnnaBridge | 168:e84263d55307 | 89 | /* Assign the internal user callback pointer to the SAL handle */ |
AnnaBridge | 168:e84263d55307 | 90 | pSalADCHND->pUserCB = pSalADCMngtAdpt->pUserCB; |
AnnaBridge | 168:e84263d55307 | 91 | |
AnnaBridge | 168:e84263d55307 | 92 | /*To assign user callback pointers*/ |
AnnaBridge | 168:e84263d55307 | 93 | pSalADCMngtAdpt->pUserCB->pTXCB = pSalADCUserCBAdpt; |
AnnaBridge | 168:e84263d55307 | 94 | pSalADCMngtAdpt->pUserCB->pTXCCB = (pSalADCUserCBAdpt+1); |
AnnaBridge | 168:e84263d55307 | 95 | pSalADCMngtAdpt->pUserCB->pRXCB = (pSalADCUserCBAdpt+2); |
AnnaBridge | 168:e84263d55307 | 96 | pSalADCMngtAdpt->pUserCB->pRXCCB = (pSalADCUserCBAdpt+3); |
AnnaBridge | 168:e84263d55307 | 97 | pSalADCMngtAdpt->pUserCB->pRDREQCB = (pSalADCUserCBAdpt+4); |
AnnaBridge | 168:e84263d55307 | 98 | pSalADCMngtAdpt->pUserCB->pERRCB = (pSalADCUserCBAdpt+5); |
AnnaBridge | 168:e84263d55307 | 99 | pSalADCMngtAdpt->pUserCB->pDMATXCB = (pSalADCUserCBAdpt+6); |
AnnaBridge | 168:e84263d55307 | 100 | pSalADCMngtAdpt->pUserCB->pDMATXCCB = (pSalADCUserCBAdpt+7); |
AnnaBridge | 168:e84263d55307 | 101 | pSalADCMngtAdpt->pUserCB->pDMARXCB = (pSalADCUserCBAdpt+8); |
AnnaBridge | 168:e84263d55307 | 102 | pSalADCMngtAdpt->pUserCB->pDMARXCCB = (pSalADCUserCBAdpt+9); |
AnnaBridge | 168:e84263d55307 | 103 | |
AnnaBridge | 168:e84263d55307 | 104 | /* Set ADC Device Number */ |
AnnaBridge | 168:e84263d55307 | 105 | pSalADCHND->DevNum = adc_idx; |
AnnaBridge | 168:e84263d55307 | 106 | |
AnnaBridge | 168:e84263d55307 | 107 | /* Load ADC default value */ |
AnnaBridge | 168:e84263d55307 | 108 | RtkADCLoadDefault(pSalADCHND); |
AnnaBridge | 168:e84263d55307 | 109 | |
AnnaBridge | 168:e84263d55307 | 110 | /* Assign ADC Pin Mux */ |
AnnaBridge | 168:e84263d55307 | 111 | pSalADCHND->PinMux = 0; |
AnnaBridge | 168:e84263d55307 | 112 | pSalADCHND->OpType = ADC_RDREG_TYPE; |
AnnaBridge | 168:e84263d55307 | 113 | |
AnnaBridge | 168:e84263d55307 | 114 | /* Load user setting */ |
AnnaBridge | 168:e84263d55307 | 115 | if ((pHalADCInitDataTmp->ADCEndian == ADC_DATA_ENDIAN_LITTLE) || (pHalADCInitDataTmp->ADCEndian == ADC_DATA_ENDIAN_BIG)) { |
AnnaBridge | 168:e84263d55307 | 116 | pSalADCHND->pInitDat->ADCEndian = pHalADCInitDataTmp->ADCEndian; |
AnnaBridge | 168:e84263d55307 | 117 | } |
AnnaBridge | 168:e84263d55307 | 118 | |
AnnaBridge | 168:e84263d55307 | 119 | if ((pHalADCInitDataTmp->ADCAudioEn != ADC_FEATURE_DISABLED) && (pHalADCInitDataTmp->ADCAudioEn < 2)) { |
AnnaBridge | 168:e84263d55307 | 120 | pSalADCHND->pInitDat->ADCAudioEn = pHalADCInitDataTmp->ADCAudioEn; |
AnnaBridge | 168:e84263d55307 | 121 | } |
AnnaBridge | 168:e84263d55307 | 122 | |
AnnaBridge | 168:e84263d55307 | 123 | /* Init ADC now */ |
AnnaBridge | 168:e84263d55307 | 124 | pSalADCHND->pInitDat->ADCBurstSz = 8; |
AnnaBridge | 168:e84263d55307 | 125 | pSalADCHND->pInitDat->ADCOneShotTD = 8; |
AnnaBridge | 168:e84263d55307 | 126 | RtkADCInit(pSalADCHND); |
AnnaBridge | 168:e84263d55307 | 127 | } |
AnnaBridge | 168:e84263d55307 | 128 | |
AnnaBridge | 168:e84263d55307 | 129 | float analogin_read(analogin_t *obj) |
AnnaBridge | 168:e84263d55307 | 130 | { |
AnnaBridge | 168:e84263d55307 | 131 | float value; |
AnnaBridge | 168:e84263d55307 | 132 | uint32_t AnaloginTmp[2] = {0,0}; |
AnnaBridge | 168:e84263d55307 | 133 | uint32_t AnaloginDatMsk = 0xFFFF; |
AnnaBridge | 168:e84263d55307 | 134 | uint8_t AnaloginIdx = 0; |
AnnaBridge | 168:e84263d55307 | 135 | uint32_t AnalogDat = 0; |
AnnaBridge | 168:e84263d55307 | 136 | |
AnnaBridge | 168:e84263d55307 | 137 | //no auto-calibration implemented yet, uses hard coded calibrate |
AnnaBridge | 168:e84263d55307 | 138 | uint32_t Offset = 0x2980; |
AnnaBridge | 168:e84263d55307 | 139 | uint32_t AnalogDatFull = 0xAA00; |
AnnaBridge | 168:e84263d55307 | 140 | |
AnnaBridge | 168:e84263d55307 | 141 | PSAL_ADC_MNGT_ADPT pSalADCMngtAdpt = NULL; |
AnnaBridge | 168:e84263d55307 | 142 | PSAL_ADC_HND pSalADCHND = NULL; |
AnnaBridge | 168:e84263d55307 | 143 | |
AnnaBridge | 168:e84263d55307 | 144 | pSalADCMngtAdpt = &(obj->SalADCMngtAdpt); |
AnnaBridge | 168:e84263d55307 | 145 | pSalADCHND = &(pSalADCMngtAdpt->pSalHndPriv->SalADCHndPriv); |
AnnaBridge | 168:e84263d55307 | 146 | AnaloginIdx = pSalADCHND->DevNum; |
AnnaBridge | 168:e84263d55307 | 147 | RtkADCReceiveBuf(pSalADCHND,&AnaloginTmp[0]); |
AnnaBridge | 168:e84263d55307 | 148 | |
AnnaBridge | 168:e84263d55307 | 149 | AnaloginDatMsk = (u32)(AnaloginDatMsk<<((u32)(16*(AnaloginIdx&0x01)))); |
AnnaBridge | 168:e84263d55307 | 150 | AnalogDat = AnaloginTmp[(AnaloginIdx/2)]; |
AnnaBridge | 168:e84263d55307 | 151 | AnalogDat = (AnalogDat & AnaloginDatMsk); |
AnnaBridge | 168:e84263d55307 | 152 | AnalogDat = (AnalogDat>>((u32)(16*(AnaloginIdx&0x01)))); |
AnnaBridge | 168:e84263d55307 | 153 | AnalogDat -= Offset; |
AnnaBridge | 168:e84263d55307 | 154 | |
AnnaBridge | 168:e84263d55307 | 155 | value = (float)(AnalogDat) / (float)(AnalogDatFull); |
AnnaBridge | 168:e84263d55307 | 156 | return (float)value; |
AnnaBridge | 168:e84263d55307 | 157 | } |
AnnaBridge | 168:e84263d55307 | 158 | |
AnnaBridge | 168:e84263d55307 | 159 | uint16_t analogin_read_u16(analogin_t *obj) |
AnnaBridge | 168:e84263d55307 | 160 | { |
AnnaBridge | 168:e84263d55307 | 161 | uint32_t AnaloginTmp[2] = {0,0}; |
AnnaBridge | 168:e84263d55307 | 162 | uint32_t AnaloginDatMsk = 0xFFFF; |
AnnaBridge | 168:e84263d55307 | 163 | uint8_t AnaloginIdx = 0; |
AnnaBridge | 168:e84263d55307 | 164 | uint32_t AnalogDat = 0; |
AnnaBridge | 168:e84263d55307 | 165 | |
AnnaBridge | 168:e84263d55307 | 166 | PSAL_ADC_MNGT_ADPT pSalADCMngtAdpt = NULL; |
AnnaBridge | 168:e84263d55307 | 167 | PSAL_ADC_HND pSalADCHND = NULL; |
AnnaBridge | 168:e84263d55307 | 168 | |
AnnaBridge | 168:e84263d55307 | 169 | pSalADCMngtAdpt = &(obj->SalADCMngtAdpt); |
AnnaBridge | 168:e84263d55307 | 170 | pSalADCHND = &(pSalADCMngtAdpt->pSalHndPriv->SalADCHndPriv); |
AnnaBridge | 168:e84263d55307 | 171 | AnaloginIdx = pSalADCHND->DevNum; |
AnnaBridge | 168:e84263d55307 | 172 | RtkADCRxManualRotate(pSalADCHND,&AnaloginTmp[0]); |
AnnaBridge | 168:e84263d55307 | 173 | |
AnnaBridge | 168:e84263d55307 | 174 | AnaloginDatMsk = (u32)(AnaloginDatMsk<<((u32)(16*(AnaloginIdx&0x01)))); |
AnnaBridge | 168:e84263d55307 | 175 | AnalogDat = AnaloginTmp[(AnaloginIdx/2)]; |
AnnaBridge | 168:e84263d55307 | 176 | AnalogDat = (AnalogDat & AnaloginDatMsk); |
AnnaBridge | 168:e84263d55307 | 177 | AnalogDat = (AnalogDat>>((u32)(16*(AnaloginIdx&0x01)))); |
AnnaBridge | 168:e84263d55307 | 178 | |
AnnaBridge | 168:e84263d55307 | 179 | return (uint16_t)AnalogDat; |
AnnaBridge | 168:e84263d55307 | 180 | } |
AnnaBridge | 168:e84263d55307 | 181 | |
AnnaBridge | 168:e84263d55307 | 182 | |
AnnaBridge | 168:e84263d55307 | 183 | void analogin_deinit(analogin_t *obj) |
AnnaBridge | 168:e84263d55307 | 184 | { |
AnnaBridge | 168:e84263d55307 | 185 | PSAL_ADC_MNGT_ADPT pSalADCMngtAdpt = NULL; |
AnnaBridge | 168:e84263d55307 | 186 | PSAL_ADC_HND pSalADCHND = NULL; |
AnnaBridge | 168:e84263d55307 | 187 | |
AnnaBridge | 168:e84263d55307 | 188 | pSalADCMngtAdpt = &(obj->SalADCMngtAdpt); |
AnnaBridge | 168:e84263d55307 | 189 | pSalADCHND = &(pSalADCMngtAdpt->pSalHndPriv->SalADCHndPriv); |
AnnaBridge | 168:e84263d55307 | 190 | |
AnnaBridge | 168:e84263d55307 | 191 | /* To deinit analogin */ |
AnnaBridge | 168:e84263d55307 | 192 | RtkADCDeInit(pSalADCHND); |
AnnaBridge | 168:e84263d55307 | 193 | } |
AnnaBridge | 168:e84263d55307 | 194 | #endif |