亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mfrc500uc.c

?? RC500的mifare卡開發備用程序及電路
?? C
?? 第 1 頁 / 共 3 頁
字號:
   memcpy(snr,snr_in,4);

   //----------------------Einstellungen aus Initialisierung ruecksetzen 
   ClearBitMask(RegDecoderControl,0x20); // ZeroAfterColl disable
   
   return status;  
}

///////////////////////////////////////////////////////////////////////
//          M I F A R E    S E L E C T 
// for std. select
///////////////////////////////////////////////////////////////////////
char Mf500PiccSelect(unsigned char *snr, 
                  unsigned char *sak)
{
   return Mf500PiccCascSelect(0x93,snr,sak); // first cascade level
}

///////////////////////////////////////////////////////////////////////
//          M I F A R E    C A S C A D E D   S E L E C T 
//  for extended serial number
///////////////////////////////////////////////////////////////////////
char Mf500PiccCascSelect(unsigned char select_code, 
                        unsigned char *snr,
                        unsigned char *sak)
{
   char   status = MI_OK; 

   if ((status = Mf500PcdSetDefaultAttrib()) == MI_OK)
   {
      PcdSetTmo(106);
    
      WriteRC(RegChannelRedundancy,0x0F); // RxCRC,TxCRC, Parity enable
      ClearBitMask(RegControl,0x08);    // disable crypto 1 unit
   
      //************* Cmd Sequence ********************************** 
      ResetInfo(MInfo);   
      MSndBuffer[0] = select_code;
      MSndBuffer[1] = 0x70;         // number of bytes send
      
      memcpy(MSndBuffer + 2,snr,4);
      MSndBuffer[6] = MSndBuffer[2] 
                      ^ MSndBuffer[3] 
                      ^ MSndBuffer[4] 
                      ^ MSndBuffer[5];
      MInfo.nBytesToSend   = 7;
      MInfo.DisableDF = 1;
      status = PcdSingleResponseCmd(PCD_TRANSCEIVE,
                          MSndBuffer,
                          MRcvBuffer,
                          &MInfo);
   
      *sak = 0;   
      if (status == MI_OK)    // no timeout occured
      {
         if (MInfo.nBitsReceived != 8)    // last byte is not complete
         {
            status = MI_BITCOUNTERR;
         }
         else
         {
            memcpy(MLastSelectedSnr,snr,4);            
         }
      }
      // copy received data in any case - for debugging reasons
      *sak = MRcvBuffer[0];
   }
   return status;
}

///////////////////////////////////////////////////////////////////////
//       M I F A R E   P I C C   A C T I V A T I O N    S E Q E N C E
///////////////////////////////////////////////////////////////////////
char Mf500PiccActivateIdle(unsigned char br,
                           unsigned char *atq, 
                           unsigned char *sak, 
                           unsigned char *uid, 
                           unsigned char *uid_len)
{
  unsigned char cascade_level;
  unsigned char sel_code;
  unsigned char uid_index;
  signed char status;
  unsigned char cmdASEL;

  *uid_len      = 0;

  //call activation with def. divs
  status = Mf500PcdSetDefaultAttrib();
  if (status == MI_OK)
  {
     status = Mf500PiccCommonRequest(PICC_REQIDL,atq);
  }
  if (status == MI_OK)
  {
     if((atq[0] & 0x1F) == 0x00) // check lower 5 bits, for tag-type
                                 // all tags within this 5 bits have to
                                 // provide a bitwise anticollision
     {
        status = MI_NOBITWISEANTICOLL;
     }
  }
  if (status == MI_OK)
  {
      //Get UID in 1 - 3 levels (standard, [double], [triple] )
      //-------
      switch(br)
      {
         case 0: cmdASEL = PICC_ANTICOLL1; break;
         case 1: cmdASEL = PICC_ANTICOLL11; break;
         case 2: cmdASEL = PICC_ANTICOLL12; break;
         case 3: cmdASEL = PICC_ANTICOLL13; break;
         default:
              status = MI_BAUDRATE_NOT_SUPPORTED; break;
      }
  }
  if (status == MI_OK)
  {
      cascade_level = 0;
      uid_index     = 0;
      do
      {
        //Select code depends on cascade level
        sel_code   = cmdASEL + (2 * cascade_level);
        cmdASEL = PICC_ANTICOLL1; // reset anticollistion level for calculation
        //ANTICOLLISION
        status = Mf500PiccCascAnticoll(sel_code, 0, &uid[uid_index]);
        //SELECT
        if (status == MI_OK)
        {
           status = Mf500PiccCascSelect(sel_code, &uid[uid_index], sak);
           if (status == MI_OK)
           {
              cascade_level++;

              //we differ cascaded and uncascaded UIDs
              if (*sak & 0x04) // if cascaded, bit 2 is set in answer to select
              {
                 //this UID is cascaded, remove the cascaded tag that is
                 //0x88 as first of the 4 byte received
                 memmove(&uid[uid_index], &uid[uid_index + 1], 3);
                 uid_index += 3;
                 *uid_len += 3;
              }
              else
              {
                 //this UID is not cascaded -> the length is 4 bytes
                 uid_index += 4;
                 *uid_len += 4;
              }
           }
        }
      }
      while((status == MI_OK)        // error status
            && (*sak & 0x04)         // no further cascade level
            && (cascade_level < 3)); // highest cascade level is reached
   }
   if (status == MI_OK)
   {
      //Exit function, if cascade level is triple and sak indicates another
      //cascase level.
      if ((cascade_level == 3) && (*sak & 0x04))
      {
         *uid_len = 0;
         status = MI_CASCLEVEX;
      }
      Mf500PcdSetAttrib(br,br);
   }
   return (status);
}

///////////////////////////////////////////////////////////////////////
//       M I F A R E   P I C C   A C T I V A T I O N    S E Q E N C E
///////////////////////////////////////////////////////////////////////
char Mf500PiccActivateWakeup(unsigned char br,
                             unsigned char *atq, 
                             unsigned char *sak,
                             unsigned char *uid, 
                             unsigned char uid_len)
{
   unsigned char cascade_level;
   unsigned char uid_index;
   unsigned char tmpuid[4];
   unsigned char sel_code;
   unsigned char cmdASEL;
   signed char   status;

   //call activation with def. divs
   status = Mf500PcdSetDefaultAttrib();
   if (status == MI_OK)
   {
      status = Mf500PiccCommonRequest(PICC_REQALL,atq);
   }
   if (status == MI_OK)
   {
      if ((atq[0] & 0x1F) == 0x00) // check lower 5 bits, for tag-type
                                   // all tags within this 5 bits have to
                                   // provide a bitwise anticollision
      {
         status = MI_NOBITWISEANTICOLL;
      }
   }
   if (status == MI_OK)
   {
      //Get UID in 1 - 3 levels (standard, [double], [triple] )
      //-------
      switch(br)
      {
         case 0: cmdASEL = PICC_ANTICOLL1; break;
         case 1: cmdASEL = PICC_ANTICOLL11; break;
         case 2: cmdASEL = PICC_ANTICOLL12; break;
         case 3: cmdASEL = PICC_ANTICOLL13; break;
         default:
              status = MI_BAUDRATE_NOT_SUPPORTED; break;
      }
   }
   if (status == MI_OK)
   {
      //Select UID in up to 3 cascade levels (standard, [double], [triple] )
      //------------------------------------
      cascade_level = 0;
      uid_index     = 0;
      tmpuid[0] = 0x88;     //first byte of cascaded UIDs is 0x88 (cascaded tag)

      do
      {
        sel_code   = cmdASEL + (2 * cascade_level);
        cmdASEL = PICC_ANTICOLL1; // reset anticollistion level for calculation
        //get the next UID part if we need to cascade
        if((uid_len - uid_index) > 4)
        {
          //ok, we need to cascade the UID
          memcpy(&tmpuid[1], &uid[uid_index], 3);
          uid_index += 3;
        }
        else
        {
          //ah, how nice. no need to cascade
          memcpy(tmpuid, &uid[uid_index], 4);
          uid_index += 4;
        }

        status = Mf500PiccCascSelect(sel_code, tmpuid, sak);

        if(status == MI_OK)
        {
          cascade_level++;
        }
      }
      while((status == MI_OK )    // error occured
            && (*sak & 0x04)       // no further cascade level
            && ((uid_index + 1) < uid_len) // all bytes of snr sent
            && (cascade_level < 3)); // highest cascade level reached
   }
   if ( status == MI_OK) 
   {
      //Exit function, if UID length is not of expected length
      if ((uid_index) != uid_len)
      {
         status =  MI_SERNRERR ;
      }
   }
   if (status == MI_OK)
   {
      //Exit function, if cascade level is triple and sak indicates another
      //cascase level.
      if ((cascade_level == 3) && (*sak & 0x04))
      {
         status = MI_SERNRERR;
      }
   }
   return status;
}

///////////////////////////////////////////////////////////////////////
//          M I F A R E      A U T H E N T I C A T I O N
//   calling compatible version    
///////////////////////////////////////////////////////////////////////
char Mf500PiccAuth(unsigned char key_type,    // PICC_AUTHENT1A or PICC_AUTHENT1B
                   unsigned char key_addr,    // key address in reader storage
                   unsigned char block)       // block number which should be 
                                              // authenticated
{
   char            status = MI_OK;

   status = Mf500PiccAuthE2(  key_type,
                              MLastSelectedSnr,
                              key_addr,
                              block);
   return status;
}

///////////////////////////////////////////////////////////////////////
//                  A U T H E N T I C A T I O N   
//             W I T H   K E Y S   F R O M   E 2 P R O M
///////////////////////////////////////////////////////////////////////
char Mf500PiccAuthE2(   unsigned char auth_mode,   // PICC_AUTHENT1A or PICC_AUTHENT1B
                     unsigned char *snr,        // 4 bytes card serial number
                     unsigned char key_sector,  // 0 <= key_sector <= 15                     
                     unsigned char block)      //  0 <= block <= 256
{
   char status = MI_OK;
   // eeprom address calculation
   // 0x80 ... offset
   // key_sector ... sector
   // 0x18 ... 2 * 12 = 24 = 0x18
   unsigned short e2addr = 0x80 + key_sector * 0x18;
   unsigned char *e2addrbuf = (unsigned char*)&e2addr;
   
   PcdSetTmo(106);
   if (auth_mode == PICC_AUTHENT1B)
      e2addr += 12; // key B offset   
   FlushFIFO();    // empty FIFO
   ResetInfo(MInfo);

   memcpy(MSndBuffer,e2addrbuf,2); // write low and high byte of address
   MInfo.nBytesToSend   = 2;
    // write load command
   if ((status=PcdSingleResponseCmd(PCD_LOADKEYE2,MSndBuffer,MRcvBuffer,&MInfo)) == MI_OK)
   {      
      // execute authentication
      status = Mf500PiccAuthState(auth_mode,snr,block);  
   }
   return status;
}                        

///////////////////////////////////////////////////////////////////////
//                      C O D E   K E Y S  
///////////////////////////////////////////////////////////////////////
char Mf500HostCodeKey(  unsigned char *uncoded, // 6 bytes key value uncoded
                     unsigned char *coded)   // 12 bytes key value coded
{
   char status = MI_OK;
   unsigned char cnt = 0;
   unsigned char ln  = 0;     // low nibble
   unsigned char hn  = 0;     // high nibble
   
   for (cnt = 0; cnt < 6; cnt++)
   {
      ln = uncoded[cnt] & 0x0F;
      hn = uncoded[cnt] >> 4;
      coded[cnt * 2 + 1]     =  (~ln << 4) | ln;
      coded[cnt * 2 ] =  (~hn << 4) | hn;
   }
   return MI_OK;
}

///////////////////////////////////////////////////////////////////////
//                  A U T H E N T I C A T I O N   
//             W I T H   P R O V I D E D   K E Y S
///////////////////////////////////////////////////////////////////////
char Mf500PiccAuthKey(  unsigned char auth_mode,
                     unsigned char *snr,       
                     unsigned char *keys,      
                     unsigned char block)      
{
   char status     = MI_OK;
   unsigned char i = 0;
   
   PcdSetTmo(106);
   FlushFIFO();    // empty FIFO
   ResetInfo(MInfo);
   memcpy(MSndBuffer,keys,12);                  // write 12 bytes of the key
   MInfo.nBytesToSend = 12;
    // write load command
   if ((status=PcdSingleResponseCmd(PCD_LOADKEY,MSndBuffer,MRcvBuffer,&MInfo)) == MI_OK)
   {      
      // execute authentication
      status = Mf500PiccAuthState(auth_mode,snr,block); 
   }
   return status;
}

///////////////////////////////////////////////////////////////////////
//        S T O R E   K E Y S   I N   E E P R O M
///////////////////////////////////////////////////////////////////////
char Mf500PcdLoadKeyE2(unsigned char key_type,
                       unsigned char sector,
                       unsigned char *uncoded_keys)
{
   // eeprom address calculation
   // 0x80 ... offset
   // key_sector ... sector
   // 0x18 ... 2 * 12 = 24 = 0x18
   signed char status = MI_OK;
   unsigned short e2addr = 0x80 + sector * 0x18;
   unsigned char coded_keys[12];

   if (key_type == PICC_AUTHENT1B)
      e2addr += 12; // key B offset   
   if ((status = Mf500HostCodeKey(uncoded_keys,coded_keys)) == MI_OK)
      status = PcdWriteE2(  e2addr,12,coded_keys);
   return status;
}                       
                          
///////////////////////////////////////////////////////////////////////
//        A U T H E N T I C A T I O N   S T A T E S
///////////////////////////////////////////////////////////////////////
char Mf500PiccAuthState(   unsigned char auth_mode,
                        unsigned char *snr,
                        unsigned char block)
{
   char status = MI_OK;
   unsigned char i = 0;
   
   WriteRC(RegChannelRedundancy,0x07); // RxCRC disable,TxCRC, Parity enable

   PcdSetTmo(150);
   MSndBuffer[0] = auth_mode;        // write authentication command

   MSndBuffer[1] = block;    // write block number for authentication
   memcpy(MSndBuffer + 2,snr,4); // write 4 bytes card serial number 
   ResetInfo(MInfo);
   MInfo.nBytesToSend = 6;
   if ((status = PcdSingleResponseCmd(PCD_AUTHENT1,
                            MSndBuffer,
                            MRcvBuffer,
                            &MInfo)) == MI_OK)
   {
      if (ReadRC(RegSecondaryStatus) & 0x07) // RxLastBits mu

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品免费| 国产一二三精品| 香蕉久久夜色精品国产使用方法| 亚洲欧美日韩电影| 亚洲成人一区二区| 美国精品在线观看| 国产99久久久精品| 欧美一区二区三区视频| 国产亚洲成aⅴ人片在线观看| 日本一区二区三区高清不卡| 性做久久久久久| 国产91精品免费| 678五月天丁香亚洲综合网| 欧美激情艳妇裸体舞| 国产精品色婷婷| 日本午夜一区二区| 国产在线日韩欧美| 欧美性大战xxxxx久久久| 久久蜜桃香蕉精品一区二区三区| 亚洲欧美国产高清| 国产99精品国产| 91麻豆精品国产自产在线 | 亚洲男人电影天堂| 精品一区二区影视| 欧美日本在线看| 亚洲国产一二三| 91丨porny丨首页| 国产精品免费av| 国产伦精品一区二区三区免费| 欧美日韩大陆一区二区| 中文字幕一区二区三区乱码在线 | 欧美xxxxxxxxx| 五月天丁香久久| 欧美亚洲丝袜传媒另类| 国产精品毛片久久久久久久| 国内成人精品2018免费看| 精品视频在线免费看| 亚洲欧美日韩国产综合在线| 播五月开心婷婷综合| 国产婷婷色一区二区三区在线| 另类小说综合欧美亚洲| 欧美日韩电影一区| 久久99精品国产.久久久久| 欧美高清视频一二三区| 亚洲成人精品在线观看| 在线精品亚洲一区二区不卡| 亚洲精选视频在线| 91麻豆国产自产在线观看| 一色桃子久久精品亚洲| 成人h版在线观看| 中文字幕亚洲电影| 国产成人免费视频一区| 国产拍揄自揄精品视频麻豆| 国产伦精品一区二区三区视频青涩 | 日本不卡视频在线观看| 7777精品伊人久久久大香线蕉完整版 | 国产在线精品免费av| 欧美本精品男人aⅴ天堂| 久久99精品久久久久久动态图 | 69久久夜色精品国产69蝌蚪网| 亚洲1区2区3区4区| 欧美日韩www| 免费av成人在线| 久久综合久久鬼色中文字| 麻豆精品新av中文字幕| wwwwxxxxx欧美| 麻豆91免费看| 国产欧美一区二区精品性色超碰 | 欧美三级电影在线观看| 亚洲电影在线免费观看| 欧美一区二区三区四区五区| 麻豆成人av在线| 国产精品久久毛片| 欧美日韩激情在线| 国内久久婷婷综合| 亚洲欧洲一区二区三区| 制服丝袜日韩国产| 国产成人在线观看| 亚洲h精品动漫在线观看| 欧美mv日韩mv国产网站| 不卡的电影网站| 亚洲午夜电影在线观看| 久久婷婷成人综合色| 91蝌蚪国产九色| 蜜臀av性久久久久蜜臀av麻豆| 久久精品亚洲国产奇米99| 色婷婷久久久综合中文字幕| 日韩av不卡一区二区| 国产精品久久看| 欧美高清激情brazzers| 国产成人福利片| 天天免费综合色| 中文字幕在线观看不卡| 666欧美在线视频| 91美女在线看| 五月婷婷色综合| 久久综合九色综合97婷婷| 不卡av免费在线观看| 水野朝阳av一区二区三区| 国产精品视频一二三区| 制服丝袜日韩国产| 色婷婷综合久色| 国产美女一区二区三区| 亚洲精品福利视频网站| 久久久不卡网国产精品二区| 欧美日韩国产高清一区二区三区 | 精品一区二区三区免费播放| 亚洲日本中文字幕区| 久久免费视频色| 精品国产三级a在线观看| 欧美日韩久久久久久| 激情五月播播久久久精品| 日日嗨av一区二区三区四区| 亚洲精品va在线观看| 国产精品九色蝌蚪自拍| 精品久久五月天| 欧美一区二视频| 欧美日韩中字一区| 91久久久免费一区二区| 成人激情动漫在线观看| 国产成人日日夜夜| 国产一区不卡在线| 国产电影一区二区三区| 狠狠色丁香婷婷综合久久片| 麻豆久久久久久久| 奇米888四色在线精品| 亚洲一区二区三区小说| 夜夜爽夜夜爽精品视频| 中文字幕日韩一区| 久久精品一区八戒影视| 91精品国产欧美一区二区18| 欧美日韩一本到| 欧美精选午夜久久久乱码6080| 日本韩国一区二区| 欧美性色黄大片| 91麻豆精品国产91久久久更新时间| 欧美日韩国产一区| 7777精品伊人久久久大香线蕉的 | 91蝌蚪国产九色| 国产精品影视在线观看| 成人精品免费网站| 成人美女在线视频| 99久久国产综合色|国产精品| 国产一区二区在线观看视频| 色综合色狠狠天天综合色| 丁香天五香天堂综合| 欧美色综合网站| 欧美日韩中文另类| 日韩小视频在线观看专区| 欧美日韩精品一区二区三区四区| 成人av网址在线观看| av一本久道久久综合久久鬼色| 懂色av中文一区二区三区 | 水蜜桃久久夜色精品一区的特点| 日韩国产高清影视| 麻豆精品在线看| 紧缚奴在线一区二区三区| 国产不卡视频在线观看| 91年精品国产| 欧美肥妇free| 欧美激情一区二区三区全黄| 亚洲欧美日韩一区二区 | 国产精品不卡一区| 视频一区国产视频| 99国产精品视频免费观看| 91精品国产91久久久久久一区二区| 欧美国产精品专区| 美腿丝袜亚洲综合| 色婷婷综合久色| 久久精品视频在线看| 日韩国产在线观看一区| 91色.com| 中文字幕免费一区| 蜜桃久久av一区| 欧美三级视频在线播放| 国产精品久久久久久久裸模| 欧美日韩视频专区在线播放| 中文字幕不卡在线| 韩国欧美一区二区| 欧美一级黄色片| 午夜视频在线观看一区| 91丝袜美腿高跟国产极品老师| 久久婷婷色综合| 久久精品免费观看| 在线成人av影院| 一区二区三区日韩| 不卡欧美aaaaa| 中文字幕av资源一区| 成人午夜视频免费看| 国产香蕉久久精品综合网| 久久99这里只有精品| 日韩欧美亚洲另类制服综合在线| 亚洲福中文字幕伊人影院| 欧洲人成人精品| 一区二区在线观看免费| 色系网站成人免费| 一区二区久久久久| 欧美最猛性xxxxx直播| 亚洲激情中文1区| 欧美调教femdomvk|