This application provides a set of demos with X-NUCLEO-NFC01A1 expansion board.
Dependencies: NDefLib X_NUCLEO_NFC01A1 mbed
Fork of X-MBED-NFC1 by
This application provides a set of demos with X-NUCLEO-NFC01A1 expansion board.
The available demos are:
- SAMPLE_WRITE_URL: write a tag with the ST home page URL
- SAMPLE_COUNT_CLICK: create a custom tag to count and report the user button clicks.
- SAMPLE_WRITE_AND_CHANGE_ALL: write a tag with all the supported records and update the tag contents when the user button is pressed.
- SAMPLE_LOCK_TAG_CONTENT: use the M24SR component API to set the NFC tag as read-only.
To enable the different demos comment/uncomment the SAMPLE_* macros provided in main.cpp .
Revision 8:a9ecd7687de7, committed 2015-12-21
- Comitter:
- giovannivisentini
- Date:
- Mon Dec 21 13:01:41 2015 +0000
- Parent:
- 7:ba6632daeea9
- Child:
- 9:9742acd0c015
- Commit message:
- remove already imported library and add a new demo
Changed in this revision
--- a/NDefLib.lib Mon Dec 21 09:50:51 2015 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1 +0,0 @@ -https://developer.mbed.org/users/giovannivisentini/code/NDefLib/#1ebd6049fa57
--- a/NDefLib_M24SR.lib Mon Dec 21 09:50:51 2015 +0000 +++ b/NDefLib_M24SR.lib Mon Dec 21 13:01:41 2015 +0000 @@ -1,1 +1,1 @@ -NDefLib_M24SR#5303652dc943 +https://developer.mbed.org/users/giovannivisentini/code/NDefLib_M24SR/#4418dfd45460
--- a/Samples/Sample_countClick.cpp Mon Dec 21 09:50:51 2015 +0000
+++ b/Samples/Sample_countClick.cpp Mon Dec 21 13:01:41 2015 +0000
@@ -90,7 +90,6 @@
void sample_countClick() {
I2C i2cChannel(X_NUCLEO_NFC01A1::DEFAULT_SDA_PIN,X_NUCLEO_NFC01A1::DEFAULT_SDL_PIN);
- i2cChannel.frequency(400000);
X_NUCLEO_NFC01A1 *nfcNucleo = X_NUCLEO_NFC01A1::Instance(i2cChannel);
//create the wrapper for use the NdefLib
--- a/Samples/Sample_writeAndChangeAll.cpp Mon Dec 21 09:50:51 2015 +0000
+++ b/Samples/Sample_writeAndChangeAll.cpp Mon Dec 21 13:01:41 2015 +0000
@@ -280,7 +280,7 @@
void sample_writeAndChangeAll() {
I2C i2cChannel(X_NUCLEO_NFC01A1::DEFAULT_SDA_PIN,X_NUCLEO_NFC01A1::DEFAULT_SDL_PIN);
- i2cChannel.frequency(400000);
+
DigitalOut nucleoLed(LED1);
X_NUCLEO_NFC01A1 *nfcNucleo = X_NUCLEO_NFC01A1::Instance(i2cChannel);
--- a/Samples/Sample_writeUrl.cpp Mon Dec 21 09:50:51 2015 +0000
+++ b/Samples/Sample_writeUrl.cpp Mon Dec 21 13:01:41 2015 +0000
@@ -45,8 +45,7 @@
Serial pc(SERIAL_TX, SERIAL_RX);
I2C i2cChannel(X_NUCLEO_NFC01A1::DEFAULT_SDA_PIN,X_NUCLEO_NFC01A1::DEFAULT_SDL_PIN);
- i2cChannel.frequency(400000);
-
+
X_NUCLEO_NFC01A1 *nfcNucleo = X_NUCLEO_NFC01A1::Instance(i2cChannel);
//create the wrapper for use the NdefLib
--- a/Samples/Samples.h Mon Dec 21 09:50:51 2015 +0000 +++ b/Samples/Samples.h Mon Dec 21 13:01:41 2015 +0000 @@ -38,5 +38,5 @@ void sample_writeUrl(); void sample_countClick(); void sample_writeAndChangeAll(); - +void sample_lockTagContent(); #endif /* __SAMPLES_H__ */ \ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/Samples/sample_lockWriteTag.cpp Mon Dec 21 13:01:41 2015 +0000
@@ -0,0 +1,151 @@
+/**
+ ******************************************************************************
+ * @file Sample_lockWriteTag.cpp
+ * @date 03/12/2015
+ * @brief This demo define a lock/unlock the tag content when the user press
+ * the user button
+ ******************************************************************************
+ *
+ * COPYRIGHT(c) 2015 STMicroelectronics
+ *
+ * Redistribution and use in source and binary forms, with or without modification,
+ * are permitted provided that the following conditions are met:
+ * 1. Redistributions of source code must retain the above copyright notice,
+ * this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
+ * this list of conditions and the following disclaimer in the documentation
+ * and/or other materials provided with the distribution.
+ * 3. Neither the name of STMicroelectronics nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ ******************************************************************************
+ */
+
+#include "mbed.h"
+
+#include "X_NUCLEO_NFC01A1.h"
+#include "Type4NfcTagM24SR.h"
+#include "NDefLib/RecordType/RecordText.h"
+
+static volatile bool buttonPress=false;
+
+static void setButtonPress(){
+ buttonPress=true;
+}//if buttonPress
+
+/**
+ * return the led that tell if the tag is read only
+ * @param nfcNucleo board where the lead lives
+ * @return let to switch on if the tag is read only
+ */
+static inline DigitalOut& getReadOnlyLed(X_NUCLEO_NFC01A1 *nfcNucleo){
+ return nfcNucleo->getLed2();
+}
+
+/**
+ * return the led that tell if the tag is write only
+ * @param nfcNucleo board where the lead lives
+ * @return let to switch on if the tag is write only
+ */
+static inline DigitalOut& getWriteableLed(X_NUCLEO_NFC01A1 *nfcNucleo){
+ return nfcNucleo->getLed3();
+}
+
+/**
+ * set the tag as read only and switch the led on
+ * @param nfcNucleo board where the lead lives
+ * @param tag helper class for manage the nfc tag
+ * @return true if the change has effect
+ */
+bool enableReadOnly( X_NUCLEO_NFC01A1 *nfcNucleo,Type4NfcTagM24SR &tag){
+
+ if(tag.enableReadOnly()){
+ getReadOnlyLed(nfcNucleo)=true;
+ getWriteableLed(nfcNucleo)=false;
+ return true;
+ }else
+ return false;
+}
+
+/**
+ * set the tag as read/write and switch the led on
+ * @param nfcNucleo board where the lead lives
+ * @param tag helper class for manage the nfc tag
+ * @return true if the change has effect
+ */
+bool disableReadOnly( X_NUCLEO_NFC01A1 *nfcNucleo,Type4NfcTagM24SR &tag){
+
+ if(tag.disableReadOnly()){
+ getReadOnlyLed(nfcNucleo)=false;
+ getWriteableLed(nfcNucleo)=true;
+ return true;
+ }else
+ return false;
+}
+
+void sample_lockTagContent() {
+ Serial console(SERIAL_TX, SERIAL_RX);
+
+ I2C i2cChannel(X_NUCLEO_NFC01A1::DEFAULT_SDA_PIN,X_NUCLEO_NFC01A1::DEFAULT_SDL_PIN);
+
+ X_NUCLEO_NFC01A1 *nfcNucleo = X_NUCLEO_NFC01A1::Instance(i2cChannel);
+ //create the wrapper for use the NdefLib
+ Type4NfcTagM24SR tag(nfcNucleo->getM24SR());
+
+ //when the user press the button set buttonPress to true
+ InterruptIn userButton(USER_BUTTON);
+ userButton.fall(setButtonPress);
+
+ //restore the board as read/write
+ tag.openSession(true);
+ nfcNucleo->getLed1()=tag.disableAllPassword();
+ tag.closeSession();
+ getReadOnlyLed(nfcNucleo)=false;
+ getWriteableLed(nfcNucleo)=true;
+ bool tagIsLock=false;
+
+
+ while(true){
+
+ if(buttonPress){
+ if(tag.openSession()){
+ bool changeStatusResult;
+
+ if(tagIsLock)
+ changeStatusResult=enableReadOnly(nfcNucleo,tag);
+ else
+ changeStatusResult=disableReadOnly(nfcNucleo,tag);
+
+ if(changeStatusResult)
+ tagIsLock=!tagIsLock;
+ else
+ console.printf("Error change the tag status");
+ tag.closeSession();
+ }else{
+ console.printf("Error opening the session, tag is in use");
+ }
+ buttonPress=false;
+ }//if
+
+ //wait next event
+ __WFE();
+ }//while
+
+}//sample_countClick
+
+
+
+
+
--- a/X_NUCLEO_NFC01A1.lib Mon Dec 21 09:50:51 2015 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1 +0,0 @@ -https://developer.mbed.org/users/giovannivisentini/code/X_NUCLEO_NFC01A1/#060f32f285ac
--- a/main.cpp Mon Dec 21 09:50:51 2015 +0000
+++ b/main.cpp Mon Dec 21 13:01:41 2015 +0000
@@ -35,7 +35,8 @@
//#define SAMPLE_WRITE_URL
//#define SAMPLE_COUNT_CLICK
-#define SAMPLE_WRITE_AND_CHANGE_ALL
+//#define SAMPLE_WRITE_AND_CHANGE_ALL
+#define SAMPLE_LOCK_TAG_CONTENT
int main(void)
{
@@ -50,4 +51,8 @@
#ifdef SAMPLE_WRITE_AND_CHANGE_ALL
sample_writeAndChangeAll();
#endif /* SAMPLE_WRITE_AND_CHANGE_ALL */
+
+#ifdef SAMPLE_LOCK_TAG_CONTENT
+ sample_lockTagContent();
+#endif /* SAMPLE_LOCK_TAG_CONTENT */
}
\ No newline at end of file
