?? 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 + -