AD7606 与STM32MINI板SPI通信采集数据,昨天采样两线全双工,读出数据为0000,现在改为一线只读,读出数据与实际接入电压不对...

2019-08-16 22:24发布

采集到数据一直在跳变,换算后与接入电压值也不对应,调了两天也没搞好,请大家看看,帮帮忙
*********************************************************以下是程序代码,希望各位帮忙指正
#include "spi.h"
#include "sys.h"

//PA4、PA5、PA6分别接AD7606CS、SCK/RD,DB7
#define SCK_0()                GPIOA->BRR = GPIO_Pin_5
#define SCK_1()                GPIOA->BSRR = GPIO_Pin_5

void _SPI__Init()
{
        GPIO_InitTypeDef  GPIO_InitStructure;
        SPI_InitTypeDef   SPI_InitStruct;

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA| RCC_APB2Periph_GPIOB|RCC_APB2Periph_SPI1 , ENABLE);

        
  //配置SPI1 : SCK, MISO and MOSI */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;//SCK配置
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
  
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;//MISO配置
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
  
  //配置片选 IO PA4
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4;//ƬѡÅäÖÃ
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
        PAout(4)=1;
  PAout(5)=0;
        
                //配置CONVST GPIO */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
        GPIO_Init(GPIOA, &GPIO_InitStructure);
        PAout(8)=1;
        //配置RANGE  
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
        GPIO_Init(GPIOB, &GPIO_InitStructure);
        PBout(5)=1;
        //配置REST
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
        GPIO_Init(GPIOB, &GPIO_InitStructure);
        PBout(7)=1;
                //busy
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//PB6_BUSY 配置
        GPIO_Init(GPIOB, &GPIO_InitStructure);
        
  SPI_InitStruct.SPI_BaudRatePrescaler=SPI_BaudRatePrescaler_64;
        SPI_InitStruct.SPI_CPHA=SPI_CPHA_2Edge;//第二个上升沿采集
        SPI_InitStruct.SPI_CPOL=SPI_CPOL_High;
        SPI_InitStruct.SPI_CRCPolynomial=7;
        SPI_InitStruct.SPI_DataSize=SPI_DataSize_8b;//8λ
        SPI_InitStruct.SPI_Direction=SPI_Direction_1Line_Rx;//只读
        SPI_InitStruct.SPI_FirstBit=SPI_FirstBit_MSB;//¸高位在前
        SPI_InitStruct.SPI_Mode=SPI_Mode_Master;
        SPI_InitStruct.SPI_NSS=SPI_NSS_Soft;
        SPI_Init(SPI1,&SPI_InitStruct);
        
        SPI_Cmd(SPI1, ENABLE);
        ad7606_SetOS(0);//设置是否过采样
  ad7606_SetInputRange(0);//设置范围
  ad7606_Reset();//硬件复位
  AD_CONVST_HIGH();
        ad7606_StartConv();//开始转换
}




//设置电压范围0代表正负5V 1代表正负10v
void ad7606_SetInputRange(u8  _ucRange)
{
        if (_ucRange == 0)
        {
                PBout(5) = 0;
        }
        else
        {
                PBout(5) = 1;
        }
}

//硬件复位函数
void ad7606_Reset(void)
{

        int i;
        AD_CS_HIGH();
        PBout(7)=0;
        PBout(7)=1;
        for(i=0;i<50;i++) ;
        PBout(7)=0;
}
//开始转换函数
void ad7606_StartConv(void)
{

        AD_CONVST_HIGH();
        AD_CONVST_HIGH();
        AD_CONVST_LOW();
        AD_CONVST_LOW();        /* μíμ&#231;&#198;&#189;50ns */
        AD_CONVST_LOW();
        AD_CONVST_LOW();
//        delay_ms(5);
        AD_CONVST_HIGH();
}

//设置是否过采样函数

void ad7606_SetOS(u8 _ucMode)
{
        if (_ucMode == 1)
        {
                AD_OS2_0();
                AD_OS1_0();
                AD_OS0_1();
        }
        else if (_ucMode == 2)
        {
                AD_OS2_0();
                AD_OS1_1();
                AD_OS0_0();
        }
        else if (_ucMode == 3)
        {
                AD_OS2_0();
                AD_OS1_1();
                AD_OS0_1();
        }
        else if (_ucMode == 4)
        {
                AD_OS2_1();
                AD_OS1_0();
                AD_OS0_0();
        }
        else if (_ucMode == 5)
        {
                AD_OS2_1();
                AD_OS1_0();
                AD_OS0_1();
        }
        else if (_ucMode == 6)
        {
                AD_OS2_1();
                AD_OS1_1();
                AD_OS0_0();
        }
        else        
        {
                AD_OS2_0();
                AD_OS1_0();
                AD_OS0_0();
        }
}
//延时函数
void bsp_spiDelay(void)
{
        u8 i;

        for (i = 0; i<2; i++);
}


//读取8位数据
u8  bsp_spiRead(void)
{

        u8 read=0;
        u8 i;
        for (i = 0; i < 8; i++)
        {  
    SCK_0();//拉低时钟延时
                bsp_spiDelay();
                read<<=1;        
                if(PAin(6)==1)
    {
                  read++;         
                }
    SCK_1();//拉高时钟
                bsp_spiDelay();
        }

        return read;

}
#include "stm32f10x.h"
#include "delay.h"
#include "usart.h"
#include "spi.h"
#include "led.h"
#include "string.h"
//#include "TIMER.h"
u16 ADC_value1[8];//′&#230;·&#197;8í¨μàêy&#214;μ
float pp[2];
char string[20];
int main(void)
{        
   u8 i;
         SystemInit();
         LED_Init();
          _SPI__Init();
        // _TIMER_Init_(4999,7199);
   delay_init();
         uart_init(115200);
         
         while(1)
         {
                 if(PBin(6)==0)//PB6接busy引脚,判断busy是否为零
                {
       PAout(5)=1;//拉高时钟线
                   AD_CS_LOW();//拉低片选
       for(i=0;i<1;i++)
            {        
              ADC_value1=bsp_spiRead();
                                ADC_value1=ADC_value1*256+bsp_spiRead();
                          pp=(float) ADC_value1/32767*5;
                    printf("%f ",pp);        
            }

      AD_CS_HIGH();//拉高片选
            ad7606_StartConv();//开始转换
                }
                delay_ms(500);
         }
}
[/mw_shl_code]

*********************************************************以上是程序代码,希望各位帮忙指正

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
24条回答
jack he
1楼-- · 2019-08-17 01:42
今天测试成功,把读取函数里加上spi开断代码,以前读出来数字无规律是因为spi初始化后就一直发出时钟,这样就不断地从ad7606读数据1


u16 SPI_ReadTwoByte(void)
{               
        u8 retry=0;       
        SPI_Cmd(SPI2, ENABLE);       
        while (SPI_I2S_GetFlagStatus(SPI2, SPI_I2S_FLAG_RXNE) == RESET) //检查指定的SPI标志位设置与否:接受缓存非空标志位
                {
                        retry++;
                        if(retry>200)return 0;
                }
        SPI_Cmd(SPI2, DISABLE);               
        return SPI_I2S_ReceiveData(SPI2); //返回通过SPIx最近接收的数据       
正点原子
2楼-- · 2019-08-17 07:38
帮顶
Rocks
3楼-- · 2019-08-17 09:53
看不懂你的讀取是在讀什麼

你到底是用模擬的SPI
還是用原生的SPI
WWWW
4楼-- · 2019-08-17 11:54
Rocks 发表于 2016-3-4 17:45
看不懂你的讀取是在讀什麼

你到底是用模擬的SPI

用模拟的SPI,读取的但是数据不正确
xuande
5楼-- · 2019-08-17 15:42
 精彩回答 2  元偷偷看……
jack he
6楼-- · 2019-08-17 17:16
楼主解决了吗,最近我也在做这个。我调试时spi读出来的数据总是毫无规律的,跟被测电压无关

一周热门 更多>