这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界» 论坛首页» 综合技术» 物联网技术» DSP2812与ads1158通讯源代码!

共12条 1/2 1 2 跳转至

DSP2812与ads1158通讯源代码!

jpp
高工
2009-11-03 17:10:02 打赏
这两天憋着劲写了这个程序,累死我了,现将自己写的代码上传,供有用的朋友参考。其实我是做硬件的,这个程序虽然让别人看着不难,可在我编写的过程中,遇到了很多很多的问题。时间有限就不说了,有兴趣的朋友可以再联系探讨。。。



关键词: DSP2812 ads1158 通讯 源代码

jpp
高工
2009-11-03 17:10:55 打赏
2楼

#include "DSP281x_Device.h" // DSP281x Headerfile Include File
#include "DSP281x_Examples.h" // DSP281x Examples Include File

void InitSystem(void);
void ConfigureGpio(void);
void spi_Init(void);
void delay_loop(int a);
void spi_xmit(Uint16 a);
Uint16 ad_read();
void initADS1158(void); //初始化ADS1158

//-----------------------------------------------------------------------------

Uint16 rdata[16]; // received data
int i = 0;
//------------------------------------------------------------------------------
void main(void)
{


InitSystem(); //初始化DSP内核寄存器
ConfigureGpio(); //配置GPIO口
// DINT;
// InitPieCtrl();
// IER = 0x0000;
// IFR = 0x0000;
// InitPieVectTable();

spi_Init();
initADS1158();
delay_loop(1600);
// spi_xmit(0x0000);
while(1)
{
// ------------------------------------------- 读寄存器,看数据能否写进ADC
/* spi_xmit(0x4300);
// while(SpiaRegs.SPISTS.bit.INT_FLAG==0);
rdata[i] = SpiaRegs.SPIRXBUF;
SpiaRegs.SPICTL.bit.TALK = 0;
*/
//-----------------------------------------------------------读ADC采样的数据

while(GpioDataRegs.GPEDAT.bit.GPIOE0 == 1);
{
spi_xmit(0x0000);
// while(SpiaRegs.SPISTS.bit.INT_FLAG==0);
rdata[i] = SpiaRegs.SPIRXBUF;
SpiaRegs.SPICTL.bit.TALK = 0;

}

i++;
if(i==16)i=0;


}


}

//------------------------------------------------------------------------------

void delay_loop(int a)
{
long i;
for (i = 0; i < a; i++) {}
}


void spi_xmit(Uint16 a)
{
SpiaRegs.SPICTL.bit.TALK = 0;
delay_loop(3);
SpiaRegs.SPICTL.bit.TALK = 1;
SpiaRegs.SPITXBUF=a;
while (SpiaRegs.SPISTS.bit.INT_FLAG==0);
//delay_loop(16);

}


void InitSystem(void)
{
EALLOW;
SysCtrlRegs.WDCR= 0x0068; // 禁止看门狗模块
SysCtrlRegs.PLLCR.bit.DIV = 10; // 将CPU的PLL倍频系数设为5

SysCtrlRegs.HISPCP.all = 0x1; // 高速时钟的预定标器设置成除以2
SysCtrlRegs.LOSPCP.all = 0x2; // 低速时钟的预定标器设置成除以4,spi的bode rate use it

// 根据需要使能各外设模块的时钟输入
SysCtrlRegs.PCLKCR.bit.EVAENCLK=0;
SysCtrlRegs.PCLKCR.bit.EVBENCLK=0;
SysCtrlRegs.PCLKCR.bit.SCIAENCLK=0;
SysCtrlRegs.PCLKCR.bit.SCIBENCLK=0;
SysCtrlRegs.PCLKCR.bit.MCBSPENCLK=0;
SysCtrlRegs.PCLKCR.bit.SPIENCLK=1;
SysCtrlRegs.PCLKCR.bit.ECANENCLK=0;
SysCtrlRegs.PCLKCR.bit.ADCENCLK=0;
EDIS;
}


void ConfigureGpio(void)
{
EALLOW;
GpioMuxRegs.GPAMUX.all = 0x0; //将GPIO口的引脚配置成通用I/O口
GpioMuxRegs.GPBMUX.all = 0x0;
GpioMuxRegs.GPDMUX.all = 0x0;
GpioMuxRegs.GPEMUX.all = 0x0; // NOset XINT1

GpioMuxRegs.GPFMUX.all = 0x000F; //将GPIOF口的引脚配置成外设功能

GpioMuxRegs.GPGMUX.all = 0x0;

GpioMuxRegs.GPADIR.all = 0xFFFF; //将所有GPIO口配置成数字量out功能
GpioMuxRegs.GPBDIR.all = 0xFFFF;
GpioMuxRegs.GPDDIR.all = 0xFFFF;
GpioMuxRegs.GPEDIR.all = 0xFFFE;
GpioMuxRegs.GPGDIR.all = 0xFFFF;

EDIS;
}

void spi_Init(void)
{

SpiaRegs.SPICCR.bit.SPISWRESET = 0; //复位SPI的操作标志位
SpiaRegs.SPICCR.bit.CLKPOLARITY = 1;//下降沿发送,上升沿捕获
SpiaRegs.SPICCR.bit.SPILBK = 0;// 自检测
SpiaRegs.SPICCR.bit.SPICHAR = 0xF; //CHAR位域= 0111表示8位数据传输


SpiaRegs.SPICTL.bit.OVERRUNINTENA = 0;//禁止接收器溢出中断
SpiaRegs.SPICTL.bit.CLK_PHASE = 0;
SpiaRegs.SPICTL.bit.MASTER_SLAVE = 1; //主模式(可以接收或者发送数据)
SpiaRegs.SPICTL.bit.TALK = 1; //en数据传输
SpiaRegs.SPICTL.bit.SPIINTENA = 0; //禁止SPI中断

SpiaRegs.SPIBRR = 62;
// SPI 波特率 = LSPCLK / ( SPIBRR + 1)
// = 37,5 MHz / ( 124 + 1 )
// = 300 kHz

//将SPI从复位状态释放(进入正常操作模式)
SpiaRegs.SPICCR.bit.SPISWRESET = 1;
// Set so breakpoints don't disturb xmission
SpiaRegs.SPIPRI.bit.FREE = 1;

}


void initADS1158(void) //初始化ADS1158 要想写进数据,每次写完要清SPI int 标志位,否则数据写不进去

{

spi_xmit(0x6008);
delay_loop(16);
rdata[i++] = SpiaRegs.SPIRXBUF;
spi_xmit(0x6101);
delay_loop(16);
rdata[i++] = SpiaRegs.SPIRXBUF;
// spi_xmit(0x6200);
// delay_loop(10);

spi_xmit(0x6301);
delay_loop(16);
rdata[i++] = SpiaRegs.SPIRXBUF;
spi_xmit(0x6400);
// delay_loop(16);
rdata[i++] = SpiaRegs.SPIRXBUF;
spi_xmit(0x6500);
// delay_loop(16);
rdata[i++] = SpiaRegs.SPIRXBUF;
spi_xmit(0x6600);
delay_loop(16);
rdata[i++] = SpiaRegs.SPIRXBUF;
}


Uint16 ad_read()//读A/D数据。
{
Uint16 b;
delay_loop(16);
SpiaRegs.SPITXBUF = 0x0000;
while (SpiaRegs.SPISTS.bit.INT_FLAG==0);
b = SpiaRegs.SPIRXBUF;
return b;
}

// ---------------------------------------------------
// CODE END
//---------------------------------------------------


高工
2009-11-03 17:23:19 打赏
3楼
支持原创

高工
2009-11-03 18:31:11 打赏
4楼
很好,jpp辛苦啦。支持一下

院士
2009-11-03 18:34:22 打赏
5楼
这可是好东西~~~~~~

助工
2009-11-03 22:56:04 打赏
6楼
支持一下楼主,像ads1158这样比较新的芯片例程一般很难找到的!

jpp
高工
2009-11-04 08:58:09 打赏
7楼

多谢大家支持,以后有好东西一定立马上传给大家,介绍一下这个AD,16bit,支持16个单通道采样,或者8组差分采样,差分采样SPS可以达到23.7KHz/chan,当然如果循环采样的话,还要除以通道数,这个AD是我在TI网站上找到的比较快速,又是sigma-deta的16bitADC,个人觉得如果做工业温度、流量多通道的检测,这款芯片还是不错的选择。个人意见,仅供参考。。。


菜鸟
2009-11-06 16:10:21 打赏
8楼
支持楼主的分享

菜鸟
2009-12-13 23:11:00 打赏
9楼
学习中,jpp辛苦啦。支持

菜鸟
2010-04-15 13:46:55 打赏
10楼

好东西啊。我现在也在调这个AD片子,但是遇到不少问题,能跟你请教一下吗,怎么跟你联系?

能不能把你的电路图发一下:zhouhaiyeild@126.com,我感觉我的硬件还有问题。
我的QQ:345985543 能跟你聊聊吗?


共12条 1/2 1 2 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册]