找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3681|回复: 3
打印 上一主题 下一主题
收起左侧

PIC16F639单片机的PKE方案源程序 3D天线可低频(125K)唤醒,空中高频端数据采用滚...

[复制链接]
跳转到指定楼层
楼主
ID:791835 发表于 2020-6-28 15:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
PIC16F639单片机C语言代码,附件完整工程MPLAB IDE可直接打开,主要功能:3D天线可低频(125K)唤醒,空中高频端数据采用滚码方式加密,PIC内部硬件加密没用。。。

单片机源程序如下:
  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要写入寄存器的数据                                                                                                   */
  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;                //产生上升沿
  39.                  asm("nop");
  40.                  asm("nop");
  41.                  asm("nop");
  42.                  asm("nop");
  43.                  AFESCLK  = 0;
  44.                  //AFESDI = 0;                 
  45.         }
  46.         crc = 0;                                //用于数据位1的个数
  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;                //进行数据采样
  60.                 asm("nop");
  61.                 asm("nop");
  62.                 asm("nop");
  63.                 asm("nop");
  64.                 AFESCLK  = 0;
  65.                 //AFESDI = 0;        
  66.         }
  67.         if(crc%2==0)                        //偶数个1
  68.         {        
  69.                 AFESDI = 1;        
  70.                 AFESCLK  = 1;                //进行数据采样
  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;                //进行数据采样
  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为地址  返回读到数据                                                                                                                                   */
  95. /*先写入命令+地址+无效数据(合计16位)拉高CS 再拉低CS 发送SCLK时钟读出数据                               */
  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);                //先写入命令和地址和无效数据
  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};//解调输出无唤醒
  137.     const unsigned char AFEConfig[6]={0xa0,0x00,0x00,0x00,0x00,0x00};//解调输出唤醒序列
  138.         unsigned char i,j,k;            //0xa0,0x00,0x00,0x00,0x00,0x10
  139.     unsigned char AFEConfig6 = 0;        //列校验

  140.         for(i=0;i<8;i++)                                //校验数据,生成列校验寄存器的值
  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  //内部振荡器用于系统时钟:8MHz
  188.     PCON = 0x00;                 //0000 1011  //电源控制   

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

  191.         CMCON0 = 0x07;       //关闭引脚比较器功能、模拟端口转入数字端口

  192. ……………………

  193. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
key-pic16f639.rar (132.86 KB, 下载次数: 48)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:300165 发表于 2020-11-4 14:53 | 只看该作者
实际量产过吗?
回复

使用道具 举报

板凳
ID:435636 发表于 2021-1-25 10:13 | 只看该作者
不全,只是钥匙部分的低频唤醒
回复

使用道具 举报

地板
ID:1106465 发表于 2024-1-8 09:18 | 只看该作者
IMMO功能无线充电这块做过吗
回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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