## **AN12364** # NTAG 5 - Bidirectional data exchange Rev. 1.0 — 9 January 2020 **Application note COMPANY PUBLIC** #### **Document information** | Information | Content | |-------------|--------------------------------------------------------------------| | Keywords | Data transfer, SRAM, PHDC, arbitration | | Abstract | How to transfer data, Pass-through, SRAM, PHDC, memory arbitration | #### NTAG 5 - Bidirectional data exchange #### **Revision history** | Rev | Date | Description | |-------|----------|---------------------------------| | v.1.0 | 20200109 | First official released version | NTAG 5 - Bidirectional data exchange ### 1 Abbreviations Table 1. Abbreviations | Acronym | Description | |------------------|-----------------------------------------------------| | EEPROM | Electrically Erasable Programmable Read-Only Memory | | GPIO | General-purpose input/output | | I <sup>2</sup> C | Inter-Integrated Circuit | | NFC | Near field communication | | PHDC | Personal Health Device Communication | | POR | Power On Reset | | PWM | Pulse width modulation | | RF | radio frequency | | SRAM | Static random-access memory | NTAG 5 - Bidirectional data exchange #### 2 Introduction NTAG 5 offers many ways for bidirectional data exchange. One of it is the "pass-through mode", which allows the NTAG 5 to be used for bidirectional data transfer from an NFC device to an I<sup>2</sup>C-bus Host (e.g. a microcontroller). The pass-through mode provides the SRAM for data communication and triggering mechanisms for the synchronization of the data transfer. #### 2.1 Potential applications - Read out of data collected in an embedded device (logging data) - Upload new data in the embedded device (e.g. firmware update of the microcontroller) - Bidirectional communication with exchange of commands and data (e.g. execute functions in the microcontroller or execute authentication schemes) NTAG 5 - Bidirectional data exchange ### 3 Interface Arbitration for memory access Interface Arbitration logic is provided to give access to RF interface and I<sup>2</sup>C interface to access memory, without collisions. Two session register bits are provided to indicate which interface booted up successfully and it is available: RF\_BOOT\_OK and VCC BOOT OK. **Note**: Tag can be "externally powered" by itself using energy harvesting, if $V_{OUT}$ and $V_{CC}$ are shorted. Memory consist of EEPROM, SRAM and Session registers. SRAM is available only when tag is supplied by $V_{CC}$ (VCC\_SUPPLY\_OK = 1b) and SRAM\_ENABLE configuration bit is set to 1b. EEPROM and Session register are available when any of the supply sources is available. Arbitration mode is applicable for I<sup>2</sup>C <u>slave</u> use case mode only. For I<sup>2</sup>C Master and GPIO/PWM use cases, no memory arbitration is done / needed. There are four (4) arbitration schemes: - 1. Normal mode [Section 4] - 2. SRAM Mirror mode [Section 5] shall be used when frequently changing data is passed over NDEF message. E.g., Host is reading temperature from temp. sensor and writing the value to the NTAG 5 User Memory Area, at the end of NDEF URL every 0.5 s, like: http://www.desireddomainwithSensorData.com/temp=023344&t1=25C. While SRAM provides unlimited write endurance, SRAM Mirror is better to use instead of writing to EEPROM. So host would be writing temperature to SRAM instead of EEPROM. Arbiter takes care that only one interface access the SRAM at the time. - 3. SRAM Pass-through mode [Section 6] for bulk data exchange (up to 256 B in one pass). Usually Host $\leftrightarrow$ NTAG 5 $\leftrightarrow$ NFC. - 4. PHDC mode [Section 7] for data exchange with Personal Health Care Device (e.g. blood pressure device, body temperature measurement device). SRAM Mirror on the first pages of User Memory is used for bulk data exchange, with help of arbitration mechanism. Also [TNEP] mode is supported. Note: NFC Forum defined TNEP is used where no special arbitration is needed on IC level. NTAG 5 - Bidirectional data exchange #### 4 Normal Mode ARBITER\_MODE [1:0] = 00b indicates normal mode. Memory is accessible by both the interfaces by "First come first serve" principle. The arbiter locks to I<sup>2</sup>C interface in following occasions: - If the NTAG 5 is correctly addressed for the memory access on the I<sup>2</sup>C interface, then set I<sup>2</sup>C\_IF\_LOCKED = 1b if NFC\_IF\_LOCKED = 1b. - If I<sup>2</sup>C\_IF\_LOCKED = 1b then I<sup>2</sup>C interface can access EEPROM and SRAM. - RF reader can access (read/write) the NTAG 5 status registers via RF commands at any time. Any RF commands accessing EEPROM/CONFIGURATION memory will be returned with NAK. I<sup>2</sup>C\_IF\_LOCKED will be cleared if - I<sup>2</sup>C host writes to clear the register bit. - If this is not done by the host, this bit will be automatically reset to 0 if Watch Dog Timer expires. - At POR (all power sources). - If I<sup>2</sup>C supply switches off. Note: If Watchdog timer is disabled, bit will not be cleared until transactions ends. The arbiter locks to RF interface: - If the NTAG 5 receives valid RF command and correctly addressed for memory access, then set NFC\_IF\_LOCKED = 1b if I<sup>2</sup>C\_IF\_LOCKED = 1b. - If NFC IF LOCKED = 1b then RF interface can access NTAG 5 memory. - I<sup>2</sup>C host can access (read/write) the TAG status registers via I<sup>2</sup>C commands. Any I<sup>2</sup>C commands to access memory will be returned with data NAK. NFC IF LOCKED will be cleared automatically after: - · Completion of current valid RF command. - At POR (all power sources). - · If RF field is switched OFF. In Normal mode SRAM can be made available as part of memory or can disabled by configuring SRAM\_ENABLE bit. If NTAG 5 is VCC supplied VCC\_SUPPLY\_OK = 1b and SRAM\_ENABLE = 1b, then SRAM is mapped at memory: - I<sup>2</sup>C interface: SRAM available at 2000h-201Fh. - RF Interface - Can be only accessed by SRAM READ and SRAM WRITE Commands. - Not mapped to any Block address from RF perspective. If NTAG 5 is VCC supplied VCC\_SUPPLY\_OK = 1b and SRAM\_ENABLE = 1b, then SRAM is not available for both the interfaces. AN12364 NTAG 5 - Bidirectional data exchange #### 5 SRAM Mirror Mode ARBITER\_MODE [1:0] = 01b indicates SRAM Mirror mode. Memory is accessible by both the interfaces by "First come first serve" principle. The arbitration scheme remains same as Normal mode. To make this mode work, the tag needs to be powered by both RF and VCC. - RF FIELD OK = 1b - VCC\_SUPPLY\_OK = 1b - SRAM ENABLE = 1b SRAM Mirror mode maps SRAM onto User memory (EEPROM) space. This enables unlimited writes to NDEF area. This mode is not used for bulk data transfer as the "pass through" mode [Section 6]. In this mode SRAM is mapped to Block 0h of EEPROM memory, for both RF to I<sup>2</sup>C interfaces. Therefore underlaying EEPROM is not accessible when SRAM is mirrored. In this mode the SRAM is mapped at memory: - I<sup>2</sup>C interface: - BLOCK0h to BLOCK3Fh - 2000h-203Fh - · RF Interface: - Can be accessed by SRAM\_READ and SRAM\_WRITE Commands. - READ\_BLOCK, READ\_MULTIPLE\_BLOCK, WRITE\_BLOCK commands to blocks BLOCK0h to BLOCK3Fh. Mirrored SRAM area can be populated with pre-defined data on boot-up. Specified bytes of SRAM NDEF data get loaded into the SRAM. In this case, boot-up time gets extended. NTAG 5 - Bidirectional data exchange ## 6 SRAM Pass-Through Mode ARBITER\_MODE [1:0] = 10b indicates SRAM Pass-Through mode. In this mode, the tag transfers data from RF to I<sup>2</sup>C or vice versa using SRAM. SRAM is available only if the tag is VCC powered. Conditions to be met that Pass-through mode is working: - RF FIELD OK = 1b - VCC\_SUPPLY\_OK = 1b - SRAM\_ENABLE = 1b In Pass-through mode the SRAM is mapped at memory: - From I<sup>2</sup>C perspective: 2000h-203Fh (SRAM not mirrored on EEPROM) - From RF perspective: 00h-3Fh SRAM memory address. Memory can be only accessed by SRAM\_READ and SRAM\_WRITE Commands (SRAM not mirrored on EEPROM). The data transfer direction can be decided by the PT\_TRANSFER\_DIR session register bit: - PT\_TRANSFER\_DIR = 0b, Data transfer direction is from I<sup>2</sup>C host to RF reader. - PT TRANSFER DIR = 1b, Data transfer direction is from RF reader to I<sup>2</sup>C host. Arbiter locks to only one interface at time. Since both the interfaces (RF and $I^2C$ ) are not active concurrently, a Terminator block mechanism is used to transfer the control from one interface (RFI/ $^2C$ ) to another interface ( $I^2C/RF$ ). Examples of pass-through mode (with source code) are described in: - 1. AN12381 NTAG 5 Firmware development for KW41Z [Application note] - 2. AN12380 NTAG 5 Android App [Application note] NTAG 5 - Bidirectional data exchange ## 6.1 Data Transfer mechanism RF to I<sup>2</sup>C Data transfer (RF reader to I<sup>2</sup>C host) #### NTAG 5 - Bidirectional data exchange #### Steps: - NTAG's configuration (start-up behavior) is set that ED pin will go LOW once NFC field is present - 2. NFC field is present, 1 ms guard time (ISO15693) for NTAG to boot up - 3. In the mean-time ED pin goes LOW - 4. μC queries (sends I<sup>2</sup>C commands in loop) for VCC and NFC field presence status registers - 5. If both 1b, move on - 6. µC reset Session registers (current session): - ARBITER\_MODE: SRAM pass through - · Enable SRAM memory - Pass-through direction: NFC->I2C - ED goes LOW when last byte (Byte3 block 3Fh) of SRAM is written (ED\_CONFIG\_REG = 0100b) - 7. Clear ED pin (ED pin is cleared i.e. released when writing 01h to the ED clear register ED INTR CLEAR REG (10ACh)) - 8. NFC can start writing to SRAM - 9. When the last page of SRAM is written, ED pin is pulled LOW - 10.NFC polls if data was read from SRAM and/or arbiter still keeps access locked to I<sup>2</sup>C interface - 11.1<sup>2</sup>C side was notified through interrupt ED pin, that data is waiting in SRAM. SRAM Memory can be read now - 12.ED pin goes low, when last byte has been READ by I<sup>2</sup>C interface (ED\_CONFIG\_REG = 0100b) - 13.Arbiter unlocks access from I<sup>2</sup>C interface and sets SRAM\_DATA\_READY bit to 0b. NFC polls for those and can restart SRAM WRITE loop with new data. NTAG 5 - Bidirectional data exchange ## 6.2 Data Transfer mechanism I<sup>2</sup>C to RF Data transfer (I<sup>2</sup>C host to RF reader) #### NTAG 5 - Bidirectional data exchange #### Steps: - NTAG's configuration (start-up behavior) is set that ED pin will go LOW once NFC field is present - 2. NFC field is present, 1 ms guard time (ISO15693) for NTAG to boot up - 3. In the mean-time ED pin goes LOW - 4. RF polls when data is ready in SRAM (SRAM\_DATA\_READY) - 5. I<sup>2</sup>C host sets NTAG 5s session registers: - · arbiter mode: pass-through - enable SRAM memory - transfer direction: I<sup>2</sup>C → RF - configure ED pin to go low when last byte of SRAM page is read by NFC - 6. I<sup>2</sup>C host writes to SRAM memory (2000h 203Fh) - 7. When last byte of SRAM is written, Arbiter locks interface to RF and releases I<sup>2</sup>C interface. SRAM\_DATA\_READY bit is set to 1b on NTAG 5. - 8. SRAM DATA READY is 1b, RF interface can read SRAM now - 9. When last byte of SRAM is read by NFC, Arbiter locks to I<sup>2</sup>C interface and SRAM\_DATA\_READY bit is set back to 0b. - 10.ED pin is pulled low - 11.1<sup>2</sup>C host can start to write another chunk of data or stop the pass-through. NTAG 5 - Bidirectional data exchange #### 7 PHDC mode This mode is defined by NFC Forum to be used in Personal Health Device Communication. For more info, refer to [PHDC]. NFC Forum Reader/Writer Mode is used. ARBITER MODE [1:0] = 11b indicates SRAM PHDC mode. The arbitration scheme remains same as Normal mode with exception of SRAM access for read. To make this mode work, the tag needs to be powered by both RF & VCC. - RF\_FIELD\_OK = 1b - VCC SUPPLY OK = 1b - SRAM\_ENABLE = 1b PHDC mode would map SRAM in user memory (EEPROM) space. SRAM is always mirrored to block0h. In PHDC mode the SRAM is mirrored on to Block 0h of EEPROM memory for both RF to I<sup>2</sup>C interfaces. In this mode the SRAM is mapped at memory: - I<sup>2</sup>C interface: - Can be accessed at BLOCK0h to BLOCK3Fh or - Can be accessed at 2000h-203Fh - RF Interface: - Can be accessed by read or write commands to SRAM mirrored blocks BLOCK0h to BLOCK3Fh. NFC Forum commands which are used are specified in [PHDC]: NFC read and NFC write - Can be accessed by SRAM\_READ and SRAM\_WRITE Commands SRAM access condition differs from Normal mode. - I<sup>2</sup>C Interface accessing SRAM - I<sup>2</sup>C IF LOCKED =1b - I<sup>2</sup>C SRAM read/write ongoing - IF RF requests for SRAM access. - RF read/write access: - The current ongoing I<sup>2</sup>C access is halted and I<sup>2</sup>C clock is stretched after completing the current Byte read or write access of I<sup>2</sup>C interface. I<sup>2</sup>C\_IF\_LOCKED = 0 and NFC\_IF\_LOCKED =1 - RF gets the access to read/write SRAM. - After RF reads/writes SRAM, I<sup>2</sup>C transaction is resumed. I<sup>2</sup>C\_IF\_LOCKED = 1 and NFC\_IF\_LOCKED =0 AN12364 NTAG 5 - Bidirectional data exchange ## 8 Configuration and SRAM memory password security SRAM and EEPROM used for bidirectional data exchange can be optionally also password protected. More details can be found in [Application note]. NTAG 5 - Bidirectional data exchange #### 9 References - [1] NFC Forum specification, Tag NDEF Exchange Protocol Technical Specification Version 1.0 2019-04-24 [TNEP] NFC Forum<sup>TM</sup> <a href="https://nfc-forum.org/our-work/specifications-and-application-documents/specifications/nfc-forum-candidate-technical-specifications/">https://nfc-forum.org/our-work/specifications-and-application-documents/specifications/nfc-forum-candidate-technical-specifications/</a> - [2] NFC Forum Personal Health Care Devices (PHDC) specification <a href="https://nfc-forum.org/product-category/specification/">https://nfc-forum.org/product-category/specification/</a> - [3] AN12366 NTAG 5 Memory Configuration and Scalable Security, doc.no. 5305xx https://www.nxp.com/docs/en/application-note/AN12366.pdf - [4] RM00221 NTAG 5 Android Application development, doc.no. 5318xx <a href="https://www.nxp.com/docs/en/reference-manual/RM00221.pdf">https://www.nxp.com/docs/en/reference-manual/RM00221.pdf</a> - [5] RM00222 NTAG 5 KW41 firmware development, doc.no. 5319xx https://www.nxp.com/docs/en/reference-manual/RM00222.pdf #### NTAG 5 - Bidirectional data exchange ### 10 Legal information #### 10.1 Definitions Draft — The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information. #### 10.2 Disclaimers Limited warranty and liability - Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors. In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory. Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors Right to make changes — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof. Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk. Applications — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification. Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products. NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect. **Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities. Non-automotive qualified products — Unless this data sheet expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of nonautomotive qualified products in automotive equipment or applications. In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications. Evaluation products — This product is provided on an "as is" and "with all faults" basis for evaluation purposes only. NXP Semiconductors, its affiliates and their suppliers expressly disclaim all warranties, whether express implied or statutory, including but not limited to the implied warranties of non-infringement, merchantability and fitness for a particular purpose. The entire risk as to the quality, or arising out of the use or performance, of this product remains with customer. In no event shall NXP Semiconductors, its affiliates or their suppliers be liable to customer for any special, indirect, consequential, punitive or incidental damages (including without limitation damages for loss of business, business interruption, loss of use, loss of data or information, and the like) arising out the use of or inability to use the product, whether or not based on tort (including negligence), strict liability, breach of contract, breach of warranty or any other theory, even if advised of the possibility of such damages. Notwithstanding any damages that customer might incur for any reason whatsoever (including without limitation, all damages referenced above and all direct or general damages), the entire liability of NXP Semiconductors, its affiliates and their suppliers and customer's exclusive remedy for all of the foregoing shall be limited to actual damages incurred by customer based on reasonable reliance up to the greater of the amount actually paid by customer for the product or five dollars (US\$5.00). The foregoing limitations, exclusions and disclaimers shall apply to the maximum extent permitted by applicable law, even if any remedy fails of its essential purpose. **Translations** — A non-English (translated) version of a document is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions. Security — While NXP Semiconductors has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP Semiconductors accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products. #### 10.3 Licenses #### Purchase of NXP ICs with NFC technology Purchase of an NXP Semiconductors IC that complies with one of the Near Field Communication (NFC) standards ISO/IEC 18092 and ISO/IEC 21481 does not convey an implied license under any patent right infringed by implementation of any of those standards. Purchase of NXP Semiconductors IC does not include a license to any NXP patent (or other IP right) covering combinations of those products with other products, whether hardware or software. AN12364 All information provided in this document is subject to legal disclaimers. © NXP B.V. 2020. All rights reserved. #### NTAG 5 - Bidirectional data exchange #### 10.4 Trademarks Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners. **I<sup>2</sup>C-bus** — logo is a trademark of NXP B.V. **NTAG** — is a trademark of NXP B.V. NTAG 5 - Bidirectional data exchange | | | IAC | |---|---|-----| | 4 | D | - | | а | ~ | | Tab. 1. Abbreviations ......3 NTAG 5 - Bidirectional data exchange | _ | | | 10 | ~ | | |---|---|---|----|---|---| | | Ю | ш | П | - | 9 | | | м | • | | ~ | ~ | | | | | | | | #### NTAG 5 - Bidirectional data exchange #### **Contents** | 1 | Abbreviations | 3 | |-----|-------------------------------------------------------------------------|---| | 2 | Introduction | 4 | | 2.1 | Potential applications | | | 3 | Interface Arbitration for memory access | 5 | | 4 | Normal Mode | 6 | | 5 | SRAM Mirror Mode | | | 6 | SRAM Pass-Through Mode | 8 | | 6.1 | Data Transfer mechanism RF to I2C Data transfer (RF reader to I2C host) | | | 6.2 | Data Transfer mechanism I2C to RF Data transfer (I2C host to RF reader) | | | 7 | PHDC mode | | | 8 | Configuration and SRAM memory password security | | | 9 | References | | | 10 | Legal information | | Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.