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

共12条 1/2 1 2 跳转至

DSP2812与ads1158通讯源代码!

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



关键词: DSP2812     ads1158     通讯     源代码    

高工
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这样比较新的芯片例程一般很难找到的!

高工
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 跳转至

回复

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