下面是模板的代码,寄存器和其他的厂商都是一致的,
/*
Copyright (c) 2014-2016 by Plexim GmbH
All rights reserved.
A free license is granted to anyone to use this software for any legal
non safety-critical purpose, including commercial applications, provided
that:
1) IT IS NOT USED TO DIRECTLY OR INDIRECTLY COMPETE WITH PLEXIM, and
2) THIS COPYRIGHT NOTICE IS PRESERVED in its entirety.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
#include "ain.h"
#pragma diag_suppress 112 // ASSERT(0) in switch statements
#define AIN_ADC_usDELAY 10000L
static void AIN_powerupAdc(AIN_Handle_t aHandle, const AIN_AdcParams_t *aParams);
uint16_t AIN_NUM_CHANNELS_USED;
void AIN_sinit()
{
AdcRegs.ADCTRL2.bit.RST_SEQ1 = 1; // Reset SEQ1
AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1; // Clear INT SEQ1 bit
AIN_NUM_CHANNELS_USED = 0;
}
void AIN_getRegisterBase(AIN_Unit_t aAdcUnit, volatile struct ADC_REGS** aReg){
switch(aAdcUnit)
{
default:
PLX_ASSERT(0);
break;
case AIN_ADC:
*aReg = &AdcRegs;
break;
}
}
void AIN_setDefaultAdcParams(AIN_AdcParams_t *aParams)
{
aParams->ADCTRL1.bit.SEQ_CASC = 1; // cascaded sequence mode
aParams->ADCTRL3.bit.SMODE_SEL = 0; // no simultaneous sampling
aParams->ADCTRL2.bit.INT_ENA_SEQ1 = 1;
aParams->ADCTRL2.bit.INT_MOD_SEQ1 = 0;
aParams->ADCTRL1.bit.CPS = 1; // clock prescaler 1/2
aParams->ADCTRL1.bit.SEQ_OVRD = 0; // disable sequencer override
aParams->ADCTRL2.bit.EPWM_SOCA_SEQ1 = 0;
aParams