mfrc522晶元需如何配置
❶ mfrc522通過串口連接51單片機,51單片機怎麼連接電腦
如果你的MFRC522是串口連接電腦的,為了與單片機連接,建議選擇雙串口單片機,比如STC12C5A60S2單片機,這樣一串口連接522一個串口連接電腦即可。如果你覺得麻煩,那你就通過串口轉成485匯流排去讀取,然後電腦與485之間也轉化一下即可。
❷ 關於MFRC522引腳選擇 可選單片機任意引腳嗎
讀卡晶元 可以 根據 PCB 布局來確定 與單片機 I/O 口的連接,把串口留出來 與 上位機通訊就可以了,其他的沒有關系。
❸ MF RC522的特性
◆高集成度的調制解調電路;
◆採用少量外部器件,即可將輸出驅動級接至天線;
◆支持 ISO/IEC 14443 TypeA 和MIFARE®通信協議;
◆ 讀寫器模式中與 ISO 14443A/MIFARE®的通信距離高達50mm,取決於天線的長度和調諧。
◆支持 ISO 14443 212kbit/s 和424kbit/s 的更高傳輸速率的通信。
◆支持 MIFARE® Classic 加密;
◆支持的主機介面:
-10Mbit/s 的SPI 介面
-I2C 介面,快速模式的速率為400kbit/s,高速模式的速率為3400kbit/s
-串列UART,傳輸速率高達1228.8kbit/s,幀取決於RS232 介面,電壓電平取決於提供的管腳電壓
◆64 位元組的發送和接收FIFO 緩沖區;
◆靈活的中斷模式;
◆可編程定時器。
◆具備硬體掉電、軟體掉電和發送器掉電 3 種節電模式,前兩種模式雷同於MFRC500 和 CL RC400,其特有的「發送器掉電」則可關閉內部天線驅動器,即關閉RF 場;
◆內置溫度感測器,以便在晶元溫度過高時自動停止 RF 發射;
◆採用相互獨立的多組電源供電,以避免模塊間的相互干擾,提高工作的穩定性;
◆具備 CRC 和奇偶校驗功能,CRC 協處理器的16 位長CRC 計算多項式固定為:x16+x12+x5+1,符合ISO/1EC14443 和CCTITT 協議;
◆內部振盪器,連接 27.12MHz 的晶體;
◆2.5~3.3V 的低電壓低功耗設計;
◆工作溫度范圍-30~+85℃;
◆5mm×5mm×0.85mm 的超小體積。

❹ RC522讀卡晶元怎麼用
什麼意思?#include
#define RST 1 << 8 // P0.7控制RC522復位,低電平復位/*
*********************************************************************************************************
** 函數名稱 :RC522_RST()
** 函數功能 :復位RC522
** 調試說明 :需將跳線JP5和RST連接。
*********************************************************************************************************
*/int RC522_RST (void)
{ //PINSEL0 = 0x00000000; // 設置管腳連接GPIO
IO0DIR = RST; // 設置RST控制口為輸出
IO0SET = RST; // P0.7置高
DelayNS(10); // 延時
IO0CLR = RST; // P0.7置低
DelayNS(3);
IO0SET = RST;
return 0;
}/*
********************************************************************************************************
** 函數名稱:ReadRawRC()
** 函數功能:讀MF522寄存器
** 參數說明:Address[IN]:寄存器地址
** 返 回 值:讀出的值
********************************************************************************************************
*/unsigned char ReadRawRC(unsigned char Address)
{
unsigned char ucAddr;
unsigned char ucResult = 0;
ucAddr = ((Address<<1)&0x7E)|0x80;
ucResult = MSPI_SendData (ucAddr);
return ucResult;
}
/*
*******************************************************************************************************
** 函數名稱:WriteRawRC()
** 函數功能:寫MF522寄存器
** 參數說明:Address[IN]:寄存器地址
** value[IN]:寫入的值
** 返 回 值:無
*******************************************************************************************************
*/void WriteRawRC(unsigned char Address,unsigned char value)
{
unsigned char ucAddr;
ucAddr = ((Address<<1)&0x7E);
MSPI_SendData(ucAddr);
MSPI_SendData(value);
return 0;}/*
*******************************************************************************************************
** 函數名稱:SetBitMask()
** 函數功能:置MF522寄存器位
** 參數說明:reg[IN]:寄存器地址
** mask[IN]:置位值
** 返 回 值:無
*******************************************************************************************************
*/void SetBitMask(unsigned char reg,unsigned char mask)
{
char tmp = 0x0;
tmp = ReadRawRC(reg);
WriteRawRC(reg,tmp | mask);
return 0;
}/*
*******************************************************************************************************
** 函數名稱:ClearBitMask()
** 函數功能:清MF522寄存器位
** 參數說明:reg[IN]:寄存器地址
** mask[IN]:清位值
** 返 回 值:無
*******************************************************************************************************
*/void ClearBitMask(unsigned char reg,unsigned char mask)
{
char tmp = 0x0;
tmp ReadRawRC(reg);
WriteRawRC(reg,tmp & ~mask);
return 0;
}/*
*******************************************************************************************************
** 函數名稱:PcdAntennaOn()
** 函數功能:開啟天線
** 函數說明:每次開啟或關閉天線發射之間至少有1ms的間隔
** 返 回 值:無
*******************************************************************************************************
*/void PcdAntennaOn()
{
unsigned char i;
i = ReadRawRC(TxControlReg);
if (!(i & 0x03))
{
SetBitMask(TxControlReg,0x03);
}return 0;
}/*
*******************************************************************************************************
** 函數名稱:PcdAntennaOff()
** 函數功能:關閉天線
** 函數說明:每次開啟或關閉天線發射之間至少有1ms的間隔
** 返 回 值:無
*******************************************************************************************************
*/void PcdAntennaOff()
{
ClearBitMask(TxControlReg,0x03);
}/*
*******************************************************************************************************
** 函數名稱:PcdComMF522()
** 函數功能:通過RC522和ISO14443卡通訊
** 函數說明:Command[IN]:RC522命令字
** pIndata[IN]:通過RC522發送到卡片的數據
** InLenByte[IN]:發送數據的位元組長度
** pOutData[OUT]:接收到的卡片返回數據
** *pOutLenBit[OUT]:返回數據的位長度
** 返 回 值:成功返回 MI_OK
*******************************************************************************************************
*/char PcdComMF522(unsigned char Command,
unsigned char *pInData,
unsigned char InLenByte,
unsigned char *pOutData,
unsigned int *pOutLenBit)
{
char status = MI_ERR;
unsigned char irqEn = 0x00;
unsigned char waitFor = 0x00;
unsigned char lastBits;
unsigned char n;
unsigned int i;
switch (Command)
{
case PCD_AUTHENT:
irqEn = 0x12;
waitFor = 0x10;
break;
case PCD_TRANSCEIVE:
irqEn = 0x77;
waitFor = 0x30;
break;
default:
break;
}
WriteRawRC(ComIEnReg,irqEn|0x80);
ClearBitMask(ComIrqReg,0x80);
WriteRawRC(CommandReg,PCD_IDLE);
SetBitMask(FIFOLevelReg,0x80);
for (i=0; i<InLenByte; i++)
{ WriteRawRC(FIFODataReg, pInData[i]); }
WriteRawRC(CommandReg, Command);
if (Command == PCD_TRANSCEIVE)
{ SetBitMask(BitFramingReg,0x80); }
i = 600;//根據時鍾頻率調整,操作M1卡最大等待時間25ms
do
{
n = ReadRawRC(ComIrqReg);
i--;
}
while ((i!=0) && !(n&0x01) && !(n&waitFor));
ClearBitMask(BitFramingReg,0x80);
if (i!=0)
{
if(!(ReadRawRC(ErrorReg)&0x1B))
{
status = MI_OK;
if (n & irqEn & 0x01)
{ status = MI_NOTAGERR; }
if (Command == PCD_TRANSCEIVE)
{
n = ReadRawRC(FIFOLevelReg);
lastBits = ReadRawRC(ControlReg) & 0x07;
if (lastBits)
{ *pOutLenBit = (n-1)*8 + lastBits; }
else
{ *pOutLenBit = n*8; }
if (n == 0)
{ n = 1; }
if (n > MAXRLEN)
{ n = MAXRLEN; }
for (i=0; i<n; i++)
{ pOutData[i] = ReadRawRC(FIFODataReg); }
}
}
else
{ status = MI_ERR; }
}
SetBitMask(ControlReg,0x80); // stop timer now
WriteRawRC(CommandReg,PCD_IDLE);
return status;
}2007-8-11 22:33:00 jianjian1981
等級:初中二年級
文章:51
積分:1461
門派:無門無派
注冊:2006年4月19日第 2 樓 --------------------------------------------------------------------------------
/*
*******************************************************************************************************
** 函數名稱:PcdRequest()
** 函數功能:尋卡
** 函數說明:req_code[IN]:尋卡方式
** 0x52 = 尋感應區內所有符合14443A標準的卡
** 0x26 = 尋未進入休眠狀態的卡
** pTagType[OUT]:卡片類型代碼
** 0x4400 = Mifare_UltraLight
** 0x0400 = Mifare_One(S50)
** 0x0200 = Mifare_One(S70)
** 0x0800 = Mifare_Pro(X)
** 0x4403 = Mifare_DESFire
** 返 回 值:成功返回MI_OK
*******************************************************************************************************
*/char PcdRequest(unsigned char req_code,unsigned char *pTagType)
{
char status;
unsigned int unLen;
unsigned char ucComMF522Buf[MAXRLEN]; ClearBitMask(Status2Reg,0x08);
WriteRawRC(BitFramingReg,0x07);
SetBitMask(TxControlReg,0x03);
ucComMF522Buf[0] = req_code; status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,1,ucComMF522Buf,&unLen);
if ((status == MI_OK) && (unLen == 0x10))
{
*pTagType = ucComMF522Buf[0];
*(pTagType+1) = ucComMF522Buf[1];
}
else
{ status = MI_ERR; }
return status;
}/*
*******************************************************************************************************
** 函數名稱:PcdAnticoll()
** 函數功能:防沖撞
** 函數說明:pSnr[OUT]:卡片序列號,4位元組
** 返 回 值:成功返回MI_OK
*******************************************************************************************************
*/char PcdAnticoll(unsigned char *pSnr)
{
char status;
unsigned char i,snr_check=0;
unsigned int unLen;
unsigned char ucComMF522Buf[MAXRLEN];
ClearBitMask(Status2Reg,0x08);
WriteRawRC(BitFramingReg,0x00);
ClearBitMask(CollReg,0x80);
ucComMF522Buf[0] = PICC_ANTICOLL1;
ucComMF522Buf[1] = 0x20; status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,2,ucComMF522Buf,&unLen); if (status == MI_OK)
{
for (i=0; i<4; i++)
{
*(pSnr+i) = ucComMF522Buf[i];
snr_check ^= ucComMF522Buf[i];
}
if (snr_check != ucComMF522Buf[i])
{ status = MI_ERR; }
}
SetBitMask(CollReg,0x80);
return status;
}/*
*******************************************************************************************************
** 函數名稱:PcdSelect()
** 函數功能:選定卡片
** 函數說明:pSnr[IN]:卡片序列號,4位元組
** 返 回 值:成功返回MI_OK
*******************************************************************************************************
*/char PcdSelect(unsigned char *pSnr)
{
char status;
unsigned char i;
unsigned int unLen;
unsigned char ucComMF522Buf[MAXRLEN];
ucComMF522Buf[0] = PICC_ANTICOLL1;
ucComMF522Buf[1] = 0x70;
ucComMF522Buf[6] = 0;
for (i=0; i<4; i++)
{
ucComMF522Buf[i+2] = *(pSnr+i);
ucComMF522Buf[6] ^= *(pSnr+i);
}
CalulateCRC(ucComMF522Buf,7,&ucComMF522Buf[7]);
ClearBitMask(Status2Reg,0x08); status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,9,ucComMF522Buf,&unLen);
if ((status == MI_OK) && (unLen == 0x18))
{ status = MI_OK; }
else
{ status = MI_ERR; } return status;
}
❺ MFRC522 對Mifare1 S50卡控制塊的讀寫操作
S50的數據塊包括控制塊的讀寫都是以16位元組為單位;
控制塊中的KEYA是永遠也讀不出來的(即讀出的內容要麼全0要麼全1),3位元組的存取條件各bit間有嚴格的互補關系,不能寫錯;
如果你把控制塊本身的存取條件設成了C1C2C3=111,整個控制塊的內容就無法讀出,會出現讀出全0或全1的情況。
❻ RC522模塊怎麼進入管理員模式添加其他卡
通過發卡器注冊授權。
門禁系統添加卡首先要看下你門禁系統是聯網的還是單機的呢。聯網的就在軟體裡面通過發卡器注冊授權。不聯網的就在機器上注冊授權添加卡。有些單機的門禁系統是可以通過管理卡注冊添加卡的。
RC522模塊採用PhilipsMFRC522原裝晶元設計讀卡電路,使用方便,成本低廉,適用於設備開發、讀卡器開發等高級應用的用戶、需要進行射頻卡終端設計/生產的用戶。
❼ 誰給講一下MFRC522電路的原理啊,什麼晶振電容啊等等
這個題目問得比較模糊,涉及晶振電容一般有以下幾個:負載電容,靜態電容,動態電容,至於各參數與電路上的對應內容,要參考電路使用目的。電路圖上的電容,只能體現一部分,因為IC內部和PCB布線分布電容均無法從原理圖上得知,需要實際量測確定。
