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布线分布电容均无法从原理图上得知,需要实际量测确定。
