找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5274|回復: 4
打印 上一主題 下一主題
收起左側(cè)

PIC16F639單片機的PKE方案源程序 3D天線可低頻(125K)喚醒,空中高頻端數(shù)據(jù)采用滾...

  [復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:791835 發(fā)表于 2020-6-28 15:12 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
PIC16F639單片機C語言代碼,附件完整工程MPLAB IDE可直接打開,主要功能:3D天線可低頻(125K)喚醒,空中高頻端數(shù)據(jù)采用滾碼方式加密,PIC內(nèi)部硬件加密沒用。。。

單片機源程序如下:
  1. #include <pic.h>
  2. #include <string.h>
  3. #include"Keeloq.h"

  4. __CONFIG(0x1004);   //0001 0000 0000 0100

  5. #define LED      RC0
  6. #define AFECS    RC1                   // CS
  7. #define AFESCLK  RC2                   // SCLK
  8. #define AFESDI   RC3                   // SDI

  9. bit Wake_flag = 0;              //休眠、工作標志位

  10. /*******************************************************************************************/
  11. /*void write_byte(unsigned char com,unsigned char addr,unsigned char byte)                                   */
  12. /*com命令 addr為地址 byte要寫入寄存器的數(shù)據(jù)                                                                                                   */
  13. /*寫命令0x07 讀命令0x06                                                                                                                                       */
  14. /*******************************************************************************************/
  15. void write_byte(unsigned char com,unsigned char addr,unsigned char byte)
  16. {
  17.         unsigned char i,temp;
  18.     unsigned char dat;
  19.         unsigned char crc;
  20.         
  21.         TRISC = 0x00;           //RC0.1.2.3.4.5輸出
  22.     asm("nop");
  23.         asm("nop");                        
  24.     AFESCLK  = 0;
  25.     AFESDI = 0;
  26.     AFECS = 0;                                //使能SPI
  27.         com = com << 4;                        //0000 0111
  28.         temp = addr|com;        //0111 xxxx
  29.     temp = temp << 1;                //將高位移除
  30.         for(i=0;i<7;i++)                //寫命令加地址
  31.         {                                                                  
  32.                  dat = temp&0x80;               
  33.                  temp = temp << 1;                                 
  34.                  if(dat==0x80)
  35.                    AFESDI = 1;        
  36.                  else
  37.                    AFESDI = 0;        
  38.                  AFESCLK  = 1;                //產(chǎn)生上升沿
  39.                  asm("nop");
  40.                  asm("nop");
  41.                  asm("nop");
  42.                  asm("nop");
  43.                  AFESCLK  = 0;
  44.                  //AFESDI = 0;                 
  45.         }
  46.         crc = 0;                                //用于數(shù)據(jù)位1的個數(shù)
  47.         temp = byte;
  48.         for(i=0;i<8;i++)
  49.         {
  50.                 dat = temp&0x80;
  51.                 temp = temp <<1;
  52.                 if(dat==0x80)
  53.                 {        
  54.                         AFESDI = 1;
  55.                         crc ++;
  56.                 }        
  57.                 else
  58.                         AFESDI = 0;        
  59.                 AFESCLK  = 1;                //進行數(shù)據(jù)采樣
  60.                 asm("nop");
  61.                 asm("nop");
  62.                 asm("nop");
  63.                 asm("nop");
  64.                 AFESCLK  = 0;
  65.                 //AFESDI = 0;        
  66.         }
  67.         if(crc%2==0)                        //偶數(shù)個1
  68.         {        
  69.                 AFESDI = 1;        
  70.                 AFESCLK  = 1;                //進行數(shù)據(jù)采樣
  71.                 asm("nop");
  72.                 asm("nop");
  73.                 asm("nop");
  74.                 asm("nop");
  75.                 AFESCLK  = 0;
  76.                 AFESDI = 0;                        
  77.         }
  78.         else
  79.         {
  80.                 AFESDI = 0;        
  81.                 AFESCLK  = 1;                //進行數(shù)據(jù)采樣
  82.                 asm("nop");
  83.                 asm("nop");
  84.                 asm("nop");
  85.                 asm("nop");
  86.                 AFESCLK  = 0;
  87.                 AFESDI = 0;                        
  88.         }
  89.     TRISC = 0x08;
  90.         AFECS = 1;
  91. }

  92. /*******************************************************************************************/
  93. /*unsigned char read_byte(unsigned char addr)                                                                                           */
  94. /*addr為地址  返回讀到數(shù)據(jù)                                                                                                                                   */
  95. /*先寫入命令+地址+無效數(shù)據(jù)(合計16位)拉高CS 再拉低CS 發(fā)送SCLK時鐘讀出數(shù)據(jù)                               */
  96. /*******************************************************************************************/
  97. unsigned char read_byte(unsigned char addr)
  98. {
  99.         unsigned int temp = 0;
  100.         unsigned char i;

  101.         write_byte(0x06,addr,0x00);                //先寫入命令和地址和無效數(shù)據(jù)
  102.         
  103.         TRISC = 0x00;                                         //0000 0100
  104.         asm("nop");
  105.         asm("nop");
  106.         asm("nop");
  107.         asm("nop");
  108.         AFECS = 0;
  109.         for(i=0;i<16;i++)                       // 1010 0000 1
  110.         {
  111.                 AFESCLK = 1;               
  112.                 if(AFESDI) temp = temp|0x01;
  113.                 temp = temp<<1;

  114.                 AFESCLK = 0;
  115.         asm("nop");
  116.         asm("nop");
  117.         asm("nop");
  118.         asm("nop");
  119.         asm("nop");
  120.         asm("nop");
  121.         asm("nop");
  122.         asm("nop");
  123.         }
  124.         TRISC = 0x08;
  125.         AFECS = 1;
  126.         temp = temp>>1;
  127.         return temp;
  128. }

  129. /*******************************************************************************************/
  130. /*void LF_Configuration(void)                                                                               */
  131. /*低頻配置                                                                                                                              */
  132. /*寫命令0x07 讀命令0x06                                                                                                                                       */
  133. /*******************************************************************************************/
  134. void LF_Configuration(void)
  135. {
  136.         //const unsigned char AFEConfig[6]={0x00,0x00,0x00,0x00,0x00,0x30};//解調(diào)輸出無喚醒
  137.     const unsigned char AFEConfig[6]={0xa0,0x00,0x00,0x00,0x00,0x00};//解調(diào)輸出喚醒序列
  138.         unsigned char i,j,k;            //0xa0,0x00,0x00,0x00,0x00,0x10
  139.     unsigned char AFEConfig6 = 0;        //列校驗

  140.         for(i=0;i<8;i++)                                //校驗數(shù)據(jù),生成列校驗寄存器的值
  141.         {
  142.                 j = 0;
  143.                 AFEConfig6 = AFEConfig6 <<1;
  144.                 for(k=0;k<6;k++)
  145.                 {
  146.                         switch(i)
  147.                         {
  148.                                 case 0: j = j^(AFEConfig[k]&0x80);
  149.                                                 break;
  150.                                 case 1: j = j^(AFEConfig[k]&0x40);
  151.                                                 break;
  152.                                 case 2: j = j^(AFEConfig[k]&0x20);
  153.                                                 break;
  154.                                 case 3: j = j^(AFEConfig[k]&0x10);
  155.                                                 break;
  156.                                 case 4: j = j^(AFEConfig[k]&0x08);
  157.                                                 break;
  158.                                 case 5: j = j^(AFEConfig[k]&0x04);
  159.                                                 break;
  160.                                 case 6: j = j^(AFEConfig[k]&0x02);
  161.                                                 break;
  162.                                 case 7: j = j^(AFEConfig[k]&0x01);
  163.                                                 break;
  164.                         }
  165.                 }
  166.                 if(j==0) AFEConfig6 = AFEConfig6 | 0x01;
  167.         }

  168.     /* while(1)
  169.     {
  170.       write_byte(0x07,0x00,AFEConfig[0]);
  171.       Delay_1ms(5);
  172.     } */
  173.     write_byte(0x07,0x00,AFEConfig[0]);
  174.         write_byte(0x07,0x01,AFEConfig[1]);
  175.         write_byte(0x07,0x02,AFEConfig[2]);
  176.         write_byte(0x07,0x03,AFEConfig[3]);
  177.         write_byte(0x07,0x04,AFEConfig[4]);
  178.         write_byte(0x07,0x05,AFEConfig[5]);
  179.         write_byte(0x07,0x06,AFEConfig6);

  180. }

  181. /*******************************************************************************************/
  182. /*初始化時鐘、IO、中斷                                                                                                                    */
  183. /*******************************************************************************************/
  184. void InIt(void)
  185. {

  186.         TRISC = 0x00;                 //0000 0000  //RC0.1.2.3.4.5輸出
  187.         OSCCON = 0x71;       //0110 0001  //內(nèi)部振蕩器用于系統(tǒng)時鐘:8MHz
  188.     PCON = 0x00;                 //0000 1011  //電源控制   

  189.     T1CON=0x00;
  190.     EECON1=0x00;

  191.         CMCON0 = 0x07;       //關(guān)閉引腳比較器功能、模擬端口轉(zhuǎn)入數(shù)字端口

  192. ……………………

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

所有資料51hei提供下載:
key-pic16f639.rar (132.86 KB, 下載次數(shù): 50)

評分

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

查看全部評分

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

使用道具 舉報

沙發(fā)
ID:300165 發(fā)表于 2020-11-4 14:53 | 只看該作者
實際量產(chǎn)過嗎?
回復

使用道具 舉報

板凳
ID:435636 發(fā)表于 2021-1-25 10:13 | 只看該作者
不全,只是鑰匙部分的低頻喚醒
回復

使用道具 舉報

地板
ID:1106465 發(fā)表于 2024-1-8 09:18 | 只看該作者
IMMO功能無線充電這塊做過嗎
回復

使用道具 舉報

5#
ID:903667 發(fā)表于 2024-9-15 08:36 | 只看該作者
樣品1顆不到5元,量產(chǎn)后1顆漲到100元,microchip我好怕喔.
回復

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表