前几天写了一篇文章,详述了libnfc 1.7.0在windows下的编译过程,打开了对acr122u模块、pn53x_usb模块、pn532_uart模块等的支持,今天试了一下,发现在win下libnfc默认好像只扫描使用acr122_pcsc driver和pn53x_usb driver的模块,而我连接了pn532_uart模块之后提示没有找到NFC设备。
Debug模式编译运行nfc-list.exe输出如下:
unknown libnfc.general log_level is set to 3
debug libnfc.general allow_autoscan is set to true
debug libnfc.general allow_intrusive_scan is set to false
debug libnfc.general 0 device(s) defined by user
nfc-list.exe uses libnfc 1.7.0
debug libnfc.general 0 device(s) found using acr122_pcsc driver
debug libnfc.general 0 device(s) found using pn53x_usb driver
No NFC device found.
于是,我开始查找支持pn532_uart的方法,通过查看源码发现libnfc使用两种方式获取nfc设备:
1.自动扫描 autoscan
2.用户自定义设备 user_defined_device
libnfc支持读取libnfc.conf配置文件的方式加载用户定义的设备。
最开始,我尝试了在cmake生成的config.h里增加#define CONFFILES,重新编译的时候报错:
undefined reference to '_imp__regcomp'
这是由于conf.c里面调用了regcomp等函数,这些函数属于regex正则解析库,但是我使用的MinGW64里面没有这个库。
于是我复制了早期的MinGW的libregex库以及头文件,编译能通过,但是运行nfc-list.exe运行到读取配置文件时就出错退出了,估计还是正则库有问题。
libregex使用不了也没关系,其实可以修改conf.c去掉正则解析的过程,直接将参数赋值给nfc_context。
主要需要修改config.h和conf.c两个文件。
在config.h里增加 #define CONFFILES
修改conf.c如下:
#include "conf.h" #ifdef HAVE_CONFIG_H # include "config.h" #endif // HAVE_CONFIG_H #ifdef CONFFILES #include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <string.h> #include <regex.h> #include <sys/stat.h> #include <nfc/nfc.h> #include "nfc-internal.h" #include "log.h" #define LOG_CATEGORY "libnfc.config" #define LOG_GROUP NFC_LOG_GROUP_CONFIG #ifndef LIBNFC_SYSCONFDIR // If this define does not already exists, we build it using SYSCONFDIR #ifndef SYSCONFDIR #error "SYSCONFDIR is not defined but required." #endif // SYSCONFDIR #define LIBNFC_SYSCONFDIR SYSCONFDIR"/nfc" #endif // LIBNFC_SYSCONFDIR //#define LIBNFC_CONFFILE LIBNFC_SYSCONFDIR"/libnfc.conf" //#define LIBNFC_DEVICECONFDIR LIBNFC_SYSCONFDIR"/devices.d" #define LIBNFC_CONFFILE "libnfc.conf" #define LIBNFC_DEVICECONFDIR "devices.d" static bool conf_parse_file(const char *filename, void (*conf_keyvalue)(void *data), void *data) { printf("Try to Conf Key Value by chenxupro\n"); conf_keyvalue(data); return true; } static void conf_keyvalue_context(void *data) { nfc_context *context = (nfc_context *)data; //if (strcmp(key, "allow_autoscan") == 0) { string_as_boolean("true", &(context->allow_autoscan)); //} else if (strcmp(key, "allow_intrusive_scan") == 0) { string_as_boolean("false", &(context->allow_intrusive_scan)); //} else if (strcmp(key, "log_level") == 0) { context->log_level = atoi("2"); //} else if (strcmp(key, "device.name") == 0) { if ((context->user_defined_device_count == 0) || strcmp(context->user_defined_devices[context->user_defined_device_count - 1].name, "") != 0) { if (context->user_defined_device_count >= MAX_USER_DEFINED_DEVICES) { log_put(LOG_GROUP, LOG_CATEGORY, NFC_LOG_PRIORITY_ERROR, "%s", "Configuration exceeded maximum user-defined devices."); return; } context->user_defined_device_count++; } strcpy(context->user_defined_devices[context->user_defined_device_count - 1].name, "chenxupro PN532"); //} else if (strcmp(key, "device.connstring") == 0) { if ((context->user_defined_device_count == 0) || strcmp(context->user_defined_devices[context->user_defined_device_count - 1].connstring, "") != 0) { if (context->user_defined_device_count >= MAX_USER_DEFINED_DEVICES) { log_put(LOG_GROUP, LOG_CATEGORY, NFC_LOG_PRIORITY_ERROR, "%s", "Configuration exceeded maximum user-defined devices."); return; } context->user_defined_device_count++; } strcpy(context->user_defined_devices[context->user_defined_device_count - 1].connstring, "pn532_uart:COM9:115200"); } void conf_load(nfc_context *context) { conf_parse_file(LIBNFC_CONFFILE, conf_keyvalue_context, context); } #endif // CONFFILES
重新编译,运行结果如下:
unknown libnfc.general log_level is set to 2
debug libnfc.general allow_autoscan is set to true
debug libnfc.general allow_intrusive_scan is set to false
debug libnfc.general 1 device(s) defined by user
debug libnfc.general #0 name: "chenxupro PN532", connstring: "pn532_uart:COM9:115200"
debug libnfc.general 0 device(s) found using acr122_pcsc driver
debug libnfc.general 0 device(s) found using pn53x_usb driver
debug libnfc.driver.pn532_uart Attempt to open: COM9 at 115200 bauds.
Try to Conf Key Value by chenxupro
nfc-list.exe uses libnfc 1.7.0
NFC device: pn532_uart:COM9 opened
1 ISO14443A passive target(s) found:
ISO/IEC 14443A (106 kbps) target:
ATQA (SENS_RES): 00 04
UID (NFCID1): 7d 88 c9 1d
SAK (SEL_RES): 08