📄 dsp28_adc.c
字号:
#include "DSP28_Device.h"
//---------------------------------------------------------------------------
// InitAdc:
//---------------------------------------------------------------------------
// This function initializes ADC to a known state.
//
void InitAdc(void)
{
unsigned int i;
AdcRegs.ADCTRL1.bit.RESET=1;
NOP;
AdcRegs.ADCTRL1.bit.RESET=0;
AdcRegs.ADCTRL1.bit.SUSMOD=3;
AdcRegs.ADCTRL1.bit.ACQ_PS=0;
AdcRegs.ADCTRL1.bit.CPS=0; // F_clk=CLK/1;
AdcRegs.ADCTRL1.bit.CONT_RUN=0; // Start-stop mode
AdcRegs.ADCTRL1.bit.SEQ_CASC=1; // Cascaded mode
// The bandgap and reference circuitry is powered up
AdcRegs.ADCTRL3.bit.ADCBGRFDN=3;
for(i=0;i<10000;i++) NOP;
// The analog circuitry inside the core is powered up
AdcRegs.ADCTRL3.bit.ADCPWDN=1;
for(i=0;i<5000;i++) NOP;
AdcRegs.ADCTRL3.bit.ADCCLKPS=15;
// HSPCLK/[30*(ADCTRL1[7] + 1)]
AdcRegs.ADCTRL3.bit.SMODE_SEL=0;
// Sequential sampling mode is selected
AdcRegs.MAX_CONV.bit.MAX_CONV=0;
//Number of conversions 0000---1
AdcRegs.CHSELSEQ1.bit.CONV00=2;
// AdcRegs.CHSELSEQ1.bit.CONV01=1;
// AdcRegs.CHSELSEQ1.bit.CONV02=2;
// AdcRegs.CHSELSEQ1.bit.CONV03=3;
/*
AdcRegs.CHSELSEQ2.bit.CONV04=4;
AdcRegs.CHSELSEQ2.bit.CONV05=5;
AdcRegs.CHSELSEQ2.bit.CONV06=6;
AdcRegs.CHSELSEQ2.bit.CONV07=7;
AdcRegs.CHSELSEQ3.bit.CONV08=8;
AdcRegs.CHSELSEQ3.bit.CONV09=9;
AdcRegs.CHSELSEQ3.bit.CONV10=10;
AdcRegs.CHSELSEQ3.bit.CONV11=11;
AdcRegs.CHSELSEQ4.bit.CONV12=12;
AdcRegs.CHSELSEQ4.bit.CONV13=13;
AdcRegs.CHSELSEQ4.bit.CONV14=14;
AdcRegs.CHSELSEQ4.bit.CONV15=15;
*/
AdcRegs.ADC_ST_FLAG.bit.INT_SEQ1_CLR=1;
// Clear the SEQ1 interrupt flag
AdcRegs.ADC_ST_FLAG.bit.INT_SEQ2_CLR=1;
// Clear the SEQ2 interrupt flag
AdcRegs.ADCTRL2.bit.EVB_SOC_SEQ=0;
AdcRegs.ADCTRL2.bit.RST_SEQ1=0;
AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1=1;
// Interrupt request by INT SEQ1 is enabled
AdcRegs.ADCTRL2.bit.INT_MOD_SEQ1=0;
// INT SEQ1 is set at the end of every SEQ1 sequence
AdcRegs.ADCTRL2.bit.EVA_SOC_SEQ1=0;
AdcRegs.ADCTRL2.bit.EXT_SOC_SEQ1=0;
AdcRegs.ADCTRL2.bit.RST_SEQ2=0;
AdcRegs.ADCTRL2.bit.SOC_SEQ2=0;
AdcRegs.ADCTRL2.bit.INT_ENA_SEQ2=0;
AdcRegs.ADCTRL2.bit.INT_MOD_SEQ2=0;
AdcRegs.ADCTRL2.bit.EVB_SOC_SEQ2=0;
AdcRegs.ADCTRL2.bit.SOC_SEQ1=1;
}
//===========================================================================
// No more.
//===========================================================================
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -