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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? mfrc500uc.c

?? 包括讀卡器源代碼
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
        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_SERNRERR;
      }
   }
   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_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;
         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;
   
   status = ReadRC(RegErrorFlag);    // read error flags of the previous
                                    // key load
   if (status != MI_OK)
   {
      if (status & 0x40)            // key error flag set
         status = MI_KEYERR;
      else
         status = MI_AUTHERR;       // generic authentication error 
   }
   else
   {
      PcdSetTmo(106);
      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

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色激情天天射综合网| 国产91在线看| 欧美大黄免费观看| 欧美人与性动xxxx| 日韩色视频在线观看| 欧美成人一区二区| 制服丝袜激情欧洲亚洲| 色婷婷久久久久swag精品| 中文字幕中文字幕在线一区| 亚洲成av人片在www色猫咪| 亚洲综合成人在线| 97aⅴ精品视频一二三区| 欧美绝品在线观看成人午夜影视| 91精品啪在线观看国产60岁| 国产91清纯白嫩初高中在线观看| 9i在线看片成人免费| 尤物视频一区二区| 成年人国产精品| 玉米视频成人免费看| 欧美日韩情趣电影| 色av成人天堂桃色av| 国产成人av电影在线观看| 亚洲少妇屁股交4| 国产亚洲va综合人人澡精品| 欧美日韩国产综合一区二区| 一本久道久久综合中文字幕| 国产一区二区不卡在线| 日韩黄色免费电影| 亚洲成a天堂v人片| 国产精品高潮呻吟| 中文字幕不卡在线播放| 欧美一二三在线| 欧美性色黄大片| 91成人国产精品| 成人激情免费视频| 成人av免费观看| 国产麻豆精品视频| 久久精品国产精品亚洲精品 | 久久97超碰国产精品超碰| 亚洲猫色日本管| 亚洲天堂成人网| 国产精品久久午夜夜伦鲁鲁| 日韩视频在线你懂得| 制服丝袜亚洲色图| 欧美日韩aaa| 欧洲精品在线观看| 欧美色倩网站大全免费| 91麻豆自制传媒国产之光| 91蝌蚪国产九色| 99精品在线免费| 国产精品乱码妇女bbbb| 在线观看亚洲精品视频| 99精品桃花视频在线观看| 成人av电影在线| 色综合中文字幕国产 | 亚洲图片激情小说| 1024亚洲合集| 亚洲国产中文字幕在线视频综合 | 欧美一区二区三区在线观看| 欧美日韩综合在线免费观看| 制服丝袜在线91| 日韩欧美你懂的| 精品国产麻豆免费人成网站| 国产女人18毛片水真多成人如厕| 久久久av毛片精品| 国产精品国产三级国产aⅴ无密码| 国产午夜精品美女毛片视频| 中文字幕巨乱亚洲| 一区二区三区中文在线观看| 亚洲午夜电影在线| 日韩主播视频在线| 日本成人在线不卡视频| 美腿丝袜亚洲色图| 成人国产在线观看| 色www精品视频在线观看| 欧美一级日韩免费不卡| 久久综合久久综合亚洲| 国产欧美日韩视频在线观看| 亚洲一区二区在线免费看| 午夜私人影院久久久久| 精品一区二区综合| 成人激情文学综合网| 在线精品视频小说1| 26uuuu精品一区二区| 日韩理论片在线| 美腿丝袜在线亚洲一区| 国产精品久久久久aaaa樱花 | 色94色欧美sute亚洲13| 日韩一级完整毛片| 欧美韩国一区二区| 三级在线观看一区二区 | 亚洲bt欧美bt精品777| 久久精品久久精品| 欧美视频一区二区三区四区 | 亚洲男同性视频| 全国精品久久少妇| 成人午夜私人影院| 91精品国产综合久久久久久漫画| 国产喷白浆一区二区三区| 丝袜a∨在线一区二区三区不卡| 另类小说综合欧美亚洲| 不卡欧美aaaaa| 精品少妇一区二区三区| 国产精品天美传媒| 激情综合色综合久久| 色综合天天在线| 日韩欧美精品三级| 亚洲国产精品综合小说图片区| 国产最新精品精品你懂的| 欧美日韩精品久久久| 亚洲国产成人一区二区三区| 日韩精品亚洲专区| 在线观看91视频| 中文字幕巨乱亚洲| 国产伦精品一区二区三区在线观看| 色猫猫国产区一区二在线视频| 欧美体内she精高潮| 自拍偷拍亚洲欧美日韩| 看片网站欧美日韩| 91精品麻豆日日躁夜夜躁| 国产精品女上位| 婷婷开心久久网| 欧美色中文字幕| 亚洲欧美自拍偷拍| 成人免费观看男女羞羞视频| 欧美不卡一区二区三区| 一区二区高清视频在线观看| 粉嫩蜜臀av国产精品网站| 日韩精品专区在线影院重磅| 日韩国产欧美视频| 欧美吻胸吃奶大尺度电影| 亚洲精品欧美二区三区中文字幕| 国产成人综合在线观看| 日韩免费高清av| 日韩经典一区二区| 欧美日韩视频在线观看一区二区三区| 久久久久久99久久久精品网站| 视频一区中文字幕| 91九色02白丝porn| 一区二区免费看| 91在线看国产| 中文子幕无线码一区tr| 大美女一区二区三区| 国产亚洲欧美色| 成人精品免费网站| 国产精品久久久久久久久果冻传媒| 不卡电影免费在线播放一区| 国产欧美视频一区二区三区| 一区二区三区中文字幕电影| 在线观看日韩电影| 亚洲精品国产精品乱码不99| 欧美主播一区二区三区| 亚洲午夜羞羞片| 欧美男女性生活在线直播观看| 亚洲午夜电影在线| 欧美美女黄视频| 麻豆国产一区二区| 久久这里都是精品| 成人高清视频在线| 亚洲欧美一区二区三区久本道91 | 国产高清不卡一区二区| 国产视频911| 91麻豆精东视频| 亚洲地区一二三色| 精品久久人人做人人爽| 精品一区二区三区av| 欧美激情综合在线| 91丨porny丨中文| 午夜精品在线看| 日韩免费看的电影| 波多野结衣在线aⅴ中文字幕不卡| 中文字幕在线免费不卡| 成人不卡免费av| 亚洲欧美另类久久久精品| 欧美日韩一区 二区 三区 久久精品| 国产精品不卡视频| 色婷婷久久久久swag精品| 蜜臀av性久久久久av蜜臀妖精 | 亚洲欧美电影院| 欧美日韩国产小视频在线观看| 午夜精品视频一区| 欧美国产欧美亚州国产日韩mv天天看完整 | 91小视频在线免费看| 亚洲影视资源网| 久久综合色综合88| 国产成人99久久亚洲综合精品| 一区二区三区在线观看欧美| 日韩一区二区三区在线| 成人av在线影院| 蜜桃一区二区三区四区| 国产精品久久久久婷婷二区次| 欧美日韩美少妇| 成人美女视频在线观看| 免费视频最近日韩| 亚洲视频综合在线| 欧美乱妇15p| 日本高清无吗v一区| 久久99精品一区二区三区| 亚洲永久精品大片| 欧美激情一区在线观看|