久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2937|回復: 4
打印 上一主題 下一主題
收起左側

SI4432完整版單片機源碼與開發文檔分享

[復制鏈接]
跳轉到指定樓層
樓主
分享一個收集到的完整版的SI4432的源碼與開發文檔等資料。這個是我自己做過實驗的完善的可行的版本。

程序功能可以發也可以收,平時處于檢測接收,有信號就會接收。而當檢測到按鍵后發送數據LED燈閃爍,對應另一方收到數據后判斷是否正確,數據正確LED閃爍。并發送返回數據。依次循環



單片機源程序如下:
  1. /*
  2. Demo 程序適用范圍: Si4431F13, Si4432F20, Si4431F27
  3. RF 模塊的參數設置為: FSK,  433.5MHz, 1.2KBPS, +/-10PPM, 頻偏:30KHz, 調制帶寬:61.2KHz
  4. 使能AFC,使能CRC, PH + FIFO 模式, 頭碼:"swwx", 同步字: 0x2d 0xd4
  5. 每秒鐘發射的固定測試數據為:
  6. 0x41,0x42,0x43,0x44,0x45,0x46,0x47,0x48,0x49,0x6d,
  7. 0x6d是發生數據的 CheckSum, 0x6d = (0x41 +0x42 +0x43 +0x44 +0x45 +0x46 +0x47 + 0x48 +0x49)
  8. 控制MCU : 8 bit MCU :STC89C52, 11.0592MHZ
  9. */

  10. #include <reg52.h>  //52寄存器
  11. #include<math.h>
  12. #include <intrins.h>

  13. #define  SI4432_PWRSTATE_READY                          01                // 模塊 Ready 狀態定義
  14. #define  SI4432_PWRSTATE_TX                                      0x09                // 模塊 發射狀態定義
  15. #define  SI4432_PWRSTATE_RX                                      05                // 模塊 接收狀態定義
  16. #define  SI4432_PACKET_SENT_INTERRUPT              04                // 模塊 發射完成中斷
  17. #define  SI4432_Rx_packet_received_interrupt  0x02      // 模塊 收到數據包中斷

  18. #define  TX1_RX0        spi_rw(0x0e|0x80, 0x01)                // 發射狀態的天線開關定義
  19. #define  TX0_RX1        spi_rw(0x0e|0x80, 0x02)                // 接收狀態的天線開關定義
  20. #define  TX0_RX0        spi_rw(0x0e|0x80, 0x00)         // 非發射,接收狀態的天線開關定義

  21. //========================================SI4432與MCU連接========================================
  22. sbit SDN   = P3^3;
  23. sbit nIRQ  = P1^4;
  24. sbit nSEL  = P1^3;
  25. sbit SCK   = P1^2;
  26. sbit SDI   = P1^1;
  27. sbit SDO   = P1^0;
  28. //========================================按鍵端口===============================================
  29. sbit KEY   = P3^6;
  30. //========================================LED顯示端口============================================
  31. sbit LED   = P3^4;

  32. unsigned char ItStatus1, ItStatus2;
  33. unsigned char rf_timeout;
  34. unsigned char rx_buf[15];

  35. // 檢測到按鍵后發射的固定內容的測試信號,第10個數據是前9個數據的校驗和
  36. const unsigned char tx_test_data[10] = {0x41,0x42,0x43,0x44,0x45,0x46,0x47,0x48,0x49,0x6d};  
  37. //===============================================================================================
  38. typedef struct
  39. {
  40.        
  41.         unsigned char reach_1s                                : 1;
  42.         unsigned char rf_reach_timeout                : 1;
  43.         unsigned char is_tx                                        : 1;
  44.        
  45.        
  46. }        FlagType;

  47. FlagType   Flag;

  48. //==============================================函數申明===========================================
  49. void delay_1ms(unsigned char time);
  50. unsigned char spi_byte(unsigned char TRdata);
  51. unsigned char spi_rw(unsigned char addr, unsigned char TRdata);
  52. void rx_data(void);
  53. void tx_data(void);
  54. void SI4432_init(void);
  55. //================================================延時函數=========================================
  56. void delay_1ms(unsigned char time)
  57. {
  58.         unsigned char i,k;
  59.         for(k = 0; k< time; k++)
  60.         {
  61.                 for(i = 0; i<130; i++)
  62.                 {
  63.                          _nop_();
  64.                 }
  65.         }               
  66. }       
  67. //===============================================SPI讀寫函數=======================================

  68. unsigned char spi_byte(unsigned char TRdata)
  69. {
  70.         unsigned char i;
  71.        
  72.         for (i = 0; i < 8; i++)                                // 控制SCK 和 SDI,發射一個字節的命令,同事讀取1個字節的數據
  73.         {                                                                        // 沒有包括nSEL的控制
  74.                 if (TRdata & 0x80)
  75.                         SDI = 1;
  76.                 else
  77.                         SDI = 0;
  78.                        
  79.                 TRdata <<= 1;
  80.                 SCK = 1;
  81.                
  82.                 if (SDO)
  83.                         TRdata |= 0x01;
  84.                 else
  85.                         TRdata &= 0xfe;
  86.                        
  87.                 SCK = 0;
  88.         }
  89.        
  90.         return (TRdata);
  91. }
  92. //-------------------------------------------對寄存器讀寫操作===========================================
  93. unsigned char spi_rw(unsigned char addr, unsigned char TRdata)
  94. {
  95.         unsigned char i;
  96.        
  97.         SCK = 0;
  98.         nSEL = 0;
  99.        
  100.         for (i = 0; i < 8; i++)
  101.         {
  102.                 if (addr & 0x80)
  103.                         SDI = 1;
  104.                 else
  105.                         SDI = 0;
  106.                 addr <<= 1;
  107.                 SCK = 1;
  108.                 _nop_();
  109.                 SCK = 0;
  110.         }
  111. //======================================================================================================       
  112.         for (i = 0; i < 8; i++)
  113.         {
  114.                 if (TRdata & 0x80)
  115.                         SDI = 1;
  116.                 else
  117.                         SDI = 0;
  118.                 TRdata <<= 1;
  119.                 SCK = 1;
  120.                 if (SDO)
  121.                         TRdata |= 0x01;
  122.                 else
  123.                         TRdata &= 0xfe;
  124.                 SCK = 0;
  125.         }
  126.         nSEL = 1;
  127.         SCK = 1;
  128.         return (TRdata);
  129. }
  130. //=========================================接收數據================================================
  131.   
  132. void rx_data(void)
  133. {       

  134.         Flag.is_tx = 0;
  135.         spi_rw(0x07|0x80, SI4432_PWRSTATE_READY);        //進入 Ready 模式
  136.         delay_1ms(5);               
  137.         TX0_RX1;                                                                        // 設置天線開關
  138.         spi_rw(0x08|0x80, 0x03);                                          //清發射,接收緩沖區
  139.         spi_rw(0x08|0x80, 0x00);                                          //清發射,接收緩沖區
  140.                
  141.         spi_rw(0x07|0x80,SI4432_PWRSTATE_RX );          // RF 模塊進入接收模式
  142.        
  143.         spi_rw(0x05|0x80, SI4432_Rx_packet_received_interrupt);  // RF模塊收到整包數據后,產生中斷
  144.                
  145.         ItStatus1 = spi_rw(0x03,0x00);                                //清掉現有的中斷標志
  146.         ItStatus2 = spi_rw(0x04,0x00);                                //清掉現有的中斷標志
  147.                
  148. }       
  149. //=========================================發送數據================================================
  150. void tx_data(void)
  151. {
  152.         unsigned char i;
  153.        
  154.         Flag.is_tx = 1;
  155.         spi_rw(0x07|0x80, SI4432_PWRSTATE_READY);        // rf 模塊進入Ready 模式

  156.         TX1_RX0;                //設置天線開關的方向
  157.        
  158.         delay_1ms(5);                // 延時 5ms, 讓系統穩定
  159.        
  160.         spi_rw(0x08|0x80, 0x03);  //
  161.         spi_rw(0x08|0x80, 0x00);  // 清發射,接收緩沖區
  162.                        
  163.         spi_rw(0x34|0x80, 40);    // 發射40個Nibble 的前導碼
  164.         spi_rw(0x3e|0x80, 10);    // 總共發射10個字節的數據
  165.           for (i = 0; i<10; i++)
  166.         {
  167.                 spi_rw(0x7f|0x80, tx_test_data[i]);         // 將要發射的數據載入緩沖區
  168.         }
  169.         spi_rw(0x05|0x80, SI4432_PACKET_SENT_INTERRUPT);        // 整包數據發射完后,產生中斷
  170.         ItStatus1 = spi_rw(0x03,0x00);                // 清RF模塊中斷       
  171.         ItStatus2 = spi_rw(0x04,0x00);
  172.         spi_rw(0x07|0x80, SI4432_PWRSTATE_TX);  // 進入發射模式
  173. //        delay_1ms(5);       

  174.         rf_timeout = 0;
  175.         Flag.rf_reach_timeout = 0;

  176.         nIRQ=1;

  177.         while(nIRQ)                // 等待中斷
  178.         {
  179.                
  180.                 if(Flag.rf_reach_timeout)
  181.                 {
  182.                        
  183.                         SDN  = 1;                //如果0.5秒還沒有中斷,則RF模塊工作不正常,重新復位并初始化模塊
  184.                         delay_1ms(10);
  185.                         SDN = 0;
  186.                         delay_1ms(200);
  187.                        
  188.                         SI4432_init();
  189.                         break;                // 則強制跳出
  190.                 }
  191.                        
  192.         }
  193.        

  194.    // rx_data();                //rf 發射完成,進入接收模式
  195. }       
  196. //==========================================================================================================
  197. void SI4432_init(void)
  198. {
  199.        
  200.         ItStatus1 = spi_rw(0x03,0x00);                                // 清RF模塊中斷       
  201.         ItStatus2 = spi_rw(0x04,0x00);
  202.        
  203.         spi_rw(0x06|0x80, 0x00);                                          //  關閉不需要的中斷
  204.        
  205.         spi_rw(0x07|0x80, SI4432_PWRSTATE_READY);   // 進入 Ready 模式
  206.          
  207.         spi_rw(0x09|0x80, 0x7f);                                          //  負載電容= 12P

  208.         spi_rw(0x0a|0x80, 0x05);                                        // 關閉低頻輸出
  209.         spi_rw(0x0b|0x80, 0xea);                                         // GPIO 0 當做普通輸出口
  210.         spi_rw(0x0c|0x80, 0xea);                                         // GPIO 1 當做普通輸出口       
  211.         spi_rw(0x0d|0x80, 0xf4);                                          // GPIO 2 輸出收到的數據
  212.        
  213.         spi_rw(0x70|0x80, 0x2c);                                          // 下面的設置根據Silabs 的Excel
  214.         spi_rw(0x1d|0x80, 0x40);                                          // 使能 afc
  215.                
  216. //======================================1.2K bps setting start===============================================
  217.         spi_rw(0x1c|0x80, 0x16);       
  218.                
  219.         spi_rw(0x20|0x80, 0x83);            
  220.         spi_rw(0x21|0x80, 0xc0);
  221.         spi_rw(0x22|0x80, 0x13);
  222.         spi_rw(0x23|0x80, 0xa9);
  223.         spi_rw(0x24|0x80, 0x00);
  224.         spi_rw(0x25|0x80, 0x04);
  225.        
  226.         spi_rw(0x2a|0x80, 0x14);
  227.         spi_rw(0x6e|0x80, 0x09);
  228.         spi_rw(0x6f|0x80, 0xd5);       
  229. //=====================================1.2K bps setting end        ===============================================               
  230.         spi_rw(0x30|0x80, 0x8c);   // 使能PH+ FIFO模式,高位在前面,使能CRC校驗
  231.                                         
  232.         spi_rw(0x32|0x80, 0xff);  // byte0, 1,2,3 作為頭碼
  233.          
  234.         spi_rw(0x33|0x80, 0x42);//  byte 0,1,2,3 是頭碼,同步字3,2 是同步字
  235.                
  236.         spi_rw(0x34|0x80, 16);  // 發射16個Nibble的Preamble
  237.         spi_rw(0x35|0x80, 0x20);  // 需要檢測4個nibble的Preamble
  238.         spi_rw(0x36|0x80, 0x2d);  // 同步字為 0x2dd4
  239.         spi_rw(0x37|0x80, 0xd4);
  240.         spi_rw(0x38|0x80, 0x00);
  241.         spi_rw(0x39|0x80, 0x00);
  242.         spi_rw(0x3a|0x80, 's');   // 發射的頭碼為: “swwx"
  243.         spi_rw(0x3b|0x80, 'w');
  244.         spi_rw(0x3c|0x80, 'w');
  245.         spi_rw(0x3d|0x80, 'x');
  246.         spi_rw(0x3e|0x80, 10);    // 總共發射10個字節的數據
  247.         spi_rw(0x3f|0x80, 's');   // 需要校驗的頭碼為:”swwx"
  248.         spi_rw(0x40|0x80, 'w');
  249.         spi_rw(0x41|0x80, 'w');
  250.         spi_rw(0x42|0x80, 'x');
  251.         spi_rw(0x43|0x80, 0xff);  // 頭碼1,2,3,4 的所有位都需要校驗
  252.         spi_rw(0x44|0x80, 0xff);  //
  253.         spi_rw(0x45|0x80, 0xff);  //
  254.         spi_rw(0x46|0x80, 0xff);  //
  255.         spi_rw(0x6d|0x80, 0x07);  // 設置為最大功率發射

  256.         spi_rw(0x79|0x80, 0x0);  // 不需要跳頻
  257.         spi_rw(0x7a|0x80, 0x0);  // 不需要跳頻
  258.        
  259.         spi_rw(0x71|0x80, 0x22); // 發射不需要 CLK,FiFo , FSK模式
  260.                        
  261.         spi_rw(0x72|0x80, 0x30);  // 頻偏為 30KHz       

  262.         spi_rw(0x73|0x80, 0x0);  // 沒有頻率偏差
  263.         spi_rw(0x74|0x80, 0x0);  // 沒有頻率偏差
  264.                
  265.         spi_rw(0x75|0x80, 0x53);  // 頻率設置 434
  266.         spi_rw(0x76|0x80, 0x57);  //
  267.         spi_rw(0x77|0x80, 0x80);       
  268. }
  269. //=================================================主函數==========================================
  270. void main()
  271. {
  272.        

  273.         unsigned char  i, chksum;
  274.         SDN = 1;
  275.         delay_1ms(10);        // RF 模塊上電復位
  276.         SDN = 0;
  277.         delay_1ms(200);        // 延時200ms RF 模塊進入工作狀態
  278.         SI4432_init();  // RF 模塊初始化        
  279.         TX0_RX0;        // 天線開關不在發射,接收狀態
  280.         rx_data();       
  281.         Flag.reach_1s = 0;       
  282.         while(1)
  283.         {               
  284.                 if(KEY==0)
  285.                 {
  286.                 //        Flag.reach_1s = 0;
  287.                         tx_data();                // 每間隔一段時間,發射一包數據,并接收 Acknowledge 信號
  288.                         LED=0;  delay_1ms(200);  LED=1        ; delay_1ms(200);
  289.                         rx_data();                //rf 發射完成,進入接收模式
  290.                 }


  291.                 if(!Flag.is_tx)
  292.        
  293.                 {
  294.                         nIRQ=1;
  295.                         if(!nIRQ)
  296.                         {        
  297.                                 ItStatus1 = spi_rw(0x03,0x00);        // 清中斷                                                                                        //read the Interrupt Status1 register
  298.                                 ItStatus2 = spi_rw(0x04,0x00);        // 清中斷
  299.                                
  300.                                 SCK = 0;
  301.                                 nSEL = 0;
  302.                                 spi_byte(0x7f);                // 從緩沖區讀數據
  303.                                 for(i = 0;i<10;i++)       
  304.                                 {
  305.                                         rx_buf[i] = spi_byte(0x00);
  306.                                 }
  307.                                 nSEL = 1;
  308.                                
  309. ……………………

  310. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼


所有資料51hei提供下載:
SI4432無線評估開發包.rar (1.5 MB, 下載次數: 68)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏3 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:243076 發表于 2018-8-29 08:52 | 只看該作者
有需要的下載吧
回復

使用道具 舉報

板凳
ID:261483 發表于 2020-4-26 17:19 | 只看該作者
謝謝 已下載 ~
回復

使用道具 舉報

地板
ID:787412 發表于 2020-6-23 11:14 | 只看該作者
正需要這個東東,標記一下.
回復

使用道具 舉報

5#
ID:774633 發表于 2020-6-23 13:50 | 只看該作者
謝謝,已下載
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲免费在线视频 | www.狠狠干| 精品久久久久久久人人人人传媒 | 奇米四色在线观看 | 欧美日韩网站 | 国产亚洲精品久久久久久牛牛 | 岛国av免费在线观看 | 一级免费毛片 | 毛片一区 | 99re视频| 久久国内| 亚洲欧美日韩精品久久亚洲区 | 91一区二区 | 欧美日韩在线精品 | 激情小视频 | 婷婷久久精品一区二区 | 国产高清一区二区 | 美女黄色在线观看 | 国产精品视频在线播放 | 国产欧美一区二区久久性色99 | 成人h片在线观看 | 黄色小视频入口 | 久久午夜视频 | 国产精品99久久久久久久久 | 一区影院 | 久久久亚洲综合 | 亚洲成人一区二区三区 | 欧美一区二区三区在线观看视频 | 夜夜爽99久久国产综合精品女不卡 | 国产精品美女久久久久久久网站 | 欧美精品在线一区二区三区 | 久久精品综合 | 日韩精品网站 | 99精品视频免费观看 | 日本不卡免费新一二三区 | 狠狠av| 男女网站免费观看 | 日本久久综合 | 国产成人精品a视频一区www | 国产精品久久国产精品久久 | 国产精品视频网址 |