# MFRC522
**Repository Path**: libdriver/mfrc522
## Basic Information
- **Project Name**: MFRC522
- **Description**: 适用于通用MCU和Linux系统的MFRC522全功能驱动
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2025-01-07
- **Last Updated**: 2025-04-22
## Categories & Tags
**Categories**: Uncategorized
**Tags**: 无线通信, SPI, IIC, 串口
## README
[English](/README.md) | [ 简体中文](/README_zh-Hans.md) | [繁體中文](/README_zh-Hant.md) | [日本語](/README_ja.md) | [Deutsch](/README_de.md) | [한국어](/README_ko.md)
## LibDriver MFRC522
[](/misra/README.md) [](https://www.libdriver.com/docs/mfrc522/index.html) [](/LICENSE)
MFRC522是一种高度集成的读写器IC,用于13.56 MHz的非接触式通信。MFRC522读卡器支持ISO/IEC 14443 A/MIFARE和NTAG。MFRC522的内部发射机能够驱动读写器天线,该天线设计用于与ISO/IEC 14443 A/MIFARE卡和转发器的通信且无需额外的有源电路。接收器模块为解调和解码来自ISO/IEC 14443 A/MIFARE兼容卡和转发器的信号提供了一种稳健而高效的实现。数字模块管理完整的ISO/IEC 14443 A成帧和错误检测(奇偶校验和CRC)功能。
LibDriver MFRC522是LibDriver推出的MFRC522全功能驱动,该驱动提供非接触通信、CRC计算、随机数生成等功能并且它符合MISRA标准。
LibDriver MFRC522提供MFRC522的全功能驱动,但不包括MIFARE Classic,MIFARE Ultralight和NTAG21x等驱动。
MIFARE Classic驱动可参考[https://gitee.com/libdriver/mifare_classic](https://gitee.com/libdriver/mifare_classic)。
MIFARE Ultralight驱动可参考[https://gitee.com/libdriver/mifare_ultralight](https://gitee.com/libdriver/mifare_ultralight)。
NTAG21x驱动可参考[https://gitee.com/libdriver/ntag21x](https://gitee.com/libdriver/ntag21x)。
### 目录
- [说明](#说明)
- [安装](#安装)
- [使用](#使用)
- [example basic](#example-basic)
- [文档](#文档)
- [贡献](#贡献)
- [版权](#版权)
- [联系我们](#联系我们)
### 说明
/src目录包含了LibDriver MFRC522的源文件。
/interface目录包含了LibDriver MFRC522与平台无关的IIC, SPI, UART总线模板。
/test目录包含了LibDriver MFRC522驱动测试程序,该程序可以简单的测试芯片必要功能。
/example目录包含了LibDriver MFRC522编程范例。
/doc目录包含了LibDriver MFRC522离线文档。
/datasheet目录包含了MFRC522数据手册。
/project目录包含了常用Linux与单片机开发板的工程样例。所有工程均采用shell脚本作为调试方法,详细内容可参考每个工程里面的README.md。
/misra目录包含了LibDriver MISRA代码扫描结果。
### 安装
参考/interface目录下与平台无关的IIC, SPI, UART总线模板,完成指定平台的IIC, SPI, UART总线驱动。
将/src目录,您使用平台的接口驱动和您开发的驱动加入工程,如果您想要使用默认的范例驱动,可以将/example目录加入您的工程。
### 使用
您可以参考/example目录下的编程范例完成适合您的驱动,如果您想要使用默认的编程范例,以下是它们的使用方法。
#### example basic
```C
#include "driver_mfrc522_basic.h"
uint8_t i;
uint8_t buf[25];
uint16_t crc;
char crc_input[] = "libdriver";
uint8_t in_buf[64];
uint8_t in_len;
uint8_t out_len;
uint8_t out_buf[64];
static void a_callback(uint16_t type)
{
switch (type)
{
case MFRC522_INTERRUPT_MFIN_ACT :
{
mfrc522_interface_debug_print("mfrc522: irq mfin act.\n");
break;
}
case MFRC522_INTERRUPT_CRC :
{
break;
}
case MFRC522_INTERRUPT_TX :
{
break;
}
case MFRC522_INTERRUPT_RX :
{
break;
}
case MFRC522_INTERRUPT_IDLE :
{
break;
}
case MFRC522_INTERRUPT_HI_ALERT :
{
break;
}
case MFRC522_INTERRUPT_LO_ALERT :
{
break;
}
case MFRC522_INTERRUPT_ERR :
{
mfrc522_interface_debug_print("mfrc522: irq err.\n");
break;
}
case MFRC522_INTERRUPT_TIMER :
{
mfrc522_interface_debug_print("mfrc522: irq timer.\n");
break;
}
default :
{
mfrc522_interface_debug_print("mfrc522: irq unknown code.\n");
break;
}
}
}
...
/* interrupt init */
g_gpio_irq = mfrc522_interrupt_irq_handler;
res = gpio_interrupt_init();
if (res != 0)
{
return 1;
}
/* init */
res = mfrc522_basic_init(MFRC522_INTERFACE_SPI, 0x00, a_callback);
if (res != 0)
{
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
...
/* get the random */
res = mfrc522_basic_generate_random(buf);
if (res != 0)
{
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
for (i = 0; i < 25; i++)
{
mfrc522_interface_debug_print("0x%02X ", buf[i]);
}
mfrc522_interface_debug_print("\n");
...
/* calculate the crc */
res = mfrc522_basic_calculate_crc((uint8_t *)crc_input, (uint8_t)strlen(crc_input), &crc);
if (res != 0)
{
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
mfrc522_interface_debug_print("%s crc is 0x%04X.\n", argv[4], crc);
...
/* set the input */
in_buf[0] = 0x26;
in_len = 1;
out_len = 64;
res = mfrc522_basic_transceiver(in_buf, in_len, out_buf, &out_len);
if (res != 0)
{
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
for (i = 0; i < 25; i++)
{
mfrc522_interface_debug_print("0x%02X ", out_buf[i]);
}
mfrc522_interface_debug_print("\n");
...
/* deinit */
(void)mfrc522_basic_deinit();
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 0;
```
### 文档
在线文档: [https://www.libdriver.com/docs/mfrc522/index.html](https://www.libdriver.com/docs/mfrc522/index.html)。
离线文档: /doc/html/index.html。
### 贡献
请参考CONTRIBUTING.md。
### 版权
版权 (c) 2015 - 现在 LibDriver 版权所有
MIT 许可证(MIT)
特此免费授予任何获得本软件副本和相关文档文件(下称“软件”)的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、转授许可和/或出售该软件副本,以及再授权被配发了本软件的人如上的权利,须在下列条件下:
上述版权声明和本许可声明应包含在该软件的所有副本或实质成分中。
本软件是“如此”提供的,没有任何形式的明示或暗示的保证,包括但不限于对适销性、特定用途的适用性和不侵权的保证。在任何情况下,作者或版权持有人都不对任何索赔、损害或其他责任负责,无论这些追责来自合同、侵权或其它行为中,还是产生于、源于或有关于本软件以及本软件的使用或其它处置。
### 联系我们
请联系lishifenging@outlook.com。