📄 2812的ad程序.txt
字号:
我写了一个2812的AD程序,思路是这样的.我要采集1V的交流电压,在一个周期内采集128个点.我用EV来定时触发AD,用DSP2812的AD外设中的ADCINA0通道来采集数据,并将采集到的128个数据存入设定的数组中.程序如下:
#include "DSP28_Device.h"
float a1[128];//定义一个数组
//unsigned int a2=0;
float adclo=0.0;
// Prototype statements for functions found within this file.
interrupt void ad(void);
void main(void)
{
InitSysCtrl();//系统初始化
DINT;//禁止中断
IER = 0x0000;
IFR = 0x0000;
InitPieCtrl();//初始化PIE
InitPieVectTable();//中断向量表初始化
EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.ADCINT=&ad;
EDIS; // This is needed to disable write to EALLOW protected registers
InitAdc();
IER |= M_INT1;
//KickDog();
// Enable global Interrupts and higher priority real-time debug events:
InitEv();
EINT; // Enable Global interrupt INTM
ERTM; // Enable Global realtime interrupt DBGM
for(;;//等待中断
}
interrupt void ad(void)
{
int i;
IFR=0x0000;
// PieCtrl.PIEIFR1.all = 0;
// PieCtrl.PIEACK.all=0xffff;
// a2++;
for(i=0;i<128;i++)
{
a1[i]=((float)AdcRegs.RESULT0)*3.0/65520.0+adclo;//将转换结果存入数组
AdcRegs.ADC_ST_FLAG.bit.INT_SEQ1_CLR=1;//清除INT_SEQ1中断标志
AdcRegs.ADCTRL2.bit.RST_SEQ1 = 1; //复位SEQ1序列
PieCtrl.PIEACK.all = 0xFFFF; //允许再次响应中断
}
EINT;//使能中断
}
void InitEv(void)
{
EvaRegs.T1CMPR=0X0000;
EvaRegs.T1PR = 0X5B; //定时器1的周期寄存,6400HZ的采样频率
EvaRegs.GPTCONA.bit.T1TOADC = 2; //使能事情管理器B,周期中断启动ADC
EvaRegs.T1CON.bit.FREE = 1;
EvaRegs.T1CON.bit.SOFT = 0;//
EvaRegs.T1CON.bit.rsvd = 0;//
EvaRegs.T1CON.bit.TMODE = 0;//停止保持模式
EvaRegs.T1CON.bit.TPS = 7; //输入时钟为HSPCLK/128
EvaRegs.T1CON.bit.T2SWT1 = 0;//使用自己的使能位
EvaRegs.T1CON.bit.TENABLE = 1;//使能定时操作
EvaRegs.T1CON.bit.TCLKS10 = 0;//内部时钟
EvaRegs.T1CON.bit.TCLD10 = 0;//
EvaRegs.T1CON.bit.TECMPR = 1;//使能定时器比较操作
EvaRegs.T1CON.bit.SET1PR = 0;//使用自己的周期寄存器
//EvaRegs.GPTCONA.bit.T2TOADC = 0;
}
void InitAdc(void)
{
unsigned int i;
AdcRegs.ADCTRL1.bit.RESET=1;//ADC模块软复位,3个周期后,该位自动清0
NOP; //等待ADC寄存器硬件复位完备
//AdcRegs.ADCTRL1.bit.RESET=0;//
AdcRegs.ADCTRL1.bit.SUSMOD=3;//仿真挂起模式,0为忽略仿真挂起
AdcRegs.ADCTRL1.bit.ACQ_PS=0;//采样周期为一个ADCLK周期数
AdcRegs.ADCTRL1.bit.CPS=0; //不再对送给ADC的时钟进行二分频
AdcRegs.ADCTRL1.bit.CONT_RUN=0;//开始停止模式
AdcRegs.ADCTRL1.bit.SEQ_CASC=0;//双排序模式
AdcRegs.ADCTRL3.bit.ADCBGRFDN=3;//带隙参考电路上电
for(i=0;i<10000;i++) NOP;
AdcRegs.ADCTRL3.bit.ADCPWDN=1;//除带隙参考电路外的其他ADC模块上电
for(i=0;i<5000;i++) NOP;
AdcRegs.ADCTRL3.bit.ADCCLKPS=15;//
AdcRegs.ADCTRL3.bit.SMODE_SEL=0;//顺序采样模式
AdcRegs.MAX_CONV.bit.MAX_CONV=0;//设置只有一个转换通道
AdcRegs.CHSELSEQ1.bit.CONV00=0;
AdcRegs.ADC_ST_FLAG.bit.INT_SEQ1_CLR=1; //清除SEQ1中断标志
AdcRegs.ADCTRL2.bit.EVA_SOC_SEQ1 = 1; //使能EVASOC启动SEQ1
AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 1; //使能SEQ1中断
AdcRegs.ADCTRL2.bit.EVB_SOC_SEQ = 0;
AdcRegs.ADCTRL2.bit.RST_SEQ1 = 0;
AdcRegs.ADCTRL2.bit.INT_MOD_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 = 0; //为1时,软件启动ADC转换
}
调试的时候,我在中断服务程序设置断点,却始终进不了中断,提示:
Breakpoint Manager: Some breakpoints are not at valid lines.
Code Composer has moved these breakpoints to the next valid line.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -