📄 dsp28_adc.c
字号:
//
// TMDX ALPHA RELEASE
// Intended for product evaluation purposes
//
//###########################################################################
//
// FILE: DSP28_Adc.c
//
// TITLE: DSP28 ADC Initialization & Support Functions.
//
//###########################################################################
//
// Ver | dd mmm yyyy | Who | Description of changes
// =====|=============|======|===============================================
// 0.55| 06 May 2002 | L.H. | EzDSP Alpha Release
// 0.56| 20 May 2002 | L.H. | No change
// 0.57| 27 May 2002 | L.H. | No change
//###########################################################################
#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;//采样时间窗大小,一个ADCLK周期的长度
AdcRegs.ADCTRL1.bit.CPS=0;//核心时钟的预分频器,CLK/1
AdcRegs.ADCTRL1.bit.CONT_RUN=0;//连续运行位,启动停止模式
AdcRegs.ADCTRL1.bit.SEQ_CASC=1;//排序器级连操作
AdcRegs.ADCTRL3.bit.ADCBGRFDN=3;//ADC带隙参考源开启
for(i=0;i<10000;i++) NOP;//?
AdcRegs.ADCTRL3.bit.ADCPWDN=1;//dsp内核所有模拟部分开启
for(i=0;i<5000;i++) NOP;
AdcRegs.ADCTRL3.bit.ADCCLKPS=15;//核心时钟分频
AdcRegs.ADCTRL3.bit.SMODE_SEL=1;//采用同步采样模式
AdcRegs.MAX_CONV.bit.MAX_CONV=15;//一次自动转换中最大的转换次数16
AdcRegs.CHSELSEQ1.bit.CONV00=0;
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;//ADC输入通道选择排序控制REG
AdcRegs.ADC_ST_FLAG.bit.INT_SEQ1_CLR=1;//中断清除位
AdcRegs.ADC_ST_FLAG.bit.INT_SEQ2_CLR=1;
AdcRegs.ADCTRL2.bit.EVB_SOC_SEQ=0;//级连排序器的EVB SOC 信号使能,没有动作
AdcRegs.ADCTRL2.bit.RST_SEQ1=0;//复位排序器1 , 没有动作
AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1=1;//INT SEQ1 中断请求被禁止
AdcRegs.ADCTRL2.bit.INT_MOD_SEQ1=0;
AdcRegs.ADCTRL2.bit.EVA_SOC_SEQ1=0;//SEQ1 不能通过EVA 触发
AdcRegs.ADCTRL2.bit.EXT_SOC_SEQ1=0;//SEQ1 的外部启动转换信号位无效
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;//SEQ1 外部启动转换信号位
}
//===========================================================================
// No more.
//===========================================================================
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -