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

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

?? m500auc.c

?? ID卡讀卡程序,采用FM1702芯片,測試OK!
?? C
?? 第 1 頁 / 共 2 頁
字號:
#define M500_GLOBALS

#include <string.h>
#include <stdio.h>
#include <absacc.h>
#include <intrins.h>

#include "Mfreg500.h"
#include "MfErrNo.h"
#include "reg52.h"
#include "M500AuC.h"

#define GetRegPage(addr)    (0x70 | (addr>>3))
#define nocard			    0
#define mifare1			    1
#define mifarepro		    2
#define mifarelight		    3
#define unknowncard		    4
#define NO_TIMER2           1

///////////////////////////////////////////////////////////////////////
// 往一個地址寫一個數據
///////////////////////////////////////////////////////////////////////
void WriteRawIO(unsigned char Address,unsigned char value)
{
	XBYTE[Address]=value;
}

///////////////////////////////////////////////////////////////////////
// 從一個地址讀出一個數據
///////////////////////////////////////////////////////////////////////
unsigned char ReadRawIO(unsigned char Address)
{
	return XBYTE[Address];
}

///////////////////////////////////////////////////////////////////////
// 往一個地址寫一個數據(EEPROM)
///////////////////////////////////////////////////////////////////////
void WriteIO(unsigned char Address, unsigned char value)
{
    WriteRawIO(0x00,GetRegPage(Address));  
    WriteRawIO(Address,value);              
}

///////////////////////////////////////////////////////////////////////
// 從一個地址讀出一個數據(EEPROM)
///////////////////////////////////////////////////////////////////////
unsigned char ReadIO(unsigned char Address)
{
   WriteRawIO(0x00,GetRegPage(Address));
   return ReadRawIO(Address);                    
}  

///////////////////////////////////////////////////////////////////////
// 設置定時時間
///////////////////////////////////////////////////////////////////////
void M500PcdSetTmo(unsigned char tmoLength)
{
    switch(tmoLength)
    {  
        case 1:                       
            WriteIO(RegTimerClock,0x07); 
            WriteIO(RegTimerReload,0x6a);
            break;
        case 2:                       
            WriteIO(RegTimerClock,0x07); 
            WriteIO(RegTimerReload,0xa0);
            break;
        case 3:  
            WriteIO(RegTimerClock,0x09); 
            WriteIO(RegTimerReload,0xa0);
            break;
        case 4: 
            WriteIO(RegTimerClock,0x09);
            WriteIO(RegTimerReload,0xff);
            break;
        case 5:  
            WriteIO(RegTimerClock,0x0b); 
            WriteIO(RegTimerReload,0xff);
            break;
        case 6:                       
            WriteIO(RegTimerClock,0x0d); 
            WriteIO(RegTimerReload,0xff);
            break;
        case 7:                      
            WriteIO(RegTimerClock,0x0f); 
            WriteIO(RegTimerReload,0xff);
            break;
        default:                       
            WriteIO(RegTimerClock,0x07); 
            WriteIO(RegTimerReload,tmoLength);
            break;
    }     
}

///////////////////////////////////////////////////////////////////////
// Request Command defined in ISO14443(Mifare)
///////////////////////////////////////////////////////////////////////
char  M500PcdCmd(unsigned char cmd,
               volatile unsigned char data *rcv,
                MfCmdInfo idata *info)
{
    char          idata status    = MI_OK;
    char          idata tmpStatus ;
    unsigned char idata lastBits;
    unsigned int  idata timecnt = 0;
    unsigned char idata irqEn = 0x00;
    unsigned char idata waitFor = 0x00;
    unsigned char idata timerCtl  = 0x00;

    WriteIO(RegInterruptEn,0x7F);
    WriteIO(RegInterruptRq,0x7F);
    WriteIO(RegCommand,PCD_IDLE); 

    FlushFIFO();     
    MpIsrInfo = info;  
    MpIsrOut = rcv;
    info->irqSource = 0x00;
    switch(cmd)
    {
        case PCD_IDLE:                
            irqEn = 0x00;
            waitFor = 0x00;
            break;
        case PCD_WRITEE2:            
            irqEn = 0x11;
            waitFor = 0x10;
            break;
        case PCD_READE2:     
            irqEn = 0x07;
            waitFor = 0x04;
            break;
        case PCD_LOADCONFIG:  
        case PCD_LOADKEYE2:   
        case PCD_AUTHENT1:    
            irqEn = 0x05;
            waitFor = 0x04;
            break;
        case PCD_CALCCRC:
            irqEn = 0x11;
            waitFor = 0x10;
            break;
        case PCD_AUTHENT2: 
            irqEn = 0x04;
            waitFor = 0x04;
            break;
        case PCD_RECEIVE:     
            info->nBitsReceived = -(ReadIO(RegBitFraming) >> 4);
            irqEn = 0x06;
            waitFor = 0x04;
            break;
        case PCD_LOADKEY: 
            irqEn = 0x05;
            waitFor = 0x04;
            break;
        case PCD_TRANSMIT: 
            irqEn = 0x05;
            waitFor = 0x04;
            break;
        case PCD_TRANSCEIVE: 
	        info->nBitsReceived = -(ReadIO(RegBitFraming) >> 4);
            irqEn = 0x3D;
            waitFor = 0x04;
            break;
        default:
            status = MI_UNKNOWN_COMMAND;
    }        
    if (status == MI_OK)
    {
        irqEn |= 0x20;                     
        waitFor |= 0x20;      
        timecnt=1000;
        WriteIO(RegInterruptEn,irqEn | 0x80); 
        WriteIO(RegCommand,cmd);     
        while (!(MpIsrInfo->irqSource & waitFor||!(timecnt--)));
        WriteIO(RegInterruptEn,0x7F);         
        WriteIO(RegInterruptRq,0x7F);          
        SetBitMask(RegControl,0x04);          
        WriteIO(RegCommand,PCD_IDLE);         
        if (!(MpIsrInfo->irqSource & waitFor))   
        {                               
            status = MI_ACCESSTIMEOUT;
        }
        else
        {
            status = MpIsrInfo->status;           
        }
        if (status == MI_OK)                    
        {
            if (tmpStatus = (ReadIO(RegErrorFlag) & 0x17))
            {
                if (tmpStatus & 0x01)
                {
                    info->collPos = ReadIO(RegCollPos);
                    status = MI_COLLERR;
                }
                else
                {
                    info->collPos = 0;
                    if (tmpStatus & 0x02)  
                    {
                        status = MI_PARITYERR;
                    }
                }
                if (tmpStatus & 0x04)   
                {
                    status = MI_FRAMINGERR;
                }
                if (tmpStatus & 0x10)   
                {
                    FlushFIFO();
                    status = MI_OVFLERR;
                }
 	            if (tmpStatus & 0x08) 
	            {
                    status = MI_CRCERR;
	            }	
                if (status == MI_OK)
                    status = MI_NY_IMPLEMENTED;
            }
            if (cmd == PCD_TRANSCEIVE)
            {
                lastBits = ReadIO(RegSecondaryStatus) & 0x07;
                if (lastBits)
                    info->nBitsReceived += (info->nBytesReceived-1) * 8 + lastBits;
                else
                    info->nBitsReceived += info->nBytesReceived * 8;
            }
        }
        else
        {
            info->collPos = 0x00;
        }
    }
    MpIsrInfo = 0;         
    MpIsrOut  = 0;
    return status;
}   

///////////////////////////////////////////////////////////////////////
// 置一個bit
///////////////////////////////////////////////////////////////////////
char SetBitMask(unsigned char reg,unsigned char mask)  
{
    char idata tmp = 0x00;

    tmp = ReadIO(reg);
    WriteIO(reg,tmp | mask);  // set bit mask
    return 0x00;
}

///////////////////////////////////////////////////////////////////////
// 清一個bit
///////////////////////////////////////////////////////////////////////
char ClearBitMask(unsigned char reg,unsigned char mask)  
{
    char idata tmp = 0x00;

    tmp = ReadIO(reg);
    WriteIO(reg,tmp & ~mask);  // clear bit mask
    return 0x00;
}

///////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////
void FlushFIFO(void)
{  
    SetBitMask(RegControl,0x01);
}

///////////////////////////////////////////////////////////////////////
// Set card in HALT-state
// 終止卡的操作
///////////////////////////////////////////////////////////////////////
char M500PiccHalt(void)
{
    char idata status = MI_CODEERR;

    // ************* Cmd Sequence ********************************** 
    ResetInfo(MInfo);   
    SerBuffer[0] = PICC_HALT ;      // Halt command code
    SerBuffer[1] = 0x00;            // dummy address
    MInfo.nBytesToSend = 2;
    status = M500PcdCmd(PCD_TRANSCEIVE,
                       SerBuffer,
                       &MInfo);   
    if (status)
    {
        // timeout error ==> no NAK received ==> OK
        if (status == MI_NOTAGERR || status == MI_ACCESSTIMEOUT)
        {
            status = MI_OK;
        }
    }
    //reset command register - no response from tag
    WriteIO(RegCommand,PCD_IDLE);
    return status; 
}

///////////////////////////////////////////////////////////////////////
// Reset the MF RC500 
///////////////////////////////////////////////////////////////////////
char M500PcdReset(void)
{
    char idata status = MI_OK;
    unsigned int idata timecnt=0;
    
    RC500RST = 0;  
    delay_1ms(25); 
    RC500RST = 1;  
    delay_50us(200); 
    RC500RST = 0;  
    delay_50us(50);
    timecnt=1000;
    while ((ReadIO(RegCommand) & 0x3F) && timecnt--);
    if(!timecnt)
    {
        status = MI_RESETERR;
    }
    if (status == MI_OK)
    {
        //WriteIO(RegPage,0x80);
        if (ReadIO(RegCommand) != 0x00)
        {                           
            status = MI_INTERFACEERR;
        }
    }
    return status;
}

///////////////////////////////////////////////////////////////////////
// Configures the MF RC500
///////////////////////////////////////////////////////////////////////
char M500PcdConfig(void)
{
    char idata status;

    if ((status = M500PcdReset()) == MI_OK)
    {
        WriteIO(RegClockQControl,0x00);
        WriteIO(RegClockQControl,0x40);
        delay_50us(2);  
        ClearBitMask(RegClockQControl,0x40);
        WriteIO(RegBitPhase,0xAD);      
        WriteIO(RegRxThreshold,0xFF);   
        WriteIO(RegRxControl2,0x01);
        WriteIO(RegFIFOLevel,0x1A);
        WriteIO(RegTimerControl,0x02);
        WriteIO(RegIRqPinConfig,0x03); 
        M500PcdRfReset(1);               
    }
    return status;
}

///////////////////////////////////////////////////////////////////////
// Select Command defined in ISO14443(MIFARE)
///////////////////////////////////////////////////////////////////////
char M500PcdMfOutSelect(unsigned char type)
{
    WriteIO(RegMfOutSelect,type&0x7);
    return MI_OK;
}

///////////////////////////////////////////////////////////////////////
// Request Command defined in ISO14443(MIFARE)
// Request,Anticoll,Select,return CardType(2 bytes)+CardSerialNo(4 bytes)    
// 尋卡,防沖突,選擇卡    返回卡類型(2 bytes)+ 卡系列號(4 bytes)
///////////////////////////////////////////////////////////////////////
char M500PiccCommonRequest(unsigned char req_code,unsigned char *atq)
{
    char idata status = MI_OK;
	
    M500PcdSetTmo(3);
    WriteIO(RegChannelRedundancy,0x03);
    ClearBitMask(RegControl,0x08);
    WriteIO(RegBitFraming,0x07);     
    SetBitMask(RegTxControl,0x03);     
    ResetInfo(MInfo);
    SerBuffer[0] = req_code;
    MInfo.nBytesToSend = 1;   
    
    status = M500PcdCmd(PCD_TRANSCEIVE,SerBuffer,&MInfo);
    if (status)     
    {
        *atq = 0;
    } 
    else 
    {
        if (MInfo.nBitsReceived != 16) 
        {
            *atq = 0;
            status = MI_BITCOUNTERR;
        } 
        else 
        {
            status = MI_OK;
            memcpy(atq,SerBuffer,2);
        }
    }
    return status; 
}

///////////////////////////////////////////////////////////////////
// Cascaded Anti-Collision Command defined in ISO14443(MIFARE)
// 防沖突 讀卡的系列號 MLastSelectedSnr
///////////////////////////////////////////////////////////////////
char M500PiccCascAnticoll (unsigned char bcnt,unsigned char *snr)       
{
    char idata status = MI_OK;
    char idata snr_in[5];//snr_in[4];    
    char idata nbytes = 0;
    char idata nbits = 0;
    char idata complete = 0;
    char idata i        = 0;
    char idata byteOffset = 0;
    unsigned char dummyShift1;       
    unsigned char dummyShift2;      
    
    M500PcdSetTmo(106);
    memcpy(snr_in,snr,5);//memcpy(snr_in,snr,4);   
   
    WriteIO(RegDecoderControl,0x28); 
    ClearBitMask(RegControl,0x08);   
    complete = 0;
    while (!complete && (status == MI_OK) )
    {
        ResetInfo(MInfo);           
        WriteIO(RegChannelRedundancy,0x03);
        nbits = bcnt % 8;  
        if(nbits)
        {
            WriteIO(RegBitFraming,nbits << 4| nbits); 
            nbytes = bcnt / 8 + 1;   
            if (nbits == 7)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美中文字幕一区| 欧美又粗又大又爽| 91在线观看高清| 91.com在线观看| 亚洲欧洲另类国产综合| 麻豆国产91在线播放| 99国产麻豆精品| 久久精品夜色噜噜亚洲aⅴ| 亚洲国产日产av| 99久久夜色精品国产网站| 欧美精品一区在线观看| 亚洲成人免费电影| 91日韩一区二区三区| 国产精品初高中害羞小美女文| 国产女人aaa级久久久级| 日韩欧美一区在线观看| 亚洲美女视频一区| hitomi一区二区三区精品| 日韩情涩欧美日韩视频| 香蕉成人啪国产精品视频综合网| 高清不卡一区二区在线| 久久精品在线免费观看| 韩国女主播一区| 欧美成人伊人久久综合网| 亚洲成人一二三| 欧美日韩久久久一区| 中文字幕在线不卡视频| av亚洲精华国产精华精华 | 一区二区欧美视频| 岛国精品在线观看| 国产欧美视频在线观看| 高清视频一区二区| 国产无人区一区二区三区| 狠狠色丁香婷婷综合| 久久免费的精品国产v∧| 韩国午夜理伦三级不卡影院| 精品福利一区二区三区| 极品少妇xxxx精品少妇偷拍| 精品福利一二区| 国产成人精品综合在线观看| 日本一区二区三区国色天香| 成人综合婷婷国产精品久久蜜臀| 欧美激情综合五月色丁香| 欧美一级欧美三级| 国产日韩欧美高清| 在线影院国内精品| 亚洲一区二区五区| 欧美日韩在线观看一区二区| 蜜臀av一区二区在线观看| 精品区一区二区| 福利电影一区二区三区| 亚洲欧美日韩国产成人精品影院| 91最新地址在线播放| 亚洲风情在线资源站| 日韩欧美一级二级三级| 国产精品一区二区三区99| 亚洲欧洲精品一区二区三区不卡| 在线免费一区三区| 蜜臀av性久久久久蜜臀aⅴ| 久久久久久综合| 色婷婷精品久久二区二区蜜臂av| 亚洲国产日韩一区二区| 久久亚洲影视婷婷| www..com久久爱| 日本伊人午夜精品| 国产精品久久久久久久久动漫| 日本韩国一区二区| 久久精品国产一区二区| 国产精品白丝在线| 色av一区二区| 激情六月婷婷综合| 在线观看欧美精品| 美女网站色91| 一区二区三区欧美在线观看| 欧美精品欧美精品系列| 国产精品一区二区三区乱码| 亚洲图片欧美色图| 国产欧美日韩精品在线| 欧美日韩高清一区二区三区| 国产精品一区二区久久不卡| 亚洲成av人片观看| 国产精品久久久久影院亚瑟| 日韩网站在线看片你懂的| 成人污污视频在线观看| 蜜臀a∨国产成人精品| 国产精品初高中害羞小美女文| 日韩一卡二卡三卡四卡| 一本大道久久a久久精二百| 国产精品资源网站| 亚洲无人区一区| 亚洲视频你懂的| 国产欧美日韩激情| 精品福利av导航| 国产主播一区二区| 中文字幕 久热精品 视频在线| 欧美视频日韩视频在线观看| 舔着乳尖日韩一区| 欧美一级一区二区| 国产一区二区三区高清播放| 欧美激情中文字幕| 91国产免费看| 日韩影院精彩在线| 国产午夜精品理论片a级大结局| 成人黄色软件下载| 亚洲成a人片在线不卡一二三区| 日韩一区二区视频在线观看| 国产成人自拍网| 亚洲综合色自拍一区| 精品免费国产二区三区| 成人av在线一区二区三区| 亚洲午夜久久久久| www久久久久| 在线观看网站黄不卡| 久久精品国产99| 亚洲精品免费在线观看| 欧美一级欧美一级在线播放| 成人午夜视频免费看| 日韩精品一级中文字幕精品视频免费观看| 精品国产伦一区二区三区观看方式 | 蜜臀精品久久久久久蜜臀| 国产精品视频在线看| 日韩午夜三级在线| 99国产精品一区| 国产老妇另类xxxxx| 丝袜诱惑亚洲看片| 亚洲欧洲国产专区| 久久久久国产精品免费免费搜索| 在线观看一区不卡| caoporen国产精品视频| 久久精品国产99久久6| 亚洲www啪成人一区二区麻豆| 精品亚洲aⅴ乱码一区二区三区| 欧美日韩高清在线| 日日摸夜夜添夜夜添国产精品| 国产欧美日韩三区| www激情久久| 日韩一区二区视频| 正在播放一区二区| 欧美视频一区在线观看| 99精品国产99久久久久久白柏| 国内偷窥港台综合视频在线播放| 天堂一区二区在线| 亚洲国产精品久久久久秋霞影院| **网站欧美大片在线观看| 久久蜜桃香蕉精品一区二区三区| 日韩精品一区二区三区四区视频| 欧美影视一区二区三区| 日本韩国欧美在线| 99久久免费国产| a亚洲天堂av| av亚洲精华国产精华精华| 丁香天五香天堂综合| 丁香网亚洲国际| 成人国产电影网| 91一区二区在线| 91黄色免费看| 久久久久久久久久久久久久久99 | 日韩午夜激情免费电影| 日韩1区2区3区| 亚洲免费资源在线播放| 国产欧美日韩综合| 欧美一区二区视频观看视频| 久久精品日产第一区二区三区高清版| 国产精品久久久一本精品| 日韩精品亚洲专区| 91小视频在线| 26uuu亚洲综合色欧美| 亚洲欧美视频一区| 国产乱码一区二区三区| 精品视频在线免费观看| 国产精品初高中害羞小美女文| 蜜桃视频一区二区| 在线精品视频一区二区三四| 久久久无码精品亚洲日韩按摩| 亚洲bdsm女犯bdsm网站| a级精品国产片在线观看| 国产成人亚洲精品狼色在线| 国产精品美女久久久久久久网站| 亚洲午夜三级在线| 国产成人av一区二区三区在线| 色av一区二区| 一区在线观看免费| 激情久久五月天| 日韩三级在线观看| 亚洲丶国产丶欧美一区二区三区| caoporm超碰国产精品| 久久久久久久久99精品| 麻豆传媒一区二区三区| 51久久夜色精品国产麻豆| 一区二区三区 在线观看视频| 菠萝蜜视频在线观看一区| 久久久99精品久久| 国产一区二区久久| 精品久久五月天| 黑人精品欧美一区二区蜜桃 | 欧美一区二区三区视频在线观看 | 久久69国产一区二区蜜臀| 欧美一区午夜精品| 日韩极品在线观看| 天堂成人免费av电影一区|