zoukankan      html  css  js  c++  java
  • MFRCC522 SPI无法通讯【worldsing笔记】

    用单片机于MRFC522与单片接时,加上485通讯后出现很诡异的像:

    只要485芯片上有收到外部发送的信号时RC522就死掉,经过仿真卡在了SPI的收发部分(等待回复)

    u8 MFRC522WriteByte(u8 Byte)
        {
          {int i = 0; while((SPI1->SR&0X02)==0 && i < 0xff) i++;}         //等待发送区空      
          SPI1->DR=Byte;                                                  //发送一个byte   
          {int i = 0; while((SPI1->SR&0X01)==0&& i < 0xff) i++;};        //等待接收完一个byte  
          return SPI1->DR;                                               //返回收到的数据            
        }
     
    初步分析是因为485收到的数据过于频繁,导致RC522操作过程中被中断而超时,于是把485主机端发送停止掉,
    再测试果然是,以为就是RC522通讯过程中不能中断,然后把RC522的SPI通讯部分改成不中断的:
     
    u8 MFRC522WriteByte(u8 Byte)
        {
          __enable_irq();
          {int i = 0; while((SPI1->SR&0X02)==0 && i < 0xff) i++;}         //等待发送区空      
          SPI1->DR=Byte;                                                  //发送一个byte   
          {int i = 0; while((SPI1->SR&0X01)==0&& i < 0xff) i++;};         //等待接收完一个byte  
          return SPI1->DR;                                                //返回收到的数据        
          __disable_irq();
        }

    再测试,还没法通讯,把串口关了还是不行,此时得到的结论是:由于485总线上发送的数据叠加在RC522天线上,

    或者是说由于485芯片上的信号导致的RC522无法工作。用示波器测量天线的发送信号,和485信号,电源。天线

    信号幅值偏低,通讯时波动比较大。

    解决办法:在RC522的电源上加大续流电容。

  • 相关阅读:
    Hadoop工作流--ChainMapper/ChainReducer?(三)
    什么是工作流?(二)
    Hadoop工作流概念学习系列总述(一)
    Hadoop的ChainMapper和ChainReducer使用案例(链式处理)(四)
    Azkaban是什么?(一)
    爬虫概念与编程学习之如何爬取视频网站页面(三)
    爬虫概念与编程学习之如何爬取视频网站页面(用HttpClient)(二)
    爬虫概念与编程学习之如何爬取网页源代码(一)
    net命令
    arp命令
  • 原文地址:https://www.cnblogs.com/worldsing/p/3443804.html
Copyright © 2011-2022 走看看