打印

DSP28335 ADC采集 DMA搬数据

[复制链接]
1836|2
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
williamzjy|  楼主 | 2017-3-15 16:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 williamzjy 于 2017-3-15 16:07 编辑

我用f28335 的PWM触发AD采集数据,用DMA搬移数据,发现仿真时cmd文件用28335_RAM_lnk.cmd
,DMA缓冲数组是对的,而用F28335.cmd时,AD值变成两倍了,求各位指点,实在想不通

#include "DSP2833x_Device.h" // DSP2833x Headerfile Include File
#include "DSP2833x_Examples.h" // DSP2833x Examples Include File

// Determine when the shift to right justify the data takes place
// Only one of these should be defined as 1.
// The other two should be defined as 0.


// ADC start parameters
#if (CPU_FRQ_150MHZ) // Default - 150 MHz SYSCLKOUT
#define ADC_MODCLK 0x3 // HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 150/(2*3) = 25.0 MHz
#endif
#if (CPU_FRQ_100MHZ)
#define ADC_MODCLK 0x2 // HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 100/(2*2) = 25.0 MHz
#endif
#define ADC_CKPS 0x1 // ADC module clock = HSPCLK/1 = 25.5MHz/(1) = 25.0 MHz
#define ADC_SHCLK 0xf // S/H width in ADC module periods = 2 ADC cycle




// Global variable for this example



#define CPU_FREQ 150E6
#define LSPCLK_FREQ CPU_FREQ/4
#define SCI_FREQ 115200
#define SCI_PRD (LSPCLK_FREQ/(SCI_FREQ*8))-1




#define BUF_SIZE 160 // Sample buffer size

// Global variable for this example
Uint16 j = 0,ADC_END = 0; // ADC finish flag



#pragma DATA_SECTION(ADC_Result,"DMARAML4");
volatile float ADC_Result[160];

#pragma DATA_SECTION(DMABuf1,"DMARAML4");
volatile Uint16 DMABuf1[160];

volatile Uint16 *DMADest;
volatile Uint16 *DMASource;
interrupt void local_DINTCH1_ISR(void);


main()
{
Uint16 i;

InitSysCtrl();

// InitSciGpio();

EALLOW;
SysCtrlRegs.HISPCP.all = ADC_MODCLK; // HSPCLK = SYSCLKOUT/ADC_MODCLK
EDIS;


DINT;

InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

InitPieVectTable();
EALLOW;
// PieVectTable.SCIRXINTA = &sciaRxFifoIsr;
PieVectTable.DINTCH1= &local_DINTCH1_ISR;
EDIS;


// PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
//PieCtrlRegs.PIEIER9.bit.INTx1=1; // PIE Group 9, int1
// IER = 0x100; // Enable CPU INT
IER = M_INT7 ; //Enable INT7 (7.1 DMA Ch1)
EnableInterrupts();




InitAdc(); // For this example, init the ADC




// Specific ADC setup for this example:
AdcRegs.ADCTRL1.bit.ACQ_PS = ADC_SHCLK; // Sequential mode: Sample rate = 1/[(2+ACQ_PS)*ADC clock in ns]
// = 1/(3*40ns) =8.3MHz (for 150 MHz SYSCLKOUT)
// = 1/(3*80ns) =4.17MHz (for 100 MHz SYSCLKOUT)
// If Simultaneous mode enabled: Sample rate = 1/[(3+ACQ_PS)*ADC clock in ns]
AdcRegs.ADCTRL3.bit.ADCCLKPS = ADC_CKPS;
AdcRegs.ADCTRL1.bit.CPS = 0; //
AdcRegs.ADCTRL1.bit.SEQ_CASC = 1; // 1 Cascaded mode
AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 0x1;
AdcRegs.ADCTRL2.bit.RST_SEQ1 = 0x1;
// AdcRegs.ADCTRL1.bit.CONT_RUN = 1; // Setup continuous run

// AdcRegs.ADCTRL1.bit.SEQ_OVRD = 1; // Enable Sequencer override feature
AdcRegs.ADCCHSELSEQ1.all = 0x0; // Initialize all ADC channel selects to A0
AdcRegs.ADCCHSELSEQ2.all = 0x0; // Initialize all ADC channel selects to A0
AdcRegs.ADCCHSELSEQ3.all = 0x0; // Initialize all ADC channel selects to A0
AdcRegs.ADCCHSELSEQ4.all = 0x0; // Initialize all ADC channel selects to A0

AdcRegs.ADCMAXCONV.bit.MAX_CONV1 = 15; // convert and store in 8 results registers

AdcRegs.ADCTRL2.bit.EPWM_SOCA_SEQ1 = 1;// Enable SOCA from ePWM to start SEQ1
//AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 1; // Enable SEQ1 interrupt (every EOS)

// Assumes ePWM1 clock is already enabled in InitSysCtrl();
EPwm1Regs.ETSEL.bit.SOCAEN = 1; // Enable SOC on A group
EPwm1Regs.ETSEL.bit.SOCASEL = 4; // Select SOC from from CPMA on upcount
EPwm1Regs.ETPS.bit.SOCAPRD = 1; // Generate pulse on 1st event
EPwm1Regs.CMPA.half.CMPA = 0x0080; // Set compare A value
EPwm1Regs.TBPRD = 0xFFFF; // Set period for ePWM1




// Clear SampleTable
for (i=0; i<BUF_SIZE; i++)
{
DMABuf1[i] = 0x0000;
}


// Configure DMA Channel
DMADest = &DMABuf1[0]; //Point DMA destination to the beginning of the array
DMASource = &AdcMirror.ADCRESULT0; //Point DMA source to ADC result register base
DMACH1AddrConfig(DMADest,DMASource);
DMACH1BurstConfig(15,1,10);
DMACH1TransferConfig(9,-15,(-150 + 1));
DMACH1WrapConfig(100,100,100,100); //Don't use wrap function
DMACH1ModeConfig(DMA_SEQ1INT,PERINT_ENABLE,ONESHOT_DISABLE,CONT_DISABLE,SYNC_DISABLE,SYNC_SRC,
OVRFLOW_DISABLE,SIXTEEN_BIT,CHINT_END,CHINT_ENABLE);


StartDMACH1();
EPwm1Regs.TBCTL.bit.CTRMODE = 0; // count up and start








// Waiting ADC finish
while(!ADC_END);
// Translate DMABuf to ADC_Result
for (i=0; i<BUF_SIZE; i++)
{
ADC_Result[i] = (float)DMABuf1[i] * 3.0 / 4096.0;
}

for(;;);



}






// INT7.1
interrupt void local_DINTCH1_ISR(void) // DMA Channel 1
{

// To receive more interrupts from this PIE group, acknowledge this interrupt
PieCtrlRegs.PIEACK.all = PIEACK_GROUP7;
ADC_END = 1;
}






//===========================================================================
// No more.
//===========================================================================



相关帖子

沙发
sdlls| | 2017-3-17 20:46 | 只看该作者
数据宽度对不对?

使用特权

评论回复
板凳
sdlls| | 2017-3-17 20:55 | 只看该作者
是不是ADC转换的时候有问题?

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

10

主题

72

帖子

8

粉丝