OpenEdv-开源电子网

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

51和STM32用NRF2401通信问题

[复制链接]

7

主题

35

帖子

0

精华

初级会员

Rank: 2

积分
151
金钱
151
注册时间
2016-2-12
在线时间
28 小时
发表于 2017-3-30 22:47:22 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 superyou 于 2017-3-31 09:06 编辑

51和51是可以用NRF2401模块通信的,但是51发送给STM32却不可以,两边的基本设置都已经一样了,还是不行,是什么问题,是和数据传输率有关吗?还是?求大神帮忙啦!32是用原子哥的nrf2401的历程
51的代码如下:
#include <reg52.h>
#include <intrins.h>
#include <api.h>

/***************************************************/
#define uchar unsigned char
#define TX_ADR_WIDTH   5  //
#define TX_PLOAD_WIDTH 4  //
uchar code TX_ADDRESS[TX_ADR_WIDTH] = {0x34,0x43,0x10,0x10,0x01};  //
//uchar code RX_ADDRESS[TX_ADR_WIDTH] = {0x34,0x43,0x10,0x10,0x02};
uchar RX_BUF[TX_PLOAD_WIDTH];
uchar TX_BUF[TX_PLOAD_WIDTH] = {0x22,0x34,0x56,0x78};
uchar flag;
uchar DATA = 0x01;
uchar bdata sta;
sbit  RX_DR         = sta^6;
sbit  TX_DS         = sta^5;
sbit  MAX_RT = sta^4;
/**************************************************/

/**************************************************

/**************************************************/
void init_io(void)
{
        CE  = 0;        // ′y&#187;ú
        CSN = 1;        // SPI&#189;&#251;&#214;1
        SCK = 0;        // SPIê±&#214;ó&#214;&#195;μí
        IRQ = 1;        // &#214;D&#182;&#207;&#184;′&#206;&#187;
}
/**************************************************/

/**************************************************

/**************************************************/
void delay_ms(uchar x)
{
    uchar i, j;
    i = 0;
    for(i=0; i<x; i++)
    {
       j = 250;
       while(--j);
           j = 250;
       while(--j);
    }
}
/**************************************************/

/**************************************************

/**************************************************/
uchar SPI_RW(uchar byte)
{
        uchar i;
           for(i=0; i<8; i++)          // &#209;-&#187;·8′&#206;
           {
                   MOSI = (byte & 0x80);   //
                   byte <<= 1;             //
                   SCK = 1;                //
                   byte |= MISO;               //
                   SCK = 0;                    //
           }
    return(byte);                   //
}
/**************************************************/

/**************************************************

/**************************************************/
uchar SPI_RW_Reg(uchar reg, uchar value)
{
        uchar status;
          CSN = 0;                   //
          status = SPI_RW(reg);      //
          SPI_RW(value);             //
          CSN = 1;                   //
          return(status);            //
}
/**************************************************/

/**************************************************

/**************************************************/
uchar SPI_Write_Buf(uchar reg, uchar * pBuf, uchar bytes)
{
        uchar status, i;
          CSN = 0;                    //
          status = SPI_RW(reg);       //
          for(i=0; i<bytes; i++)
            SPI_RW(pBuf);        //
          CSN = 1;                    //
          return(status);             //
}
/**************************************************/

/**************************************************

/**************************************************/
void TX_Mode(uchar * BUF)
{
        CE = 0;
          SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH);     //
          SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH);  //
          SPI_Write_Buf(WR_TX_PLOAD, BUF, TX_PLOAD_WIDTH);                  //
          SPI_RW_Reg(WRITE_REG + EN_AA, 0x01);       //
          SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01);   //
          SPI_RW_Reg(WRITE_REG + SETUP_RETR, 0x0a);  //
          SPI_RW_Reg(WRITE_REG + RF_CH, 40);         //
          SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x01);    //
          SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e);      //
        CE = 1;
}
/**************************************************/

/**************************************************

/**************************************************/
uchar Check_ACK(bit clear)
{
        while(IRQ);
        sta = SPI_RW(NOP);                    //
        if(MAX_RT)
                if(clear)                         //
                        SPI_RW(FLUSH_TX);
        SPI_RW_Reg(WRITE_REG + STATUS, sta);  //
        IRQ = 1;
        if(TX_DS)
                return(0x00);
        else
                return(0xff);
}

/**************************************************/

/**************************************************

/**************************************************/
void main(void)
{
        init_io();
        while(1)
        {
                TX_Mode(TX_BUF);
                Check_ACK(1);
                delay_ms(1000);
        }
}
/**************************************************/

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2017-3-31 00:37:23 | 显示全部楼层
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手上路

积分
20
金钱
20
注册时间
2017-2-18
在线时间
3 小时
发表于 2017-5-7 21:25:26 | 显示全部楼层
现在弄出来了吗?我也遇到同样的问题了
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
13
金钱
13
注册时间
2017-4-7
在线时间
3 小时
发表于 2017-5-10 17:59:42 | 显示全部楼层
uchar SPI_RW(uchar byte) {         uchar i;            for(i=0; i<8; i++)          // &#209;-&#187;·8′&#206;            {                    MOSI = (byte & 0x80);   //                     byte <<= 1;             //                     SCK = 1;                //                    byte |= MISO;               //                     SCK = 0;                    //            }     return(byte);                   // }
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
13
金钱
13
注册时间
2017-4-7
在线时间
3 小时
发表于 2017-5-10 18:00:43 | 显示全部楼层
感觉 你这个函数里面的byte又是要写的数据 又是读回来的数据 造成了混乱
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-23 03:26

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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