From f93b4939f42b682fe370e00b3eba0c626ac4e256 Mon Sep 17 00:00:00 2001 From: Romuald Conty Date: Tue, 7 Sep 2010 17:33:45 +0000 Subject: [PATCH] Set/reset configuration options at nfc_connect() time. (Fixes issue 108) --- libnfc/nfc.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/libnfc/nfc.c b/libnfc/nfc.c index 471728a..40d2d75 100644 --- a/libnfc/nfc.c +++ b/libnfc/nfc.c @@ -161,6 +161,7 @@ nfc_device_t* nfc_connect(nfc_device_desc_t* pndd) // Reset the ending transmission bits register, it is unknown what the last tranmission used there if (!pn53x_set_reg(pnd,REG_CIU_BIT_FRAMING,SYMBOL_TX_LAST_BITS,0x00)) return NULL; + // Set default configuration options // Make sure we reset the CRC and parity to chip handling. if (!nfc_configure(pnd,NDO_HANDLE_CRC,true)) return NULL; if (!nfc_configure(pnd,NDO_HANDLE_PARITY,true)) return NULL; @@ -168,6 +169,18 @@ nfc_device_t* nfc_connect(nfc_device_desc_t* pndd) // Deactivate the CRYPTO1 chiper, it may could cause problems when still active if (!nfc_configure(pnd,NDO_ACTIVATE_CRYPTO1,false)) return NULL; + // Activate "easy framing" feature by default + if (!nfc_configure (pnd, NDO_EASY_FRAMING, true)) return NULL; + + // Activate auto ISO14443-4 switching by default + if (!nfc_configure (pnd, NDO_AUTO_ISO14443_4, true)) return NULL; + + // Disallow invalid frame + if (!nfc_configure (pnd, NDO_ACCEPT_INVALID_FRAMES, false)) return NULL; + + // Disallow multiple frames + if (!nfc_configure (pnd, NDO_ACCEPT_MULTIPLE_FRAMES, false)) return NULL; + return pnd; } else { DBG("No device found using driver: %s", drivers_callbacks_list[uiDriver].acDriver); @@ -236,12 +249,6 @@ bool nfc_initiator_init(nfc_device_t* pnd) // Configure the PN53X to be an Initiator or Reader/Writer if (!pn53x_set_reg(pnd,REG_CIU_CONTROL,SYMBOL_INITIATOR,0x10)) return false; - // NDO_EASY_FRAMING is activated by default - nfc_configure (pnd, NDO_EASY_FRAMING, true); - - // NDO_AUTO_ISO14443_4 is activated by default - nfc_configure (pnd, NDO_AUTO_ISO14443_4, true); - return true; }