OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3239|回复: 2

STM32和DSP通信,STM32发送引脚一直是高没有数据?

[复制链接]

4

主题

11

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-2-16
在线时间
5 小时
发表于 2016-3-20 14:34:52 | 显示全部楼层 |阅读模式
1金钱
我用示波器观察,时钟信号是有的,DSP是主机MOSI引脚有DSP那边发过来的数据(示波器观察到波形),但是STM32的PA6脚一直是高电平,我是哪里出了问题,希望大家帮忙看看。#include "led.h"#include "delay.h"
#include "sys.h"
#include "spi.h"

int main(void)
{
        u16 rdata;
        u16 sdata=0x0000;
        delay_init();                     //延时函数初始化
  SPI1_Init();    //初始化SPI口         
        SPI1_SetSpeed(SPI_BaudRatePrescaler_2);//SPI速度两分频,从机的话这句话应该不起作用
        while(1)
        {
                        rdata=SPI1_ReadWriteByte(sdata);
                        sdata=rdata;               
        }
}

SPI1_ReadWriteByte()这个函数的参数和返回参数我都改成16位了,为了和DSP数据匹配,请问还有哪些地方不合适吗?

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

11

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-2-16
在线时间
5 小时
 楼主| 发表于 2016-3-20 14:36:18 | 显示全部楼层

RE: STM32和DSP的SPI通信,STM32发送引脚一直是高没有数据?

忘了说明我用的SPI通信
回复

使用道具 举报

4

主题

11

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-2-16
在线时间
5 小时
 楼主| 发表于 2016-3-20 14:43:50 | 显示全部楼层
#include "spi.h"
//////////////////////////////////////////////////////////////////////////////////         
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//Mini STM32开发板
//SPI 驱动函数          
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//修改日期:2010/6/13
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 正点原子 2009-2019
//All rights reserved
//////////////////////////////////////////////////////////////////////////////////           


//以下是SPI模块的初始化代码,配置成主机模式,访问SD Card/W25X16/24L01/JF24C                                                          
//SPI口初始化
//这里针是对SPI1的初始化

SPI_InitTypeDef  SPI_InitStructure;

void SPI1_Init(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
  
        RCC_APB2PeriphClockCmd(        RCC_APB2Periph_GPIOA|RCC_APB2Periph_SPI1, ENABLE );        //使能SPI1时钟

        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7;//SCK.、MISO、MOSI?
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;  //复用推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

        GPIO_SetBits(GPIOA,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);

        SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;  //设置SPI单向或者双向的数据模式:SPI设置为双线双向全双工
        SPI_InitStructure.SPI_Mode = SPI_Mode_Slave;                //设置SPI工作模式:设置为从SPI
        SPI_InitStructure.SPI_DataSize = SPI_DataSize_16b;                //设置SPI的数据大小:SPI发送接收16位帧结构
        SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;                //选择了串行时钟的稳态:时钟悬空低
        SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;        //数据捕获于第一个时钟沿
        SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;                //NSS信号由硬件(NSS管脚)还是软件(使用SSI位)管理:内部NSS信号有SSI位控制
//        SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256;                //定义波特率预分频的值:波特率预分频值为256
        SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;        //指定数据传输从MSB位还是LSB位开始:数据传输从MSB位开始,高位
        SPI_InitStructure.SPI_CRCPolynomial = 7;        //用来设置CRC校验多项式,提高通信可靠性,大于1即可。
        SPI_Init(SPI1, &SPI_InitStructure);  //根据SPI_InitStruct中指定的参数初始化外设SPIx寄存器

        SPI_Cmd(SPI1, ENABLE); //使能SPI外设
       
        SPI1_ReadWriteByte(0xff);//启动传输                 
}   
//SPI 速度设置函数
//SpeedSet:
//SPI_BaudRatePrescaler_2   2分频   (SPI 36M@sys 72M)
//SPI_BaudRatePrescaler_8   8分频   (SPI 9M@sys 72M)
//SPI_BaudRatePrescaler_16  16分频  (SPI 4.5M@sys 72M)
//SPI_BaudRatePrescaler_256 256分频 (SPI 281.25K@sys 72M)
  
void SPI1_SetSpeed(u8 SpeedSet)
{
        SPI_InitStructure.SPI_BaudRatePrescaler = SpeedSet ;
          SPI_Init(SPI1, &SPI_InitStructure);
        SPI_Cmd(SPI1,ENABLE);
}

//SPIx 读写一个字节
//TxData:要写入的字节
//返回值:读取到的字节
u16 SPI1_ReadWriteByte(u16 TxData)
{               
        u8 retry=0;                                        
        while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET) //检查指定的SPI标志位设置与否:发送缓存空标志位
                {
                retry++;
                if(retry>200)return 0;
                }                          
        SPI_I2S_SendData(SPI1, TxData); //通过外设SPIx发送一个数据
        retry=0;

        while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_RXNE) == RESET)//检查指定的SPI标志位设置与否:接受缓存非空标志位
                {
                retry++;
                if(retry>200)return 0;
                }                                                              
        return SPI_I2S_ReceiveData(SPI1); //返回通过SPIx最近接收的数据                                            
}






























这是SPI.C的配置
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-20 03:53

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表