# ST25DV04K ST25DV16K ST25DV64K Datasheet # Dynamic NFC/RFID tag IC with 4-Kbit, 16-Kbit or 64-Kbit EEPROM, and fast transfer mode capability | Product status link | |---------------------| | ST25DV04K | | ST25DV16K | | ST25DV64K | #### **Features** #### **I2C** interface - Two-wire I<sup>2</sup>C serial interface supports 1MHz protocol - Single supply voltage: 1.8V to 5.5V - Multiple byte write programming (up to 256 bytes) #### **Contactless interface** - · Based on ISO/IEC 15693 - · NFC Forum Type 5 tag certified by the NFC Forum - Supports all ISO/IEC 15693 modulations, coding, sub-carrier modes and data rates - Custom fast read access up to 53 Kbit/s - Single and multiple blocks read (same for Extended commands) - Single and multiple blocks write (up to 4) (same for Extended commands) - Internal tuning capacitance: 28.5 pF #### Memory - Up to 64-kbits of EEPROM (depending on version) - I<sup>2</sup>C interface accesses bytes - RF interface accesses blocks of 4 bytes - Write time - From I<sup>2</sup>C: typical 5ms for 1 byte - From RF: typical 5ms for 1 block - Data retention: 40 years - · Write cycles endurance: - 1 million write cycles at 25 °C - 600k write cycles at 85 °C - 500k write cycles at 105 °C - 400k write cycles at 125 °C # Fast transfer mode - Fast data transfer between I<sup>2</sup>C and RF interfaces - Half-duplex 256-byte dedicated buffer # **Energy harvesting** Analog output pin to power external components #### **Data protection** - User memory: 1 to 4 configurable areas, protectable in read and/or write by three 64-bit passwords in RF and one 64-bit password in I<sup>2</sup>C - System configuration: protected in write by a 64-bit password in RF and a 64-bit password in I<sup>2</sup>C #### **GPO** - Interruption pin configurable on multiple RF events (field change, memory write, activity, Fast Transfer end, user set/reset/pulse) - Open Drain or CMOS output (depending on version) # Low power mode (10-ball and 12-pin package only) Input pin to trigger low power mode # RF management • RF command interpreter enabled/disabled from I<sup>2</sup>C host controller # Temperature range - Range 6: - From -40 to 85 °C - Range 8: - From -40 to 105 °C - (UDFPN8 and UDFPN12 only) - From -40 to 125 °C (SO8N and TSSOP8 only, 105 °C max on RF interface) #### **Package** - 8-pin, 10-ball and 12-pin packages - ECOPACK2<sup>®</sup> (RoHS compliant) DS10925 - Rev 9 page 2/200 # 1 Description The ST25DV04K, ST25DV16K and ST25DV64K devices are NFC RFID tags offering respectively 4 Kbit, 16 Kbit, and 64 Kbit of electrically erasable programmable memory (EEPROM). ST25DV04K, ST25DV16K and ST25DV64K offer two interfaces. The first one is an I<sup>2</sup>C serial link and can be operated from a DC power supply. The second one is a RF link activated when ST25DV04K, ST25DV16K or ST25DV64K act as a contactless memory powered by the received carrier electromagnetic wave. In I<sup>2</sup>C mode, the ST25DV04K, ST25DV16K and ST25DV64K user memory contains up to 512 bytes, 2048 bytes and 8192 bytes, which could be split in 4 flexible and protectable areas. In RF mode, following ISO/IEC 15693 or NFC forum type 5 recommendations, ST25DV04K, ST25DV16K and ST25DV64K user memory contains respectively up to 128 blocks, 512 blocks and 2048 blocks of 4 bytes which could be split in 4 flexible and protectable areas. ST25DV04K, ST25DV16K and ST25DV64K offer a fast transfer mode between the RF and contact worlds, thanks to a 256 bytes volatile buffer (also called Mailbox). In addition, the GPO pin of the ST25DV04K, ST25DV16K and ST25DV64K provide data informing the contact world about incoming events, like RF field detection, RF activity in progress or mailbox message availability. An energy harvesting feature is also proposed when external conditions make it possible. Herein after all concerned devices (ST25DV04K, ST25DV16K and ST25DV64K) are mentioned as ST25DVxxx. # 1.1 ST25DVxxx block diagram Figure 1. ST25DVxxx block diagram V<sub>DCG</sub> and LPD are included in 10 balls and 12 pins package only. DS10925 - Rev 9 page 3/200 # 1.2 ST25DVxxx packaging ST25DVxxx is provided in different packages: - 8 pins (S08N or TSSPOP8 or UFDFPN8) for the open drain version of Interrupt output - 10 balls (WLCSP) and 12 pins (UFDFPN12) for a CMOS interrupt output. This package includes an additional element that minimizes standby consumption. Table 1. Signal names | Signal name | Function | Direction | |----------------------|-------------------------------|-----------------------| | V_EH | Energy Harvesting | Power output | | GPO | Interrupt Output | Output | | SDA | Serial Data | I/O | | SCL | Serial Clock | Input | | AC0, AC1 | Antenna coils | - | | V <sub>CC</sub> | Supply voltage | Power | | V <sub>SS</sub> | Ground | - | | LPD (1) | Low power down mode | Input | | V <sub>DCG</sub> (1) | Supply voltage for GPO driver | Power | | NC | Not connected | Must be left floating | | EP (2) | Exposed Pad | Must be left floating | - 1. Available only on 10-ball and 12-pin packages. - 2. Available only on UFDPN8 and UFDFPN12 packages. Figure 2. ST25DVxxx 8-pin packages connections with open drain Interruption Output 1. Exposed Pad is only present on UFDFPN8 package. DS10925 - Rev 9 page 4/200 Figure 3. ST25DVxxx 12-pin package connections with Cmos interrupt output (GPO) 1. Exposed Pad is only present on UFDFPN12 package. Figure 4. ST25DVxxx 10-ball WLCSP package connections with Cmos interrupt output (GPO) DS10925 - Rev 9 page 5/200 # 2 Signal descriptions # 2.1 Serial link (SCL, SDA) #### 2.1.1 Serial clock (SCL) This input signal is used to strobe all data in and out of the ST25DVxxx. In applications where this signal is used by slave devices to synchronize the bus to a slower clock, the bus master must have an open drain output, and a pull-up resistor must be connected from Serial Clock (SCL) to $V_{CC}$ . See Section 9.2 I2C DC and AC parameters to know how to calculate the value of this pull-up resistor #### 2.1.2 Serial data (SDA) This bidirectional signal is used to transfer data in or out of the ST25DVxxx. It is an open drain output that may be wire-OR'ed with other open drain or open collector signals on the bus. A pull-up resistor must be connected from Serial Data (SDA) to $V_{CC}$ . (Figure 76. $I^2C$ Fast mode ( $f_C = 1$ MHz): maximum $R_{bus}$ value versus bus parasitic capacitance ( $C_{bus}$ ) indicates how the value of the pull-up resistor can be calculated). # 2.2 Power control (V<sub>CC</sub>, LPD, V<sub>SS</sub>) # 2.2.1 Supply voltage (V<sub>CC</sub>) This pin can be connected to an external DC supply voltage. Note: An internal voltage regulator allows the external voltage applied on $V_{CC}$ to supply the ST25DVxxx, while preventing the internal power supply (rectified RF waveforms) to output a DC voltage on the $V_{CC}$ pin. #### 2.2.2 Low Power Down (LPD) This input signal is used to control an internal 1.8 V regulator delivering ST25DVxxx internal supply. When LPD is high, this regulator is shut off and its consumption is reduced below $1\mu$ A. This regulator has a turn on time in range of 100us, to be added to the boot duration, before the device becomes fully operational. The impedance on LDP pin when set high doesn't exceed $5k\Omega$ . This feature is only available on the 10-ball and 12-pin ST25DVxxx package. The LPD pin is internally pulled-down. #### 2.2.3 Ground (V<sub>SS</sub>) V<sub>SS</sub> is the reference for the V<sub>CC</sub> and V<sub>DCG</sub> supply voltages and V\_EH analog output voltage. DS10925 - Rev 9 page 6/200 # 2.3 RF link (AC0 AC1) #### 2.3.1 Antenna coil (AC0, AC1) These inputs are used to connect the ST25DVxxx device to an external coil exclusively. It is advised not to connect any other DC or AC path to AC0 or AC1. When correctly tuned, the coil is used to power and access the device using the ISO/IEC 15693 and ISO 18000-3 mode 1 protocols. # 2.4 Process control (V<sub>DCG</sub>, GPO) #### 2.4.1 Driver Supply voltage (V<sub>DCG</sub>) This pin, available only with ST25DVxx-JF version, can be connected to an external DC supply voltage. It only supplies the GPO driver block. ST25DVxxx cannot be powered by $V_{DCG}$ . If $V_{DCG}$ is left floating, no information will be available on GPO pin. # 2.4.2 General purpose output (GPO) The ST25DVxxx features a configurable output GPO pin used to provide RF activity information to an external device. ST25DVxx-IE offers a GPO open drain. This GPO pin must be connected to an external pull-up resistor (> $4.7 \text{ K}\Omega$ ) to operate. The interrupt consists in pulling the state to a low level or outputting a low-level pulse on GPO pin. ST25DVxx-JF offers a GPO CMOS output, which requires to connect $V_{DCG}$ pin to an external power supply. The interrupt consists in setting the state to a high level or outputting a positive pulse on the GPO pin. GPO pin is a configurable output signal, and can mix several Interruption modes. By default, the GPO register sets the interruption mode as a RF Field Change detector. It is able to raise various events like RF Activity, Memory Write completion, or fast transfer actions. It can authorize the RF side to directly drive GPO pin using the Manage GPO command to set the output state or emit a single pulse (for example, to wake up an application.). See Section 5.2 GPO for details. # 2.5 Energy harvesting analog output (V\_EH) This analog output pin is used to deliver the analog voltage V\_EH available when the Energy harvesting mode is enabled and if the RF field strength is sufficient. When the Energy harvesting mode is disabled or the RF field strength is not sufficient, V\_EH pin is in High-Z state (See Section 5.3 Energy Harvesting (EH) for details). Energy harvesting voltage output is not regulated. DS10925 - Rev 9 page 7/200 # 3 Power management #### 3.1 Wired interface #### Operating supply voltage V<sub>CC</sub> In contact mode, prior to selecting the memory and issuing instructions to it, a valid and stable $V_{CC}$ voltage within the specified [ $V_{CC}$ (min), $V_{CC}$ (max)] range must be applied (see Table 243. $I^2C$ operating conditions). To maintain a stable DC supply voltage, it is recommended to decouple the $V_{CC}$ line with a suitable capacitor (usually of the order of 10 nF and 100 nF) close to the $V_{CC}/V_{SS}$ package pins. This voltage must remain stable and valid until the end of the transmission of the instruction and, for a Write instruction, until the completion of the internal I²C write cycle ( $t_W$ ). Instructions are not taken into account until completion of ST25DVxxx's boot sequence (see Figure 5. ST25DVxxx power-up sequence (No RF field, LPD pin tied to $V_{SS}$ or package without LPD pin) ). Figure 5. ST25DVxxx power-up sequence (No RF field, LPD pin tied to V<sub>SS</sub> or package without LPD pin) #### Power-up conditions When the power supply is turned on, $V_{CC}$ rises from $V_{SS}$ to $V_{CC}$ . The $V_{CC}$ rise time must not vary faster than 1V/us. #### Device reset in I<sup>2</sup>C mode In order to prevent inadvertent write operations during power-up, a power-on reset (POR) circuit is included. At power-up (continuous rise of $V_{CC}$ ), the ST25DVxxx does not respond to any $I^2C$ instruction until $V_{CC}$ has reached the power-on reset threshold voltage (this threshold is lower than the minimum $V_{CC}$ operating voltage defined in Table 243. $I^2C$ operating conditions). When $V_{CC}$ passes over the POR threshold, the device is reset and enters the Standby power mode. However, the device must not be accessed until $V_{CC}$ has reached a valid and stable $V_{CC}$ voltage within the specified $[V_{CC(min)}, V_{CC(max)}]$ range and t\_boot time necessary to ST25DVxxx set-up has passed. In the version supporting LPD pin, the boot will take place only when LPD goes low. In a similar way, during power-down (continuous decrease in $V_{CC}$ ), as soon as $V_{CC}$ drops below the power-on reset threshold voltage, the device stops responding to any instruction sent to it, and I<sup>2</sup>C address counter is reset. DS10925 - Rev 9 page 8/200 #### Power-down mode During power-down (continuous decay of $V_{CC}$ ), the device must be in Standby power mode (mode reached after decoding a Stop condition, assuming that there is no internal write cycle in progress). #### 3.2 Contactless interface #### Device set in RF mode To ensure a proper boot of the RF circuitry, the RF field must be turned ON without any modulation for a minimum period of time $t_{RF\_ON}$ . Before this time, ST25DVxxx will ignore all received RF commands. (See Figure 6. ST25DVxxx RF power-up sequence (No DC supply)). #### Device reset in RF mode To ensure a proper reset of the RF circuitry, the RF field must be turned off (100% modulation) for a minimum $t_{\rm RF\ OFF}$ period of time. The RF access can be temporarily or indefinitely disabled by setting the appropriate value in the RF disable register. Figure 6. ST25DVxxx RF power-up sequence (No DC supply) DS10925 - Rev 9 page 9/200 # 4 Memory management # 4.1 Memory organization overview The ST25DVxxx memory is divided in four main memory areas: - User memory - Dynamic registers - · Fast transfer mode buffer - System configuration area The ST25DVxxx user memory can be divided into 4 flexible user areas. Each area can be individually read - and/or - write-protected with one out of three specific 64-bit password. The ST25DVxxx dynamic registers are accessible by RF or I<sup>2</sup>C host and provide dynamic activity status or allow temporary activation or deactivation of some ST25DVxxx features. The ST25DVxxx also provides a 256 byte fast transfer mode buffer, acting as a mailbox between RF and I<sup>2</sup>C interface, allowing fast data transfer between contact and contactless worlds. Finally, the ST25DVxxx system configuration area contains static registers to configure all ST25DVxxx features, which can be tuned by user. Its access is protected by a 64 bit configuration password. This system configuration area also includes read only device information such as IC reference, memory size or IC revision, as well as a 64-bit block that is used to store the 64-bit unique identifier (UID), and the AFI (default 00h) and DSFID (default 00h) registers. The UID is compliant with the ISO 15693 description, and its value is used during the anticollision sequence (Inventory). The UID value is written by ST on the production line. The AFI register stores the application family identifier. The DSFID register stores the data storage family identifier used in the anticollision algorithm. The system configuration area includes five additional 64-bit blocks that store an I<sup>2</sup>C password plus three RF user area access passwords and a RF configuration password. DS10925 - Rev 9 page 10/200 Figure 7. Memory organization # 4.2 User memory User memory is accessible from both RF contactless interface and I<sup>2</sup>C wired interface. From RF interface, user memory is addressed as Blocks of 4 bytes, starting at address 0. RF extended read and write commands can be used to address all ST25DVxxx memory blocks. Other read and write commands can only address up to block FFh. From $I^2C$ interface, user memory is addressed as Bytes, starting at address 0. Device select must be set with E2=0. User memory can be read in continuity. Unlike the RF interface, there is no roll-over when the requested address reaches the end of the memory capacity. Table 2 shows how memory is seen from RF interface and from I<sup>2</sup>C interface. DS10925 - Rev 9 page 11/200 Table 2. User memory as seen by RF and by I<sup>2</sup>C | RF command<br>(block addressing) | | User n | nemory | | I <sup>2</sup> C command<br>(byte addressing) | |----------------------------------------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|---------------------------------------------------| | | | RF block | k (00)00h | | | | | I <sup>2</sup> C byte<br>0003h | I <sup>2</sup> C byte<br>0002h | I <sup>2</sup> C byte<br>0001h | I <sup>2</sup> C byte<br>0000h | | | Read Single Block | | RF block | (00)01h | | | | Read Multiple Blocks Fast Read Single Block | I <sup>2</sup> C byte<br>0007h | I <sup>2</sup> C byte<br>0006h | I <sup>2</sup> C byte<br>0005h | I <sup>2</sup> C byte<br>0004h | | | Fast Read Multiple Blocks | | RF block | k (00)02h | | | | Write Single Block Write Multiple Blocks Ext Read Single Block | I <sup>2</sup> C byte<br>000Bh | I <sup>2</sup> C byte<br>000Ah | I <sup>2</sup> C byte<br>0009h | I <sup>2</sup> C byte<br>0008h | | | Ext Read Multiple Blocks | | •• | | | | | Fast Ext Read Single Block | | RF block | (00)7Fh <sup>(1)</sup> | | | | Fast Ext Read Multi. Blocks | I <sup>2</sup> C byte | I <sup>2</sup> C byte | I <sup>2</sup> C byte | I <sup>2</sup> C byte | | | Ext Write Single Block | 01FFh | 01FEh | 01FDh | 01FCh | 120 Deed ee man | | Ext Write Multiple Blocks | | | | | I <sup>2</sup> C Read command | | | | RF block | (00)FFh <sup>(2)</sup> | | I <sup>2</sup> C Write command Device select E2=0 | | | I <sup>2</sup> C byte | I <sup>2</sup> C byte | I <sup>2</sup> C byte | I <sup>2</sup> C byte | Device select L2-0 | | | 03FFh | 03FEh | 03FDh | 03FCh | | | | | RF bloc | k 0100h | | | | | I <sup>2</sup> C byte | I <sup>2</sup> C byte | I <sup>2</sup> C byte | I <sup>2</sup> C byte | | | | 0403h | 0402h | 0401h | 0400h | | | Ext Read Single Block | | | ••• | | | | Ext Read Multiple Blocks Fast Ext Read Single Block | | RF block | 01FFh (3) | | | | Fast Ext Read Multi. Blocks | I <sup>2</sup> C byte<br>07FFh | I <sup>2</sup> C byte<br>07FEh | I <sup>2</sup> C byte<br>07FDh | I <sup>2</sup> C byte<br>07FCh | | | Ext Write Single Block | | | | | | | Ext Write Multiple Blocks | | RF block | 07FFh (4) | | | | | I <sup>2</sup> C byte<br>1FFFh | I <sup>2</sup> C byte | I <sup>2</sup> C byte<br>1FFDh | I <sup>2</sup> C byte<br>1FFCh | | - 1. Last block of user memory in ST25DV04K-XX.. - Last block accessible with Read Single Block, Read Multiple Blocks, Fast Read Single Block, Fast Read Multiple Blocks, Write Single Block and Write Multiple Blocks RF commands. - 3. Last block of user memory in ST25DV16K-XX. - 4. Last block of user memory in ST25DV64K-XX. Note: In the factory all blocks of user memory are initialized to 00h. DS10925 - Rev 9 page 12/200 #### 4.2.1 User memory areas The user memory can be split into different areas, each one with a distinct access privilege. RF and I<sup>2</sup>C read and write commands are legal only within a same zone: - In RF, a multiple read or a multiple write command is not executed and returns the error code 0Fh if addresses cross the area borders. - In I<sup>2</sup>C, a read data always return FFh after crossing an area border. A write command is not acknowledged and not executed if the command crosses the area border. Each user memory area is defined by its ending block address ENDA<sub>i</sub>. The starting block address is defined by the end of the preceding area. There are three ENDA<sub>i</sub> registers in the configuration system memory, used to define the end block addresses of Area 1, Area 2 and Area 3. The end of Area 4 is always the last block of memory and is not configurable. Figure 8. ST25DVxxx user memory areas # Areas limit registers Area1 (8 Blocks/32 Bytes minimum) ENDA1 Area2 ENDA2 Area3 ENDA3 Area4 Last Block/Byte of user memory # ST25DV user memory On factory delivery all ENDA<sub>i</sub> are set to maximum value, only Area1 exists and includes the full user memory. A granularity of 8 Blocks (32 Bytes) is offered to code area ending points. An area's end limit is coded as followed in ENDA<sub>i</sub> registers: - Last RF block address of area = 8 x ENDA<sub>i</sub> + 7 => ENDA<sub>i</sub> = int(Last Area<sub>i</sub> RF block address / 8) - Last I<sup>2</sup>C byte address of area = 32 \* ENDA<sub>i</sub> + 31 => ENDA<sub>i</sub> = int(Last Area<sub>i</sub> I<sup>2</sup>C byte address / 32) - As a consequence, ENDA1 = 0 minimum size of Area 1 is 8 blocks (32 Bytes). Table 3. Maximum user memory Block and Byte addresses and ENDA; value | Device | Last user memory block address<br>seen by RF | Last user memory byte address seen by I <sup>2</sup> C | Maximum ENDA <sub>i</sub> value | |--------------|----------------------------------------------|--------------------------------------------------------|---------------------------------| | ST25DV04K-xx | 007Fh | 01FFh | 0Fh | | ST25DV16K-xx | 01FFh | 07FFh | 3Fh | | ST25DV64K-xx | 07FFh | 1FFFh | FFh | DS10925 - Rev 9 page 13/200 | Table 4. Areas and limit cal | ulation from | <b>ENDA</b> <sub>i</sub> registers | |------------------------------|--------------|------------------------------------| |------------------------------|--------------|------------------------------------| | Area | Seen from RF interface | Seen from I <sup>2</sup> C interface | |--------|------------------------|--------------------------------------| | | Block 0000h | Byte 0000h | | Area 1 | | | | | Block (ENDA1*8)+7 | Byte (ENDA1*32)+31 | | | Block (ENDA1+1)*8 | Byte (ENDA1+1)*32 | | Area 2 | | | | | Block (ENDA2*8)+7 | Byte (ENDA2*32)+31 | | | Block (ENDA2+1)*8 | Byte (ENDA2+1)*32 | | Area 3 | | | | | Block (ENDA3*8)+7 | Byte (ENDA3*32)+31 | | | Block (ENDA3+1)*8 | Byte (ENDA3+1)*32 | | Area 4 | | | | | Last memory Block | Last memory Byte | Organization of user memory in areas have the following characteristics: - At least one area exists (Area1), starting at Block/Byte address 0000h and finishing at ENDA1, with ENDA1 = ENDA2 = ENDA3 = End of user memory (factory setting). - Two Areas could be defined by setting ENDA1 < ENDA2 = ENDA3 = End of user memory.</li> - Three Areas may be defined by setting ENDA1 < ENDA2 < ENDA3 = End of user memory.</li> - A maximum of four areas may be defined by setting ENDA1 < ENDA2 < ENDA3 < End of user memory.</li> - Area 1 specificities - Start of Area1 is always Block/Byte address 0000h. - Area1 minimum size is 8 Blocks (32 Bytes) when ENDA1 = 00h. - Area1 is always readable. - The last area always finishes on the last user memory Block/Byte address (ENDA4 doesn't exist). - All areas are contiguous: end of Area(n) + one Block/Byte address is always start of Area(n+1). #### Area size programming RF user must first open the RF configuration security session to write ENDAi registers. I<sup>2</sup>C host must first open I<sup>2</sup>C security session to write ENDAi registers. When programming an ENDAi register, the following rule must be respected: ENDAi-1 < ENDAi ≤ ENDAi+1 = End of memory.</li> This means that prior to programming any ENDAi register, its successor (ENDAi+1) must first be programmed to the last Block/Byte of memory: - Successful ENDA3 programming condition: ENDA2 < ENDA3 ≤ End of user memory</li> - Successful ENDA2 programming condition: ENDA1 < ENDA2 ≤ ENDA3 = End of user memory</li> - Successful ENDA1 programming condition: ENDA1 ≤ ENDA2 = ENDA 3 = End of user memory If this rule is not respected, an error 0Fh is returned in RF, NoAck is returned in I2C, and programming is not done. In order to respect this rule, the following procedure is recommended when programming Areas size (even for changing only one Area size): DS10925 - Rev 9 page 14/200 - 1. Ends of Areas 3 and 2 must first be set to the end of memory while respecting the following order: - a. If ENDA3 ≠ end of user memory, then set ENDA3 = end of memory; else, do not write ENDA3. - b. If ENDA2 ≠ end of user memory, then set ENDA2 = end of memory; else, do not write ENDA2. - 2. Then, desired area limits can be set respecting the following order: - a. Set new ENDA1 value. - b. Set new ENDA2 value, with ENDA2 > ENDA1 - c. Set new ENDA3 value, with ENDA3 > ENDA2 Example of successive user memory area setting (for a ST25DV64K-xx): - Initial state, 2 Areas are defined: - a. ENDA1 = 10h (Last block of Area 1: (10h x 8) + 7 = 0087h) - b. ENDA2 = FFh (Last block of Area 2: (FFh x 8) + 7 = 07FFh) - c. ENDA3 = FFh (No Area 3) - Area 1 from Block 0000h to 0087h (136 Blocks) - Area 2 from Block 0088h to 07FFh (1912 Blocks) - There is no Area 3 - There is no Area 4 - 2. Split of user memory in four areas: - a. ENDA3 is not updated as it is already set to end of memory - b. ENDA2 is not updated as it is already set to end of memory - c. Set ENDA1 = 3Fh (Last block of Area 1: $(3Fh \times 8) + 7 = 01FFh$ ) - d. Set ENDA2 = 5Fh (Last block of Area 1: (5Fh x 8) + 7 = 02FFh) - e. Set ENDA3 = BFh (Last block of Area 1: (BFh x 8) + 7 = 05FFh) - Area1 from Block 0000h to 01FFh (512 Blocks) - Area2 from Block 0200h to 02FFh (256 Blocks) - Area3 from Block 0300h to 05FFh (768 Blocks) - Area4 from Block 0600h to 07FFh (512 Blocks). - 3. Return to a split in two equal areas: - a. Set ENDA3 = FFh - b. Set ENDA2 = FFh - c. Set ENDA1 = 7Fh (Last block of Area 1: (7Fh x 8) + 7 = 03FFh) - Area1 from Block 0000h to 03FFh (1024 Blocks) - Area2 from Block 0400h to 07FFh (1024 Blocks) - There is no Area3 - There is no Area 4 Programming ENDA3 to FFh in step 2.a would have resulted in into an error, since rule ENDAi-1 < ENDAi would not been respected (ENDA2 = ENDA3 in that case). #### Registers for user memory area configuration Table 5. ENDA1 access | RF | | | 12C | |--------------------------------------------------------------------------------------|------------------------------------------|----------------|---------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @05h | R always, W if RF configuration security | E2 = 1, 0005h | R always, W if I2C security session is open | | Write Configuration (cmd code A1h) @05h session is open and configuration not locked | | E2 = 1, 000511 | session is open | DS10925 - Rev 9 page 15/200 # Table 6. ENDA1 | Bit | Name | Function | Factory Value | |-------|-------------|---------------------------------------------------------------------|-------------------| | | | End Area 1 = 8*ENDA1+7 when expressed in blocks (RF) | ST25DV04K-xx: 0Fh | | b7-b0 | b7-b0 ENDA1 | ST25DV16K-xx: 3Fh | | | | | End Area 1 = 32*ENDA1+31 when expressed in bytes (I <sup>2</sup> C) | ST25DV64K-xx: FFh | Note: Refer to Table 11. System configuration memory map for ENDA1 register. #### Table 7. ENDA2 access | | I2C | | | |-----------------------------------------|----------------------------------------------|----------------|---------------------------------------------| | Command | Type A | | Туре | | Read Configuration (cmd code A0h) @07h | R always, W if RF configuration security | E2 = 1, 0007h | R always, W if I2C security session is open | | Write Configuration (cmd code A1h) @07h | session is open and configuration not locked | E2 = 1, 000711 | session is open | # Table 8. ENDA2 | Bit | Name | Function | Factory Value | |-------|-------------|-----------------------------------------------------------------------|-------------------| | | | End Area 2 = 8 x ENDA2 + 7 when expressed in blocks (RF) | ST25DV04K-xx: 0Fh | | b7-b0 | b7-b0 ENDA2 | | ST25DV16K-xx: 3Fh | | | | End Area 2 = 32*ENDA2 + 31 when expressed in bytes (I <sup>2</sup> C) | ST25DV64K-xx: FFh | Note: Refer to Table 11. System configuration memory map for ENDA2 register. # Table 9. ENDA3 access | RF | | | 12C | |-----------------------------------------|----------------------------------------------|----------------|---------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @09h | R always, W if RF configuration security | E2 = 1, 0009h | R always, W if I2C security session is open | | Write Configuration (cmd code A1h) @09h | session is open and configuration not locked | LZ = 1, 000911 | session is open | # Table 10. ENDA3 | Bit | Name | Function | Factory Value | |-------|-------------|-------------------------------------------------------------------------|-------------------| | | | End Area 3 = 8 x ENDA3 + 7 when expressed in blocks (RF) | ST25DV04K-xx: 0Fh | | b7-b0 | b7-b0 ENDA3 | , | ST25DV16K-xx: 3Fh | | | | End Area 3 = 32 x ENDA3 + 31 when expressed in bytes (I <sup>2</sup> C) | ST25DV64K-xx: FFh | Note: Refer to Table 11. System configuration memory map for ENDA3 register. DS10925 - Rev 9 page 16/200 # 4.3 System configuration area In addition to EEPROM user memory, ST25DVxxx includes a set of static registers located in the system configuration area memory (EEPROM nonvolatile registers). Those registers are set during device configuration (i.e.: area extension), or by the application (i.e.: area protection). Static registers content is read during the boot sequence and define basic ST25DVxxx behavior. In RF, the static registers located in the system configuration area can be accessed via dedicated Read Configuration and Write Configuration commands, with a pointer acting as the register address. The RF configuration security session must first be open, by presenting a valid RF configuration password, to grant write access to system configuration registers. The system configuration area write access by RF can also be deactivated by I<sup>2</sup>C host. In I<sup>2</sup>C static registers located in the system configuration area can be accessed with I<sup>2</sup>C read and write commands with device select E2=1. Readable system areas could be read in continuity. I<sup>2</sup>C security session must first be open, by presenting a valid I<sup>2</sup>C password, to grant write access to system configuration registers. Table 11. System configuration memory map shows the complete map of the system configuration area, as seen by RF and $I^2C$ interface. Table 11. System configuration memory map | RF access | | Static Register | | I <sup>2</sup> C access | | | |-----------|-------------------|-----------------|-----------------------------------------------------------|--------------------------------------------------|---------|-------------------| | Address | Туре | Name | Function | Device select | Address | Туре | | 00h | RW (1) | GPO | Enable/disable ITs on GPO | E2=1 | 0000h | RW (2) | | 01h | RW <sup>(1)</sup> | IT_TIME | Interruption pulse duration | E2=1 | 0001h | RW <sup>(2)</sup> | | 02h | RW <sup>(1)</sup> | EH_MODE | Energy Harvesting default strategy after Power ON | E2=1 | 0002h | RW <sup>(2)</sup> | | 03h | RW <sup>(1)</sup> | RF_MNGT | RF interface state after Power ON | E2=1 | 0003h | RW <sup>(2)</sup> | | 04h | RW <sup>(1)</sup> | RFA1SS | Area1 RF access protection | E2=1 | 0004h | RW <sup>(2)</sup> | | 05h | RW <sup>(1)</sup> | ENDA1 | Area 1 ending point | E2=1 | 0005h | RW <sup>(2)</sup> | | 06h | RW <sup>(1)</sup> | RFA2SS | Area2 RF access protection | E2=1 | 0006h | RW <sup>(2)</sup> | | 07h | RW <sup>(1)</sup> | ENDA2 | Area 2 ending point | E2=1 | 0007h | RW <sup>(2)</sup> | | 08h | RW <sup>(1)</sup> | RFA3SS | Area3 RF access protection | E2=1 | 0008h | RW <sup>(2)</sup> | | 09h | RW <sup>(1)</sup> | ENDA3 | Area 3 ending point | E2=1 | 0009h | RW <sup>(2)</sup> | | 0Ah | RW <sup>(1)</sup> | RFA4SS | rea4 RF access protection E2=1 | | 000Ah | RW <sup>(2)</sup> | | No a | ccess | I2CSS | Area 1 to 4 I <sup>2</sup> C access protection | E2=1 | 000Bh | RW <sup>(2)</sup> | | N/A | RW (3) (4) | LOCK_CCFILE | Blocks 0 and 1 RF Write protection | E2=1 | 000Ch | RW <sup>(2)</sup> | | 0Dh | RW <sup>(1)</sup> | MB_MODE | Fast transfer mode state after power ON | E2=1 | 000Dh | RW <sup>(2)</sup> | | 0Eh | RW <sup>(1)</sup> | MB_WDG | Maximum time before the message is automatically released | E2=1 | 000Eh | RW <sup>(2)</sup> | | 0Fh | RW <sup>(1)</sup> | LOCK_CFG | Protect RF Write to system configuration registers | E2=1 | 000Fh | RW <sup>(2)</sup> | | N/A | WO <sup>(5)</sup> | LOCK_DSFID | DSFID lock status | E2=1 | 0010h | RO | | NA | WO <sup>(6)</sup> | LOCK_AFI | AFI lock status | l lock status E2=1 00 | | RO | | N/A | RW <sup>(5)</sup> | DSFID | DSFID value E2=1 001: | | 0012h | RO | | N/A | RW <sup>(6)</sup> | AFI | AFI value E2=1 0013 | | 0013h | RO | | N/A | RO | MEM_SIZE | Memory size value in blocks, 2 bytes | emory size value in blocks, 2 bytes E2=1 0014h t | | RO | | IN/A | RO | BLK_SIZE | Block size value in bytes | E2=1 | 0016h | RO | | N/A | RO | IC_REF | IC reference value | E2=1 | 0017h | RO | DS10925 - Rev 9 page 17/200 | RF ac | RF access | | Static Register | I <sup>2</sup> C access | | | |-----------|--------------------------------|----------|-----------------------------------------------------|-------------------------|----------------|-----------------------------------| | Address | Address Type Name | | Function | Device select | Address | Туре | | NA | RO | UID | Unique identifier, 8 bytes | E2=1 | 0018h to 001Fh | RO | | | | IC_REV | IC revision | E2=1 | 0020h | RO | | | | - | ST Reserved | E2=1 | 0021h | RO | | No access | | - | ST Reserved | E2=1 0022h R0 | | RO | | - | | - | ST Reserved | E2=1 | 0023h | RO | | I2C_PWD | | I2C_PWD | I <sup>2</sup> C security session password, 8 bytes | E2=1 | 0900h to 0907h | R/W <sup>(7)</sup> <sup>(8)</sup> | | N/A | WO <sup>(9)</sup> | RF_PWD_0 | RF configuration security session password, 8 bytes | | | | | N/A | N/A WO <sup>(9)</sup> RF_PWD_1 | | RF user security session password 1, 8 bytes | | | | | N/A | WO <sup>(9)</sup> | RF_PWD_2 | RF user security session password 2, 8 bytes | No access | | | | N/A | WO <sup>(9)</sup> | RF_PWD_3 | RF user security session password 3, 8 bytes | | | | - Write access is granted if RF configuration security session is open and configuration is not locked (LOCK\_CFG register equals to 0). - 2. Write access if $I^2C$ security session is open. - 3. Write access to bit 0 if Block 00h is not already locked and to bit 1 if Block 01h is not already locked. - 4. LOCK\_CCFILE content is only readable through reading the Block Security Status of blocks 00h and 001h (see Section 5.6.3 User memory protection) - 5. Write access if DSFID is not locked - 6. Write access if AFI is not locked. - 7. Write access with $I^2C$ Write Password command, only after presenting a correct $I^2C$ password. - 8. Read access is granted if I<sup>2</sup>C security session is open. - 9. Write access only if corresponding RF security session is open. DS10925 - Rev 9 page 18/200 # 4.4 Dynamic configuration ST25DV has a set of dynamic registers that allow temporary modification of its behavior or report on its activity. Dynamic registers are volatile and not restored to their previous values after POR. Some static registers have an image in dynamic registers: dynamic register value is initialized with the static register value and may be updated by the application to modify the device behavior temporarily (i.e.: set reset of Energy Harvesting). When a valid change occurs in a static register, in RF or I<sup>2</sup>C, the corresponding dynamic register is automatically updated. Other, dynamic registers, automatically updated, contain indication on ST25DV activity. (i.e.: IT\_STS\_Dyn gives the interruption's status or MB\_CTRL\_Dyn gives the fast transfer mode mailbox control). In RF, dynamic registers can be accessed via dedicated (Fast) Read Dynamic Configuration and (Fast) Write Dynamic Configuration commands, with a pointer acting as the register address. No password is needed to access dynamic registers. In I<sup>2</sup>C, dynamic registers can be accessed with I<sup>2</sup>C read and write commands with device select E2=0. Dynamic registers can be read in continuity. Dynamic registers and fast transfer mode mailbox can be read in continuity, but not written in continuity. No password is needed to access dynamic registers. Table 12. Dynamic registers memory map shows the complete map of dynamic registers, as seen by RF interface and by $I^2C$ interface. RF access **Dynamic Registers** I<sup>2</sup>C access **Device Address** Type Name **Function Address** Type select GPO\_CTRL\_Dyn GPO control E2 = 02000h R/W 00h 2001h No access ST Reserved F2 = 0RO 02h R/W EH\_CTRL\_Dyn Energy Harvesting management & usage status E2 = 02002h R/W RF MNGT Dyn RF interface usage management E2 = 02003h R/W No access I2C\_SSO\_Dyn I<sup>2</sup>C security session status E2 = 02004h RO IT\_STS\_Dyn Interruptions Status E2 = 02005h RO 0Dh R/W 2006h R/W MB\_CTRL\_Dyn Fast transfer mode control and status E2 = 0NA E2 = 02007h RO MB LEN Dyn length of fast transfer mode message RO Table 12. Dynamic registers memory map DS10925 - Rev 9 page 19/200 #### 4.5 Fast transfer mode mailbox ST25DVxxx fast transfer mode uses a dedicated mailbox buffer for transferring messages between RF and I<sup>2</sup>C worlds. This mailbox contains up to 256 Bytes of data which are filled from the first byte. Fast transfer mode mailbox is accessed in bytes from both RF and I<sup>2</sup>C. In RF, mailbox is read via a dedicated (Fast) Read Message command. Read can start from any address value inside the mailbox, between 00h and FFh. Writing in the mailbox is done via the (Fast) Write Message command in one shot, always starting at mailbox address 00h. No password is needed to access mailbox from RF, but fast transfer mode must be enabled. In I<sup>2</sup>C, mailbox read can start from any address value between 2008h and 2107h. Write mailbox MUST start from address 2008h to a max of 2107h. No password is needed to access mailbox from I<sup>2</sup>C, but fast transfer mode must be enabled. Table 13. Fast transfer mode mailbox memory map shows the map of fast transfer mode mailbox, as seen by RF interface and by I<sup>2</sup>C interface. Table 13. Fast transfer mode mailbox memory map | RF access | | | Fast transfer mode buffer | | I <sup>2</sup> C access | | |-----------|------|-----------------|---------------------------------------|------------------|-------------------------|------| | Address | Туре | Name | Function | Device<br>select | Address | Туре | | 00h | R/W | MB_Dyn Byte 0 | | E2 = 0 | 2008h | R/W | | 01h | R/W | MB_Dyn Byte 1 | Fast transfer mode buffer (256-Bytes) | E2 = 0 | 2009h | R/W | | | | | | E2 = 0 | | | | FEh | R/W | MB_Dyn Byte 254 | | E2 = 0 | 2106h | R/W | | FFh | R/W | MB_Dyn Byte 255 | | E2 = 0 | 2107h | R/W | DS10925 - Rev 9 page 20/200 # 5 ST25DVxxx specific features ST25DVxxx offers the following features: - A fast transfer mode (FTM), to achieve a fast link between RF and contact worlds, via a 256 byte buffer called Mailbox. This mailbox dynamic buffer of 256 byte can be filled or emptied via either RF or I<sup>2</sup>C. - A GPO pin, which indicates incoming event to the contact side, like RF Field changes, RF activity in progress, RF writing completion or Mailbox message availability. - An Energy Harvesting element to deliver μW of power when external conditions make it possible. - RF management, which allows ST25DVxxx to ignore RF requests. All these features can be programmed by setting static and/or dynamic registers of the ST25DVxxx. ST25DVxxx can be partially customized using configuration registers located in the $E^2$ system area. These registers are: - dedicated to Data Memory organization and protection ENDA<sub>i</sub>, I2CSS, RFAiSS, LOCK\_CCFILE. - dedicated to fast transfer mode MB WDG, MB MODE - dedicated to observation, GPO, IT TIME - dedicated to RF, RF\_MNGT, EH\_MODE - · dedicated the device's structure LOCK CFG A set of additional registers allows to identify and customize the product (DSFID, AFI, IC REF, etc.). #### In I2C, Read accesses to the static configuration register is always allowed, except for passwords. For dedicated registers, write access is granted after prior successful presentation of the I<sup>2</sup>C password. Configuration register are located from @00h to 0Fh in the system area (device code 111) #### In RF Dedicated commands Read Configuration and Write Configuration must be used to access the static configuration registers. Update is only possible when the access right was granted by presenting the RF configuration password (RF\_PWD\_0), and if the system configuration was not previously locked by the I<sup>2</sup>C host (LOCK\_CFG=1), which acts as security master. After any valid write access to the static configuration registers, the new configuration is immediately applied. Some of the static registers have a dynamic image (notice \_Dyn) preset with the static register value: GPO\_CTRL\_Dyn, EH\_CTRL\_Dyn, RF\_MNGT\_Dyn and MB\_CTRL\_Dyn. When it exists, ST25DVxxx uses the dynamic configuration register to manage its processes. A dynamic configuration register updated by the application will recover its default static value after a Power On Reset (POR). Other dynamic registers are dedicated to process monitoring: - I2C\_SSO\_Dyn is dedicated to data memory protection - MB\_LEN\_Dyn, MB\_CTRL\_Dyn are dedicated to fast transfer mode - IT STS Dyn is dedicated to interrupt In $I^2C$ , read and write of the Dynamic registers is done using usual $I^2C$ read & write command at dedicated address. (E2 =0 in device select). In RF read or write accesses to the Dynamic registers are associated to the dedicated commands, Read Dynamic Configuration, Write Dynamic Configuration and Read Message Length. DS10925 - Rev 9 page 21/200 # 5.1 Fast transfer mode (FTM) # 5.1.1 Fast transfer mode registers **Static Registers** Table 14. MB\_MODE access | RF | I2C | | | |--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------|---------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @0Dh Write Configuration (cmd code A1h) @0Dh | R always, W if RF configuration security session is open and configuration not locked | E2=1, 000Dh | R always, W if I2C security session is open | # Table 15. MB\_MODE | Bit | Name | Function | Factory Value | |-------|---------|--------------------------------------------------------------------------------------------|---------------| | b0 | MB_MODE | 0: Enabling fast transfer mode is forbidden. 1: Enabling fast transfer mode is authorized. | 0b | | b7-b1 | RFU | - | 0000000b | Note: Refer to Table 11. System configuration memory map for the MB\_MODE register. # Table 16. MB\_WDG access | RF | | 12C | | |--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @0Eh Write Configuration (cmd code A1h) @0Eh | R always, W if RF configuration security session is open and configuration not locked | E2=1, 000Eh | R always, W if I <sup>2</sup> C security session is open | #### Table 17. MB\_WDG | Bit | Name | Function | Factory Value | |-------|--------|---------------------------------------------------------------------------------------------------------|---------------| | b2-b0 | MB_WDG | Watch dog duration = 2 <sup>(MB_WDG-1)</sup> x30ms±6 If MD_WDG = 0, then watchdog duration is infinite | 111b | | b7-b3 | RFU | - | 00000b | Note: Refer to Table 11. System configuration memory map for the MB\_WDG register. DS10925 - Rev 9 page 22/200 # **Dynamic Registers** Table 18. MB\_CTRL\_Dyn access | RF | I2C | | | |------------------------------------------------------|------------------------|----------------|------------------------| | Command | Туре | Address | Туре | | Read Dynamic Configuration (cmd code ADh) @0Dh | | | | | Fast Read Dynamic Configuration (cmd code CDh) @0Dh | b0: R always, W always | E2 = 0. 2006h | b0: R always, W always | | Write Dynamic Configuration (cmd code AEh) @0Dh | b7-b1: RO | E2 - 0, 200011 | b7-b1: RO | | Fast Write Dynamic Configuration (cmd code CEh) @0Dh | | | | # Table 19. MB\_CTRL\_Dyn | Bit | Name | Function | Factory Value | |-----|------------------|--------------------------------------------------------------------------------------------------------------------------|---------------| | b0 | MB_EN (1) | 0: Disable FTM, FTM mailbox is empty 1: Enable FTM | 0b | | b1 | HOST_PUT_MSG | 0: No I <sup>2</sup> C message in FTM mailbox 1: I <sup>2</sup> C has Put a message in FTM mailbox | 0b | | b2 | RF_PUT_MSG | No RF message in FTM mailbox RF has Put message in FTM mailbox | 0b | | b3 | RFU | - | 0b | | b4 | HOST_MISS_MSG | 0: No message missed by I <sup>2</sup> C 1: I <sup>2</sup> C did not read RF message before watchdog time out | 0b | | b5 | RF_MISS_MSG | O: No message missed by RF 1: RF did not read message before watchdog time out | 0b | | b6 | HOST_CURRENT_MSG | O: No message or message not coming from I <sup>2</sup> C 1: Current Message in FTM mailbox comes from I <sup>2</sup> C | 0b | | b7 | RF_CURRENT_MSG | No message or message not coming from RF Current Message in FTM mailbox comes from RF | 0b | <sup>1.</sup> MB\_EN bit is automatically reset to 0 if MB\_MODE register is reset to 0. Note: Refer to Table 12. Dynamic registers memory map for the MB\_CTRL\_Dyn register. Table 20. MB\_LEN\_Dyn access | RF | | I2C | | |-----------------------------------------|------|----------------|------| | Command | Туре | Address | Туре | | Read Message Length (cmd code ABh) | RO | E2 = 0, 2007h | RO | | Fast Read Message Length (cmd code CBh) | NO | L2 - 0, 200711 | NO | DS10925 - Rev 9 page 23/200 Table 21. MB\_LEN\_Dyn | Bit | Name | Function | Factory Value | |-------|--------|--------------------------------------------------------------------------------------------------|---------------| | b7-b0 | MB_LEN | Size in byte, minus 1 byte, of message contained in FTM mailbox (automatically set by ST25DVxxx) | 0h | Note: Refer to Table 12. Dynamic registers memory map for the MB\_LEN\_Dyn register. #### 5.1.2 Fast transfer mode usage ST25DV acts as mailbox between RF (reader, smartphone, ...) and an I<sup>2</sup>C host (microcontroller...). Each interface can send a message containing up to 256 bytes of data to the other interface through that mailbox. To send data from RF reader to $I^2C$ host, fast transfer mode must be enabled, the mailbox must be free, $V_{CC}$ power must be present, and the RF user must first writes the message containing data in the mailbox. I<sup>2</sup>C host is then informed (by interruption on GPO output or polling on MB\_CTRL\_Dyn register) that a message from RF is present in the mailbox. Once the complete message has been read by $I^2C$ , mailbox is considered free again and is available for receiving a new message (data is not cleared). The RF user is informed that the message has been read by the I<sup>2</sup>C host by polling on MB\_CTRL\_Dyn register. ST25DV Dynamic registers MB LEN Dyn MB\_CRTL\_Dyn 1Mb/s 26.5kb/s RF message Fast Transfer Mode mailbox ISO/IEC I2C host I2C (256 Bytes) 15693 reader Static registers GPO/RF PUT MSG MB MODE MB\_WDG Figure 9. RF to I<sup>2</sup>C fast transfer mode operation To send data from the $I^2C$ host to the RF reader, fast transfer mode must be enabled, the mailbox must be free, $V_{CC}$ power must be present, and the I2C host must first write the message containing data in the mailbox. The RF user must poll on MB\_CTRL\_Dyn register to check for the presence of a message from I<sup>2</sup>C in the mailbox. Once the complete message has been read by RF user, mailbox is considered free again and is available for receiving a new message (data is not cleared). The I<sup>2</sup>C host is informed that message has been read by RF user through a GPO interruption or by polling on the MB CTRL Dyn register. DS10925 - Rev 9 page 24/200 Figure 10. I<sup>2</sup>C to RF fast transfer mode operation V<sub>CC</sub> supply source is mandatory to activate this feature. No precedence rule is applied: the first request is served first. Adding a message is only possible when fast transfer mode is enabled (MB\_EN=1) and mailbox is free (HOST\_PUT\_MSG and RF\_PUT\_MSG cleared, which is the case after POR or after complete reading of I<sup>2</sup>C message by RF, and complete reading of RF message by I<sup>2</sup>C). A watchdog limits the message availability in time: when a time-out occurs, the mailbox is considered free, and the HOST\_MISS\_MSG or RF\_MISS\_MSG bits is set into MB\_CTRL\_Dyn register. The data contained in the mailbox is not cleared after a read or after the watchdog has been triggered: message data is still available for read and until fast transfer mode is disabled. HOST\_CURRENT\_MSG and RF\_CURRENT\_MSG bits are indicating the source of the current data. The message is stored in a buffer (256 Bytes), and the write operation is done immediately. . # **Caution:** The data written in user or system memory (EEPROM), either from I<sup>2</sup>C or from RF, transits via the 256-Bytes fast transfer mode's buffer. Consequently fast transfer mode must be deactivated (MB\_EN=0) before starting any write operation in user or system memory, otherwise command will be NotACK for I<sup>2</sup>C or get an answer 0Fh for RF and programming is not done. #### I<sup>2</sup>C access to mailbox The access by $I^2C$ can be done by dedicated address mapping to mailbox (2008h to 2107h) with device identifier E2 = 0. I<sup>2</sup>C reading operation does not support rollover. Therefore data out is set to FFh when the counter reaches the message end. The RF\_PUT\_MSG is cleared after reaching the STOP consecutive to reading the last message byte, and the mailbox is considered free (but the message is not cleared and it is still present in the mailbox). A I<sup>2</sup>C reading operation will never clear HOST PUT MSG, and the message remains available for RF. An I<sup>2</sup>C read can start at any address inside the mailbox (between address 2008h and 2107h). A I<sup>2</sup>C write operation must start from the first mailbox location, at address 2008h. After reaching the Mailbox border at address 2107h all bytes are NACK and the command is not executed (rollover feature not supported). At the end of a successful I<sup>2</sup>C message write, the message length is automatically set into MB\_LEN\_Dyn register, and HOST\_PUT\_MSG bit is set into MB\_CTRL\_Dyn register, and the write access to the mailbox is not possible until the mailbox has been released again. MB\_LEN\_Dyn contains the size of the message in byte, minus 1. DS10925 - Rev 9 page 25/200 #### RF access to mailbox The RF Control & Access to mailbox is possible using dedicated custom commands: - Read Dynamic Configuration and Fast Read Dynamic Configuration to check availability of mailbox. - Write Dynamic Configuration and Fast Write Dynamic configuration to enable or disable fast transfer mode. - Read Message Length and Fast Read Message Length to get the length of the contained message, - Read Message and Fast Read Message to download the content of the mailbox, - Write Message and Fast Write Message to put a new message in mailbox. (New length is automatically updated after completion of a successful Write Message or Fast Write Message command). HOST\_PUT\_MSG is cleared following a valid reading of the last message byte, and mailbox is considered free (but message is not cleared and is still present in the mailbox). A RF read can start at any address of inside the message, but return an error 0Fh if trying to read after the last byte of the message. A RF reading operation will never clear RF\_PUT\_MSG , the message will remain available for I<sup>2</sup>C. At the end of a successful RF message write, the message length is automatically set in MB\_LEN\_Dyn register, and RF\_PUT\_MSG bit is set in MB\_CTRL\_Dyn register. and write access to the mailbox is not possible until mailbox has been freed again. The presence of a DC supply is mandatory to get RF access to the mailbox. VCC\_ON can be checked reading the dynamic register EH\_CTRL\_Dyn. To get more details about sequences to prepare and initiate a Fast Transfer, to detect progress of a fast transfer or to control and execute a fast transfer, please refer to AN4910. How to exchange data between wired (I<sup>2</sup>C) and wireless world (RF ISO15693) using fast transfer mode supported by ST25DVxxx). DS10925 - Rev 9 page 26/200 MB EN=00h or MB EN=00h or FTM disabled VCC OFF VCC OFF MB\_CTRL\_Dyn=00h No access VCC ON and MB EN=00h or I2C read msg VCC OFF MB\_EN=01h RF read msg FTM enabled I2C write msq RF write msg FTM enabled FTM enabled Mailbox empty **I2C Message RF Message** MB\_CTRL\_Dyn=01h MB\_CTRL\_Dyn=43h MB\_CTRL\_Dyn=85h R/W access Read access Read access RF read full msg 12C read full meg Mailbox free FTM enabled Mailbox free MB\_CTRL\_Dyn=41/81h R/W access RF read I2C read MB\_CTRL\_Dyn MB\_CTRL\_Dyn FTM enabled Mailbox free MB\_CTRL\_Dyn=61/91h Watchdog trig Watchdog trig R/W access Figure 11. Fast transfer mode mailbox access management. Note: Assuming MB\_MODE=01h Assuming no error occurred #### 5.2 GPO GPO signal is used to alert the I<sup>2</sup>C host of external RF events or ST25DVxxx processes activity. Several causes could be used to request a host interruption. RF user can also directly drive GPO pin level using a dedicated RF command. # 5.2.1 ST25DVxxx interrupt capabilities on RF events ST25DVxxx supports multi interruption mode and can report several events occurring through RF interface. In this chapter, all drawings are referring to the open drain version of GPO output (ST25DVxxK-IE). The reader can retrieve the behaviour of CMOS version (ST25DVxxK-JF) by inverting the GPO curve polarity and replace in text "released" or "high-Z" by "pull to ground". Supported RF events is listed hereafter: DS10925 - Rev 9 page 27/200 # RF\_USER: - GPO output level is controlled by Manage GPO command (set or reset) - When RF\_USER is activated, GPO level is changed after EOF of ST25DV response to a Manage GPO set or reset command (see Section 7.6.30 Manage GPO). - RF\_USER is prevalent over all other GPO events when set by Manage GPO command (other interrupts are still visible in IT\_STS\_Dyn status register, but do not change GPO output level). Figure 12. RF\_USER chronogram 1) VCD sends a ManageGPO command with value 00h (set GPO) and ST25DV replies. GPO/RF\_USER is tied low after ST25DV response. 2) VCD sends a ManageGPO command with value 01h (reset GPO) and ST25DV replies. GPO/RF\_USER is set high-Z low after ST25DV response. 3) VCD sends a ManageGPO command (any value) and ST25DV replies with error. GPO/RF\_USER remains high-Z. GPO/RF\_USER (OD) 4) VCD sends a ManageGPO command (any value) and ST25DV stays quiet (command not for this VICC, or quiet state). GPO/RF\_USER remains high-Z. GPO/RF\_USER (OD) 5) VCD sends any command other than ManageGPO command and ST25DV replies. GPO/RF\_USER remains high-Z. GPO/RF\_USER (OD) DS10925 - Rev 9 page 28/200 #### RF\_ACTIVITY: - GPO output level reflects the RF activity. - When RF\_ACTIVITY is activated, a GPO output level change from RF command EOF to ST25DV response FOF Figure 13. RF\_ACTIVITY chronogram 1) VCD sends a command and ST25DV replies. GPO/RF\_ACTIVITY is released after ST25DV response 2) VCD sends a write command and ST25DV replies after write completed. GPO/RF\_ACTIVITY is released after ST25DV response. 3) VCD sends a write command with option flag set to 1, and ST25DV replies after receiving EOF. GPO/RF\_ACTIVITY is released after ST25DV response. 4) VCD sends an Inventory 16 slots command, and ST25DV replies in its slot. GPO/RF\_ACTIVITY is released after ST25DV response. 5) VCD sends a command and ST25DV stays quiet (Stay Quiet command, command not for this VICC, or quiet state). GPO/RF\_ACTIVITY remains high-Z. GPO/RF\_ACTIVITY (OD) DS10925 - Rev 9 page 29/200 # **RF\_INTERRUPT**: - A pulse is emitted on GPO by Manage GPO command (interrupt). - When RF\_INTERRUPT is activated, a pulse of duration IT\_TIME is emitted after EOF of ST25DV response to a Manage GPO interrupt command (see Section 7.6.30 Manage GPO). Figure 14. RF\_INTERRUPT chronogram 1) VCD sends a ManageGPO command with value 80h (GPO emit pulse) and ST25DV replies. GPO/RF\_INTERRUPT generates a pulse of duration IT\_TIME after ST25DV response. 2) VCD sends a ManageGPO command (any value) and ST25DV replies with error. GPO/RF\_INTERRUPT remains high-Z. GPO/RF\_INTERRUPT (OD) 3) VCD sends a ManageGPO command (any value) and ST25DV stays quiet (command not for this VICC, or quiet state). GPO/RF\_INTERRUPT remains high-Z. GPO/RF\_INTERRUPT (OD) 4) VCD sends any command other than ManageGPO command and ST25DV replies. GPO/RF\_INTERRUPT remains high-Z. GPO/RF\_INTERRUPT (OD) DS10925 - Rev 9 page 30/200 #### FIELD\_CHANGE: - A pulse is emitted on GPO to signal a change in RF field state. - When FIELD\_CHANGE is activated, and when RF field appear or disappear, GPO emits a pulse of duration IT\_TIME. - In case of RF field disappear, the pulse is emitted only if V<sub>CC</sub> power supply is present. - If RF is configured in RF\_SLEEP mode, field change are not reported on GPO, even if FIELD\_CHANGE event is activated, as shown in Table 22. FIELD\_CHANGE when RF is disabled or in sleep mode. Table 22. FIELD\_CHANGE when RF is disabled or in sleep mode | RF_DISABLE | RF_SLEEP | GPO behaviour when FIELD_CHANGE is enabled | | |------------|----------|-----------------------------------------------------------------|--| | 0 | 0 | A nulse is emitted an CDO if DE field annears or disappears (1) | | | 1 | 0 | A pulse is emitted on GPO if RF field appears or disappears (1) | | | X | 1 | GPO remains High-Z (OD) or tied low (CMOS) | | | X | 1 | IT_STS_Dyn register is not updated. | | 1. assuming that GPO output is enabled (GPO\_EN = 1). Figure 15. FIELD\_CHANGE chronogram DS10925 - Rev 9 page 31/200 # RF\_PUT\_MSG: - A pulse is emitted on GPO when a message is successfully written by RF in fast transfer mode mailbox. - When RF\_PUT\_MSG is activated, a pulse of duration IT\_TIME is emitted on GPO at completion of valid Write Message or Fast Write Message commands (after EOF of ST25DV response). Figure 16. RF\_PUT\_MSG chronogram VCD sends a Write Message or Fast Write Message command and ST25DV replies with no error. GPO/RF\_PUT\_MSG generates a pulse during IT\_TIME after ST25DV response. VCD sends a Write Message or Fast Write Message command and ST25DV replies with error. GPO/RF\_PUT\_MSG remains high-Z. GPO/RF\_PUT\_MSG (OD) 3) VCD sends Write Message or Fast Write Message command and ST25DV stays quiet (command not for this VICC, or quiet state). GPO/RF\_PUT\_MSG stays high-Z. GPO/RF\_PUT\_MSG (OD) 4) VCD sends a any other command than Write Message or Fast Write Message commands and ST25DV replies. GPO/RF\_PUT\_MSG remains high-Z. GPO/RF\_PUT\_MSG (OD) DS10925 - Rev 9 page 32/200 # RF\_GET\_MSG: - A pulse is emitted on GPO when RF has successfully read a message, up to its last byte, in fast transfer mode mailbox. - When RF\_GET\_MSG is activated, a pulse of duration IT\_TIME is emitted on GPO at completion of valid Read Message or Fast Read Message commands (after EOF of ST25DV response), and end of message has been reached. Figure 17. RF\_GET\_MSG chronogram 1) VCD sends a Read Message or Fast Read Message command and ST25DV replies with no error. GPO/RF\_GET\_MSG generates a pulse during IT\_TIME after ST25DV response. 2) VCD sends a Read Message or Fast Read Message command and ST25DV replies with error. GPO/RF\_GET\_MSG remains high-Z. GPO/RF\_GET\_MSG (OD) 3) VCD sends Read Message or Fast Read Message command and ST25DV stays quiet (command not for this VICC, or quiet state). GPO/RF\_GET\_MSG stays high-Z. GPO/RF\_GET\_MSG (OD) 4) VCD sends any other command than Read Message or Fast Read Message commands and ST25DV replies. GPO/RF\_GET\_MSG remains high-Z. GPO/RF\_GET\_MSG (OD) DS10925 - Rev 9 page 33/200 # RF\_WRITE: - When RF\_WRITE is activated, a pulse of duration IT\_TIME is emitted at completion of a valid RF write operation in EEPROM (after EOF of ST25DV response). - Following commands trigger the RF\_WRITE interrupt after a valid write operation in EEPROM: - Write Single Block - Extended Write Single Block - Write Multiple Block - Extended Write Multiple Block - Lock Block - Extended Lock Block - Write AFI - Lock AFI - Write DSFID - Lock DSFID - Write Configuration - Write Password - Note that writing in dynamic registers or fast transfer mode mailbox does not trigger RF\_WRITE interrupt (no write operation in EEPROM). Figure 18. RF\_WRITE chronogram 1) VCD sends a write command and ST25DV replies after write completed. GPO/RF\_WRITE generates a pulse during IT TIME after ST25DV response. 2) VCD sends a write command with option flag set to 1, and ST25DV replies after receiving EOF. GPO/RF\_WRITE generates a pulse during IT\_TIME after ST25DV response. 3) VCD sends a write command and ST25DV replies with error. GPO/RF\_WRITE remains high-Z. GPO/RF\_WRITE (OD) 4) VCD sends any other command than a write command. GPO/RF\_WRITE remains high-Z. GPO/RF\_WRITE (OD) 5) VCD sends any command and ST25DV stays quiet (command not for this VICC, or quiet state). RF\_ACTIVITY remains high-Z. GPO/RF\_WRITE (OD) DS10925 - Rev 9 page 34/200 #### 5.2.2 GPO and power supply When at the same time RF field is present and $V_{CC}$ is ON, GPO is acting as configured in GPO, GPO\_CTRL\_Dyn and IT\_TIME registers. When the RF field disappears, the GPO state is reset and the output level is set to high-Z (open drain) or tied low (CMOS). Interruption status in IT\_STS\_Dyn register is maintained until next I<sup>2</sup>C read or V<sub>CC</sub> power off. Table 23. GPO interrupt capabilities in function of RF field | RF field on | RF field off | |----------------------------------------|--------------------------------------------| | GPO state is function of RF events (1) | GPO remains High-Z (OD) or tied low (CMOS) | <sup>1.</sup> If pull-up resistor is powered (Open Drain-IE version), and V<sub>DCG</sub> is powered (CMOS –JF version). When $V_{CC}$ is not present, or ST25DVxxx is in low power mode, all events are available on GPO pin, assuming pull-up resistor is supplied with correct voltage (Open Drain-IE version) or $V_{DCG}$ is powered (CMOS-JF version). The host can be waken up using GPO interrupt in any power condition. The exception is FIELD\_CHANGE when RF field is falling, which can't be reported on GPO output if $V_{CC}$ is off or in low power mode (no power supply on ST25DVxxx). Table 24. GPO interrupt capabilities in function of V<sub>CC</sub> power supply | GPO events | V <sub>CC</sub> OFF | V <sub>CC</sub> ON and LPD high <sup>(1)</sup> (low power mode) | V <sub>CC</sub> ON and LPD low <sup>(1)</sup> | |-------------------------------------|---------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------| | FIELD_CHANGE if RF field disappears | GPO remains High-Z (OD) or tied low (CMOS) | GPO remains High-Z (OD) or tied low (CMOS) (2) | Pulse emitted on GPO | | Any other activated RF event | GPO state is function of RF events <sup>(2)</sup> | GPO state is function of RF events <sup>(2)</sup> | GPO state is function of RF events <sup>(2)</sup> | <sup>1.</sup> For STM25DVxxK-JF only. DS10925 - Rev 9 page 35/200 <sup>2.</sup> If pull-up resistor is powered (Open Drain-IE version) and $V_{DCG}$ is powered (CMOS-JF version). #### 5.2.3 GPO registers Four registers are dedicated to this feature: - Two static registers in system configuration - Two dynamic registers Table 25. GPO access | RF | | I2C | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @00h<br>Write Configuration (cmd code A1h) @00h | R always, W if RF configuration security session is open and configuration not locked | E2=1, 0000h | R always, W if I <sup>2</sup> C security session is open | Table 26, GPO | Bit | Name | Function | Factory Value | |------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------| | b0 RF USER EN | | 0: disabled | Ob | | 50 | b0 RF_USER_EN | 1: GPO output level is controlled by Manage GPO Command (set/reset) | OD | | h1 | b1 RF_ACTIVITY_EN | 0: disabled | 0b | | D1 | | 1: GPO output level changes from RF command EOF to response EOF. | OD | | ha | b2 RF_INTERRUPT_EN | 0: disabled | Ob | | UZ | | 1: GPO output level is controlled by Manage GPO Command (pulse). | OD | | h2 | b3 FIELD_CHANGE_EN | 0: disabled | 1h | | DS | | 1: A pulse is emitted on GPO, when RF field appears or disappears. | 1b | | | | 0: disabled | | | b4 RF_PUT_MSG_EN | 1: A pulse is emitted on GPO at completion of valid RF Write Message command. | 0b | | | | | 0: disabled | | | b5 | b5 RF_GET_MSG_EN | 1: A pulse is emitted on GPO at completion of valid RF Read Message command if end of message has been reached. | 0b | | | | 0: disabled | | | b6 RF_WRITE_EN | 1: A pulse is emitted on GPO at completion of valid RF write operation in EEPROM. | 0b | | | b7 | GPO EN | 0: GPO output is disabled. GPO is High-Z (open drain) or 0 (CMOS) | 1b | | J7 | UI GFO_EN | 1: GPO output is enabled. GPO outputs enabled interrupts. | ID | #### Note: Refer to Table 11. System configuration memory map for the GPO register. - · Enables the interruption source, and enable GPO output. - Several interruption sources can be enabled simultaneously. - The updated value is valid for the next command (except for the RF\_WRITE interrupt, which is valid right after EOF of the Write Configuration command if enabled through RF). - The GPO\_EN bit (b7) allows to disable GPO output (High-Z for open drain version, driven low for CMOS version). Interruptions are still reported in IT\_STS\_Dyn register. - RF configuration security session (present RF password 0) or I<sup>2</sup>C security session (present I<sup>2</sup>C password) must be open in order to write the GPO register. DS10925 - Rev 9 page 36/200 ### Table 27. IT\_TIME access | RF | | I2C | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @01h<br>Write Configuration (cmd code A1h) @01h | R always, W if RF configuration security session is open and configuration not locked | E2=1, 0001h | R always, W if I <sup>2</sup> C security session is open | # Table 28. IT\_TIME | Bit | Name | Function | Factory Value | |-------|---------|-----------------------------------------------------|---------------| | b2-b0 | IT_TIME | Pulse duration = 301 us - IT_TIME x 37.65 us ± 2 us | 011b | | b7-b3 | RFU | - | 00000b | Note: Refer to Table 11. System configuration memory map for the IT\_TIME register. - Defines interrupt pulse duration on GPO pin for the flowing events: RF\_INTERRUPT, FIELD\_CHANGE, RF\_PUT\_MSG, RF\_GET\_MSG and RF\_WRITE. - See Eq. (1) for interrupt duration calculation. - RF configuration security session (present RF password 0) or I<sup>2</sup>C security session (present I<sup>2</sup>C password) must be open in order to write IT\_TIME register. # Table 29. GPO\_CTRL\_Dyn access | RF | | I2C | | |-----------------------------------------------------------------------------------------------------|--|----------------|-------------------------| | Command Type A | | Address | Туре | | Read Dynamic Configuration (cmd code ADh) @00h Fast Read Dynamic Configuration (cmd code CDh) @00h | | E2 = 0, 2000h | b0-b6: RO | | | | E2 - 0, 200011 | b7 : R always, W always | DS10925 - Rev 9 page 37/200 Table 30. GPO\_CTRL\_Dyn | Bit | Name | Function | Factory Value | |-----|-----------------|-----------------------------------------------------------------------------------------------------------------|---------------| | b0 | RF USER EN | 0: disabled | 0b | | 50 | IN _OOLIN_LIN | 1: GPO output level is controlled by Manage GPO Command (set/reset) | OD | | b1 | RF ACTIVITY EN | 0: disabled | 0b | | БТ | IN _ACTIVITI_EN | 1: GPO output level changes from RF command EOF to response EOF. | OD | | b2 | RF INTERRUPT EN | 0: disabled | 0b | | 02 | KI_INTERROFI_EN | 1: GPO output level is controlled by Manage GPO Command (pulse). | OD | | b3 | EIELD CHANGE EN | 0: disabled | 1b | | 55 | FIELD_CHANGE_EN | 1: A pulse is emitted on GPO, when RF field appears or disappears. | 10 | | b4 | RF PUT MSG EN | 0: disabled | 0b | | 54 | RF_FUI_W3G_EN | 1: A pulse is emitted on GPO at completion of valid RF Write Message command. | OD | | | | 0: disabled | | | b5 | RF_GET_MSG_EN | 1: A pulse is emitted on GPO at completion of valid RF Read Message command if end of message has been reached. | 0b | | | | 0: disabled | | | b6 | RF_WRITE_EN | 1: A pulse is emitted on GPO at completion of valid RF write operation in EEPROM. | 0b | | b7 | GPO_EN | 0: GPO output is disabled. GPO is High-Z (open drain) or 0 (CMOS) | 1b | | 07 | GFO_LIN | 1: GPO output is enabled. GPO outputs enabled interrupts. | IU | Note: Refer to Table 12. Dynamic registers memory map for the GPO\_CTRL\_Dyn register. - Allows I<sup>2</sup>C host to dynamically enable or disable GPO output by writing in GPO\_EN bit (b7). - GPO\_EN bit of GPO\_CTRL\_Dyn register is prevalent over GPO\_EN bit of GPO register. - At power up, and each time GPO register is updated, GPO\_CTRL\_Dyn content is copied from GPO register. - GPO\_CTRL\_Dyn is a volatile register. Value is maintained only if at least one of the two power sources is present (RF field or V<sub>CC</sub>). - GPO\_CTRL\_Dyn bit 7 (GPO\_EN) can be written even if I<sup>2</sup>C security session is closed (I<sup>2</sup>C password not presented) but is read only for RF user. - Modifying GPO\_CTRL\_Dyn, the bit 7 GPO\_EN does not affect the value of GPO register bit 7 GPO\_EN Table 31. IT\_STS\_Dyn access | RF I | | I2C | | |--------------|--|---------------|------| | Command Type | | Address | Туре | | No access | | E2 = 0, 2005h | RO | DS10925 - Rev 9 page 38/200 Table 32. IT\_STS\_Dyn | Bit | Name | Function | Factory Value | |-----|---------------|-------------------------------------------------------------------------------------------------------------------------|---------------| | b0 | RF_USER | 0: Manage GPO reset GPO 1: Manage GPO set GPO | 0b | | b1 | RF_ACTIVITY | 0: No RF access 1: RF access | Ob | | b2 | RF_INTERRUPT | No Manage GPO interrupt request Manage GPO interrupt request | 0b | | b3 | FIELD_FALLING | 0: No RF field falling 1: RF Field falling | 0b | | b4 | FIELD_RISING | 0: No RF field rising 1: RF field rising | 0b | | b5 | RF_PUT_MSG | No message put by RF in FTM mailbox Hessage put by RF in FTM mailbox | 0b | | b6 | RF_GET_MSG | O: No message read by RF from FTM mailbox 1: Message read by RF from FTM mailbox, and end of message has been reached. | 0b | | b7 | RF_WRITE | 0: No write in EEPROM 1: Write in EEPROM | 0b | Note: Refer to Table 12. Dynamic registers memory map for the IT\_STS\_Dyn register. - Cumulates all events which generate interruptions. It should be checked by I<sup>2</sup>C host to know which event triggered an interrupt on GPO pin. - When enabled, RF events are reported in IT\_STS\_Dyn register even if GPO output is disabled though the GPO\_EN bit. - Once read the ITSTS\_Dyn register is cleared (set to 00h). - At power up, IT\_STS\_Dyn content is cleared (set to 00h). - IT\_STS\_Dyn is a volatile register. Value is maintained only if at least one of the two power sources is present (RF field or V<sub>CC</sub>). DS10925 - Rev 9 page 39/200 ### 5.2.4 Configuring GPO GPO and interruption pulse duration can be configured by RF user or by I<sup>2</sup>C host. One or more interrupts can be enabled at same time. RF user can use Read Configuration and Write Configuration commands to set accordingly the GPO and IT TIME registers, after presenting a valid RF configuration password to open RF configuration security session. I<sup>2</sup>C host can write GPO and IT\_TIME registers, after presenting a valid I<sup>2</sup>C password to open I<sup>2</sup>C security session. Enabling or disabling GPO output: - RF user and I<sup>2</sup>C host can disable or enable GPO output at power up time by writing in GPO\_EN bit 7 of GPO register (if write access is granted). - I<sup>2</sup>C host can temporarily enable or disable GPO output at any time by toggling GPO\_EN bit 7 of GPO\_CTRL\_Dyn register. No password is required to write into GPO\_CTRL\_Dyn register. - Disabling GPO output by writing in GPO\_EN bit (either in GPO or in GPO\_CTRL\_Dyn registers) does not disable interruption report in IT\_STS\_Dyn status register. GPO bit 7: GPO\_EN GPO\_EN GPO\_EN GPO output GPO output GPO output GPO output GPO remains High-Z (OD) or tied low (CMOS) GPO remains High-Z (OD) or tied low (CMOS) Activated RF events are reported on GPO output (1) Activated RF events are reported on GPO output(1) Table 33. Enabling or disabling GPO interruptions Interruption pulse duration configuration: 1 - Interrupt pulse duration is configured by writing pulse duration value in IT\_TIME register. - Pulse duration is calculated with the following equation IT pulse duration equation: 1 $$ITpulse\ duration = 301\mu s - IT\_TIME \times 37.65\mu s \pm 2\mu s$$ (1) DS10925 - Rev 9 page 40/200 <sup>1.</sup> If pull-up resistor is powered (Open Drain -IE version), and $V_{DCG}$ is powered (CMOS –JF version). # 5.3 Energy Harvesting (EH) # 5.3.1 Energy harvesting registers Table 34. EH\_MODE access | RF | | | I2C | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------|----------------------------------------------------------|--| | Command | Туре | Address | Туре | | | Read Configuration (cmd code A0h) @02h<br>Write Configuration (cmd code A1h) @02h | R always, W if RF configuration security session is open and configuration not locked | E2 = 1,<br>0002h | R always, W if I <sup>2</sup> C security session is open | | ### Table 35. EH\_MODE | Bit | Name | Function | Factory Value | |-------|---------|----------------------------------------------|---------------| | b0 | EH_MODE | 0: EH forced after boot 1: EH on demand only | 1b | | b7-b1 | RFU | - | 0000000b | Note: Refer to Table 11. System configuration memory map for the EH\_MODE register. Table 36. EH\_CTRL\_Dyn access | RF | I2C | | | |----------------------------------------------------------------------------|-------------|-------------|------------------------| | Command | Туре | Address | Туре | | Read Dynamic Configuration (cmd code ADh) @02h | | | | | Fast Read Dynamic Configuration (cmd code CDh) @02h b0: R always, W always | | F2-0 2002b | b0: R always, W always | | Write Dynamic Configuration (cmd code AEh) @02h | b1 - b7: RO | E2=0, 2002h | b1-b7 : RO | | Fast Write Dynamic Configuration (cmd code CEh) @02h | | | | ### Table 37. EH\_CTRL\_Dyn | Bit | Name | Function | Factory Value | |--------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------| | b0 | EH EN | 0: Disable EH feature | 0b | | | 2.1_2.1 | 1: Enable EH feature | | | b1 | 0: EH feature is disabled | | 0b | | 1: EH feature is enabled | | 1: EH feature is enabled | 0.0 | | b2 | FIELD ON | 0: RF field is not detected | Depending of power source | | UZ. | TILLD_ON | 1: RF field is present and ST25DVxxx may communicate in RF | Depending of power source | | b3 | 0: No DC supply detected on V <sub>CC</sub> pin or Low Power Down mode is forced (LPD is h | | Depending of power source | | DS | VCC_ON | VCC_ON 1: V <sub>CC</sub> supply is present and Low Power Down mode is not forced (LPD is low) | | | b7-b4 | RFU | - | 0b | Note: Refer to Table 12. Dynamic registers memory map for the EH\_CTRL\_Dyn register. DS10925 - Rev 9 page 41/200 #### 5.3.2 Energy harvesting feature description The usage of Energy Harvesting element can be defined in configuration register EH\_MODE. When the Energy harvesting mode is disabled or the RF field strength is not sufficient, the energy harvesting analog voltage output V\_EH is in High-Z state. EH MODE Static Register is used to define the Energy Harvesting default strategy after boot. At boot EH EN (in EH CTRL Dyn register) is set depending EH MODE value as shown in table below: Table 38. Energy harvesting at power-up | EH_MODE | EH_EN (at boot) | Energy harvesting at power-up | |---------|-----------------|----------------------------------------| | 0 | 1 | EH enabled after boot (when possible) | | 1 | 0 | EH disabled initially, | | ' | U | EH delivered on demand (when possible) | Writing 0 in EH\_MODE at any time after boot will automatically set EH\_EN bit to 1, and thus activate energy harvesting. Writing 1 in EH\_MODE at any time after boot will not modify EH\_EN bit (until next reboot) and thus will not modify energy harvesting current state. EH\_CTRL\_Dyn allows to activate or deactivate on the fly the Energy harvesting (EH\_EN) and bring information on actual state of EH and state of power supplies : - · EH ON set reflects the EH EN bit value - FIELD ON is set in presence of a RF field - VCC\_ON is set when Host power supply is on, and low power-down mode is not forced. During boot, EH is not delivered to avoid alteration in device configuration. #### Caution: Communication is not guaranteed during EH delivery. Refer to the application note AN4913 (Energy harvesting delivery impact on ST25DVxxx behaviour during RF communication). Energy harvesting can be set even if ST25DVxxx is in RF disabled or RF Sleep mode, or in Low power mode. In all these cases, ST25DVxxx will deliver power on V\_EH pin if RF field is present. Energy harvesting voltage output is not regulated. DS10925 - Rev 9 page 42/200 ### 5.3.3 EH delivery state diagram Figure 19. EH delivery state diagram Note: Power is delivered on V\_EH only if harvested energy is sufficient to supply ST25DV and leave over power. Grey color indicates the states where power is delivered on V\_EH pin. DS10925 - Rev 9 page 43/200 ## 5.3.4 EH delivery sequence Figure 20. ST25DVxxx Energy Harvesting Delivery Sequence - 1. We suppose that the captured RF power is sufficient to trig EH delivery. - V\_EH = 1 means some μW are available on V\_EH pin. V\_EH = 0 means V\_EH pin is in high-Z. DS10925 - Rev 9 page 44/200 # 5.4 RF management feature # 5.4.1 RF management registers Table 39. RF\_MNGT access | RF | | I2C | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @03h<br>Write Configuration (cmd code A1h) @03h | R always, W if RF configuration security session is open and configuration not locked | E2 = 1, 0003h | R always, W if I <sup>2</sup> C security session is open | Table 40. RF\_MNGT | Bit | Name | Function | Factory Value | |-------|------------|------------------------------------------------------|---------------| | b0 | DE DISABLE | 0: RF commands executed | Oh | | DU | RF_DISABLE | 1: RF commands not executed (error 0Fh returned) | 0b | | b1 | RF_SLEEP | 0: RF communication enabled | Oh | | DI | | 1: RF communication disabled (ST25DV remains silent) | 0b | | b7-b2 | RFU | - | 000000b | Note: Refer to Table 11. System configuration memory map for the RF\_MNGT register. Table 41. RF\_MNGT\_Dyn access | RF | | I2C | | |--------------------|--|---------------|--------------------| | Command Type Addre | | Address | Туре | | No access | | E2 = 0, 2003h | R always, W always | # Table 42. RF\_MNGT\_Dyn | Bit | Name | Function | Factory Value | |-------|------------|------------------------------------------------------|---------------| | b0 | DE DISABLE | 0: RF commands executed | Oh | | DU | RF_DISABLE | 1: RF commands not executed (error 0Fh returned) | Ob | | h.1 | RF_SLEEP | 0: RF communication enabled | Oh | | b1 | | 1: RF communication disabled (ST25DV remains silent) | 0b | | b7-b2 | RFU | - | 0000000b | Note: Refer to Table 12. Dynamic registers memory map for the RF\_MNGT\_Dyn register. DS10925 - Rev 9 page 45/200 #### 5.4.2 RF management feature description RF\_MNGT Register is used to control the RF communication between ST25DVxxx and a RF reader. At boot time, and each time RF\_MNGT register it is updated, content of RF\_MNGT\_Dyn register is copied from RF\_MNGT register. The content of RF\_MNGT\_Dyn register is used during application to set ST25DVxxx behavior. Content of this dynamic register RF\_MNGT\_Dyn can be updated on the fly, to temporarily modify the behavior of ST25DVxxx without affecting the static value of RF\_MNGT which will be recovered at next POR. RF\_MNGT register is composed of two bits (see Table 42. RF\_MNGT\_Dyn): RF\_DISABLE and RF\_SLEEP For a normal usage of RF interface, bits RF\_SLEEP and RF\_DISABLE must be set to 0. For RF are offered three modes: - RF sleep mode: - When RF\_SLEEP is set to 1, all RF communications are disabled, RF interface doesn't interpret commands, but minimizes consumption of RF interface. - RF disable mode: - When RF\_SLEEP is set to 0 and RF\_DISABLE is set to 1, RF commands are interpreted but not executed. In case of a valid command, ST25DVxxx will respond after t<sub>1</sub> with the error code 0Fh. The Inventory command is not answered. - RF normal mode: - In normal usage, RF\_SLEEP and RF\_DISABLE are set to 0, ST25DVxxx will process the request and respond accordingly when I<sup>2</sup>C is not accessing ST25DVxxx. If I<sup>2</sup>C is busy, ST25DV will respond to RF request with the error code 0Fh. DS10925 - Rev 9 page 46/200 ### 5.5 Interface Arbitration ST25DVxxx automatically arbitrates the exclusive usage of RF and I<sup>2</sup>C interfaces. Arbitration scheme obeys to "first talk first served" basic law. (see Figure 21. ST25DVxxx, Arbitration between RF and I<sup>2</sup>C). Power OFF VCC ON RF field ON **Boot** RF mute I2C mute Boot done RF request SOF I2C start I2C busy ST25DV standby RF busy (0Fh or no (I2C commands RF free response to RF are NoAck) I2C free requests) RF transaction terminated I2C transition terminated Figure 21. ST25DVxxx, Arbitration between RF and I<sup>2</sup>C ### RF transaction is terminated: - · at response EOF if answer. - at request EOF is no answer. - at RF field OFF. #### I2C transaction is terminated: - at the end of EEPROM programming time after the stop condition of a successful write into EEPROM (user memory or system configuration). See Section 6.4 I2C Write operations for write time calculation - at stop condition for any other I2C transaction - at VCC power off - at any I2C error (terminated before stop condition) - · at I2C timeout if it occurs When RF is busy, $I^2C$ interface answers by NoAck on any $I^2C$ command. When I<sup>2</sup>C is busy, RF commands receive no response (Inventory, Stay quiet, addressed commands) or error code 0Fh for any other command. DS10925 - Rev 9 page 47/200 ### **5.6** Data Protection ST25DVxxx provides a special data protection mechanism based on passwords that unlock security sessions. User memory can be protected for read and/or write access and system configuration can be protected from write access, both from RF and $I^2C$ assess. # 5.6.1 Data protection registers Table 43. RFA1SS access | RF | | I2C | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @04h<br>Write Configuration (cmd code A1h) @04h | R always, W if RF configuration security session is open and configuration not locked | E2 = 1, 0004h | R always, W if I <sup>2</sup> C security session is open | Table 44. RFA1SS | Bit | Name | Function | Factory Value | |-------|------------------|----------------------------------------------------------------------------------------------|---------------| | | | 00: Area 1 RF user security session can't be open by password | | | b1-b0 | PWD CTRL A1 | 01: Area 1 RF user security session is open by RF_PWD_1 | 00b | | טט-וט | PWD_CTRL_AT | 10: Area 1 RF user security session is open by RF_PWD_2 | 000 | | | | 11: Area 1 RF user security session is open by RF_PWD_3 | | | | RW_PROTECTION_A1 | 00: Area 1 RF access: Read always allowed / Write always allowed | | | b3-b2 | | 01: Area 1 RF access: Read always allowed, Write allowed if RF user security session is open | 00b | | 03-02 | | 10: Area 1 RF access: Read always allowed, Write allowed if RF user security session is open | OOD | | | | 11: Area 1 RF access: Read always allowed, Write always forbidden | | | b7-b4 | RFU | - | 0000b | Note: Refer to Table 11. System configuration memory map for the RFA1SS register. Table 45. RFA2SS access | RF | | I2C | | |--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @06h Write Configuration (cmd code A1h) @06h | R always, W if RF configuration security session is open and configuration not locked | E2 = 1, 0006h | R always, W if I <sup>2</sup> C security session is open | DS10925 - Rev 9 page 48/200 Table 46. RFA2SS | Bit | Name | Function | Factory Value | |-------|------------------|---------------------------------------------------------------------------------------------------------------------------|---------------| | | PWD_CTRL_A2 | 00: Area 2 RF user security session can't be open by password | | | b1-b0 | | 01: Area 2 RF user security session is open by RF_PWD_1 | 00b | | D1-00 | | 10: Area 2 RF user security session is open by RF_PWD_2 | OOD | | | | 11: Area 2 RF user security session is open by RF_PWD_3 | | | | RW_PROTECTION_A2 | 00: Area 2 RF access: Read always allowed, Write always allowed | | | | | 01: Area 2 RF access: Read always allowed, Write allowed if RF user security session is open | | | b3-b2 | | 10: Area 2 RF access: Read allowed if RF user security session is open, Write allowed if RF user security session is open | 00b | | | | 11: Area 2 RF access: Read allowed if RF user security session is open, Write always forbidden | | Note: Refer to Table 11. System configuration memory map for the RFA2SS register. Table 47. RFA3SS access | RF | | 12C | | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @08h<br>Write Configuration (cmd code A1h) @08h | R always, W if RF configuration security session is open and configuration not locked | E2 = 1, 0008h | R always, W if I <sup>2</sup> C security session is open | Table 48. RFA3SS | Bit | Name | Function | Factory Value | |-------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------| | | | 00: Area 3 RF user security session can't be open by password | | | b1-b0 | PWD CTRL A3 | 01: Area 3 RF user security session is open by RF_PWD_1 | 00b | | D1-00 | PWD_CTRL_A3 | 10: Area 3 RF user security session is open by RF_PWD_2 | OOD | | | | 11: Area 3 RF user security session is open by RF_PWD_3 | | | | | 00: Area 3 RF access: Read always allowed / Write always allowed | | | | | 01: Area 3 RF access: Read always allowed, Write allowed if RF user security session is open | | | b3-b2 | RW_PROTECTION_A3 | RW_PROTECTION_A3 10: Area 3 RF access: Read allowed if RF user security session is open, Write allowed if RF user security session is open | 00b | | | | 11: Area 3 RF access: Read allowed if RF user security session is open, Write always forbidden | | | b7-b4 | RFU | - | 0000b | Note: Refer to Table 11. System configuration memory map for the RFA3SS register. Table 49. RFA4SS access | RF | | I2C | | |--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @0Ah Write Configuration (cmd code A1h) @0Ah | R always, W if RF configuration security session is open and configuration not locked | E2 = 1, 000Ah | R always, W if I <sup>2</sup> C security session is open | DS10925 - Rev 9 page 49/200 Table 50. RFA4SS | Bit | Name | Function | Factory Value | |-------|------------------|---------------------------------------------------------------------------------------------------------------------------|---------------| | | | 00: Area 4RF user security session can't be open by password | | | b1-b0 | PWD CTRL A4 | 01: Area 4 RF user security session is open by RF_PWD_1 | 00b | | טו-טט | FWD_CTRL_A4 | 10: Area 4 RF user security session is open by RF_PWD_2 | UUD | | | | 11: Area 4 RF user security session is open by RF_PWD_3 | | | | RW_PROTECTION_A4 | 00: Area 4 RF access: Read always allowed, Write always allowed | | | | | 01: Area 4 RF access: Read always allowed, Write allowed if RF user security session is open | | | b3-b2 | | 10: Area 4 RF access: Read allowed if RF user security session is open, Write allowed if RF user security session is open | 00b | | | | 11: Area 4 RF access: Read allowed if RF user security session is open, Write always forbidden | | | b7-b4 | RFU | - | 0000b | Note: Refer to Table 11. System configuration memory map for the RFA4SS register. Table 51. I2CSS access | RF | | I2C | | |--------------|--|---------------|----------------------------------------------------------| | Command Type | | Address | Туре | | No access | | E2 = 1, 000Bh | R always, W if I <sup>2</sup> C security session is open | DS10925 - Rev 9 page 50/200 Table 52. I2CSS | Bit | Name | Function | Factory Value | |-------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | | | 00: Area 1 I <sup>2</sup> C access: Read always allowed, Write always allowed | | | b1-b0 | RW_PROTECTION_A1 | 01: Area 1 I <sup>2</sup> C access: Read always allowed, Write allowed if I <sup>2</sup> C user security session is open | 00b | | D1-00 | KW_I KOTEOTION_AT | 10: Area 1 I <sup>2</sup> C access: Read always allowed, Write always allowed | 005 | | | | 11: Area 1 $I^2C$ access: Read always allowed, Write allowed if $I^2C$ user security session is open | | | | | 00: Area 2 I <sup>2</sup> C access: Read always allowed, Write always allowed | | | | | 01: Area 2 I <sup>2</sup> C access: Read always allowed, Write allowed if I <sup>2</sup> C user security session is open | | | b3-b2 | RW_PROTECTION_A2 | 10: Area 2 I <sup>2</sup> C access: Read allowed if I <sup>2</sup> C user security session is open, Write always allowed | 00b | | | | 11: Area 2 I <sup>2</sup> C access: Read allowed if I <sup>2</sup> C security session is open, Write allowed if I <sup>2</sup> C security session is open | | | | RW_PROTECTION_A3 | 00: Area 3 I <sup>2</sup> C access: Read always allowed, Write always allowed | | | | | 01: Area 3 I <sup>2</sup> C access: Read always allowed, Write allowed if I <sup>2</sup> C user security session is open | | | b5-b4 | | 10: Area 3 I <sup>2</sup> C access: Read allowed if I <sup>2</sup> C user security session is open, Write always allowed | 00b | | | | 11: Area 3 I <sup>2</sup> C access: Read allowed if I <sup>2</sup> C security session is open, Write allowed if I <sup>2</sup> C security session is open | | | | | 00: Area 4 I <sup>2</sup> C access: Read always allowed, Write always allowed | | | | | 01: Area 4 I <sup>2</sup> C access: Read always allowed, Write allowed if I <sup>2</sup> C user security session is open | | | b7-b6 | RW_PROTECTION_A4 | 10: Area 4 I <sup>2</sup> C access: Read allowed if I <sup>2</sup> C user security session is open, Write always allowed | 00b | | | | 11: Area 4 I <sup>2</sup> C access: Read allowed if I <sup>2</sup> C security session is open, Write allowed if I <sup>2</sup> C security session is open | | Note: Refer to Table 11. System configuration memory map for the I2CSS register. DS10925 - Rev 9 page 51/200 Table 53. LOCK\_CCFILE access | RF | RF | | | |------------------------------------------------------------------|-------------------------------------------|---------------|---------------------------------| | Command | Туре | Address | Туре | | Lock Block (cmd code 22h) @00h/01h | | | | | Ext Lock Block (cmd code 32h) @00h/01h | | | | | Read Block (cmd code 20h) @00h/01h | | | | | Fast Read Block <sup>(1)</sup> (cmd code C0h) @00h/01h | | | | | Ext Read Block <sup>(1)</sup> (cmd code 30h) @00h/01h | | | | | Fast Ext Read Block <sup>(1)</sup> (cmd code C4h) @00h/01h | R always | | | | Read Multi Block <sup>(1)</sup> (cmd code 23h) @00h/01h | b0: W if Block 00h is not already locked, | E2 = 1, 000Ch | R always, W if I <sup>2</sup> C | | Ext Read Multi Block <sup>(1)</sup> (cmd code 33h) @00h/01h | b1: W if Block 01h is not already locked. | | security session is open | | Fast Read Multi Block <sup>(1)</sup> (cmd code C3h)<br>@00h/01h | | | | | Fast Ext Read Multi Block <sup>(1)</sup> (cmd code C5h) @00h/01h | | | | | Get Multi Block SS (cmd code 2Ch) @00h/01h | | | | | Ext Get Multi Block SS (cmd code 3Ch) @00h/01h | | | | <sup>1.</sup> With option flag set to 1. # Table 54. LOCK\_CCFILE | Bit | Name | Function | Factory Value | |------------|---------|------------------------------------|---------------| | b0 | LCKBCKO | 0: Block @ 00h is not Write locked | Ob | | DU | LCKBCK0 | 1: Block @ 00h is Write locked | 0b | | <b>b</b> 4 | LOVDOVA | 0: Block @ 01h is not Write locked | Ole | | b1 | LCKBCK1 | 1: Block @ 01h is Write locked | 0b | | b7-b2 | RFU | - | 000000b | Note: Refer to Table 11. System configuration memory map for the LOCK\_CCFILE register. # Table 55. LOCK\_CFG access | RF | I2C | | | |--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------| | Command | Туре | Address | Туре | | Read Configuration (cmd code A0h) @0Fh Write Configuration (cmd code A1h) @0Fh | R always, W if RF configuration security session is open and configuration not locked | E2 = 1, 000Fh | R always, W if I <sup>2</sup> C security session is open | # Table 56. LOCK\_CFG | Bit | Name | Function | Factory Value | |-------|---------|-------------------------------------------------------|---------------| | b0 | LCK_CFG | Configuration is unlocked Configuration is locked | 0b | | b7-b1 | RFU | - | 000000b | Note: Refer to Table 11. System configuration memory map for the LOCK\_CFG register. DS10925 - Rev 9 page 52/200 Table 57. I2C\_PWD access | RF | | | 12C | | | |----|----------------------|--|----------------------------------------------------------------|------------------------------------------------------------------------------------------------|--| | C | Command Type Address | | Address | Туре | | | | No access | | E2 = 1, 0900h to 0907h, Present/Write password command format. | R if I <sup>2</sup> C security session is open, W if I <sup>2</sup> C security session is open | | # Table 58. I2C\_PWD | I2C address | Bit | Name | Function | Factory<br>Value | |-------------|-------|---------|----------------------------------------------------------------|------------------| | 0900h | b7-b0 | | Byte 7 (MSB) of password for I <sup>2</sup> C security session | 00h | | 0901h | b7-b0 | | Byte 6 of password for I <sup>2</sup> C security session | 00h | | 0902h | b7-b0 | | Byte 5 of password for I <sup>2</sup> C security session | 00h | | 0903h | b7-b0 | ISC DWD | Byte 4 of password for I <sup>2</sup> C security session | 00h | | 0904h | b7-b0 | I2C_PWD | Byte 3 of password for I <sup>2</sup> C security session | 00h | | 0905h | b7-b0 | | Byte 2 of password for I <sup>2</sup> C security session | 00h | | 0906h | b7-b0 | | Byte 1 of password for I <sup>2</sup> C security session | 00h | | 0907h | b7-b0 | | Byte 0 (LSB) of password for I <sup>2</sup> C security session | 00h | Note: Refer to Table 11. System configuration memory map for the I2C\_PWD register. Table 59. RF\_PWD\_0 access | RF | 12 | C C | | |---------------------------------------------------------------|-------------------------------------------------|---------|-------| | Command | Туре | Address | Туре | | Present Password (cmd code B3h) Write Password (cmd code B1h) | WO if RF configuration security session is open | No ad | ccess | # Table 60. RF\_PWD\_0 | Bit | Name | Function | Factory Value | |-------|----------|----------------------------------------------------------------|---------------| | | | Byte 0 (LSB) of password for RF configuration security session | 00h | | | | Byte 1 of password for RF configuration security session | 00h | | | RF_PWD_0 | Byte 2 of password for RF configuration security session | 00h | | b7-b0 | | Byte 3 of password for RF configuration security session | 00h | | D7-DU | | Byte 4 of password for RF configuration security session | 00h | | | | Byte 5 of password for RF configuration security session | 00h | | | | Byte 6 of password for RF configuration security session | 00h | | | | Byte 7 (MSB) of password for RF configuration security session | 00h | Note: Refer to Table 11. System configuration memory map for the RF\_PWD\_0 register. DS10925 - Rev 9 page 53/200 Table 61. RF\_PWD\_1 access | RF | I2C | | | |---------------------------------------------------------------|--------------------------------------------------------------------|-----------|------| | Command | Туре | Address | Туре | | Present Password (cmd code B3h) Write Password (cmd code B1h) | WO if RF configuration security session is open with RF password 1 | No access | | Table 62. RF\_PWD\_1 | Bit | Name | Function | Factory Value | |-------|----------|---------------------------------------------------------|---------------| | | | Byte 0 (LSB) of password 1 for RF user security session | 00h | | | | Byte 1 of password 1 for RF user security session | 00h | | | | Byte 2 of password 1 for RF user security session | 00h | | b7-b0 | RF_PWD_1 | Byte 3 of password 1 for RF user security session | 00h | | 07-00 | | Byte 4 of password 1 for RF user security session | 00h | | | | Byte 5 of password 1 for RF user security session | 00h | | | | Byte 6 of password 1 for RF user security session | 00h | | | | Byte 7 (MSB) of password 1 for RF user security session | 00h | Note: Refer to Table 11. System configuration memory map for the RF\_PWD\_1 register. Table 63. RF\_PWD\_2 access | RF | I2C | | | |---------------------------------------------------------------|-----------------------------------------------------------|-----------|------| | Command | Туре | Address | Туре | | Present Password (cmd code B3h) Write Password (cmd code B1h) | WO if RF user security session is open with RF password 2 | No access | | Table 64. RF\_PWD\_2 | Bit | Name | Function | Factory Value | |-------|----------|---------------------------------------------------------|---------------| | | RF_PWD_2 | Byte 0 (LSB) of password 2 for RF user security session | 00h | | | | Byte 1 of password 2 for RF user security session | 00h | | | | Byte 2 of password 2 for RF user security session | 00h | | b7-b0 | | Byte 3 of password 2 for RF user security session | 00h | | D7-D0 | | Byte 4 of password 2 for RF user security session | 00h | | | | Byte 5 of password 2 for RF user security session | 00h | | | | Byte 6 of password 2 for RF user security session | 00h | | | | Byte 7 (MSB) of password 2 for RF user security session | 00h | Note: Refer to Table 11. System configuration memory map for the RF\_PWD\_2 register. DS10925 - Rev 9 page 54/200 ### Table 65. RF\_PWD\_3 access | RF | | I2C | | |---------------------------------------------------------------|-----------------------------------------------------------|-----------|------| | Command | Туре | Address | Туре | | Present Password (cmd code B3h) Write Password (cmd code B1h) | WO if RF user security session is open with RF password 3 | No access | | ## Table 66. RF\_PWD\_3 | Bit | Name | Function | Factory Value | |-------|----------|---------------------------------------------------------|---------------| | | RF_PWD_3 | Byte 0 (LSB) of password 3for RF user security session | 00h | | | | Byte 1 of password 3 for RF user security session | 00h | | | | Byte 2 of password 3 for RF user security session | 00h | | b7-b0 | | Byte 3 of password 3 for RF user security session | 00h | | 07-00 | | Byte 4 of password 3 for RF user security session | 00h | | | | Byte 5 of password 3 for RF user security session | 00h | | | | Byte 6 of password 3 for RF user security session | 00h | | | | Byte 7 (MSB) of password 3 for RF user security session | 00h | Note: Refer to Table 11. System configuration memory map for the RF\_PWD\_3 register. Table 67. I2C\_SSO\_Dyn access | RF | | I2C | | |--------------|--|---------------|------| | Command Type | | Address | Туре | | No access | | E2 = 0, 2004h | RO | ### Table 68. I2C\_SSO\_Dyn | Bit | Name | Function | Factory Value | |-------|---------|--------------------------------------------------------------|---------------| | b7-b1 | RFU | - | 0b | | | | 0: I <sup>2</sup> C security session close | | | b0 | I2C_SSO | 1: I <sup>2</sup> C security session open | 0b | | | | (Set or reset via I <sup>2</sup> C Present password command) | | Note: Refer to Table 12. Dynamic registers memory map for the I2C\_SSO\_Dyn register. ### 5.6.2 Passwords and security sessions ST25DVxxx provides protection of user memory and system configuration static registers. RF user and $I^2C$ host can access those protected data by opening security sessions with the help of passwords. Access rights is more restricted when security sessions are closed, and less restricted when security sessions are open. Dynamic registers and fast transfer mode mailbox are not protected by any security session. There is three type of security sessions, as shown in Table 69. Security session type: DS10925 - Rev 9 page 55/200 | I ania ku | SACHIFITM | , ebeeivu | TV/DA | |--------------------|-----------|-----------|-------| | <b>Table 69. S</b> | Jecuitiv | 36331011 | LVDG | | | | | | | Security session | Open by presenting | Right granted when security session is open, and until it is closed | |------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RF user | RF password 1, 2 or 3 <sup>(1)</sup> (RF_PWD_1, RF_PWD_2, RF_PWD_3) | RF user access to protected user memory as defined in RFA <sub>i</sub> SS registers RF user write access to RF password 1, 2 or 3 <sup>(2)</sup> | | RF configuration | RF password 0<br>(RF_PWD_0) | RF user write access to configuration static registers RF user write access to RF password 0 | | l <sup>2</sup> C | I <sup>2</sup> C password<br>(I2C_PWD) | I <sup>2</sup> C host access to protected user memory as defined in I2CSS register I <sup>2</sup> C host write access to configuration static registers I <sup>2</sup> C host write access to I <sup>2</sup> C password | - 1. Password number must be the same as the one selected for protection. - 2. Write access to the password number corresponding to the password number presented. All passwords are 64-bits long, and default factory passwords value is 00000000000000000h. The ST25DVxxx passwords management is organized around RF and I<sup>2</sup>C dedicated set of commands to access the dedicated registers in system configuration area where password values are stored. The dedicated password commands in RF mode are: - Write Password command (code B1h): see Section 7.6.35 Write Password. - Present Password command (code B3h): see Section 7.6.36 Present Password. RF user possible actions for security sessions are: - Open RF user security session: Present Password command, with password number 1, 2 or 3 and the valid corresponding password - Write RF password: Present Password command, with password number (0, 1, 2 or 3) and the current valid corresponding password. Then Write Password command, with same password number (0, 1, 2 or 3) and the new corresponding password. - Close RF user security session: Present Password command, with a different password number than the one used to open session or any wrong password. Or remove tag from RF field (POR). Presenting a password with an invalid password number doesn't close the session. - **Open RF configuration security session**: Present Password command, with password number 0 and the valid password 0. - Close RF configuration security session: Present Password command, with a password number different than 0, or password number 0 and wrong password 0. Or remove tag from RF field (POR). Presenting a password with an invalid password number doesn't close the session. Opening any new RF security session (user or configuration) automatically close the previously open one (even if it fails). There is no interaction between I<sup>2</sup>C and RF security sessions. Both are independent, and can run in parallel. #### Caution: If ST25DVxxx is powered through $V_{CC}$ , removing $V_{CC}$ during a RF command can abort the command. As a consequence, before writing a new password, RF user should check if $V_{CC}$ is ON, by reading EH\_CTRL\_Dyn register bit 3 (VCC\_ON), and eventually ask host to maintain or to shut down $V_{CC}$ , before issuing the Write Password command in order to avoid password corruption. To make the application more robust, it is recommended to use addressed or selected mode during write password operations to get the traceability of which tags/UID have been programmed. DS10925 - Rev 9 page 56/200 Figure 22. RF security sessions management 1. Presenting a password with an invalid password number doesn't close the session. The dedicated password commands in I<sup>2</sup>C mode are: - I<sup>2</sup>C Write Password command: see Section 6.6.2 I2C write password command description. - I<sup>2</sup>C Present Password command: see Section 6.6.1 I2C present password command description. I<sup>2</sup>C host possible actions for security sessions are: - Open I 2 C security session: I2C Present Password command with valid I2C password. - Write I <sup>2</sup> C password: I<sup>2</sup>C Present Password command with valid I<sup>2</sup>C password. Then I<sup>2</sup>C Write Password command with new I<sup>2</sup>C password. - Close I <sup>2</sup> C security session: I<sup>2</sup>C Present Password command with wrong I<sup>2</sup>C password. Or remove tag V<sub>CC</sub> power supply (POR). - Check if I <sup>2</sup> C security session is open: I<sup>2</sup>C host can read the current status (open or closed) of I<sup>2</sup>C security session by reading the I2C\_SSO\_Dyn register. There is no interaction between I<sup>2</sup>C and RF security sessions. Both are independent and can run in parallel. DS10925 - Rev 9 page 57/200 VCC OFF VCC VCC ON OFF Any other I2C security command session closed 12C SSO=00h Present Present I2C\_PWD I2C PWD not OK ŌΚ I2C security session opened Any other I2C\_SSO=01h command Figure 23. I<sup>2</sup>C security sessions management ### 5.6.3 User memory protection On factory delivery, areas are not protected. Each area can be individually protected in read and/or write access from RF and I<sup>2</sup>C. Area 1 is always readable (from RF and I<sup>2</sup>C). Furthermore, RF blocks 0 and 1 (I<sup>2</sup>C bytes 0000h to 0007h) can be independently write locked. #### User memory protection from RF access In RF mode, each memory area of the ST25DVxxx can be individually protected by one out of three available passwords (RF password 1, 2 or 3), and each area can also have individual Read/Write access conditions. For each area, an RFA<sub>i</sub>SS register is used to: - Select the RF password that unlock the RF user security session for this area - Select the protection against read and write operations for this area (See Table 44. RFA1SS, Table 46. RFA2SS, Table 48. RFA3SS, and Table 50. RFA4SS for details about available read and write protections). Note: Setting 00b in PWD\_CTRL\_ $A_i$ field means that RF user security session cannot be open by any password for the corresponding area. When updating RFA<sub>i</sub>SS registers, the new protection value is effective immediately after the register write completion. DS10925 - Rev 9 page 58/200 - Rf blocks 0 and 1 are exceptions to this protection mechanism: - RF blocks 0 and 1 can be individually write locked by issuing a (Ext) Lock Single Block RF command. Once locked, they cannot be unlock through RF. LOCK\_CCFILE register is automatically updated when using (Ext) Lock Single Block command. - A RF user needs no password to lock blocks 0 and/or 1. - Locking blocks 0 and/or 1 is possible even if the configuration is locked (LOCK\_CFG=1). - Locking blocks 0 and/or 1 is possible even if the area is write locked. - Unlocking area1 (through RFA1SS register) does not unlock blocks 0 and 1 if they have been locked though (Ext) Lock Block command. - Once locked, the RF user cannot unlock blocks 0 and/or 1 (can be done by I<sup>2</sup>C host). Note: When areas size are modified (ENDAi registers), RFAiSS registers are not modified. #### User memory protection from I<sup>2</sup>C access In I<sup>2</sup>C mode, each area can also have individual Read/Write access conditions, but only one I<sup>2</sup>C password is used to unlock I<sup>2</sup>C security session for all areas. The I2CSS register is used to set protection against read and write operation for each area (see Table 52. I2CSS for details about available read and write protections). When updating I2CSS registers, the new protection value is effective immediately after the register write completion. I<sup>2</sup>C user memory Bytes 0000h to 0003h (RF Block 0) and 0004h to 0007h (RF Block 1) can be individually locked and unlocked by writing in the LOCK\_CCFILE register (by group of 4 Bytes), independently of Area 1 protection. Unlocking Area 1 (through I2CSS register) does not unlock those bytes if they have been locked though the LOCK\_CCFILE register. Note: When areas size are modified (ENDAi registers), I2CSS register is not modified. #### Retrieve the security status of a user memory block or byte RF user can read a block security status by issuing following RF commands: - (Ext) Get Multiple Blocks Security Status command. - (Ext) (Fast) Read Single Block with option flag set to 1. - (Ext) (Fast) Read Multiple Blocks with option flag set to 1. ST25DV will respond with a Block security status containing a Lock\_bit flag as specified in ISO 15693 standard. This lock\_bit flag is set to one if block is locked against write. Lock bit flag value may vary if corresponding RF user security session is open or closed. I<sup>2</sup>C host can retrieve a block security status by reading the I2CSS register to get security status of the corresponding area and by reading the I2C\_SSO\_Dyn register to know if I<sup>2</sup>C security session is open or closed. For blocks 0 and 1 (Bytes 0000h to 0007h in $I^2C$ user memory), lock status can also be read in the LOCK\_CCFILE register. ## 5.6.4 System memory protection By default, system memory (static registers) is write protected, both in RF and I<sup>2</sup>C. $I^2C$ host must open the $I^2C$ security session (by presenting a valid $I^2C$ password) to enable write access to system configuration static registers. I<sup>2</sup>C host doesn't have read or write access to RF passwords. By default, I<sup>2</sup>C host can read all system configuration static registers (except RF passwords) In RF, to enable write access to system configuration static registers, RF user must open the RF configuration security session (by presenting a valid RF password 0) and system configuration must not be locked (LOCK\_CFG=00h). RF doesn't have read or write access to I<sup>2</sup>C password. By default, RF user can read all system configuration static registers, except all passwords, LOCK\_CCFILE, LOCK\_DSFID and LOCK\_AFI. RF configuration lock: DS10925 - Rev 9 page 59/200 Note: - RF write access to system configuration static registers can be locked by writing 01h in the LOCK\_CFG register (by RF or I<sup>2</sup>C). - RF user cannot unlock system configuration if LOCK\_CFG=01h, even after opening RF configuration security session (only I<sup>2</sup>C host can unlock system configuration). - When system configuration is locked (LOCK CFG=01h), it is still possible to change RF passwords (0 to 3). #### Device identification registers: - AFI and DFSID registers can be independently locked by RF user, issuing respectively a Lock AFI and a Lock DSFID command. Lock is definitive: once locked, AFI and DSFID registers cannot be unlocked (either by RF or I<sup>2</sup>C). System configuration locking mechanism (LOCK\_CFG=01h) does not lock AFI and DSFID registers. - Other device identification registers (MEM\_SIZE, BLK\_SIZE, IC\_REF, UID, IC\_REV) are read only registers for both RF and I<sup>2</sup>C. ## 5.7 Device Parameter Registers ### Table 70. LOCK\_DSFID access | RF | | 12C | | |---------------------------|------------------------|---------------|------| | Command Type | | Address | Туре | | Lock DSFID (cmd code 2Ah) | WO if DSFID not locked | E2 = 1, 0010h | RO | ### Table 71. LOCK\_DSFID | Bit | Name | Function | Factory Value | |-------|------------|-------------------------------------------|---------------| | b0 | LOCK_DSFID | 0: DSFID is not locked 1: DSFID is locked | 0b | | b7-b1 | RFU | - | 000000b | Refer to Table 11. System configuration memory map for the LOCK\_DSFID register. ### Table 72. LOCK\_AFI access | RF | | I2C | | |-------------------------|----------------------|---------------|------| | Command Type A | | Address | Туре | | Lock AFI (cmd code 28h) | WO if AFI not locked | E2 = 1, 0011h | RO | ## Table 73. LOCK\_AFI | Bit | Name | Function | Factory Value | |-------|----------|---------------------------------------|---------------| | b0 | LOCK_AFI | 0: AFI is not locked 1: AFI is locked | 0b | | b7-b1 | RFU | - | 000000b | Note: Refer to Table 11. System configuration memory map for the LOCK\_AFI register. DS10925 - Rev 9 page 60/200 ### Table 74. DSFID access | RF | | I2C | | |------------------------------------|---------------------------------|---------------|------| | Command | Туре | Address | Туре | | Inventory (cmd code 01h) | | | | | Get System Info (cmd code 2Bh) | D. I. WIEDOEID III I | E2 = 1, 0012h | RO | | Ext Get System Info (cmd code 3Bh) | R always, W if DSFID not locked | | | | Write DSFID (cmd code 28h) | | | | #### Table 75. DSFID | Bit | Name | Function | Factory Value | |-------|-------|----------------------------------------------|---------------| | b7-b0 | DSFID | ISO/IEC 15693 Data Storage Format Identifier | 00h | Note: Refer to Table 11. System configuration memory map for the DSFID register. ### Table 76. AFI access | RF | | I2C | | |------------------------------------|-------------------------------|---------------|------| | Command | Туре | Address | Туре | | Inventory (cmd code 01h) | | | | | Get System Info (cmd code 2Bh) | District Mif AEI not looked | F2 = 1 0012h | RO | | Ext Get System Info (cmd code 3Bh) | R always, W if AFI not locked | E2 = 1, 0013h | KO | | Write AFI (cmd code 27h) | | | | ### Table 77. AFI | Bit | Name | Function | Factory Value | |-------|------|---------------------------------------------|---------------| | b7-b0 | AFI | ISO/IEC 15693 Application Family Identifier | 00h | Note: Refer to Table 11. System configuration memory map for the AFI register. # Table 78. MEM\_SIZE access | RF | | | I2C | |------------------------------------|------|----------------|------| | Command | Туре | Address | Туре | | Get System Info (cmd code 2Bh) (1) | RO | E2=1, 0014h to | RO | | Ext Get System Info (cmd code 3Bh) | NO | 0015h | NO | 1. Only ST25DV04K-IE and ST25DV04K-JF DS10925 - Rev 9 page 61/200 Table 79. MEM\_SIZE | I <sup>2</sup> C<br>Address | Bit | Name | Function | Factory Value | | |-----------------------------|-------|----------|---------------------------------------------------------------------------|-------------------|-------------------| | | | | | ST25DV04K-xx: 7Fh | | | 0014h | b7-b0 | | expressed in RF blocks ST25D Address 0015h: MSB byte of the memory size | | ST25DV16K-xx: FFh | | | | MEM CIZE | | ST25DV64K-xx: FFh | | | | | MEM_SIZE | | ST25DV04K-xx: 00h | | | 0015h | b7-b0 | | | ST25DV16K-xx: 01h | | | | | | CAPICOGCO III IXI BIOGRO | ST25DV64K-xx: 07h | | Note: Refer to Table 11. System configuration memory map for the MEM\_SIZE register. Table 80. BLK\_SIZE access | RF | | | 12C | |------------------------------------|------|-----------------|------| | Command | Туре | Address | Туре | | Get System Info (cmd code 2Bh) (1) | RO | E2 = 1, 0016h | RO | | Ext Get System Info (cmd code 3Bh) | RO | E2 = 1, 00 1011 | , RO | 1. Only ST25DV04K-IE and ST25DV04K-JF ### Table 81. BLK\_SIZE | Bit | Name | Function | Factory Value | | |-------|----------|---------------------------|---------------|--| | b7-b0 | BLK_SIZE | RF user memory block size | 03h | | Note: Refer to Table 11. System configuration memory map for the BLK\_SIZE register. # Table 82. IC\_REF access | RF | | I2C | | |------------------------------------|----|---------------|------| | Command Type | | Address | Туре | | Get System Info (cmd code 2Bh) | RO | E2 = 1, 0017h | RO | | Ext Get System Info (cmd code 3Bh) | RO | 2 - 1,001711 | RO | # Table 83. IC\_REF | Bit | Name | Function | Factory Value | |-------|-----------------------------------------|----------------------------|-------------------| | | | | ST25DV04K-IE: 24h | | | b7-b0 IC_REF ISO/IEC 15693 IC Reference | ISO/IEC 15693 IC Reference | ST25DV16K-IE: 26h | | h7 h0 | | | ST25DV64K-IE: 26h | | 00-70 | | | ST25DV04K-JF: 24h | | | | | ST25DV16K-JF: 26h | | | | ST25DV64K-JF: 26h | | Note: Refer to Table 11. System configuration memory map for the IC\_REF register. DS10925 - Rev 9 page 62/200 ### Table 84. UID access | RF | | 12C | | |------------------------------------|------|----------------------|------| | Command | Туре | Address | Туре | | Inventory (cmd code 01h) | | | | | Get System Info (cmd code 2Bh) | RO | E2=1, 0018h to 001Fh | RO | | Ext Get System Info (cmd code 3Bh) | | | | # Table 85. UID | I <sup>2</sup> C<br>Address | Bit | Name | Function | Factory Value | | | | |-----------------------------|-------|------|-------------------------------------------|-------------------------------|--|--|-------------------| | 0018h | | | ISO/IEC 15693 UID byte 0 (LSB) | | | | | | 0019h | | | ISO/IEC 15693 UID byte 1 | | | | | | 001Ah | | | ISO/IEC 15693 UID byte 2 | IC manufacturer serial number | | | | | 001Bh | | | ISO/IEC 15693 UID byte 3 | | | | | | 001Ch | | | ISO/IEC 15693 UID byte 4 | | | | | | | | | | ST25DV04K-IE: 24h | | | | | | b7-b0 | UID | | ST25DV16K-IE: 26h | | | | | 001Dh | | | ISO/IEC 15693 UID byte 5: ST Product code | ST25DV64K-IE: 26h | | | | | ווטוטו | | | | ST25DV04K-JF: 25h | | | | | | | | | ST25DV16K-JF: 27h | | | | | | | | | | | | ST25DV64K-JF: 27h | | 001Eh | | | ISO/IEC 15693 UID byte 6: IC Mfg code | 02h | | | | | 001Fh | | | ISO/IEC 15693 UID byte 7 (MSB) | E0h | | | | Note: Refer to Table 11. System configuration memory map for the UID register. # Table 86. IC\_REV access | RF | | | 12C | |--------------|-----------|---------|------| | Command Type | | Address | Туре | | No acce | No access | | RO | # Table 87. IC\_REV | Bit | Name | Function | Factory Value | |-------|--------|-------------|-----------------------| | b7-b0 | IC_REV | IC revision | Depending on revision | Note: Refer to Table 11. System configuration memory map for the IC\_REV register. DS10925 - Rev 9 page 63/200 Condition # 6 I2C operation ## 6.1 I2C protocol The device supports the I<sup>2</sup>C protocol. This is summarized in Figure 24. I<sup>2</sup>C bus protocol. Any device that sends data to the bus is defined as a transmitter, and any device that reads data is defined as a receiver. The device that controls the data transfer is known as the bus master, and the other as the slave device. A data transfer can only be initiated by the bus master, which also provides the serial clock for synchronization. The ST25DVxxx device is a slave in all communications. SCL SDA SDA → SDA → START STOP Input Change Condition Condition SCL MSB **ACK** SDA START Condition SCL MSB ACK SDA STOP Figure 24. I<sup>2</sup>C bus protocol ### 6.1.1 Start condition Start is identified by a falling edge of serial data (SDA) while the serial clock (SCL) is stable in the high state. A Start condition must precede any data transfer command. The device continuously monitors (except during a write cycle) the SDA and the SCL for a Start condition, and does not respond unless one is given. DS10925 - Rev 9 page 64/200 #### 6.1.2 Stop condition Stop is identified by a rising edge of serial data (SDA) while the serial clock (SCL) is stable and driven high. A Stop condition terminates communication between the device and the bus master. A Read command that is followed by NoAck can be followed by a Stop condition to force the device into the Standby mode. A Stop condition at the end of a Write command triggers the internal write cycle. #### 6.1.3 Acknowledge bit (ACK) The acknowledge bit is used to indicate a successful byte transfer. The bus transmitter, whether a bus master or a slave device, releases the serial data (SDA) after sending eight bits of data. During the 9<sup>th</sup> clock pulse period, the receiver pulls the SDA low to acknowledge the receipt of the eight data bits. #### 6.1.4 Data input During data input, the device samples serial data (SDA) on the rising edge of the serial clock (SCL). For correct device operation, the SDA must be stable during the rising edge of the SCL, and the SDA signal must change only when the SCL is driven low. ### 6.2 I2C timeout During the execution of an I<sup>2</sup>C operation, RF communications are not possible. To prevent RF communication freezing due to inadvertent indeterminate instructions sent to the I²C bus, the ST25DVxxx features a timeout mechanism that automatically resets the I²C logic block. #### 6.2.1 I2C timeout on Start condition I<sup>2</sup>C communication with the ST25DVxxx starts with a valid Start condition, followed by a device select code. If the delay between the Start condition and the following rising edge of the serial clock (SCL) that samples the most significant of the Device Select exceeds the t<sub>START\_OUT</sub> time (see Table 248. I<sup>2</sup>C AC characteristics up to 85°C and Table 249. I<sup>2</sup>C AC characteristics up to 125°C), the I<sup>2</sup>C logic block is reset and further incoming data transfer is ignored until the next valid Start condition. Figure 25. I<sup>2</sup>C timeout on Start condition #### 6.2.2 I2C timeout on clock period During data transfer on the $I^2C$ bus, if the serial clock pulse width high ( $t_{CHCL}$ ) or serial clock pulse width low ( $t_{CLCH}$ ) exceeds the maximum value specified in Table 248. $I^2C$ AC characteristics up to 85°C and Table 249. $I^2C$ AC characteristics up to 125°C, the $I^2C$ logic block is reset and any further incoming data transfer is ignored until the next valid Start condition. DS10925 - Rev 9 page 65/200 ### 6.3 Device addressing To start a communication between the bus master and the slave device, the bus master must initiate a Start condition. Following this, the bus master sends the device select code, shown in Table 88. Device select code (on Serial Data (SDA), the most significant bit first). The device select code consists of a 4-bit device type identifier and a 3-bit Chip Enable "Address" (E2,1,1). To address the memory array, the 4-bit device type identifier is 1010b. Refer to Table 88. Device select code. The eighth bit is the Read/Write bit (RW). It is set to 1 for Read and to 0 for Write operations. Table 88. Device select code | | Device type identifier <sup>(1)</sup> | | | Chip Enable address | | | R₩ | | |--------------------|---------------------------------------|----|----|---------------------|-------------------|----|----|----| | | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | | Device select code | 1 | 0 | 1 | 0 | E2 <sup>(2)</sup> | 1 | 1 | R₩ | - 1. The most significant bit, b7, is sent first. - E2 is not connected to any external pin. It is however used to address the ST25DVxxx as described in Section 4 Memory management. - E2 = 0, access to user memory, Dynamic registers or Mailbox. - E2 =1, access to system area. If a match occurs on the device select code, the corresponding device gives an acknowledgment on serial data (SDA) during the ninth bit time. If the device does not match the device select code, it deselects itself from the bus, and goes into Standby mode. Table 89. Operating modes | Mode | RW bit | Bytes | Initial sequence | | | |----------------------|-------------------------|------------|----------------------------------------------------|--|--| | Current address read | ad 1 Start, device sele | | Start, device select, $R\overline{W}$ = 1 | | | | Random address read | 0 | 1 | Start, device select, $R\overline{W}$ = 0, address | | | | Random address read | 1 | | reStart, device select, RW = 1 | | | | Sequential read 1 | | ≥ 1 | Similar to current or random address read | | | | Byte write 0 | | 1 | Start, device select, $R\overline{W} = 0$ | | | | Sequential write | 0 | ≤ 256 byte | Start, device select, RW = 0 | | | ### 6.4 I2C Write operations Following a Start condition, the bus master sends a device select code with the Read/Write bit (RW) reset to 0. The device acknowledges this, and waits for two address bytes. The device responds to each address byte with an acknowledge bit, and then waits for the data byte. Each data byte in the memory has a 16-bit (two-byte wide) address. The most significant byte (see Table 90. Address most significant byte) is sent first, followed by the least significant byte (see Table 91. Address least significant byte). Bits b15 to b0 form the address of the byte in memory. Table 90. Address most significant byte | b15 b14 b13 b12 b11 b10 b9 | b8 | |----------------------------|----| |----------------------------|----| Table 91. Address least significant byte | h7 | h.C | b.E | h.1 | h2 | h2 | h1 | h0 | |----|-----|-----|-----|----|----|----|----| | D7 | b6 | 00 | D4 | b3 | 02 | DI | p0 | DS10925 - Rev 9 page 66/200 When the bus master generates a Stop condition immediately after the Ack bit (in the tenth-bit time slot), either at the end of a byte write or a sequential write, the internal write cycle is triggered. A Stop condition at any other time slot does not trigger the internal write cycle. After the Stop condition, the delay t<sub>W</sub>, and the successful completion of a Write operation, the device's internal address counter is incremented automatically, to point to the next byte address after the last one that was modified. After an unsuccessful write operation, ST25DVxxx enters in I2C dead state: internal address counter is not incremented, and ST25DVxxx is waiting for a full new I2C instruction (address counter stops to be incremented after the first NoAck bit). During the internal write cycle, the serial data (SDA) signal is disabled and the device does not respond to any requests. #### Caution: I<sup>2</sup>C Writing data in user or system memory (EEPROM), transit via the 256-Bytes fast transfer mode's buffer. Consequently fast transfer mode must be deactivated before starting any write operation in user or system memory, otherwise command will be NotACK, programming is not done and device goes in standby mode. #### 6.4.1 I2C Byte write After the device select code and the address bytes, the bus master sends one data byte. If byte write is not inhibited, the device replies with Ack. If byte write is inhibited, the device replies with NoAck. The bus master terminates the transfer by generating a Stop condition (see Figure 26. Write mode sequences when write is not inhibited). For byte write in EEPROM (user memory or system configuration), internal programming starts after the Ack, for a duration of $t_W$ (as defined in Table 248. $I^2C$ AC characteristics up to 85°C and Table 249. $I^2C$ AC characteristics up to 125°C). For writes in fast transfer mode buffer or Dynamic registers, internal programming is done at the Ack. If byte write is inhibited, the device replies with NoAck. The bus master terminates the transfer by generating a Stop condition and byte location not is modified (see Figure 27. Write mode sequences when write is inhibited). Byte write is inhibited if byte complies with one of the following conditions: - · Byte is in user memory and is write protected with LOCK\_CCFILE register. - Byte is in user memory and is write protected with I2CSS register, and I<sup>2</sup>C security session is closed. - Byte is in user memory and fast transfer mode is activated. - · Byte is in system memory and is a Read Only register. - Byte is in system memory and I<sup>2</sup>C security session is closed. - Byte is in fast transfer mode's mailbox and is not the first Byte of mailbox. - Byte is in fast transfer mode's mailbox and mailbox is busy. - Byte is in fast transfer mode's mailbox and fast transfer mode is not activated. - Byte is in dynamic registers area and is a Read Only register. #### 6.4.2 I2C Sequential write The $I^2C$ sequential write allows up to 256 bytes to be written in one command, provided they are all located in the same user memory area or are all located in writable addresses. After each byte is transferred, the internal byte address counter is incremented. For each byte sent by the bus master: - If byte write is not inhibited, the device replies with Ack. - If byte write is inhibited, the device replies with NoAck. The transfer is terminated by the bus master generating a Stop condition: - For writes in EEPROM (user memory or system configuration), if all bytes have been Ack'ed, internal programming of all bytes starts after the last Ack, for a duration dependent on the number of bytes to write (see below). - For writes in fast transfer mode buffer or Dynamic registers, if all bytes have been Ack'ed, internal programming is done at the Ack. - If some bytes have been NotAck'ed, no internal programming is done (0 byte written). DS10925 - Rev 9 page 67/200 Byte write is inhibited if byte complies with conditions described in Section 6.4.1 I2C Byte write, in addition: - Byte is in user memory but does not belong to same area than previous received byte (area border crossing is forbidden). - 256 write occurrence have already been reached in the same sequential write. EEPROM memory (user memory and system configuration) is internally organized in pages of 4 bytes long. Data located in a same page all share the same most significant memory address bits b16-b2. $I^2C$ sequential write programming time in the EEPROM memory is dependent on this internal organization: total programming time is the $I^2C$ write time $t_W$ (as defined in Table 248. $I^2C$ AC characteristics up to 85°C and Table 249. $I^2C$ AC characteristics up to 125°C) multiplied by the number of internal EEPROM pages where the data must be programmed, including incomplete pages. For example, a 256 Bytes $I^2C$ sequential write, starting at address 0002h will write data over 65 pages. Total write time in this case is $t_W x$ 65. Figure 26. Write mode sequences when write is not inhibited Note: $N \le 256$ Figure 27. Write mode sequences when write is inhibited *Note: N* ≤ 256 DS10925 - Rev 9 page 68/200 ### 6.4.3 Minimizing system delays by polling on ACK During the internal write cycle, the device disconnects itself from the bus, and writes a copy of the data from its internal latches to the memory cells. The maximum $I^2C$ write time ( $t_w$ ) is shown in Table 248. $I^2C$ AC characteristics up to 85°C and Table 249. $I^2C$ AC characteristics up to 125°C, but the typical time is shorter. To make use of this, a polling sequence can be used by the bus master. The sequence, as shown in Figure 28, is: - Initial condition: a write cycle is in progress. - Step 1: the bus master issues a Start condition followed by a device select code (the first byte of the new instruction). - Step 2: if the device is busy with the internal write cycle, no Ack is returned and the bus master goes back to Step 1. If the device has terminated the internal write cycle, it responds with an Ack, indicating that the device is ready to receive the second part of the instruction (the first byte of this instruction having been sent during Step 1). Note: There is no need of polling when writing in dynamic registers or in mailbox, since programming time is null. Figure 28. Write cycle polling flowchart using ACK DS10925 - Rev 9 page 69/200 ## 6.5 I2C read operations Read operation in user memory is performed successfully only if: - Area to which the byte belongs is not read protected by I2CSS register. - Area to which the byte belongs is read protected by I2CSS register, but I<sup>2</sup>C security session is open. Read operations in system memory and dynamic registers are done independently of any protection mechanism, except I2C PWD register which needs I<sup>2</sup>C security session to be open first. Read operation in fast transfer mode's mailbox is performed successfully only if fast transfer mode is activated. If read is not successful, ST25DVxxx releases the bus and I<sup>2</sup>C host reads byte value FFh. After the successful completion of a read operation, the device's internal address counter is incremented by one, to point to the next byte address. After an unsuccessful read operation, ST25DVxxx enters in I<sup>2</sup>C dead state: internal address counter is not incremented, and ST25DVxxx is waiting for a full new I<sup>2</sup>C instruction. #### 6.5.1 Random Address Read A dummy write is first performed to load the address into this address counter (as shown in Figure 29. Read mode sequences) but without sending a Stop condition. Then, the bus master sends another Start condition, and repeats the device select code, with the Read/Write bit $(R\overline{W})$ set to 1. The device acknowledges this, and outputs the contents of the addressed byte. The bus master must not acknowledge the byte, and terminates the transfer with a Stop condition. #### 6.5.2 Current Address Read For the Current Address Read operation, following a Start condition, the bus master only sends a device select code with the Read/Write bit (RW) set to 1. The device acknowledges this, and outputs the byte addressed by the internal address counter. The counter is then incremented. The bus master terminates the transfer with a Stop condition, as shown in Figure 29. Read mode sequences, without acknowledging the byte. DS10925 - Rev 9 page 70/200 Figure 29. Read mode sequences ### 6.5.3 Sequential Read access This operation can be used after a Current Address Read or a Random Address Read. The bus master does acknowledge the data byte output, and sends additional clock pulses so that the device continues to output the next byte in sequence. To terminate the stream of bytes, the bus master must not acknowledge the last byte, and must generate a Stop condition, as shown in Figure 29. Read mode sequences. The output data comes from consecutive addresses, with the internal address counter automatically incremented after each byte output. Sequential read in user memory: - Sequential read cannot cross area borders. After reaching area border, device continues to output FFh - There is no roll over inside area or at the end of user memory (ST25DVxxx returns only FFh after last user memory byte address). Sequential read in system memory: - There is no roll over after reaching end of system memory (ST25DVxxx returns only FFh after last system memory byte address). - Sequential read in dynamic registers: - It is possible to read sequentially dynamic registers and fast transfer mode's mailbox (contiguous I<sup>2</sup>C addresses). DS10925 - Rev 9 page 71/200 #### Sequential read in dynamic registers: There is no roll over at the end of the mailbox (ST25DVxxx returns only FFh after last system memory byte address). ### 6.5.4 Acknowledge in Read mode For all Read commands, the device waits, after each byte read, for an acknowledgement during the ninth bit time. If the bus master does not drive serial data (SDA) low during this time, the device terminates the data transfer and switches to its Standby mode. # 6.6 I2C password management The ST25DVxxx controls $I^2C$ security session using an $I^2C$ 64-bit password. This $I^2C$ password is managed with two $I^2C$ dedicated commands: $I^2C$ present password and $I^2C$ write password. #### 6.6.1 I2C present password command description The $I^2C$ present password command is used in $I^2C$ mode to present the password to the ST25DVxxx. This is used to open $I^2C$ security session or to allow $I^2C$ password modification (see Section 5.6 Data Protection for detailed explanation about password usage). Following a Start condition, the bus master sends a device select code with the Read/Write bit (RW) reset to 0 and the Chip Enable bit E2 at 1. The device acknowledges this, as shown in Figure 30. I<sup>2</sup>C Present Password Sequence, and waits for two I<sup>2</sup>C password address bytes, 09h and 00h. The device responds to each address byte with an acknowledge bit, and then waits for the eight password data bytes, the validation code, 09h, and a resend of the eight password data bytes. The most significant byte of the password is sent first, followed by the least significant bytes. It is necessary to send the 64-bit password twice to prevent any data corruption during the sequence. If the two 64-bit passwords sent are not exactly the same, the ST25DVxxx does not start the internal comparison. When the bus master generates a Stop condition immediately after the Ack bit (during the tenth bit time slot). The ST25DVxxx compares the 64 received data bits with the 64 bits of the stored I<sup>2</sup>C password. If the values match, the I<sup>2</sup>C security session is open, and the I2C\_SSO\_Dyn register is set to 01h. If the values do not match, the I<sup>2</sup>C security session is closed and I2C\_SSO\_dyn register is set to 00h. I2C SSO Dyn is a Dynamic register, it can be checked via I<sup>2</sup>C host to know If I<sup>2</sup>C security session is open. Figure 30. I<sup>2</sup>C Present Password Sequence ### 6.6.2 I2C write password command description The I<sup>2</sup>C write password command is used to update the I<sup>2</sup>C password value (register I2C\_PWD). It cannot be used to update any of the RF passwords. After the write cycle, the new I<sup>2</sup>C password value is automatically activated. The I<sup>2</sup>C password value can only be modified after issuing a valid I<sup>2</sup>C present password command. DS10925 - Rev 9 page 72/200 Following a Start condition, the bus master sends a device select code with the Read/ Write bit (R W) reset to 0 and the Chip Enable bit E2 at 1. The device acknowledges this, as shown in Figure 31. I<sup>2</sup>C Write Password Sequence, and waits for the two I<sup>2</sup>C password address bytes, 09h and 00h. The device responds to each address byte with an acknowledge bit, and then waits for the four password data bytes, the validation code, 07h, and a resend of the eight password data bytes. The most significant byte of the password is sent first, followed by the least significant bytes. It is necessary to send twice the 64-bit password to prevent any data corruption during the write sequence. If the two 64-bit passwords sent are not exactly the same, the ST25DVxxx does not modify the I<sup>2</sup>C password value. When the bus master generates a Stop condition immediately after the Ack bit (during the tenth bit time slot), the internal write cycle is triggered. A Stop condition at any other time does not trigger the internal write cycle. During the internal write cycle, the serial data (SDA) signal is disabled internally, and the device does not respond to any requests. #### Caution: I<sup>2</sup>C write password command data transits via the 256-Bytes fast transfer mode's buffer. Consequently fast transfer mode must be deactivated before issuing a write password command, otherwise command is NotACK (after address LSB), and programming is not done and device goes in standby mode. Figure 31. I<sup>2</sup>C Write Password Sequence DS10925 - Rev 9 page 73/200 # 7 RF operations Contactless exchanges are performed in RF mode as specified by ISO/IEC 15693 or NFC Forum Type 5. The ST25DVxxx communicates via the 13.56 MHz carrier electromagnetic wave on which incoming data are demodulated from the received signal amplitude modulation (ASK: amplitude shift keying). The received ASK wave is 10% or 100% modulated with a data rate of 1.6 Kbit/s using the 1/256 pulse coding mode or a data rate of 26 Kbit/s using the 1/4 pulse coding mode. Outgoing data are generated by the ST25DVxxx load variation using Manchester coding with one or two subcarrier frequencies at 423 kHz and 484 kHz. Data are transferred from the ST25DVxxx at 6.6 Kbit/s in low data rate mode and 26 Kbit/s in high data rate mode. The ST25DVxxx supports the 53 Kbit/s in high data rate mode in one subcarrier frequency at 423 kHz. The ST25DVxxx follows ISO/IEC 15693 or NFC Forum Type 5 recommendation for radio-frequency power and signal interface and for anticollision and transmission protocol. ## 7.1 RF communication #### 7.1.1 Access to a ISO/IEC 15693 device ## The dialog between the "RF reader" and the ST25DVxxx takes place as follows: These operations use the RF power transfer and communication signal interface described below (see Power transfer, Frequency and Operating field). This technique is called RTF (Reader talk first). - activation of the ST25DVxxx by the RF operating field of the reader, - transmission of a command by the reader (ST25DVxxx detects carrier amplitude modulation) - transmission of a response by the ST25DVxxx(ST25DVxxx modulates is load clocked at subcarrier rate) ## Operating field The ST25DVxxx operates continuously between the minimum and maximum values of the electromagnetic field H defined in Table 253. RF characteristics. The Reader has to generate a field within these limits. ### Power transfer Power is transferred to the ST25DVxxx by radio frequency at 13.56 MHz via coupling antennas in the ST25DVxxx and the Reader. The RF operating field of the reader is transformed on the ST25DVxxx antenna to an AC voltage which is rectified, filtered and internally regulated. During communications, the amplitude modulation (ASK) on this received signal is demodulated by the ASK demodulator #### Frequency The ISO 15693 standard defines the carrier frequency (f<sub>C</sub>) of the operating field as 13.56 MHz ±7 kHz. # 7.2 RF communication and energy harvesting As the current consumption can affect the AC signal delivered by the antenna, RF communications with ST25DVxxx are not guaranteed during voltage delivery on the energy harvesting analog output V\_EH. RF communication can disturb and possibly stop Energy Harvesting mode. ### 7.3 Fast transfer mode mailbox access in RF Thanks to dedicated commands, the RF interface has the possibility to check Mailbox availability, and the capability to access it directly to put or get a message from it (see Section 5.1 Fast transfer mode (FTM) for specific features). DS10925 - Rev 9 page 74/200 # 7.4 RF protocol description ## 7.4.1 Protocol description The transmission protocol (or simply "the protocol") defines the mechanism used to exchange instructions and data between the VCD (Vicinity Coupling Device) and the ST25DVxxx in both directions. It is based on the concept of "VCD talks first". This means that a ST25DVxxx does not start transmitting unless it has received and properly decoded an instruction sent by the VCD. The protocol is based on an exchange of: - a request from the VCD to the ST25DVxxx, - a response from the ST25DVxxx to the VCD. Each request and each response are contained in a frame. The frame are delimited by a Start of Frame (SOF) and End of Frame (EOF). The protocol is bit-oriented. The number of bits transmitted in a frame is a multiple of eight (8), that is an integer number of bytes. A single-byte field is transmitted least significant bit (LSBit) first. A multiple-byte field is transmitted least significant byte (LSByte) first and each byte is transmitted least significant bit (LSBit) first. Figure 32. ST25DVxxx protocol timing ### 7.4.2 ST25DVxxx states referring to RF protocol The ST25DVxxx can be in one of four states: - Power-off - Ready - Quiet - Selected Transitions between these states are specified in Figure 33. ST25DVxxx state transition diagram and Table 92. ST25DVxxx response depending on Request flags. ## Power-off state The ST25DVxxx is in the Power-off state when it does not receive enough energy from the VCD. # Ready state The ST25DVxxx is in the Ready state when it receives enough energy from the VCD. When in the Ready state, the ST25DVxxx answers any request where the Select\_flag is not set. DS10925 - Rev 9 page 75/200 #### **Quiet state** When in the Quiet state, the ST25DVxxx answers any request with the Address\_flag set, except for Inventory requests. #### Selected state In the Selected state, the ST25DVxxx answers any request in all modes (see Section 7.4.3 Modes): - Request in Select mode with the Select flag set - Request in Addressed mode if the UID matches - · Request in Non-Addressed mode as it is the mode for general requests Address\_flag Select\_flag Flags 1 1 **Addressed** Non addressed Selected Non selected ST25DVxxx in Ready or Selected state Χ Χ (Devices in Quiet state do not answer) Х ST25DVxxx in Selected state Х ST25DVxxx in Ready, Quiet or Selected state (the device which matches the Х X Error (03h) or no response (command Χ Х dependent) Table 92. ST25DVxxx response depending on Request\_flags Figure 33. ST25DVxxx state transition diagram 1. The ST25DVxxx returns to the Power Off state if the tag is out of the RF field for at least t<sub>RF\_OFF</sub>. The intention of the state transition method is that only one ST25DVxxx should be in the Selected state at a time. When the Select\_flag is set to 1, the request shall NOT contain a unique ID. When the address\_flag is set to 0, the request shall NOT contain a unique ID. DS10925 - Rev 9 page 76/200 #### **7.4.3** Modes The term "mode" refers to the mechanism used in a request to specify the set of ST25DVxxx devices that shall execute the request. #### Addressed mode When the Address\_flag is set to 1 (Addressed mode), the request contains the Unique ID (UID) of the addressed ST25DVxxx. Any ST25DVxxx that receives a request with the Address\_flag set to 1 compares the received Unique ID to its own. If it matches, then the ST25DVxxx executes the request (if possible) and returns a response to the VCD as specified in the command description. If the UID does not match, then it remains silent. ### Non-addressed mode (general request) When the Address\_flag is cleared to 0 (Non-Addressed mode), the request does not contain a Unique ID. #### Select mode When the Select\_flag is set to 1 (Select mode), the request does not contain a unique ID. The ST25DVxxx in the Selected state that receives a request with the Select\_flag set to 1 executes it and returns a response to the VCD as specified in the command description. Only the ST25DVxxx in the Selected state answers a request where the Select flag is set to 1. The system design ensures that only one ST25DVxxx can be in the Select state at a time. ### 7.4.4 Request format The request consists of: - an SOF, - flags. - · a command code, - parameters and data, - a CRC, - an EOF. ## Table 93. General request format | S | Request_flags | | Command code | Parameters | Data | 2 byte CRC | EOF | |---|---------------|--|--------------|------------|------|------------|-----| |---|---------------|--|--------------|------------|------|------------|-----| ### 7.4.5 Request flags In a request, the "flags" field specifies the actions to be performed by the ST25DVxxx and whether corresponding fields are present or not. The flags field consists of eight bits. Bit 3 (Inventory\_flag) of the request flag defines the contents of the four MSBs (bits 5 to 8). When bit 3 is reset (0), bits 5 to 8 define the ST25DVxxx selection criteria. When bit 3 is set (1), bits 5 to 8 define the ST25DVxxx Inventory parameters. DS10925 - Rev 9 page 77/200 | Bit No | Flag | Level | Description | |--------|---------------------|-------|-----------------------------------------------------------------------------------------------------------| | Bit 1 | Subservier flog (1) | 0 | A single subcarrier frequency is used by the ST25DVxxx | | DIL I | Subcarrier_flag (1) | 1 | Two subcarriers are used by the ST25DVxxx | | Bit 2 | Data_rate_flag (2) | 0 | Low data rate is used | | DIL Z | | 1 | High data rate is used | | Bit 3 | Inventory_flag | 0 | The meaning of flags 5 to 8 is described in Table 95. Request flags 5 to 8 when inventory_flag, Bit 3 = 0 | | ысэ | | 1 | The meaning of flags 5 to 8 is described in Table 96. Request flags 5 to 8 when inventory_flag, Bit 3 = 1 | | Bit 4 | Protocol_extension | 0 | No Protocol format extension | | DIL 4 | _flag | 1 | Protocol format extension. Reserved for future use. | - 1. Subcarrier\_flag refers to the ST25DVxxx-to-VCD communication. - 2. Data\_rate\_flag refers to the ST25DVxxx-to-VCD communication. Table 95. Request flags 5 to 8 when inventory\_flag, Bit 3 = 0 | Bit nb | Flag | Level | Description | |--------|-----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 5 | Select flag (1) | 0 | The request is executed by any ST25DVxxx according to the setting of Address_flag | | Dit 3 | | 1 | The request is executed only by the ST25DVxxx in Selected state | | | Address flag | 0 | The request is not addressed. UID field is not present. The request is executed by all ST25DVxxxs. | | Bit 6 | | 1 | The request is addressed. UID field is present. The request is executed only by the ST25DVxxx whose UID matches the UID specified in the request. | | Bit 7 | Ontion floa | 0 | Option not activated. | | DIL / | Option flag | 1 | Option activated. | | Bit 8 | RFU | 0 | - | <sup>1.</sup> If the Select\_flag is set to 1, the Address\_flag is set to 0 and the UID field is not present in the request. Table 96. Request flags 5 to 8 when inventory\_flag, Bit 3 = 1 | Bit nb | Flag | Level | Description | |--------|---------------|-------|--------------------------| | Bit 5 | A E I floor | 0 | AFI field is not present | | DIL 3 | AFI flag | 1 | AFI field is present | | Bit 6 | Nb_slots flag | 0 | 16 slots | | DIL 0 | | 1 | 1 slot | | Bit 7 | Option flag | 0 | - | | Bit 8 | RFU | 0 | - | DS10925 - Rev 9 page 78/200 # 7.4.6 Response format The response consists of: - an SOF - flags - parameters and data - a CRC - an EOF # Table 97. General response format | SOF Response | e_flags Parameters | Data 2 byte | CRC EOF | |--------------|--------------------|-------------|---------| |--------------|--------------------|-------------|---------| # 7.4.7 Response flags In a response, the flags indicate how actions have been performed by the ST25DVxxx and whether corresponding fields are present or not. The response flags consist of eight bits. Table 98. Definitions of response flags 1 to 8 | Bit Nb | Flag | Level | Description | |------------|----------------|-------|-----------------------------------------------------| | Bit 1 | Error_flag | 0 | No error | | DIL I EIIO | LITOI_liag | 1 | Error detected. Error code is in the "Error" field. | | Bit 2 | RFU | 0 | - | | Bit 3 | Bit 3 RFU | | - | | Bit 4 | Extension flag | 0 | No extension | | Bit 5 | RFU | 0 | - | | Bit 6 | Bit 6 RFU | | - | | Bit 7 RFU | | 0 | - | | Bit 8 | RFU | 0 | - | DS10925 - Rev 9 page 79/200 #### 7.4.8 Response and error code If the Error\_flag is set by the ST25DVxxx in the response, the Error code field is present and provides information about the error that occurred. Error codes not specified in Table 99 are reserved for future use. Table 99. Response error code definition | Error code | Meaning | |------------|------------------------------------------------------------------------| | 01h | Command is not supported. | | 02h | Command is not recognized (format error). | | 03h | The option is not supported. | | 0Fh | Error with no information given. | | 10h | The specified block is not available. | | 11h | The specified block is already locked and thus cannot be locked again. | | 12h | The specified block is locked and its contents cannot be changed. | | 13h | The specified block was not successfully programmed. | | 14h | The specified block was not successfully locked. | | 15h | The specified block is protected in read. | # 7.5 Timing definition ## t<sub>1</sub>: ST25DVxxx response delay Upon detection of the rising edge of the EOF received from the VCD, the ST25DVxxx waits for a $t_{1nom}$ time before transmitting its response to a VCD request or switching to the next slot during an inventory process. Values of $t_{1}$ are given in Table 100. Timing values. ## t<sub>2</sub>: VCD new request delay t<sub>2</sub> is the time after which the VCD may send an EOF to switch to the next slot when one or more ST25DVxxx responses have been received during an Inventory command. It starts from the reception of the EOF from the ST25DVxxxs. The EOF sent by the VCD may be either 10% or 100% modulated regardless of the modulation index used for transmitting the VCD request to the ST25DVxxx. $t_2$ is also the time after which the VCD may send a new request to the ST25DVxxx, as described in Figure 32. ST25DVxxx protocol timing. Values of t<sub>2</sub> are given in Table 100. Timing values. ## t<sub>3</sub>: VCD new request delay when no response is received from the ST25DVxxx t<sub>3</sub> is the time after which the VCD may send an EOF to switch to the next slot when no ST25DVxxx response has been received. The EOF sent by the VCD may be either 10% or 100% modulated regardless of the modulation index used for transmitting the VCD request to the ST25DVxxx. From the time the VCD has generated the rising edge of an EOF: - If this EOF is 100% modulated, the VCD waits for a time at least equal to t<sub>3min</sub> for 100% modulation before sending a new EOF. - If this EOF is 10% modulated, the VCD waits for a time at least equal to t<sub>3min</sub> for 10% modulation before sending a new EOF. DS10925 - Rev 9 page 80/200 # Table 100. Timing values | | Minimur | m (min) values | Nominal (nom) values | Maximum (max) values | | |----------------|---------------------------------------------------------------------------------------------------------------|----------------|----------------------------------|-------------------------------------------------|--| | | 100% modulation 10% modulation | | Nominal (nom) values | Maximum (max) values | | | t <sub>1</sub> | 4320 / f <sub>C</sub> = 318.6 μs | | 4352 / f <sub>c</sub> = 320.9 μs | 4384 / f <sub>c</sub> = 323.3 µs <sup>(1)</sup> | | | t <sub>2</sub> | 4192 / $f_c$ = 309.2 µs<br>$t_{1max}^{(2)} + t_{SOF}^{(3)}$ $t_{1max}^{(2)} + t_{NRT}^{(4)} + t_{2min}^{(4)}$ | | No t <sub>nom</sub> | No t <sub>max</sub> | | | t <sub>3</sub> | | | No t <sub>nom</sub> | No t <sub>max</sub> | | - 1. VCD request will not be interpreted during the first milliseconds following the RF field rising. - 2. $t_{1max}$ does not apply for write-alike requests. Timing conditions for write-alike requests are defined in the command description. - 3. t<sub>SOF</sub> is the time taken by the ST25DVxxx to transmit an SOF to the VCD. t<sub>SOF</sub> depends on the current data rate: High data rate or Low data rate. - t<sub>NRT</sub> is the nominal response time of the ST25DVxxx. t<sub>NRT</sub> depends on V<sub>ICC</sub> to ST25DVxxx data rate and subcarrier modulation mode. Note: The tolerance of specific timings is $\pm 32/f_C$ . DS10925 - Rev 9 page 81/200 ### 7.6 RF commands #### 7.6.1 RF command code list The ST25DVxxx supports the following legacy and extended RF command set: - Inventory, used to perform the anticollision sequence. - Stay Quiet, used to put the ST25DVxxx in quiet mode, where it does not respond to any inventory command. - Select, used to select the ST25DVxxx. After this command, the ST25DVxxx processes all Read/Write commands with Select flag set. - Reset To Ready, used to put the ST25DVxxx in the ready state. - Read Single Block and Extended Read Single Block, used to output the 32 bit of the selected block and its locking status. - Write Single Block and Extended Write Single Block, used to write and verify the new content for an update of a 32 bit block, provided that it is not in a locked memory area. - Read Multiple Blocks and Extended Read Multiple Block, used to read the selected blocks in an unique area, and send back their value. - Write Multiple Blocks and Extended Write Multiple Block, used to write and verify the new content for an update of up to 4 blocks located in the same memory area, which was not previously locked for writing. - Write AFI, used to write the 8-bit value in the AFI register. - Lock AFI, used to lock the AFI register. - Write DSFID, used to write the 8-bit value in the DSFID register. - Lock DSFID, used to lock the DSFID register. - Get System information and Extended Get System Information, used to provide the system information value. - Get System information, used to provide the standard system information values. - Extended Get System Information, used to provide the extended system information values. - Write Password, used to update the 64 bit of the selected areas or configuration password, but only after presenting the current one. - Lock Block and Extended Lock block, used to write the CC file blocks security status bits (Protect the CC File content against writing). - Present Password, enables the user to present a password to open a security session. - Fast Read Single Block and Fast Extended Read Single Block, used to output the 32 bits of the selected block and its locking status at doubled data rate. - Fast Read Multiple Blocks and Fast Extended Read Multiple Blocks, used to read the selected blocks in a single area and send back their value at doubled data rate. - Read Message, used to output up to 256 byte of the Mailbox. - Read Message Length, used to output the Mailbox message length. - Fast Read Message, used to output up to 256 byte of the mailbox, at double data rate. - Write Message, used to write up to 256 byte in the Mailbox. - Fast Read Message Length, used to ouput the mailbox length, at double data rate. - Fast Write Message, used to write up to 256 bytes in the mailbox, with answer at double data rate. - Read Configuration, used to read static configuration registers. - Write Configuration, used to write static configuration registers. - Read Dynamic Configuration, used to read dynamic register. - Write Dynamic Configuration, used to write dynamic register. - Fast Read Dynamic Configuration, used to read dynamic register, at double data rate. - Fast Write Dynamic Configuration, used to write dynamic register, with answer at double data rate. Manage GPO, used to drive GPO output value when corresponding GPO mode is enabled. DS10925 - Rev 9 page 82/200 ## 7.6.2 Command codes list The ST25DVxxx supports the commands described in this section. Their codes are given in Table 101. Command codes. Table 101. Command codes | Command code standard | Function | Command code custom | Function | |-----------------------|---------------------------------------------|---------------------|-----------------------------------| | 01h | Inventory | A0h | Read Configuration | | 02h | Stay Quiet | A1h | Write Configuration | | 20h | Read Single Block | A9h | Manage GPO | | 21h | Write Single Block | AAh | Write Message | | 22h | Lock Block | ABh | Read Message Length | | 23h | Read Multiple Blocks | ACh | Read Message | | 24h | Write Multiple Blocks | ADh | Read Dynamic Configuration | | 25h | Select | AEh | Write Dynamic Configuration | | 26h | Reset to Ready | B1h | Write Password | | 27h | Write AFI | B3h | Present Password | | 28h | Lock AFI | C0h | Fast Read Single Block | | 29h | Write DSFID | C3h | Fast Read Multiple Blocks | | 30h | Extended Read Single Block | C4h | Fast Extended Read Single Block | | 31h | Extended Write Single Block | C5h | Fast Extended Read Multiple Block | | 32h | Extended Lock block | CAh | Fast Write Message | | 33h | Extended Read Multiple Blocks | CBh | Fast Read Message Length | | 34h | Extended Write Multiple Blocks | CCh | Fast Read Message | | 2Ah | Lock DSFID | CDh | Fast Read Dynamic configuration | | 2Bh | Get System Info | CEh | Fast Write Dynamic Configuration | | 2Ch | Get Multiple Block Security Status | - | - | | 3Bh | Extended Get System Info | - | - | | 3Ch | Extended Get Multiple Block Security Status | - | - | ## 7.6.3 General command rules In case of a valid command, the following paragraphs will describe the expected behavior for each command. But in case of an invalid command, in a general manner, the ST25DVxxx will behave as follows: - 1. if flag usage is incorrect, the error code 03h will be issued only if the right UID is used in the command, otherwise no response will be issued. - 2. error 02h will be issued if the custom command is used with the manufacturer code different from the ST one Another case is if I<sup>2</sup>C is busy. In this case, any RF command (except Inventory, Select, Stay quiet and Reset to ready) will get 0Fh error code as response only: - if select flag and address flags are not set at the same time (except if ST25DVxxx is in quiet state) - if select flag is set and ST25DVxxx is in selected state. For all other commands, if I<sup>2</sup>C is busy, no response will be issued by ST25DVxxx. DS10925 - Rev 9 page 83/200 #### 7.6.4 Inventory Upon receiving the Inventory request, the ST25DVxxx runs the anticollision sequence. The Inventory\_flag is set to 1. The meaning of flags 5 to 8 is shown in Table 96. Request flags 5 to 8 when inventory\_flag, Bit 3 = 1. The request contains: - the flags - the Inventory command code (001) - the AFI if the AFI flag is set - · the mask length - the mask value if mask length is different from 0 - the CRC The ST25DVxxx does not generate any answer in case of error. Table 102. Inventory request format | Request<br>SOF | Request_flags | Inventory | Optional AFI | Mask length | Mask value | CRC16 | Request<br>EOF | |----------------|---------------|-----------|--------------|-------------|-------------|---------|----------------| | - | 8 bits | 01h | 8 bits | 8 bits | 0 - 64 bits | 16 bits | - | The response contains: - the flags - · the Unique ID Table 103. Inventory response format | Response SOF | Response_flags | DSFID | UID | CRC16 | Response EOF | |--------------|----------------|--------|---------|---------|--------------| | - | 8 bits | 8 bits | 64 bits | 16 bits | - | During an Inventory process, if the VCD does not receive an RF ST25DVxxx response, it waits for a time $t_3$ before sending an EOF to switch to the next slot. $t_3$ starts from the rising edge of the request EOF sent by the VCD. - If the VCD sends a 100% modulated EOF, the minimum value of t<sub>3</sub> is: - $t_3$ min = 4384/ $f_C$ (323.3 $\mu$ s) + $t_{SOF}$ - If the VCD sends a 10% modulated EOF, the minimum value of t<sub>3</sub> is: $$t_3$$ min = 4384/f<sub>C</sub> (323.3 $\mu$ s) + $t_{NRT}$ + $t_{2min}$ #### where: - t<sub>SOF</sub> is the time required by the ST25DVxxx to transmit an SOF to the VCD, - t<sub>NRT</sub> is the nominal response time of the ST25DVxxx. $t_{\mbox{\scriptsize NRT}}$ and $t_{\mbox{\scriptsize SOF}}$ are dependent on the ST25DVxxx-to-VCD data rate and subcarrier modulation mode. Note: In case of error, no response is sent by ST25DVxxx. ### 7.6.5 Stay Quiet On receiving the Stay Quiet command, the ST25DVxxx enters the Quiet state if no error occurs, and does NOT send back a response. There is NO response to the Stay Quiet command even if an error occurs. The Option\_flag is not supported. The Inventory\_flag must be set to 0. When in the Quiet state: - the ST25DVxxx does not process any request if the Inventory\_flag is set, - the ST25DVxxx processes any Addressed request. DS10925 - Rev 9 page 84/200 The ST25DVxxx exits the Quiet state when: - it is reset (power off), - · receiving a Select request. It then goes to the Selected state, - receiving a Reset to Ready request. It then goes to the Ready state. Table 104. Stay Quiet request format | Request SOF | Request flags | Stay Quiet | UID | CRC16 | Request EOF | |-------------|---------------|------------|---------|---------|-------------| | - | 8 bits | 02h | 64 bits | 16 bits | - | The Stay Quiet command must always be executed in Addressed mode (Select\_flag is reset to 0 and Address\_flag is set to 1). Figure 34. Stay Quiet frame exchange between VCD and ST25DVxxx | VCD SOF | Stay Quiet request | EOF | |---------|--------------------|-----| |---------|--------------------|-----| ST25DVxxx ## 7.6.6 Read Single Block On receiving the Read Single Block command, the ST25DVxxx reads the requested block and sends back its 32-bit value in the response. The Option\_flag is supported, when set response include the Block Security Status. The Inventory\_flag must be set to 0. Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 105. Read Single Block request format | Request SOF | Request_flags | Read Single Block | UID (1) | Block number | CRC16 | Request EOF | |-------------|---------------|-------------------|---------|--------------|---------|-------------| | - | 8 bits | 20h | 64 bits | 8 bits | 16 bits | - | <sup>1.</sup> This the field is optional. # Request parameters: - Request flags - UID (optional) - Block number Table 106. Read Single Block response format when Error\_flag is NOT set | Response SOF | Response_flags | Block security status <sup>(1)</sup> | Data | CRC16 | Response EOF | |--------------|----------------|--------------------------------------|---------|---------|--------------| | - | 8 bits | 8 bits | 32 bits | 16 bits | - | 1. This field is optional. #### Response parameters: - Block security status if Option\_flag is set (see Table 107. Block security status) - Four bytes of block data DS10925 - Rev 9 page 85/200 ## Table 107. Block security status | b <sub>7</sub> | b <sub>7</sub> b <sub>6</sub> b <sub>5</sub> b <sub>4</sub> b <sub>3</sub> | | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | | |----------------|----------------------------------------------------------------------------|----|-----------------------------|----------------|----------------|----------------|-------------------------| | Reserved | for future us | e. | 0: Current block not locked | | | | | | All at 0. | | | | | | | 1: Current block locked | Table 108. Read Single Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set - 03h: command option not supported - 0Fh: error with no information - 10h: the specified block is not available - 15h: the specified block is read-protected Figure 35. Read Single Block frame exchange between VCD and ST25DVxxx # 7.6.7 Extended Read Single Block On receiving the Extended Read Single Block command, the ST25DVxxx reads the requested block and sends back its 32-bit value in the response. When the Option\_flag is set, the response includes the Block Security Status. Block number is coded on 2 Bytes so all memory blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 109. Extended Read Single Block request format | Request SOF | Request_flags | Extended Read Single Block | UID (1) | Block number | CRC16 | Request EOF | |-------------|---------------|----------------------------|---------|--------------|---------|-------------| | - | 8 bits | 30h | 64 bits | 16 bits | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flags - UID (optional) - Block number (from LSB byte to MSB byte) DS10925 - Rev 9 page 86/200 Table 110. Extended Read Single Block response format when Error\_flag is NOT set | Response SOF | Response_flags | Block security status (1) | Data | CRC16 | Response EOF | |--------------|----------------|---------------------------|---------|---------|--------------| | - | 8 bits | 8 bits | 32 bits | 16 bits | - | 1. This field is optional. #### Response parameters: - Block security status if Option\_flag is set (see Table 107. Block security status) - · Four bytes of block data Table 111. Block security status | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | | |--------------------------|----------------|----------------|----------------|----------------|----------------|-------------------------|-----------------------------|--| | Reserved for future use. | | | | | | | 0: Current block not locked | | | All at 0. | | | | | | 1: Current block locked | | | Table 112. Extended Read Single Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set - 03h: command option not supported or no response - 0Fh: error with no information - 10h: the specified block is not available - 15h: the specified block is read-protected Figure 36. Extended Read Single Block frame exchange between VCD and ST25DVxxx ### 7.6.8 Write Single Block On receiving the Write Single Block command, the ST25DVxxx writes the data contained in the request to the targeted block and reports whether the write operation was successful in the response. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not program correctly the data into the memory. The $W_t$ time is equal to $t_{1nom} + N \times 302 \,\mu s$ (N is an integer). Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. DS10925 - Rev 9 page 87/200 Table 113. Write Single Block request format | Request SOF | Request_flags | Write Single Block | UID (1) | Block number | Data | CRC16 | Request EOF | |-------------|---------------|--------------------|---------|--------------|---------|---------|-------------| | - | 8 bits | 21h | 64 bits | 8 bits | 32 bits | 16 bits | - | 1. This field is optional. #### Request parameters: - Request flags - UID (optional) - Block number - Data Table 114. Write Single Block response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | ## Response parameter: No parameter. The response is sent back after the writing cycle. Table 115. Write Single Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set - 03h: command option not supported - 0Fh: error with no information given - 10h: the specified block is not available - 12h: the specified block is locked or protected and its contents cannot be changed - 13h: the specified block was not successfully programmed Note: For more details, see Figure 7. Memory organization. Figure 37. Write Single Block frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 88/200 ### 7.6.9 Extended Write Single Block On receiving the Extended Write Single command, the ST25DVxxx writes the data contained in the request to the targeted block and reports whether the write operation was successful in the response. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not program correctly the data into the memory. The $W_t$ time is equal to $t_{1nom}$ + N × 302 $\mu$ s (N is an integer). Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 116. Extended Write Single request format | Request SOF | Request_flags | Extended Write Single Block | UID (1) | Block number | Data | CRC16 | Request EOF | |-------------|---------------|-----------------------------|---------|--------------|---------|---------|-------------| | - | 8 bits | 31h | 64 bits | 16 bits | 32 bits | 16 bits | - | 1. This field is optional. #### Request parameters: - · Request flags - UID (optional) - Block number (from LSB byte to MSB byte) - Data (from LSB byte to MSB byte) Table 117. Extended Write Single response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | ## Response parameter: No parameter. The response is sent back after the writing cycle. Table 118. Extended Write Single response format when Error flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 03h: command option not supported - 0Fh: error with no information given - 10h: the specified block is not available - 12h: the specified block is locked and its contents cannot be changed - 13h: the specified block was not successfully programmed DS10925 - Rev 9 page 89/200 Figure 38. Extended Write Single frame exchange between VCD and ST25DVxxx #### 7.6.10 Lock Block On receiving the Lock block request, the ST25DVxxx locks the single block value permanently and protects its content against new writing. This command is only applicable for the blocks 0 and 1 which may include a CC file. For a global protection of a area, update accordingly the RFA<sub>i</sub>SS bits in the system area. The Option\_flag is supported, when set wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not lock correctly the single block value in memory. The $W_t$ time is equal to $t_{1nom}$ + N × 302 $\mu$ s (N is an integer). Table 119. Lock block request format | Request SOF | Request_flags | Lock block | UID (1) | block number | CR7C16 | Request EOF | |-------------|---------------|------------|---------|--------------|---------|-------------| | - | 8 bits | 22h | 64 bits | 8 bits | 16 bits | - | ## 1. This field is optional. ### Request parameter: - Request Flags - UID (optional) - Only block numbers 0 and 1 are allowed to protect the CCFile in case of NDEF (from LSB byte to MSB byte) Table 120. Lock block response format when Error flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | #### Response parameter: · No parameter Table 121. Lock block response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | DS10925 - Rev 9 page 90/200 ### Response parameter: - · Error code as Error\_flag is set - 03h: command option not supported - 10h: block not available - 11h: the specified block is already locked and thus cannot be locked again - 14h: the specified block was not successfully locked Figure 39. Lock Block frame exchange between VCD and ST25DVxxx ## 7.6.11 Extended Lock block On receiving the extended Lock block request, the ST25DVxxx locks the single block value permanently and protects its content against new writing. This command is only applicable for the blocks 0 and 1 which may include a CC file. For a global protection of a area, update accordingly the AiSS bits in the system area. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not lock correctly the single block value in memory. The $W_t$ time is equal to $t_{1nom}$ + N × 302 $\mu$ s (N is an integer). Table 122. Extended Lock block request format | | Request SOF | Request_flags | Extended Lock block | UID (1) | block number | CRC16 | Request EOF | |---|-------------|---------------|---------------------|---------|--------------|---------|-------------| | - | | 8 bits | 32h | 64 bits | 16 bits | 16 bits | - | 1. The field is optional. #### Request parameter: - Request Flags - UID (optional) - Only block numbers 0 and 1 are allowed to protect the CCFile in case of NDEF (from LSB byte to MSB byte) Table 123. Extended Lock block response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | Response parameter: DS10925 - Rev 9 page 91/200 · No parameter Table 124. Extended Lock block response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set - 03h: command option not supported - 10h: block not available - 11h: the specified block is already locked and thus cannot be locked again - 14h: the specified block was not successfully locked Figure 40. Extended Lock block frame exchange between VCD and ST25DVxxx # 7.6.12 Read Multiple Blocks When receiving the Read Multiple Block command, the ST25DVxxx reads the selected blocks and sends back their value in multiples of 32 bits in the response. The blocks are numbered from 00h to FFh in the request and the value is minus one (–1) in the field. For example, if the "Number of blocks" field contains the value 06h, seven blocks are read. The maximum number of blocks is fixed at 256 assuming that they are all located in the same area. If the number of blocks overlaps areas or overlaps the end of user memory, the ST25DVxxx returns an error code. When the Option\_flag is set, the response returns the Block Security Status. The Inventory\_flag must be set to 0. Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 125. Read Multiple Block request format | Request SOF | Request_flags | Read Multiple<br>Block | UID (1) | First block<br>number | Number of blocks | CRC16 | Request EOF | |-------------|---------------|------------------------|---------|-----------------------|------------------|---------|-------------| | - | 8 bits | 23h | 64 bits | 8 bits | 8 bits | 16 bits | - | 1. The field is optional. #### Request parameters: - Request flags - UID (optional) - · First block number DS10925 - Rev 9 page 92/200 · Number of blocks Table 126. Read Multiple Block response format when Error\_flag is NOT set | Response SOF | Response_<br>flags | Block security<br>status <sup>(1)</sup> | Data | CRC16 | Response EOF | |--------------|--------------------|-----------------------------------------|------------------------|---------|--------------| | - | 8 bits | 8 bits <sup>(2)</sup> | 32 bits <sup>(2)</sup> | 16 bits | - | - 1. The field is optional. - 2. Repeated as needed. ## Response parameters: - Block security status if Option\_flag is set (see Table 127. Block security status) - N blocks of data Table 127. Block security status | b <sub>7</sub> | b6 b5 b4 b3 b2 b1 | | b <sub>0</sub> | | | | | | |--------------------------|-----------------------------------------------------------|--|----------------|--|--|--|-----------------------------|--| | Reserved for future use. | | | | | | | 0: Current block not locked | | | All at 0. | | | | | | | 1: Current block locked | | Table 128. Read Multiple Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 03h: command option is not supported - 0Fh: error with no information given - 10h: the specified block is not available - 15h: the specified block is read-protected Figure 41. Read Multiple Block frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 93/200 #### 7.6.13 Extended Read Multiple Blocks When receiving the Extended Read multiple block command, the ST25DVxxx reads the selected blocks and sends back their value in multiples of 32 bits in the response. The blocks are numbered from 00h to last block of memory in the request and the value is minus one (-1) in the field. For example, if the "Number of blocks" field contains the value 06h, seven blocks are read. The maximum number of blocks is fixed at 2047 assuming that they are all located in the same area. If the number of blocks overlaps areas or overlaps the end of user memory, the ST25DVxxx returns an error code. When the Option\_flag is set, the response returns the Block Security Status. The Inventory\_flag must be set to 0. Block number is coded on 2 Bytes so all memory blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 129. Extended Read Multiple Block request format | Request<br>SOF | Request_flags | Extended<br>Read<br>Multiple<br>Block | UID <sup>(1)</sup> | First block<br>number | Number of<br>blocks | CRC16 | Request<br>EOF | |----------------|---------------|---------------------------------------|--------------------|-----------------------|---------------------|---------|----------------| | - | 8 bits | 33h | 64 bits | 16 bits | 16 bits | 16 bits | - | <sup>1.</sup> This field is optional. ## Request parameters: - Request flags - UID (optional) - First block number (from LSB byte to MSB byte) - Number of blocks (from LSB byte to MSB byte) Table 130. Extended Read Multiple Block response format when Error\_flag is NOT set | Response SOF | Response_<br>flags | Block security<br>status <sup>(1)</sup> | Data | CRC16 | Response EOF | |--------------|--------------------|-----------------------------------------|------------------------|---------|--------------| | - | 8 bits | 8 bits <sup>(2)</sup> | 32 bits <sup>(2)</sup> | 16 bits | - | - 1. This field is optional. - 2. Repeated as needed. # Response parameters: - Block security status if Option\_flag is set (see Table 131. Block security status) - · N blocks of data Table 131. Block security status | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | | |--------------------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------------------|--| | Reserved for future use. | | | | | | | 0: Current block not locked | | | All at 0 | | | | | | | 1: Current block locked | | Table 132. Extended Read Multiple Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: DS10925 - Rev 9 page 94/200 - Error code as Error\_flag is set: - 03h: command option is not supported - 0Fh: error with no information given - 10h: the specified block is not available - 15h: the specified block is read-protected Figure 42. Extended Read Multiple Block frame exchange between VCD and ST25DVxxx ## 7.6.14 Write Multiple Blocks On receiving the Write Multiple Block command, the ST25DVxxx writes the data contained in the request to the requested blocks, and reports whether the write operation were successful in the response. ST25DVxxx supports up to 4 blocks, data field must be coherent with the number of blocks to program. If some blocks overlaps areas, or overlap end of user memory, the ST25DVxxx returns an error code and none of the blocks are programmed. When the Option\_flag is set, wait for EOF to respond. During the RF write cycle Wt, there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not program correctly the data into the memory. The $W_t$ time is equal to $t_{1nom}$ + m × 302 $\mu$ s < 20 ms. (m is an integer, it is function of Nb number of blocks to be programmed). The Inventory\_flag must be set to 0. Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Write First Block Number of Request Request Request\_flags Multiple UID (1) Data CRC16 SOF EOF number block (2) **Block** Block length 8 bits 64 bits 16 bits 24h 8 bits 8 bits Table 133. Write Multiple Block request format - 1. This field is optional. - 2. The number of blocks in the request is one less than the number of blocks that the VICC shall write. - 3. Repeated as needed ## Request parameters: - Request flags - UID (optional) - First Block number - Number of blocks - Data DS10925 - Rev 9 page 95/200 Table 134. Write Multiple Block response format when Error\_flag is NOT set | Response SOF | Response SOF Response_flags | | Response EOF | | |--------------|-----------------------------|---------|--------------|--| | - | 8 bits | 16 bits | - | | #### Response parameter: No parameter. The response is sent back after the writing cycle. Table 135. Write Multiple Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | | |--------------|----------------|------------|---------|--------------|--| | - | 8 bits | 8 bits | 16 bits | - | | #### Response parameter: - Error code as Error\_flag is set: - 03h: command option is not supported - 0Fh: error with no information given - 10h: the specified block is not available - 12h: the specified block is locked and its contents cannot be changed - 13h: the specified block was not successfully programmed Figure 43. Write Multiple Block frame exchange between VCD and ST25DVxxx # 7.6.15 Extended Write Multiple Blocks On receiving the Extended Write multiple block command, the ST25DVxxx writes the data contained in the request to the targeted blocks and reports whether the write operation were successful in the response. ST25DVxxx supports up to 4 blocks, data field must be coherent with number of blocks to program. If some blocks overlaps areas, or overlap end of user memory the ST25DVxxx returns an error code and none of the blocks are programmed. When the Option\_flag is set, wait for EOF to respond. During the RF write cycle Wt, there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not program correctly the data into the memory. The $W_t$ time is equal to $t_{1nom}$ + m × 302 $\mu$ s < 20 ms (m is an integer function of Nb number of blocks to be programmed). The inventory\_flag must be set to 0. Block number is coded on 2 Bytes so all memory blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. DS10925 - Rev 9 page 96/200 Table 136. Extended Write Multiple Block request format | Request<br>SOF | Request_flags | Extended<br>Write multiple<br>block | UID (1) | First Block<br>number | Number of<br>block <sup>(2)</sup> | Data | CRC16 | Request<br>EOF | |----------------|---------------|-------------------------------------|---------|-----------------------|-----------------------------------|---------------------|---------|----------------| | - | 8 bits | 34h | 64 bits | 16 bits | 16 bits | Block<br>length (3) | 16 bits | - | - 1. This field is optional. - 2. The number of blocks in the request is one less than the number of blocks that the VICC shall write. - 3. Repeated as needed ## Request parameters: - Request flags - UID (optional) - First block number (from LSB byte to MSB byte) - Number of block (from LSB byte to MSB byte) - Data (from first to last blocks, from LSB bytes to MSB bytes) Table 137. Extended Write Multiple Block response format when Error\_flag is NOT set | Response SOF | Response SOF Response_flags | | Response EOF | | |--------------|-----------------------------|---------|--------------|--| | - | 8 bits | 16 bits | - | | #### Response parameter: No parameter. The response is sent back after the writing cycle. Table 138. Extended Write Multiple Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ## Response parameter: - Error code as Error\_flag is set: - 03h: command option is not supported - 0Fh: error with no information given - 10h: the specified block is not available - 12h: the specified block is locked and its contents cannot be changed - 13h: the specified block was not successfully programmed DS10925 - Rev 9 page 97/200 Figure 44. Extended Write Multiple Block frame exchange between VCD and ST25DVxxx #### 7.6.16 Select When receiving the Select command: - If the UID is equal to its own UID, the ST25DVxxx enters or stays in the Selected state and sends a response. - If the UID does not match its own UID, the selected ST25DVxxx returns to the Ready state and does not send a response. The ST25DVxxx answers an error code only if the UID is equal to its own UID. If not, no response is generated. If an error occurs, the ST25DVxxx remains in its current state. The Option\_flag is not supported, and the Inventory\_flag must be set to 0. Table 139. Select request format | | Request SOF | Request_flags | Select | UID | CRC16 | Request EOF | |---|-------------|---------------|--------|---------|---------|-------------| | - | | 8 bits | 25h | 64 bits | 16 bits | - | ## Request parameter: • UID Table 140. Select Block response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | #### Response parameter: · No parameter Table 141. Select response format when Error\_flag is set | Response | SOF | Response_flags | Error code | CRC16 | Response EOF | |----------|------|----------------|------------|---------|--------------| | - | 8 bi | ts | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 03h: the option is not supported - 0Fh: error with no information given DS10925 - Rev 9 page 98/200 Figure 45. Select frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 99/200 ## 7.6.17 Reset to Ready On receiving a Reset to Ready command, the ST25DVxxx returns to the Ready state if no error occurs. In the Addressed mode, the ST25DVxxx answers an error code only if the UID is equal to its own UID. If not, no response is generated. The Option\_flag is not supported, and the Inventory\_flag must be set to 0. Table 142. Reset to Ready request format | Request SOF | Request_flags | Reset to Ready | UID <sup>(1)</sup> | CRC16 | Request EOF | |-------------|---------------|----------------|--------------------|---------|-------------| | - | 8 bits | 26h | 64 bits | 16 bits | - | <sup>1.</sup> This field is optional. ## Request parameter: UID (optional) Table 143. Reset to Ready response format when Error\_flag is NOT set | Response SOF Response_flags | | CRC16 | Response EOF | |-----------------------------|--------|---------|--------------| | - | 8 bits | 16 bits | - | ### Response parameter: No parameter Table 144. Reset to ready response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | # Response parameter: - Error code as Error\_flag is set: - 03h: the option is not supported - 0Fh: error with no information given Figure 46. Reset to Ready frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 100/200 ## **7.6.18** Write AFI On receiving the Write AFI request, the ST25DVxxx programs the 8-bit AFI value to its memory. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not write correctly the AFI value into the memory. The $W_t$ time is equal to $t_{1nom} + N \times 302 \,\mu s$ (N is an integer). Table 145. Write AFI request format | Request SOF | Request_flags | Write AFI | UID (1) | AFI | CRC16 | Request EOF | |-------------|---------------|-----------|---------|--------|---------|-------------| | - | 8 bits | 27h | 64 bits | 8 bits | 16 bits | - | <sup>1.</sup> This field is optional. ## Request parameter: - Request flags - UID (optional) - AFI Table 146. Write AFI response format when Error\_flag is NOT set | Response SOF Response_flags | | CRC16 | Response EOF | |-----------------------------|--------|---------|--------------| | - | 8 bits | 16 bits | - | ## Response parameter: No parameter Table 147. Write AFI response format when Error\_flag is set | Response SOF | Response_<br>flags | Error code | CRC16 | Response EOF | |--------------|--------------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set - 03h: command option is not supported - 0Fh: error with no information given - 12h: the specified block is locked and its contents cannot be changed - 13h: the specified block was not successfully programmed DS10925 - Rev 9 page 101/200 Figure 47. Write AFI frame exchange between VCD and ST25DVxxx #### 7.6.19 Lock AFI On receiving the Lock AFI request, the ST25DVxxx locks the AFI value permanently. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not lock correctly the AFI value in memory. The $W_t$ time is equal to $t_{1nom} + N \times 302 \,\mu s$ (N is an integer). Table 148. Lock AFI request format | Request SOF | Request_flags | Lock AFI | UID (1) | CRC16 | Request EOF | |-------------|---------------|----------|---------|---------|-------------| | - | 8 bits | 28h | 64 bits | 16 bits | - | 1. This field is optional. ## Request parameter: - Request Flags - UID (optional) Table 149. Lock AFI response format when Error\_flag is NOT set | Response SOF | Response SOF Response_flags | | Response EOF | |--------------|-----------------------------|---------|--------------| | - | 8 bits | 16 bits | - | ## Response parameter: No parameter Table 150. Lock AFI response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | Response parameter: DS10925 - Rev 9 page 102/200 - Error code as Error\_flag is set - 03h: command option is not supported - 0Fh: error with no information given - 11h: the specified block is already locked and thus cannot be locked again - 14h: the specified block was not successfully locked Figure 48. Lock AFI frame exchange between VCD and ST25DVxxx #### 7.6.20 Write DSFID On receiving the Write DSFID request, the ST25DVxxx programs the 8-bit DSFID value to its memory. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not write correctly the DSFID value in memory. The $W_t$ time is equal to $t_{1nom} + N \times 302 \,\mu s$ (N is an integer). Table 151. Write DSFID request format | Req | uest SOF | Request_flags | Write DSFID | UID (1) | DSFID | CRC16 | Request EOF | |-----|----------|---------------|-------------|---------|--------|---------|-------------| | - | | 8 bits | 29h | 64 bits | 8 bits | 16 bits | - | 1. This field is optional. ## Request parameter: - Request flags - UID (optional) - DSFID Table 152. Write DSFID response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | ## Response parameter: No parameter DS10925 - Rev 9 page 103/200 Table 153. Write DSFID response format when Error\_flag is set | | Response SOF Response_flags | | Error code | CRC16 | Response EOF | |---|-----------------------------|--------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set - 03h: command option is not supported - 0Fh: error with no information given - 12h: the specified block is locked and its contents cannot be changed - 13h: the specified block was not successfully programmed Figure 49. Write DSFID frame exchange between VCD and ST25DVxxx ## 7.6.21 Lock DSFID On receiving the Lock DSFID request, the ST25DVxxx locks the DSFID value permanently. When the Option\_flag is set, wait for EOF to respond. The Inventory\_flag must be set to 0. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not lock correctly the DSFID value in memory. The $W_t$ time is equal to $t_{1nom}$ + N × 302 $\mu$ s (N is an integer). Table 154. Lock DSFID request format | Request SOF | Request_flags | Lock DSFID | UID (1) | CRC16 | Request EOF | |-------------|---------------|------------|---------|---------|-------------| | - | 8 bits | 2Ah | 64 bits | 16 bits | - | 1. This field is optional. #### Request parameter: - Request flags - UID (optional) Table 155. Lock DSFID response format when Error flag is NOT set | | Response SOF | Response_flags | CRC16 | Response EOF | |---|--------------|----------------|---------|--------------| | - | - | 8 bits | 16 bits | - | DS10925 - Rev 9 page 104/200 # Response parameter: No parameter. Table 156. Lock DSFID response format when Error\_flag is set | | Response SOF Response_flags | | Error code | CRC16 | Response EOF | |---|-----------------------------|--------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 03h: command option is not supported - 0Fh: error with no information given - 11h: the specified block is already locked and thus cannot be locked again - 14h: the specified block was not successfully locked Figure 50. Lock DSFID frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 105/200 # 7.6.22 Get System Info When receiving the Get System Info command, the ST25DVxxx sends back its information data in the response. The Option\_flag is not supported. The Inventory\_flag must be set to 0. The Get System Info can be issued in both Addressed and Non Addressed modes. Table 157. Get System Info request format | Request SOF | Request_flags | Get System Info | UID <sup>(1)</sup> | CRC16 | Request EOF | |-------------|---------------|-----------------|--------------------|---------|-------------| | - | 8 bits | 2Bh | 64 bits | 16 bits | - | 1. This field is optional. ### Request parameter: - Request flags - UID (optional) Table 158. Get System Info response format Error\_flag is NOT set | Device | Response SOF | Response flags | Information flags | UID | DSFID | AFI | Mem. Size | IC ref. | CRC16 | Response EOF | |--------------|--------------|----------------|-------------------|------------|-------|-----------|-------------------|---------|------------|--------------| | ST25DV64K-xx | | | 0Bh | 64 | 0 | 0 | NA <sup>(1)</sup> | 26h | 16 | | | ST25DV16K-xx | - | 00h | ОВП | 64<br>bits | bits | o<br>bits | INA (1) | 2011 | 16<br>bits | - | | ST25DV04K-xx | | | 0Fh | DILS | טונס | טונס | 037Fh | 24h | טונס | | 1. Field not present in this configuration ## Response parameters: - Information flags set to 0Bh/0Fh. DSFID, AFI and IC reference fields are present. - UID code on 64 bits - DSFID value - AFI value - MemSize: Block size in bytes and memory size in number of blocks (only present for ST25DV04K-xx configurations) Table 159. Memory size | MSB | | | LSB | |-------|--|--------------------|------------------| | 16 14 | | 13 9 | 8 1 | | RFU | | Block size in byte | Number of blocks | | 0h | | 03h | 7Fh | ST25DVxxx IC reference: the 8 bits are significant. Table 160. Get System Info response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 01h | 8 bits | 16 bits | - | ## Response parameter: - Error code as Error\_flag is set: - 03h: Option not supported - 0Fh: error with no information given DS10925 - Rev 9 page 106/200 Figure 51. Get System Info frame exchange between VCD and ST25DVxxx # 7.6.23 Extended Get System Info When receiving the Extended Get System Info command, the ST25DVxxx sends back its information data in the response. The Option\_flag is not supported. The Inventory\_flag must be set to 0. The Extended Get System Info can be issued in both Addressed and Non Addressed modes. Table 161. Extended Get System Info request format | Request SOF | Request_flags | Extended Get System Info | Parameter request field | UID (1) | CRC16 | Request EOF | |-------------|---------------|--------------------------|-------------------------|---------|---------|-------------| | - | 8 bits | 0xx1xxxxb | 8 bits | 64 bits | 16 bits | - | - 1. This field is optional. - Request flags - Request parameters - UID (optional) Table 162. Parameter request list | Bit | Flag name | Value | Description | |-----------|----------------------|-------|-----------------------------------------------------| | b1 | DSFID | 0 | No request of DSFID | | וטו | DSFID | 1 | Request of DSFID | | <b>LO</b> | ٨٦١ | 0 | No request of AFI | | b2 | AFI | 1 | Request of AFI | | | | 0 | No request of data field on VICC memory size | | b3 | VICC memory size | 1 | Request of data field on VICC memory size | | L. 4 | IC reference | 0 | No request of Information on IC reference | | b4 | | 1 | Request of Information on IC reference | | b5 | MOI | 1 | Information on MOI always returned in response flag | | hC | VICC Command list | 0 | No request of Data field of all supported commands | | b6 | VICC Command list | 1 | Request of Data field of all supported commands | | b7 | CSI Information | 0 | No request of CSI list | | D7 | Col information | 1 | Request of CSI list | | b8 | Extended Get System | 0 | One byte length of Extended Get System | | DO | Info parameter Field | | Info parameter field | DS10925 - Rev 9 page 107/200 Table 163. Extended Get System Info response format when Error\_flag is NOT set | Response<br>SOF | Response_flags | Information<br>flags | UID | DSFID (1) (2) | AFI <sup>(2) (1)</sup> | Other Field <sup>(2) (1)</sup> | CRC16 | Response<br>EOF | |-----------------|----------------|-----------------------|---------|---------------|------------------------|--------------------------------|---------|-----------------| | - | 00h | 8 bits <sup>(1)</sup> | 64 bits | 8 bits | 8 bits | up to 64 bits (3) | 16 bits | - | - 1. See Table 164. Response Information Flag. - 2. This field is optional. - 3. Number of bytes is function of parameter list selected. # Response parameters: - Information flag defining which fields are present - UID code on 64 bits - DSFID value (if requested in Parameters request field) - AFI value (if requested in Parameters request field) - Other fields: - VICC Memory size (if requested in Parameters request field) - ICRef(if requested in Parameters request field) - VICC Command list (if requested in Parameters request field) Table 164. Response Information Flag | Bit | Meaning if bit is set | Comment | | | |-----|-----------------------|---------|-----------------------------------------------------|--| | b1 | DSFID | 0 | DSFID field is not present | | | | | 1 | DSFID field is present | | | b2 | AFI | 0 | AFI field is not present | | | 02 | | 1 | AFI field is present | | | b3 | VICC memory size | 0 | Data field on VICC memory size is not present. | | | DS | | 1 | Data field on VICC memory size is present. | | | b4 | IC reference | 0 | Information on IC reference field is not present. | | | | | 1 | Information on IC reference field is present | | | b5 | MOI | 0 | 1 byte addressing | | | cu | | 1 | 2 byte addressing | | | b6 | VICC Command list | 0 | Data field of all supported commands is not present | | | סמ | | 1 | Data field of all supported commands is present | | | b7 | CSI Information | 0 | CSI list is not present | | | b8 | Info flag filed | 0 | One byte length of Info flag field | | Table 165. Response other field: ST25DVxxx VICC memory size | MSB | LSB | | | |-------|--------------------|----------------------|----| | 24 22 | 21 17 | 16 | 01 | | RFU | Block size in byte | Number of blocks | | | | | 07FFh (ST25DV64K-xx) | | | 0h | 03h | 01FFh (ST25DV16K-xx) | | | | | 007Fh (ST25DV04K-xx) | | DS10925 - Rev 9 page 108/200 Table 166. Response other field: ST25DVxxx IC Ref | 1 byte | | |------------------------------------------------------|-------| | ICRef | | | 24h (ST25DV04K-xx) or 26h (ST25DV16K-xx and ST25DV64 | K-xx) | Table 167. Response other field: ST25DVxxx VICC command list | MSB | LSB | | | |--------|-------|--------|--------| | 32 25 | 24 17 | 16 09 | 08 01 | | Byte 4 | Byte3 | Byte 2 | Byte 1 | | 00h | 3Fh | 3Fh | FFh | Table 168. Response other field: ST25DVxxx VICC command list Byte 1 | Bit | Meaning if bit is set | Comment | |-----|-------------------------------------------------|------------------------| | b1 | Read single block is supported | - | | b2 | Write single block is supported | - | | b3 | Lock single block is supported | - | | b4 | Read multiple block is supported | - | | b5 | Write multiple block is supported | - | | b6 | Select is supported | including Select state | | b7 | Reset to Ready is supported | - | | b8 | Get multiple block security status is supported | - | Table 169. Response other field: ST25DVxxx VICC command list Byte 2 | Bit | Meaning if bit is set | Comment | | | |-----|-------------------------------------|---------------------|--|--| | b1 | Write AFI is supported | - | | | | b2 | Lock AFI is supported | - | | | | b3 | Write DSFID is supported | - | | | | b4 | Lock DSFID is supported | - | | | | b5 | Get System Information is supported | - | | | | b6 | Custom commands are supported | - | | | | b7 | RFU | 0 shall be returned | | | | b8 | RFU | 0 shall be returned | | | DS10925 - Rev 9 page 109/200 Table 170. Response other field: ST25DVxxx VICC command list Byte 3 | Bit | Meaning if bit is set | Comment | |-----|----------------------------------------------------|---------------------| | b1 | Extended read single block is supported | - | | b2 | Extended write single block is supported | - | | b3 | Extended lock single block is supported | - | | b4 | Extended read multiple block is supported | - | | b5 | Extended write multiple block is supported | - | | b6 | Extended Get Multiple Security Status is supported | - | | b7 | RFU | 0 shall be returned | | b8 | RFU | 0 shall be returned | Table 171. Response other field: ST25DVxxx VICC command list Byte 4 | Bit | Meaning if bit is set | Comment | |-----|----------------------------------------------|------------------------------------------------------| | b1 | Read Buffer is supported | Means Response Buffer is supported | | b2 | Select Secure State is supported | Means VCD or Mutual authentication are supported | | b3 | Final Response always includes crypto result | Means that flag b3 will be set in the Final response | | b4 | AuthComm crypto format is supported | - | | b5 | SecureComm crypto format is supported | - | | b6 | KeyUpdate is supported | - | | b7 | Challenge is supported | - | | b8 | If set to 1 a further Byte is transmitted | 0 shall be returned | Table 172. Extended Get System Info response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 01h | 8 bits | 16 bits | - | Error code as Error\_flag is set: 03h: Option not supported 0Fh: error with no information given Figure 52. Extended Get System Info frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 110/200 ### 7.6.24 Get Multiple Block Security Status When receiving the Get Multiple Block Security Status command, the ST25DVxxx sends back its security status for each address block: 0 when block is writable else 1 when block is locked for writing. The blocks security status are defined by the area security status (and by LCK\_CCFILE register for blocks 0 and 1). The blocks are numbered from 00h up to the maximum memory block number in the request, and the value is minus one (–1) in the field. For example, a value of "06" in the "Number of blocks" field requests will return the security status of seven blocks. This command does not respond an error if number of blocks overlap areas or overlap the end of the user memory. The number of blocks is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 173. Get Multiple Block Security Status request format | Request SOF | Request_flags | Get Multiple Block<br>Security Status | UID (1) | First block<br>number | Number of blocks | CRC16 | Request EOF | |-------------|---------------|---------------------------------------|---------|-----------------------|------------------|---------|-------------| | - | 8 bits | 2Ch | 64 bits | 8 bits | 8 bits | 16 bits | - | 1. This field is optional. #### Request parameter: - Request flags - UID (optional) - · First block number - Number of blocks Table 174. Get Multiple Block Security Status response format when Error\_flag is NOT set | Response SOF | Response_flags | Block security status | CRC16 | Response EOF | |--------------|----------------|-----------------------|---------|--------------| | - | 8 bits | 8 bits <sup>(1)</sup> | 16 bits | - | 1. Repeated as needed. ### Response parameters: Block security status Table 175. Block security status | <b>b</b> <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>3</sub> b <sub>2</sub> b <sub>1</sub> b <sub>0</sub> | | b <sub>0</sub> | |-------------------------|----------------|----------------|----------------|----------------|-------------------------------------------------------------|-------------------------|----------------| | Reserved for future use | | | | | 0: Current block not locked | | | | All at 0 | | | | | | 1: Current block locked | | Table 176. Get Multiple Block Security Status response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 03h: the option is not supported - 0Fh: error with no information given - 10h: the specified block is not available DS10925 - Rev 9 page 111/200 Figure 53. Get Multiple Block Security Status frame exchange between VCD and ST25DVxxx ### 7.6.25 Extended Get Multiple Block Security Status When receiving the Extended Get Multiple Block Security Status command, the ST25DVxxx sends back the security status for each address block: 0 when the block is writable else 1 when block is locked for writing. The block security statuses are defined by the area security status. The blocks are numbered from 00h up to the maximum memory block number in the request, and the value is minus one (–1) in the field. For example, a value of '06' in the "Number of blocks" field requests to return the security status of seven blocks. This command does not respond an error if number of blocks overlap areas or overlap the end of the user memory. The number of blocks is coded on 2 Bytes so all memory blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 177. Extended Get Multiple Block Security Status request format | Request<br>SOF | Request_flags | Extended<br>Get Multiple<br>Block<br>Security<br>Status | UID <sup>(1)</sup> | First block<br>number | Number of<br>blocks | CRC16 | Request<br>EOF | |----------------|---------------|---------------------------------------------------------|--------------------|-----------------------|---------------------|---------|----------------| | - | 8 bits | 3Ch | 64 bits | 16 bits | 16 bits | 16 bits | - | 1. This field is optional. # Request parameter: - Request flags - UID (optional) - First block number (from LSB byte to MSB byte) - Number of blocks (from LSB byte to MSB byte) Table 178. Extended Get Multiple Block Security Status response format when Error\_flags NOT set | Response SOF | Response_flags | Block security status | CRC16 | Response EOF | |--------------|----------------|-----------------------|---------|--------------| | - | 8 bits | 8 bits <sup>(1)</sup> | 16 bits | - | 1. Repeated as needed. # Response parameters: Block security status DS10925 - Rev 9 page 112/200 # Table 179. Block security status | b <sub>7</sub> | b <sub>7</sub> b <sub>6</sub> b <sub>5</sub> | | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | |----------------|----------------------------------------------|-----------------------------|----------------|----------------|----------------|----------------|----------------| | | | 0: Current block not locked | | | | | | | | | 1: Current block locked | | | | | | Table 180. Extended Get Multiple Block Security Status response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 03h: the option is not supported - 0Fh: error with no information given - 10h: the specified block is not available Figure 54. Extended Get Multiple Block Security Status frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 113/200 Note: # 7.6.26 Read Configuration On receiving the Read Configuration command, the ST25DVxxx reads the static system configuration register at the Pointer address and sends back its 8-bit value in the response. The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 181. Read Configuration request format | Request SOF | Request_flags | Read Configuration | IC Mfg code | UID (1) | Pointer | CRC16 | Request EOF | |-------------|---------------|--------------------|-------------|---------|---------|---------|-------------| | - | 8 bits | A0h | 02h | 64 bits | 8 bits | 16 bits | - | <sup>1.</sup> This field is optional. Please refer to Table 11. System configuration memory map for details on register addresses. Request parameters: - System configuration register pointer - UID (optional) Table 182. Read Configuration response format when Error\_flag is NOT set | Response SOF | Response_flags | Register value | CRC16 | Response EOF | |--------------|----------------|----------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameters: One byte of data: system configuration register Table 183. Read Configuration response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set - 02h: command not recognized - 03h: the option is not supported - 10h: block not available - 0Fh: error with no information given Figure 55. Read Configuration frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 114/200 #### 7.6.27 Write Configuration The Write Configuration command is used to write static system configuration register. The Write Configuration must be preceded by a valid presentation of the RF configuration password (00) to open the RF configuration security session. On receiving the Write Configuration command, the ST25DVxxx writes the data contained in the request to the system configuration register at the Pointer address and reports whether the write operation was successful in the response or not. When the Option flag is set, wait for EOF to respond. The Inventory flag is not supported. During the RF write cycle $W_t$ , there should be no modulation (neither 100% nor 10%), otherwise the ST25DVxxx may not program correctly the data into the Configuration byte. The $W_t$ time is equal to $t_{1nom} + N \times 302 \,\mu s$ (N is an integer). Table 184. Write Configuration request format | Request<br>SOF | Request_flags | Write<br>Configuration | IC Mfg<br>code | UID (1) | Pointer | Register<br>value <sup>(2)</sup> | CRC16 | Request<br>EOF | |----------------|---------------|------------------------|----------------|---------|---------|----------------------------------|---------|----------------| | - | 8 bits | A1h | 02h | 64 bits | 8 bits | 8 bits | 16 bits | - | - 1. This field is optional. - 2. Before updating the register value, check the meaning of each bit in previous sections. ### Request parameters: - Request flags - Register pointer - · Register value - UID (optional) Table 185. Write Configuration response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | Note: Please refer to Table 11. System configuration memory map for details on register addresses. ### Response parameter: No parameter. The response is sent back after the writing cycle. Table 186. Write configuration response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option is not supported - 0Fh: error with no information given - 10h: block not available - 12h: block already locked, content can't change - 13h: the specified block was not successfully programmed DS10925 - Rev 9 page 115/200 Figure 56. Write Configuration exchange between VCD and ST25DVxxx # 7.6.28 Read Dynamic Configuration On receiving the Read Dynamic Configuration command, the ST25DVxxx reads the Dynamic register address indicated by the pointer and sends back its 8-bit value in the response. The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 187. Read Dynamic Configuration request format | Request SOF | Request_flags | Read Dynamic<br>Configuration | IC Mfg code | UID (1) | Pointer address | CRC16 | Request EOF | |-------------|---------------|-------------------------------|-------------|---------|-----------------|---------|-------------| | - | 8 bits | ADh | 02h | 64 bits | 8 bits | 16 bits | - | 1. This field is optional. ### Request parameters: UID (Optional) Table 188. Read Dynamic Configuration response format when Error\_flag is NOT set | Response SOF | Response_flags | Data | CRC16 | Response EOF | |--------------|----------------|--------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | # Response parameters: · One byte of data Note: Please refer to Table 11. System configuration memory mapfor details on register addresses. Table 189. Read Dynamic Configuration response format when Error\_flag is set | | Response SOF | Response_flags | error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | ſ | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error given with no information - 10h: block not available DS10925 - Rev 9 page 116/200 Figure 57. Read Dynamic Configuration frame exchange between VCD and ST25DVxxx VCD SOF Read Dynamic Configuration request EOF ST25DVxxx SOF Read Dynamic Configuration response EOF # 7.6.29 Write Dynamic Configuration On receiving the Write Dynamic Configuration command, the ST25DVxxx updates the Dynamic register addressed by the pointer. The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 190. Write Dynamic Configuration request format | Request<br>SOF | Request_flags | Write Dynamic<br>Configuration | IC Mfg<br>code | UID (1) | Pointer address | Register<br>value | CRC16 | Request<br>EOF | |----------------|---------------|--------------------------------|----------------|---------|-----------------|-------------------|---------|----------------| | - | 8 bits | AEh | 02h | 64 bits | 8 bits | 8 bits | 16 bits | - | 1. This field is optional. #### Request parameters: - Request flags - UID (Optional) - Pointer address - · Register value Table 191. Write Dynamic Configuration response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | ### Response parameters: No parameter. The response is sent back after t<sub>1</sub>. Table 192. Write Dynamic Configuration response format when Error\_flag is set | Response SOF | Response_flags | error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: Error code as Error\_flag is set: 02h: command not recognized 03h: command option not supported 0Fh: error with no information given 10h: block not available DS10925 - Rev 9 page 117/200 Figure 58. Write Dynamic Configuration frame exchange between VCD and ST25DVxxx ### 7.6.30 Manage GPO On receiving the Manage GPO command. Depending on the command argument, the ST25DV force the GPO output level if RF\_USER interrupt is enabled, or send a pulse on GPO output if RF\_INTERRUPT is enabled. If neither RF\_USER nor RF\_INTERRUPT was enabled, the command is not executed and ST25DVxxx responds an Error code "0F". The IT duration is defined by IT\_TIME register and occurs just after the command response. For the ST25DVxx-JF (CMOS output), a set means that the GPO pin is driven to a High level ( $V_{DCG}$ ) and a Reset pulls the GPO pin to a low level ( $V_{SS}$ ). The IT corresponds to a transmission of a positive pulse on the GPO pin. For the ST25DVxx-IE (open drain output), a Set means that the GPO pin is driven to a low level ( $V_{SS}$ ) and a Reset releases the GPO (High impedance). IT corresponds to the GPO pin driven to ground during the IT duration, then pin is released. Thanks to an external pull up, the high level will be recovered. Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 193. ManageGPO request format | Request SOF | Request_ flags | ManageGPO | IC Mfg code | UID (1) | GPO VAL <sup>(2)</sup> | CRC16 | Request EOF | |-------------|----------------|-----------|-------------|---------|------------------------|---------|-------------| | - | 8 bits | A9h | 02h | 64 bits | 8 bits | 16 bits | - | - 1. This field is optional. - 2. See Table 194 Table 194. GPOVAL | GPOVAL | GPOVAL IT ST25DVxx-IE (OD) | | ST25DVxx-JF (CMOS) | | |-----------|----------------------------|-------------------------------------------------------|----------------------------------------------|--| | 0xxxxxx0b | RF_USER enabled | Pin pull to 0 | GPO Pin set to logic One (V <sub>DCG</sub> ) | | | 0xxxxxx1b | RF_USER enabled | Pin released (HZ) | GPO Pin reset to logic zero | | | 1xxxxxxxb | RF_INTERRUPT enabled | GPO pin pulled to 0 during IT Time then released (HZ) | GPO Pin drives a positive pulse | | | А | ny other conditions | GPO released (Hz) | GPO pin reset to logic zero | | #### Request parameters: - Request flag - UID (optional) - Data: Define static or dynamic Interrupt DS10925 - Rev 9 page 118/200 Table 195. ManageGPO response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | No parameter. The response is sent back after the write cycle. Table 196. ManageGPO response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 13h: the specified block was not successfully programmed (this error is generated if the ManageCPO GPOVAL value is not in line with the GPO interrupts setting as specified in Table 194. GPOVAL) Figure 59. Manage GPO frame exchange between VCD and ST25DVxxx #### 7.6.31 Write Message On receiving the Write Message command, the ST25DVxxx puts the data contained in the request into the Mailbox buffer, update the MB\_LEN\_Dyn register, and set bit RF\_PUT\_MSG in MB\_CTRL\_Dyn register. It then reports if the write operation was successful in the response. The ST25DVxxx Mailbox contains up to 256 data bytes which are filled from the first location '00'. MSGlength parameter of the command is the number of Data bytes minus - 1 (00 for 1 byte of data, FFh for 256 bytes of data). Write Message could be executed only when Mailbox is accessible by RF (fast transfer mode is enabled, previous RF message was read or time-out occurs, no I<sup>2</sup>C message to be read). User can check it by reading b1 of MB\_CTRL\_Dyn "HOST\_PUT\_MSG" which must be reset to "0". The Option\_flag is not supported. (refer to Section 5.1 Fast transfer mode (FTM)) Table 197. Write Message request format | Request<br>SOF | Request_<br>flags | Write<br>Message | IC Mfg<br>code | UID (1) | MSGLength | Message<br>Data | CRC16 | Request<br>EOF | |----------------|-------------------|------------------|----------------|---------|-----------|-----------------------|---------|----------------| | - | 8 bits | AAh | 02h | 64 bits | 1 byte | (MSGLength + 1) bytes | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flags - UID (optional) - Message Length - Message Data DS10925 - Rev 9 page 119/200 Table 198. Write Message response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | No parameter. The response is sent back after the write cycle. Table 199. Write Message response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given Figure 60. Write Message frame exchange between VCD and ST25DVxxx # 7.6.32 Read Message Length On receiving the Read Message Length command, the ST25DVxxx reads the MB\_LEN\_Dyn register which contains the Mailbox message length and sends back its 8-bit value in the response. The value of MB\_LEN\_Dyn returned is the (size of the message length in Bytes - 1). The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 200. Read Message Length request format | Request SOF | Request_flags | Read Message Length | IC Mfg code | UID (1) | CRC16 | Request EOF | |-------------|---------------|---------------------|-------------|---------|---------|-------------| | - | 8 bits | ABh | 02h | 64 bits | 16 bits | - | 1. The field is optional. ## Request parameters: UID (Optional) DS10925 - Rev 9 page 120/200 Table 201. Read Message Length response format when Error\_flag is NOT set | Respons | se SOF | Response_flags | Data | CRC16 | Response EOF | |---------|--------|----------------|--------|---------|--------------| | - | 3 | 8 bits | 8 bits | 16 bits | - | One byte of data: MB\_LEN\_Dyn register value Table 202. Read Message Length response format when Error\_flag is set | Response SOF | Response SOF Response_flags | | CRC16 | Response EOF | | |--------------|-----------------------------|--------|---------|--------------|--| | - | 8 bits | 8 bits | 16 bits | - | | #### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error given with no information Figure 61. Read Message Length frame exchange between VCD and ST25DVxxx ### 7.6.33 Read Message On receiving the Read Message command, the ST25DVxxx reads up to 256 byte in the Mailbox from the location specified by MBpointer and sends back their value in the response. First MailBox location is '00'. When Number of bytes is set to 00h and MBPointer is equals to 00h, the MB\_LEN bytes of the full message are returned. Otherwise, Read Message command returns (Number of Bytes + 1) bytes (i.e. 01h returns 2 bytes, FFh returns 256 bytes). An error is reported if (Pointer + Nb of bytes + 1) is greater than the message length. RF Reading of the last byte of the mailbox message automatically clears b1 of MB\_CTRL\_Dyn "HOST\_PUT\_MSG", and allows RF to put a new message. The Option\_flag is not supported. The Inventory\_flag must be set to 0. Table 203. Read Message request format | Request<br>SOF | Request_flags | Read<br>Message | IC Mfg<br>code | UID (1) | MBpointer | Number of<br>Bytes | CRC16 | Request<br>EOF | |----------------|---------------|-----------------|----------------|---------|-----------|--------------------|---------|----------------| | - | 8 bits | ACh | 02h | 64 bits | 8 bits | 8 bits | 16 bits | - | 1. This field is optional. #### Request parameters: - Request flag - UID (Optional) DS10925 - Rev 9 page 121/200 - Pointer (start at 00h) - Number of bytes is one less then the requested data Table 204. Read Message response format when Error flag is NOT set | Response SOF Response_flags | | Mailbox content | CRC16 | Response EOF | |-----------------------------|--------|---------------------------------|---------|--------------| | - | 8 bits | (Number of bytes + 1) bytes (1) | 16 bits | - | <sup>1.</sup> Number of message Bytes when Number of Bytes is set to 00h. (number of data + 1) data bytes # Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given Figure 62. Read Message frame exchange between VCD and ST25DVxxx ### 7.6.34 Fast Read Message On receiving the Fast Read Message command, the ST25DVxxx reads up to 256 byte in the Mailbox from the location specified by MBpointer and sends back their value in the response. First MailBox location is '00'. When Number of bytes is set to 00h and MBPointer is equals to 00h, the MB\_LEN bytes of the full message are returned. Otherwise, Fast Read Message command returns (Number of Bytes + 1) bytes (i.e. 01h returns 2 bytes, FFh returns 256 bytes). An error is reported if (Pointer + Nb of bytes + 1) is greater than the message length... RF Reading of the last byte of mailbox message automatically clears b1 of MB\_CTRL\_Dyn "HOST\_PUT\_MSG" and allows RF to put a new message. The data rate of the response is multiplied by 2 compated to Read Message. The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The Option\_flag is not supported, and the Inventory\_flag must be set to 0. Table 205. Fast Read Message request format | Request<br>SOF | Request_flags | Fast Read<br>Message | IC Mfg<br>code | UID <sup>(1)</sup> | MBpointer | Number of<br>Bytes | CRC16 | Request<br>EOF | |----------------|---------------|----------------------|----------------|--------------------|-----------|--------------------|---------|----------------| | - | 8 bits | CCh | 02h | 64 bits | 8 bits | 8 bits | 16 bits | - | <sup>1.</sup> This field is optional ### Request parameters: Request flag DS10925 - Rev 9 page 122/200 - UID (Optional) - Pointer (start at 00h) - Number of bytes is one less than the requested data Table 206. Fast Read Message response format when Error\_flag is NOT set | Response SOF Response_flags | | Mailbox content | CRC16 | Response EOF | | |-----------------------------|--------|--------------------------------------------|---------|--------------|--| | - | 8 bits | (Number of bytes + 1) bytes <sup>(1)</sup> | 16 bits | 64 bits | | 1. Number of message Bytes when Number of Bytes is set to 00h #### Response parameters: (number of bytes + 1) data bytes #### Response parameter: - Error code as Error flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given Figure 63. Fast Read Message frame exchange between VCD and ST25DVxxx #### 7.6.35 Write Password On receiving the Write Password command, the ST25DVxxx uses the data contained in the request to write the password and reports whether the operation was successful in the response. It is possible to modify a Password value only after issuing a valid Present password command (of the same password number). When the Option\_flag is set, wait for EOF to respond. Refer to Section 5.6 Data Protection for details on password Management. The Inventory\_flag must be set to 0. During the RF write cycle time, $W_t$ , there must be no modulation at all (neither 100% nor 10%), otherwise the ST25DVxxx may not correctly program the data into the memory. The $W_t$ time is equal to $t_{1nom}$ + N × 302 $\mu$ s (N is an integer). After a successful write, the new value of the selected password is automatically activated. It is not required to present the new password value until the ST25DVxxx power-down. #### Caution: If ST25DVxxx is powered through $V_{CC}$ , removing $V_{CC}$ during Write Password command can abort the command. As a consequence, before writing a new password, RF user should check if $V_{CC}$ is ON, by reading EH\_CTRL\_Dyn register bit 3 (VCC\_ON), and eventually ask host to maintain or to shut down $V_{CC}$ , during the Write Password command in order to avoid password corruption. To make the application more robust, it is recommended to use addressed or selected mode during write password operations to get the traceability of which tags/UID have been programmed DS10925 - Rev 9 page 123/200 # Table 207. Write Password request format | Request<br>SOF | Request_flags | Write<br>password | IC Mfg code | UID <sup>(1)</sup> | Password<br>number | Data | CRC16 | Request<br>EOF | |----------------|---------------|-------------------|-------------|--------------------|--------------------|---------|---------|----------------| | - | 8 bits | B1h | 02h | 64 bits | 8 bits | 64 bits | 16 bits | - | ### 1. This field is optional. # Request parameter: - Request flags - UID (optional) - Password number: - 00h = RF configuration password RF\_PWD\_0, - 01h = RF\_PWD\_1, - 02h = RF\_PWD\_2, - 03h = RF\_PWD\_3, - other = Error - Data Table 208. Write Password response format when Error\_flag is NOT set | Response SOF | Response SOF Response_flags | | Response EOF | | |--------------|-----------------------------|---------|--------------|--| | - | 8 bits | 16 bits | - | | ### Response parameter: no parameter. Table 209. Write Password response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 10h: the password number is incorrect - 12h: update right not granted, Present Password command not previously executed successfully - 13h: the specified block was not successfully programmed DS10925 - Rev 9 page 124/200 Figure 64. Write Password frame exchange between VCD and ST25DVxxx #### 7.6.36 Present Password On receiving the Present Password command, the ST25DVxxx compares the requested password with the data contained in the request and reports if the operation has been successful in the response. Refer to Section 5.6 Data Protection for details on password Management. After a successful command, the security session associate to the password is open as described in Section 5.6 Data Protection. The Option\_flag is not supported, and the Inventory\_flag must be set to 0. Table 210. Present Password request format | Requ<br>SO | Request_flags | Present<br>Password | IC Mfg<br>code | UID (1) | Password<br>number | Password | CRC16 | Request<br>EOF | |------------|---------------|---------------------|----------------|---------|--------------------|----------|---------|----------------| | - | 8 bits | B3h | 02h | 64 bits | 8 bits | 64 bits | 16 bits | - | 1. This field is optional. # Request parameter: - Request flags - UID (optional) - Password Number: - 00h = RF configuration password RF\_PWD\_0 - 01h = RF\_PWD\_1 - 02h = RF\_PWD\_2 - 03h = RF\_PWD\_3 - other = Error - Password Table 211. Present Password response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | #### Response parameter: No parameter. The response is sent back after the write cycle. DS10925 - Rev 9 page 125/200 Table 212. Present Password response format when Error\_flag is set | | Response SOF Response_flags | | Error code | CRC16 | Response EOF | | |---|-----------------------------|--------|------------|---------|--------------|--| | - | | 8 bits | 8 bits | 16 bits | - | | - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: the present password is incorrect - 10h: the password number is incorrect Figure 65. Present Password frame exchange between VCD and ST25DVxxx ### 7.6.37 Fast Read Single Block On receiving the Fast Read Single Block command, the ST25DVxxx reads the requested block and sends back its 32-bit value in the response. When the Option\_flag is set, the response includes the Block Security Status. The data rate of the response is multiplied by 2. The subcarrier flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The Inventory flag must be set to 0. Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 213. Fast Read Single Block request format | Request SOF | Request_flags | Fast Read Single Block | IC Mfg code | UID (1) | Block number | CRC16 | Request EOF | |-------------|---------------|------------------------|-------------|---------|--------------|---------|-------------| | - | 8 bits | C0h | 02h | 64 bits | 8 bits | 16 bits | - | <sup>1.</sup> This field is optional. #### Request parameters: - Request flags - UID (optional) - Block number Table 214. Fast Read Single Block response format when Error\_flag is NOT set | Response SOF | Response_flags | Block security status (1) | Data CRC16 | | Response EOF | |--------------|----------------|---------------------------|------------|---------|--------------| | - | 8 bits | 8 bits | 32 bits | 16 bits | - | 1. This field is optional. DS10925 - Rev 9 page 126/200 - Block security status if Option\_flag is set (see Table 215. Block security status) - Four bytes of block data #### Table 215. Block security status Table 216. Fast Read Single Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | | |--------------|----------------|------------|---------|--------------|--| | - | 8 bits | 8 bits | 16 bits | - | | #### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given - 10h: the specified block is not available - 15h: the specified block is read-protected Figure 66. Fast Read Single Block frame exchange between VCD and ST25DVxxx #### 7.6.38 Fast Extended Read Single Block On receiving the Fast Extended Read Single Block command, the ST25DVxxx reads the requested block and sends back its 32-bit value in the response. When the Option\_flag is set, the response includes the Block Security Status. The data rate of the response is multiplied by 2. The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The Inventory\_flag must be set to 0. Block number is coded on 2 Bytes so all memory blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command DS10925 - Rev 9 page 127/200 Table 217. Fast Extended Read Single Block request format | Request<br>SOF | Request_flags | Fast<br>Extended<br>Read Single<br>Block | IC Mfg code | UID <sup>(1)</sup> | Block<br>number | CRC16 | Request<br>EOF | |----------------|---------------|------------------------------------------|-------------|--------------------|-----------------|---------|----------------| | - | 8 bits | C4h | 02h | 64 bits | 16 bits | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flags - UID (optional) - Block number (from LSB byte to MSB byte) Table 218. Fast Extended Read Single Block response format when Error\_flag is NOT set | Response SOF | Response_flags | Block security status (1) | Data | CRC16 | Response EOF | |--------------|----------------|---------------------------|---------|---------|--------------| | - | 8 bits | 8 bits | 32 bits | 16 bits | - | 1. This field is optional. #### Response parameters: - Block security status if Option\_flag is set (see Table 219. Block security status) - Four bytes of block data ## Table 219. Block security status | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | |----------------|----------------|----------------|----------------|-----------------------------|----------------|----------------|-------------------------| | Reserved | d for future | use | | 0: Current Block not locked | | | | | All at 0 | | | | | | | 1: Current Block locked | Table 220. Fast Extended Read Single Block response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given - 10h: the specified block is not available - 15h: the specified block is read-protected DS10925 - Rev 9 page 128/200 Figure 67. Fast Extended Read Single Block frame exchange between VCD and ST25DVxxx ### 7.6.39 Fast Read Multiple Blocks On receiving the Fast Read Multiple Blocks command, the ST25DVxxx reads the selected blocks and sends back their value in multiples of 32 bits in the response. The blocks are numbered from 00h up to the last block of user memory in the request, and the value is minus one (–1) in the field. For example, if the "Number of blocks" field contains the value 06h, seven blocks are read. The maximum number of blocks is fixed to 256 assuming that they are all located in the same area. If the number of blocks overlaps area or overlaps the end of user memory, the ST25DVxxx returns an error code. When the Option\_flag is set, the response includes the Block Security Status. The data rate of the response is multiplied by 2. The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The Inventory\_flag must be set to 0. Block number is coded on 1 Byte and only first 256 blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 221. Fast Read Multiple Block request format | Request<br>SOF | Request_flags | Fast Read<br>Multiple Block | IC Mfg<br>code | UID (1) | First block<br>number | Number of blocks | CRC16 | Request<br>EOF | |----------------|---------------|-----------------------------|----------------|---------|-----------------------|------------------|---------|----------------| | - | 8 bits | C3h | 02h | 64 bits | 8 bits | 8 bits | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flag - UID (Optional) - First block number - Number of blocks Table 222. Fast Read Multiple Block response format when Error flag is NOT set | Response SOF | Response_flags | Block security status <sup>(1)</sup> | Data CRC16 | | Response EOF | |--------------|----------------|--------------------------------------|------------------------|---------|--------------| | - | 8 bits | 8 bits <sup>(2)</sup> | 32 bits <sup>(2)</sup> | 16 bits | - | - 1. This field is optional. - 2. Repeated as needed. #### Response parameters: - Block security status if Option\_flag is set (see Table 223. Block security status if Option\_flag is set) - N block of data DS10925 - Rev 9 page 129/200 # Table 223. Block security status if Option\_flag is set Table 224. Fast Read Multiple Block response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 0Fh: error with no information given - 03h: the option is not supported - 10h: block address not available - 15h: block read-protected Figure 68. Fast Read Multiple Block frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 130/200 ### 7.6.40 Fast Extended Read Multiple Block On receiving the Fast Extended Read Multiple Block command, the ST25DVxxx reads the selected blocks and sends back their value in multiples of 32 bits in the response. The blocks are numbered from 00h to up to the last block of memory in the request and the value is minus one (–1) in the field. For example, if the "Number of blocks" field contains the value 06h, seven blocks are read. The maximum number of blocks is fixed to 2047 assuming that they are all located in the same area. If the number of blocks overlaps several areas or overlaps the end of user memory, the ST25DVxxx returns an error code. When the Option\_flag is set, the response includes the Block Security Status. The data rate of the response is multiplied by 2. The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The Inventory\_flag must be set to 0. Block number is coded on 2 Bytes so all memory blocks of ST25DV16K-xx and ST25DV64K-xx can be addressed using this command. Table 225. Fast Extended Read Multiple Block request format | Request<br>SOF | Request_flags | Fast Extended<br>Read Multiple<br>Block | IC Mfg<br>code | UID (1) | First block<br>number | Block<br>Number | CRC16 | Request<br>EOF | |----------------|---------------|-----------------------------------------|----------------|---------|-----------------------|-----------------|---------|----------------| | - | 8 bits | C5h | 02h | 64 bits | 16 bits | 16 bits | 16 bits | - | 1. This field is optional. #### Request parameters: - Request flag - UID (Optional) - First block number (from LSB byte to MSB byte) - Number of blocks (from LSB byte to MSB byte) Table 226. Fast Extended Read Multiple Block response format when Error\_flag is NOT set | Response SOF | Response_flags | Block security status <sup>(1)</sup> | Data CRC16 | | Response EOF | |--------------|----------------|--------------------------------------|------------------------|---------|--------------| | - | 8 bits | 8 bits <sup>(2)</sup> | 32 bits <sup>(2)</sup> | 16 bits | - | - 1. This field is optional. - 2. Repeated as needed. #### Response parameters: - Block security status if Option\_flag is set (see Table 223. Block security status if Option\_flag is set) - N block of data Table 227. Block security status if Option\_flag is set | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | $b_0$ | |----------------|----------------|----------------|----------------|----------------|-----------------------|----------------|-------------------| | Reserved | d for future | | | | 0: Current not locked | | | | use All at 0 | | | | | | | 1: Current locked | Table 228. Fast Read Multiple Block response format when Error\_flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | DS10925 - Rev 9 page 131/200 - Error code as Error\_flag is set: - 02h: command not recognized - 03h: the option is not supported - 0Fh: error with no information given - 10h: block address not available - 15h: block read-protected Figure 69. Fast Extended Read Multiple Block frame exchange between VCD and ST25DVxxx # 7.6.41 Fast Write Message On receiving the Fast Write Message command, the ST25DVxxx puts the data contained in the request into the mailbox buffer, updates the Message Length register MB\_LEN\_Dyn, and set Mailbox loaded bit RF\_PUT\_MSG. It then reports if the write operation was successful in the response. The ST25DVxxx mailbox contains up to 256 data bytes which are filled from the first location '00'. MSGlength parameter of the command is the number of Data bytes minus - 1 (00 for 1 byte of data, FFh for 256 bytes of data). Fast Write Message can be executed only when Mailbox is accessible by RF (previous RF message was read or time-out occurs, no I<sup>2</sup>C message to be read). User can check it by reading b1 of MB\_CTRL\_Dyn "HOST\_PUT\_MSG", which must be reset to "0". (refer to Section 5.1 Fast transfer mode (FTM)). - The data rate of the response is multiplied by 2 compared to Write Message command. - · The Option flag is not supported. - The Inventory flag must be set to 0. - The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. Table 229. Fast Write Message request format | Request<br>SOF | Request_flags | Fast Write<br>Message | IC Mfg<br>code | UID (1) | MSGLength | Message Data | CRC16 | Request<br>EOF | |----------------|---------------|-----------------------|----------------|---------|-----------|--------------------------|---------|----------------| | - | 8 bits | CAh | 02h | 64 bits | 1 byte | (MsgLenght + 1)<br>bytes | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flag - · UID (optional) - Message Lenght - Message Data Table 230. Fast Write Message response format when Error flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | DS10925 - Rev 9 page 132/200 • No parameter. The response is sent back after the write cycle. Table 231. Fast Write Message response format when Error flag is set | | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |---|--------------|----------------|------------|---------|--------------| | - | | 8 bits | 8 bits | 16 bits | - | #### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given Figure 70. Fast Write Message frame exchange between VCD and ST25DVxxx # 7.6.42 Fast Read Message Length On receiving the Fast Read Message Length command, the ST25DV reads the MB\_LEN\_dyn register which contains the mailbox message length and sends back its 8-bit value in the response. The value of MB\_LEN\_Dyn returned is the (size of the message length in Bytes - 1). The Option\_flag is not supported. The Inventory\_flag must be set to 0. The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The data rate of the response is multiplied by 2 compared to Read Message Length command. Table 232. Fast Read Message Length request format | Request SOF | Request_flags | Fast Read Message Length | IC Mfg code | UID (1) | CRC16 | Request EOF | |-------------|---------------|--------------------------|-------------|---------|---------|-------------| | - | 8 bits | CBh | 02h | 64 bits | 16 bits | - | 1. This field is optional. # Request parameters: - Request flag - UID (optional) DS10925 - Rev 9 page 133/200 Table 233. Fast Read Message Length response format when Error\_flag is NOT set | Response S | OF Respons | se_flags Data | CRC16 | Response EOF | |------------|------------|---------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | One byte of data: volatile Control register. Table 234. Fast Read Message Length response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 02h: command option not recognized - 03h: command not supported - 0Fh: error with no information given Figure 71. Fast Read Message Length frame exchange between VCD and ST25DVxxx ### 7.6.43 Fast Read Dynamic configuration On receiving the Fast Read Dynamic configuration command, the ST25DVxxx reads the Dynamic register address by the pointer and sends back its 8-bit value in the response. The Option\_flag is not supported. The Inventory\_flag must be set to 0. The subcarrier\_flag should be set to 0, otherwise the ST25DVxxx answers with an error code. The data rate of the response is multiplied by 2 compared to Read Dynamic configuration command. Table 235. Fast Read Dynamic configuration request format | Request SOF | Request_flags | Fast Read Dynamic configuration | IC Mfg code | UID (1) | Pointer address | CRC16 | Request EOF | |-------------|---------------|---------------------------------|-------------|---------|-----------------|---------|-------------| | - | 8 bits | CDh | 02h | 64 bits | 8 bits | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flag - UID (optional) DS10925 - Rev 9 page 134/200 Table 236. Fast Read Dynamic configuration response format when Error\_flag is NOT set | Response SOF | Response_flags | Data | CRC16 | Response EOF | |--------------|----------------|--------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | One byte of data Table 237. Fast Read Dynamic configuration response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error\_flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given - 10h: block not available Figure 72. Fast Read Dynamic configuration frame exchange between VCD and ST25DVxxx # 7.6.44 Fast Write Dynamic Configuration On receiving the Fast Write Dynamic Configuration command, the ST25DV updates the Dynamic register addressed by the pointer. The Option\_flag is not supported. The Inventory\_flag must be set to 0. The data rate of the response is multiplied by 2 compared to Write Dynamic Configuration command. Table 238. Fast Write Dynamic Configuration request format | Request<br>SOF | Request_flags | Fast Write<br>Dynamic<br>Configuration | IC Mfg<br>code | UID (1) | Pointer<br>address | Register<br>Value | CRC16 | Request<br>EOF | |----------------|---------------|----------------------------------------|----------------|---------|--------------------|-------------------|---------|----------------| | - | 8 bits | CEh | 02h | 64 bits | 8 bits | 8 bits | 16 bits | - | 1. This field is optional. ### Request parameters: - Request flag - UID (optional) - Pointer address - Register value DS10925 - Rev 9 page 135/200 Table 239. Fast Write Dynamic Configuration response format when Error\_flag is NOT set | Response SOF | Response_flags | CRC16 | Response EOF | |--------------|----------------|---------|--------------| | - | 8 bits | 16 bits | - | No parameter. The response is sent back after t<sub>1</sub>. Table 240. Fast Write Dynamic Configuration response format when Error\_flag is set | Response SOF | Response_flags | Error code | CRC16 | Response EOF | |--------------|----------------|------------|---------|--------------| | - | 8 bits | 8 bits | 16 bits | - | ### Response parameter: - Error code as Error flag is set: - 02h: command not recognized - 03h: command option not supported - 0Fh: error with no information given - 10h: block not available Figure 73. Fast Write Dynamic Configuration frame exchange between VCD and ST25DVxxx DS10925 - Rev 9 page 136/200 # 8 Unique identifier (UID) The ST25DVxxx is uniquely identified by a 64-bit unique identifier (UID). This UID complies with ISO/IEC 15963 and ISO/IEC 7816-6. The UID is a read-only code and comprises: - eight MSBs with a value of E0h, - the IC manufacturer code "ST 02h" on 8 bits (ISO/IEC 7816-6/AM1), - a unique serial number on 48 bits. Table 241, UID format | MSB | | | | LSB | | | | |------|----|------|----|----------------|------------------|---------------|--------| | 63 | 56 | 55 | 48 | 47 | 40 | 39 | 0 | | 0xE0 | | 0x02 | | ST product cod | e <sup>(1)</sup> | Unique serial | number | 1. See Table 85. UID for ST product code value definition. With the UID, each ST25DVxxx can be addressed uniquely and individually during the anticollision loop and for one-to-one exchanges between a VCD and an ST25DVxxx. DS10925 - Rev 9 page 137/200 # 9 Device parameters ### 9.1 Maximum rating Stressing the device above the rating listed in Table 242. Absolute maximum ratings may cause permanent damage to the device. These are stress ratings only and operation of the device, at these or any other conditions above those indicated in the operating sections of this specification, is not implied. Exposure to absolute maximum rating conditions for extended periods may affect the device reliability. Device mission profile (application conditions) is compliant with JEDEC JESD47 qualification standard. Extended mission profiles can be assessed on demand. Refer also to the STMicroelectronics SURE Program and other relevant quality documents. Symbol **Parameter** Min. Max. Unit RF and Range 6 All packages -40 °C I<sup>2</sup>C interfaces RF and - 40 105 °C UFDFPN8, UFDFPN12 $T_A$ Ambient operating temperature I<sup>2</sup>C interfaces Range 8 RF interface - 40 105 °C SO8N, TSSOP I<sup>2</sup>C interface - 40 125 °C TSTG Storage Temperature 15 25 °C Sawn wafer on UV tape kept in its original packing form tstg Retain 9 (1) months **T<sub>STG</sub>** UFDFPN8 (MLP8), SO8N, TSSOP8, UFDFPN12, WLCSP10 - 65 150 °C Storage temperature see note (2) °C **TLEAD** Lead temperature during soldering $V_{IO}$ - 0.50 6.5 I<sup>2</sup>C input or output range V $V_{DCG}$ Supply GPO CMOS driver - 0.50 6.5 V $V_{CC}$ - 0.50 6.5 V I<sup>2</sup>C supply voltage DC output current on pin SDA (when equal to 0) 5 mΑ I<sub>OL\_MAX\_SDA</sub> DC output current on pin GPO open drain (when equal to 0) IOL MAX GPO OD 1.5 mA RF input voltage amplitude peak to peak between AC0 and AC1, V<sub>SS</sub> pin left floating V<sub>MAX\_1</sub> (3) V<sub>AC0</sub> - V<sub>AC1</sub> 11 ٧ V<sub>AC0</sub> - V<sub>SS</sub>, $V_{MAX_2}^{(3)}$ AC voltage between AC0 and V<sub>SS</sub>, or AC1 and V<sub>SS</sub> - 0.50 5.5 ٧ or VAC1 - VSS $V_{ESD}$ All pins 2000 V Electrostatic discharge voltage (human body model) (4) Table 242. Absolute maximum ratings DS10925 - Rev 9 page 138/200 <sup>1.</sup> Counted from ST production date. Compliant with JEDEC Std J-STD-020C (for small body, Sn-Pb or Pb assembly), the ST ECOPACK® 7191395 specification, and the European directive on Restrictions on Hazardous Substances (RoHS) 2002/95/EU. <sup>3.</sup> Based on characterization, not tested in production. <sup>4.</sup> AEC-Q100-002 (compliant with JEDEC Std JESD22-A114, C1 = 100 pF, R1 = 1500 $\Omega$ , R2 = 500 $\Omega$ ) # 9.2 I2C DC and AC parameters This section summarizes the operating and measurement conditions, and the DC and AC characteristics of the device in I<sup>2</sup>C mode. The parameters in the DC and AC characteristic tables that follow are derived from tests performed under the measurement conditions summarized in the relevant tables. Designers should check that the operating conditions in their circuit match the measurement conditions when relying on the quoted parameters. Table 243. I<sup>2</sup>C operating conditions | Symbol | Parameter | | | | Max. | Unit | |-----------------|-------------------------------|---------|-------------------|-----|------|------| | V <sub>CC</sub> | C Supply voltage | | | | 5.5 | V | | | | Range 6 | All packages | -40 | 85 | °C | | T <sub>A</sub> | Ambient operating temperature | Danga 9 | UFDFPN8, UFDFPN12 | -40 | 105 | °C | | | | Range 8 | SO8N, TSSOP8 | -40 | 125 | °C | Table 244. AC test measurement conditions | Symbol | Parameter | Min. | Max. | Unit | |--------------------------------|-----------------------------------------------------------------------------------|------|------|------| | C <sub>L</sub> | Load capacitance | 100 | | pF | | t <sub>r,</sub> t <sub>f</sub> | Input rise and fall times | - | 50 | ns | | V <sub>hi-lo</sub> | Input levels 0.2V <sub>CC</sub> to 0.8V <sub>CC</sub> | | cc | V | | V <sub>ref(t)</sub> | Input and output timing reference levels 0.3V <sub>CC</sub> to 0.7V <sub>CC</sub> | | | V | Figure 74. AC test measurement I/O waveform Table 245. Input parameters | Symbol | Parameter | | Max. | Unit | |---------------------|---------------------------------------------------|---|------|------| | C <sub>IN</sub> | Input capacitance (SDA) | - | 8 | pF | | C <sub>IN</sub> | Input capacitance (other pins) | - | 6 | pF | | t <sub>NS</sub> (1) | Pulse width ignored (Input filter on SCL and SDA) | - | 80 | ns | 1. Characterized only. Table 246. I<sup>2</sup>C DC characteristics up to 85°C | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |--------|----------------------------------|----------------------------------------------------------------|------|------|-------|------| | ILI | Input leakage current (SCL, SDA) | $V_{IN} = V_{SS} \text{ or } V_{CC}$<br>device in Standby mode | - | 0.03 | ± 0.1 | μΑ | | ILI | Input leakage current | V <sub>IN</sub> = V <sub>SS</sub> | - | 0.1 | ± 0.5 | μΑ | DS10925 - Rev 9 page 139/200 | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |---------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------|----------------------|------------|----------------------|----------| | | (LPD) | device in Standby mode | | | | | | I <sub>LO</sub> | Output leakage current | SDA in Hi-Z, external voltage | _ | 0.03 | ± 0.1 | ^ | | iLO | (SDA) | applied on SDA: $V_{SS}$ or $V_{CC}$ | - | 0.00 | 10.1 | μA | | | | $V_{CC}$ = 1.8 V, $f_{C}$ = 1MHz | _ | 116 | 160 | | | I <sub>CC</sub> _E <sup>2</sup> | Operating Supply current (Device select E <sup>2</sup> Address) Read <sup>(1)</sup> | (rise/fall time < 50 ns) | | 110 | 100 | | | | | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | _ | 220 | 240 | μA | | 100 | | (rise/fall time < 50 ns) | | | | μπ | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 510 | 550 | | | | | (rise/fall time < 50 ns) | | | 000 | | | | | $V_{CC} = 1.8 \text{ V}, f_{C} = 1 \text{MHz}$ | _ | 116 | 160 | | | | | (rise/fall time < 50 ns) | | | | | | I <sub>CC</sub> _MB | Operating Supply current (Device | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | _ | 220 | 240 | μA | | .002 | select MB Address) Read <sup>(1)</sup> | (rise/fall time < 50 ns) | | | 210 | <b>P</b> | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 510 | 550 | | | | | (rise/fall time < 50 ns) | | J10 | | | | I <sub>CC0</sub> | Operating Supply current (Device select E <sup>2</sup> Address) Write <sup>(1)</sup> | $V_{CC}$ = 1.8 V, $f_C$ = 1MHz | _ | 110 | 300 | | | | | (rise/fall time < 50 ns) | | | | | | | | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | _ | 110 | 330 | μA | | | | (rise/fall time < 50 ns) | | | | · | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 130 | 430 | | | | | (rise/fall time < 50 ns) | | | | | | | Operating Supply current (Device | $V_{CC}$ = 1.8 V, $f_C$ = 1MHz | _ | 170<br>280 | 200 | | | | | (rise/fall time < 50 ns) | | | | | | I <sub>CC0</sub> _MB | | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | _ | | | μA | | | select MB Address) Write <sup>(1)</sup> | (rise/fall time < 50 ns) | | | | - | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 520 | 600 | | | | | (rise/fall time < 50 ns) | | | | | | I <sub>CC1</sub> | | V <sub>CC</sub> = 1.8 V | - | 0.84 | 1.5 | | | (LPD = 1) | Low Power Down supply current | V <sub>CC</sub> = 3.3 V | - | 1.3 | 2 | μA | | (=: - : ) | | V <sub>CC</sub> = 5.5 V | - | 1.7 | 3 | | | I DON | Static Standby supply current after | V <sub>CC</sub> = 1.8 V | - | 72 | 100 | | | I <sub>CC1</sub> PON | power ON or device select stop or | V <sub>CC</sub> = 3.3 V | - | 76 | 100 | μΑ | | (LPD = 0) | time out | V <sub>CC</sub> = 5.5 V | - | 87 | 120 | | | | | V <sub>CC</sub> = 1.8 V | - 0.45 | - | 0.25 V <sub>CC</sub> | | | V <sub>IL</sub> | Input low voltage (SDA, SCL) | V <sub>CC</sub> = 3.3 V | - 0.45 | - | 0.3 V <sub>CC</sub> | V | | | , , , , , , , , , , , , , , , , , , , , | V <sub>CC</sub> = 5.5 V | - 0.45 | - | 0.3 V <sub>CC</sub> | | | V <sub>IL_LPD</sub> | Input low voltage (LPD) | V <sub>CC</sub> = 3.3 V | - 0.45 | _ | 0.2 V <sub>CC</sub> | V | | | . , | V <sub>CC</sub> = 1.8 V | 0.75 V <sub>CC</sub> | _ | V <sub>CC</sub> + 1 | | | $V_{IH}$ | Input high voltage (SDA, SCL) | V <sub>CC</sub> = 3.3 V | 0.75 V <sub>CC</sub> | _ | V <sub>CC</sub> + 1 | V | | * 1111 | | V <sub>CC</sub> = 5.5 V | 0.75 V <sub>CC</sub> | | V <sub>CC</sub> + 1 | • | | | | VGC = 3.3 V | 0.73 VCC | - | ACC + 1 | | DS10925 - Rev 9 page 140/200 | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |----------------------------|--------------------------------|---------------------------------------------------|----------------------|-------|---------------------|------| | | Input high voltage (LPD) | V <sub>CC</sub> = 1.8 V | 0.85 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | | | V <sub>IH</sub> _LPD | | V <sub>CC</sub> = 3.3 V | 0.85 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | V | | | | V <sub>CC</sub> = 5.5 V | 0.85 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | | | | Output low voltage SDA (1 MHz) | I <sub>OL</sub> = 1 mA, V <sub>CC</sub> = 1.8 V | - | 0.05 | 0.4 | | | V <sub>OL</sub> SDA | | I <sub>OL</sub> = 2.1 mA, V <sub>CC</sub> = 3.3 V | - | 0.075 | 0.4 | V | | | | $I_{OL}$ = 3 mA, $V_{CC}$ = 5.5 V | - | 0.09 | 0.4 | | | V <sub>CC</sub> _Powe r_up | Device Select Acknowledge | f <sub>C</sub> = 100 KHz | - | 1.48 | 1.7 | V | <sup>1.</sup> SCL, SDA connected to Ground or $V_{\text{CC}}$ . SDA connected to $V_{\text{CC}}$ through a pull-up resistor. Table 247. I<sup>2</sup>C DC characteristics up to 125°C | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | |---------------------------------|-------------------------------------------------------------------------|----------------------------------------------------|------|-------|-------|------| | I <sub>LI</sub> | Input leakage current | $V_{IN} = V_{SS} \text{ or } V_{CC}$ | | 0.03 | + 0.1 | | | 'LI | (SCL, SDA) | device in Standby mode | _ | 0.03 | ± 0.1 | μA | | I <sub>LI</sub> | Input leakage current | $V_{IN} = V_{SS}$ | _ | 0.1 | . 0.5 | μA | | •ы | (LPD) | device in Standby mode | _ | 0.1 | ± 0.5 | μΑ | | I <sub>LO</sub> | Output leakage current | SDA in Hi-Z, external voltage | _ | 0.03 | ± 0.1 | μA | | ·LO | (SDA) | applied on SDA: V <sub>SS</sub> or V <sub>CC</sub> | | 0.00 | 1 0.1 | μΛ | | | | $V_{CC}$ = 1.8 V, $f_C$ = 1MHz | _ | 126 | 180 | | | | | (rise/fall time < 50 ns) | _ | 120 | 100 | | | I <sub>CC</sub> _E <sup>2</sup> | Operating Supply current (Device | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | _ | 230 | 260 | μA | | ICC_L | select E <sup>2</sup> Address) Read <sup>(1)</sup> | (rise/fall time < 50 ns) | _ | 230 | 200 | μΛ | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 510 | 550 | | | | | (rise/fall time < 50 ns) | _ | | | | | | Operating Supply current (Device select MB Address) Read <sup>(1)</sup> | $V_{CC}$ = 1.8 V, $f_C$ = 1MHz | _ | 126 | 180 | | | | | (rise/fall time < 50 ns) | _ | | | | | I <sub>CC</sub> _MB | | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | - | 230 | 260 | μΑ | | ICC_IVID | | (rise/fall time < 50 ns) | | | | | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 510 | 550 | | | | | (rise/fall time < 50 ns) | _ | | | | | | | $V_{CC}$ = 1.8 V, $f_C$ = 1MHz | _ | 120 | 310 | | | | | (rise/fall time < 50 ns) | _ | 120 | 310 | | | I <sub>CC0</sub> | Operating Supply current (Device | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | _ | 120 | 350 | μA | | iCC0 | select E <sup>2</sup> Address) Write <sup>(1)</sup> | (rise/fall time < 50 ns) | _ | 120 | 330 | μΑ | | | | $V_{CC}$ = 5.5 V, $f_C$ = 1MHz | _ | 140 | 450 | | | | | (rise/fall time < 50 ns) | _ | 140 | 450 | | | | | $V_{CC}$ = 1.8 V, $f_C$ = 1MHz | _ | 100 | 220 | | | I MD | Operating Supply current (Device | (rise/fall time < 50 ns) | | 180 | 220 | | | I <sub>CC0</sub> _MB | select MB Address) Write(1) | $V_{CC}$ = 3.3 V, $f_C$ = 1MHz | | - 290 | 320 | μA | | | | (rise/fall time < 50 ns) | _ | | | | DS10925 - Rev 9 page 141/200 | Symbol | Parameter | Test condition | Min. | Тур. | Max. | Unit | | |----------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------|----------------------|------|----------------------|------|--| | I <sub>CC0</sub> _MB | Operating Supply current (Device | $V_{\rm CC}$ = 5.5 V, $f_{\rm C}$ = 1MHz | _ | 520 | 600 | μA | | | 1000_1112 | select MB Address) Write <sup>(1)</sup> | (rise/fall time < 50 ns) | - | 520 | 600 | μπ | | | | | V <sub>CC</sub> = 1.8 V | - | 2.5 | 5 | | | | I <sub>CC1</sub> (LPD = 1) | Low Power Down supply current | V <sub>CC</sub> = 3.3 V | - | 3 | 6 | μΑ | | | (LPD = 1) | | V <sub>CC</sub> = 5.5 V | - | 4 | 7 | | | | | Chalic Chandles assessed after | V <sub>CC</sub> = 1.8 V | - | 78 | 110 | | | | I <sub>CC1</sub> PON | Static Standby supply current after<br>power ON or device select stop or<br>time out | V <sub>CC</sub> = 3.3 V | - | 82 | 110 | μΑ | | | (LPD = 0) | | V <sub>CC</sub> = 5.5 V | - | 95 | 130 | | | | | | V <sub>CC</sub> = 1.8 V | - 0.45 | - | 0.25 V <sub>CC</sub> | | | | V <sub>IL</sub> | Input low voltage (SDA, SCL) | V <sub>CC</sub> = 3.3 V | - 0.45 | - | 0.3 V <sub>CC</sub> | V | | | | | V <sub>CC</sub> = 5.5 V | - 0.45 | - | 0.3 V <sub>CC</sub> | | | | V <sub>IL_LPD</sub> | Input low voltage (LPD) | V <sub>CC</sub> = 3.3 V | - 0.45 | - | 0.2 V <sub>CC</sub> | V | | | | | V <sub>CC</sub> = 1.8 V | 0.75 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | | | | V <sub>IH</sub> | Input high voltage (SDA, SCL) | V <sub>CC</sub> = 3.3 V | 0.75 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | V | | | | | V <sub>CC</sub> = 5.5 V | 0.75 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | | | | | | V <sub>CC</sub> = 1.8 V | 0.85 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | | | | V <sub>IH</sub> _LPD | Input high voltage (LPD) | V <sub>CC</sub> = 3.3 V | 0.85 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | V | | | | | V <sub>CC</sub> = 5.5 V | 0.85 V <sub>CC</sub> | - | V <sub>CC</sub> + 1 | | | | | | I <sub>OL</sub> = 1 mA, V <sub>CC</sub> = 1.8 V | - | 0.05 | 0.4 | | | | V <sub>OL</sub> SDA | Output low voltage SDA (1 MHz) | I <sub>OL</sub> = 2.1 mA, V <sub>CC</sub> = 3.3 V | - | 0.08 | 0.4 | V | | | | | $I_{OL}$ = 3 mA, $V_{CC}$ = 5.5 V | - | 0.1 | 0.4 | | | | V <sub>CC</sub> _Powe r_up | Device Select Acknowledge | f <sub>C</sub> = 100 KHz | - | 1.48 | 1.7 | V | | <sup>1.</sup> SCL, SDA connected to Ground or $V_{\rm CC}$ . SDA connected to $V_{\rm CC}$ through a pull-up resistor. Table 248. I<sup>2</sup>C AC characteristics up to 85°C | | Test conditions specified in Table 243. I <sup>2</sup> C operating conditions | | | | | | | | | |-------------------------|-------------------------------------------------------------------------------|---------------------------------------------|------|----------------------|------|--|--|--|--| | Symbol | Alt. | Parameter | Min. | Max. | Unit | | | | | | f <sub>C</sub> | f <sub>SCL</sub> | Clock frequency | 0.05 | 1000 | kHz | | | | | | t <sub>CHCL</sub> | t <sub>HIGH</sub> | Clock pulse width high | 0.26 | 25000 <sup>(1)</sup> | μs | | | | | | t <sub>CLCH</sub> | t <sub>LOW</sub> | Clock pulse width low | 0.5 | 25000 <sup>(2)</sup> | μs | | | | | | t <sub>START_OUT</sub> | - | I <sup>2</sup> C timeout on Start condition | 35 | - | ms | | | | | | t <sub>XH1XH2</sub> | t <sub>R</sub> | Input signal rise time | (3) | (3) | ns | | | | | | t <sub>XL1XL2</sub> | t <sub>F</sub> | Input signal fall time | (3) | (3) | ns | | | | | | t <sub>DL1DL2</sub> (4) | t <sub>F</sub> | SDA (out) fall time | 20 | 120 | ns | | | | | | t <sub>DXCX</sub> | t <sub>SU:DAT</sub> | Data in set up time | 0 | - | ns | | | | | | t <sub>CLDX</sub> | t <sub>HD:DAT</sub> | Data in hold time | 0 | - | ns | | | | | | t <sub>CLQX</sub> (5) | t <sub>DH</sub> | Data out hold time | 100 | - | ns | | | | | DS10925 - Rev 9 page 142/200 | | Test conditions specified in Table 243. I <sup>2</sup> C operating conditions | | | | | | | | | |-----------------------|-------------------------------------------------------------------------------|------------------------------------------------------|------|-----------|------|--|--|--|--| | Symbol | Alt. | Parameter | Min. | Max. | Unit | | | | | | t <sub>CLQV</sub> (6) | t <sub>AA</sub> | Clock low to next data valid (access time) | - | 450 | ns | | | | | | t <sub>CHDX</sub> (7) | t <sub>SU:STA</sub> | Start condition set up time | 250 | - | ns | | | | | | t <sub>DLCL</sub> | t <sub>HD:STA</sub> | Start condition hold time | 0.25 | 35000 (8) | μs | | | | | | t <sub>CHDH</sub> | t <sub>SU:STO</sub> | Stop condition set up time | 250 | - | ns | | | | | | t <sub>DHDL</sub> | t <sub>BUF</sub> | Time between Stop condition and next Start condition | 500 | - | ns | | | | | | t <sub>W</sub> | - | I <sup>2</sup> C write time <sup>(9)</sup> | - | 5 | ms | | | | | | t <sub>bootDC</sub> | - | RF OFF and LPD = 0 | - | 0.6 | ms | | | | | | t <sub>bootLPD</sub> | - | RF OFF | - | 0.6 | ms | | | | | - 1. t<sub>CHCL</sub> timeout. - 2. t<sub>CLCH</sub> timeout. - 3. There is no min. or max. values for the input signal rise and fall times. It is however recommended by the $l^2C$ specification that the input signal rise and fall times be less than 120 ns when $f_C < 1$ MHz. - 4. Characterized on bench. - To avoid spurious Start and Stop conditions, a minimum delay is placed between SCL=1 and the falling or rising edge of SDA. - 6. t<sub>CLQV</sub> is the time (from the falling edge of SCL) required by the SDA bus line to reach 0.8V<sub>CC</sub> in a compatible way with the l<sup>2</sup>C specification (which specifies t<sub>SU:DAT</sub> (min) = 100 ns), assuming that the R<sub>bus</sub> × C<sub>bus</sub> time constant is less than 150 ns (as specified in the Figure 76. l<sup>2</sup>C Fast mode (f<sub>C</sub> = 1 MHz): maximum R<sub>bus</sub> value versus bus parasitic capacitance (C<sub>bus</sub>)). - 7. For a reStart condition, or following a write cycle. - 8. $t_{DLCL}$ timeout. - 9. I<sup>2</sup>C write time for 1 Byte, 2 Bytes, 3 Bytes or 4 Bytes in EEPROM (user memory and system configuration), provided they are all located in the same memory page, that is the most significant memory address bits (b16-b2) are the same. Table 249. I<sup>2</sup>C AC characteristics up to 125°C | Test conditions specified in Table 243. I <sup>2</sup> C operating conditions | | | | | | | | | |-------------------------------------------------------------------------------|---------------------|---------------------------------------------|------|-----------|------|--|--|--| | Symbol | Alt. | Parameter | Min. | Max. | Unit | | | | | f <sub>C</sub> | f <sub>SCL</sub> | Clock frequency | 0.05 | 1000 | kHz | | | | | t <sub>CHCL</sub> | t <sub>HIGH</sub> | Clock pulse width high | 0.26 | 25000 (1) | μs | | | | | tclch | t <sub>LOW</sub> | Clock pulse width low | 0.5 | 25000 (2) | μs | | | | | t <sub>START_OUT</sub> | - | I <sup>2</sup> C timeout on Start condition | 35 | - | ms | | | | | t <sub>XH1XH2</sub> | t <sub>R</sub> | Input signal rise time | (3) | (3) | ns | | | | | t <sub>XL1XL2</sub> | t <sub>F</sub> | Input signal fall time | (3) | (3) | ns | | | | | t <sub>DL1DL2</sub> (4) | t <sub>F</sub> | SDA (out) fall time | 20 | 120 | ns | | | | | t <sub>DXCX</sub> | t <sub>SU:DAT</sub> | Data in set up time | 0 | - | ns | | | | | t <sub>CLDX</sub> | t <sub>HD:DAT</sub> | Data in hold time | 0 | - | ns | | | | | t <sub>CLQX</sub> (5) | t <sub>DH</sub> | Data out hold time | 100 | - | ns | | | | | t <sub>CLQV</sub> (6) | t <sub>AA</sub> | Clock low to next data valid (access time) | - | 450 | ns | | | | | t <sub>CHDX</sub> (7) | t <sub>SU:STA</sub> | Start condition set up time | 250 | - | ns | | | | DS10925 - Rev 9 page 143/200 | Test conditions specified in Table 243. I <sup>2</sup> C operating conditions | | | | | | | | | |-------------------------------------------------------------------------------|---------------------|------------------------------------------------------|------|----------------------|------|--|--|--| | Symbol | Alt. | Parameter | Min. | Max. | Unit | | | | | t <sub>DLCL</sub> | t <sub>HD:STA</sub> | Start condition hold time | 0.25 | 35000 <sup>(8)</sup> | μs | | | | | t <sub>CHDH</sub> | t <sub>SU:STO</sub> | Stop condition set up time | 250 | - | ns | | | | | t <sub>DHDL</sub> | t <sub>BUF</sub> | Time between Stop condition and next Start condition | 500 | - | ns | | | | | t <sub>W</sub> | - | I <sup>2</sup> C write time <sup>(9)</sup> | - | 5.5 | ms | | | | | t <sub>bootDC</sub> | - | RF OFF and LPD = 0 | - | 0.6 | ms | | | | | t <sub>bootLPD</sub> | - | RF OFF | - | 0.6 | ms | | | | - 1. t<sub>CHCL</sub> timeout. - 2. t<sub>CLCH</sub> timeout. - 3. There is no min. or max. values for the input signal rise and fall times. It is however recommended by the $l^2C$ specification that the input signal rise and fall times be less than 120 ns when $f_C < 1$ MHz. - 4. Characterized on bench. - To avoid spurious Start and Stop conditions, a minimum delay is placed between SCL=1 and the falling or rising edge of SDA. - 6. $t_{CLQV}$ is the time (from the falling edge of SCL) required by the SDA bus line to reach 0.8 $V_{CC}$ in a compatible way with the $I^2C$ specification (which specifies $t_{SU:DAT}$ (min) = 100 ns), assuming that the $R_{bus} \times C_{bus}$ time constant is less than 150 ns (as specified in the Figure 76. $I^2C$ Fast mode ( $f_C = 1$ MHz): maximum $R_{bus}$ value versus bus parasitic capacitance ( $C_{bus}$ )). - 7. For a restart condition, or following a write cycle. - 8. t<sub>DLCL</sub> timeout. - 9. I<sup>2</sup>C write time for 1 Byte, 2 Bytes, 3 Bytes or 4 Bytes in EEPROM (user memory and system configuration), provided they are all located in the same memory page, that is the most significant memory address bits (b16-b2) are the same. DS10925 - Rev 9 page 144/200 Figure 75. I<sup>2</sup>C AC waveforms Figure 76. $I^2C$ Fast mode ( $f_C$ = 1 MHz): maximum $R_{bus}$ value versus bus parasitic capacitance ( $C_{bus}$ ) indicates how the value of the pull-up resistor can be calculated. In most applications, though, this method of synchronization is not employed, and so the pull-up resistor is not necessary, provided that the bus master has a push-pull (rather than open drain) output. Figure 76. $I^2C$ Fast mode ( $f_C = 1$ MHz): maximum $R_{bus}$ value versus bus parasitic capacitance ( $C_{bus}$ ) DS10925 - Rev 9 page 145/200 ### 9.3 **GPO** characteristics This section summarizes the operating and measurement conditions of the GPO feature. The parameters in the DC and AC characteristic tables that follow are derived from tests performed under the measurement conditions summarized in the relevant tables. Table 250. GPO DC characteristics up to 85°C | Symbol | Parameter | Condition | Min | Тур | Max | Unit | | |-----------------------------------|------------------------------------|-----------------------------------------------------------------------------------|------------------------|------|------|------|--| | | 0.1.11 | $V_{DCG}$ = 1.8 V, $I_{OL}$ = 0.5 mA | - | - | 0.4 | | | | V <sub>OL</sub> GPO_CMOS | Output low voltage<br>(GPO CMOS) | $V_{DCG} = 3.3 \text{ V}, I_{OL} = 0.5 \text{ mA}$ | - | - | 0.4 | V | | | | | $V_{DCG} = 5.5 \text{ V}, I_{OL} = 0.5 \text{ mA}$ | - | - | 0.4 | | | | | | V <sub>DCG</sub> = 1.8 V, I <sub>OH</sub> = - 0.5 mA | V <sub>DCG</sub> - 0.4 | - | - | | | | V <sub>OH</sub> _GPO_CMOS | Output high voltage (GPO CMOS) | $V_{DCG}$ = 3.3 V, $I_{OH}$ = - 0.5 mA | V <sub>DCG</sub> - 0.4 | - | - | V | | | | (ar a amaa) | $V_{DCG}$ = 5.5 V, $I_{OH}$ = - 0.5 mA | V <sub>DCG</sub> - 0.4 | - | - | | | | | Output low voltage | IOL = 1 mA, VCC = 1.8 V | - | 0.28 | 0.4 | | | | V <sub>OL</sub> GPO_OD | Output low voltage | IOL = 1 mA, VCC = 3.3 V | - | 0.20 | 0.4 | V | | | | (GPO open drain) | IOL = 1 mA, VCC = 5.5 V | - | 0.20 | 0.4 | | | | I_GPO_OD | Output leakage<br>(GPO open drain) | GPO in Hi-Z, external voltage applied on: GPO, V <sub>SS</sub> or V <sub>CC</sub> | - 0.15 | 0.06 | 0.15 | μА | | | I <sub>LI</sub> _V <sub>DGC</sub> | Input leakage (V <sub>DGC</sub> ) | V <sub>DGC</sub> = 5.5 V | - | - | 0.1 | μA | | Table 251. GPO DC characteristics up to 125°C | Symbol | Parameter | Condition | Min | Тур | Max | Unit | | |----------------------------------------------------------|----------------------------------------|------------------------------------------------------|------------------------|------|------|------|--| | | | V <sub>DCG</sub> = 1.8 V, I <sub>OL</sub> = 0.5 mA | - | - | 0.4 | | | | V <sub>OL</sub> _GPO_CMOS | Output low voltage<br>(GPO CMOS) | V <sub>DCG</sub> = 3.3 V, I <sub>OL</sub> = 0.5 mA | - | - | 0.4 | V | | | | (GPO CINOS) | V <sub>DCG</sub> = 5.5 V, I <sub>OL</sub> = 0.5 mA | - | - | 0.4 | | | | | | V <sub>DCG</sub> = 1.8 V, I <sub>OH</sub> = - 0.5 mA | V <sub>DCG</sub> - 0.4 | - | - | | | | V <sub>OH</sub> _GPO_CMOS Output nign voltage (GPO CMOS) | Output high voltage | V <sub>DCG</sub> = 3.3 V, I <sub>OH</sub> = - 0.5 mA | V <sub>DCG</sub> - 0.4 | - | - | V | | | | (Of O CIVIOS) | V <sub>DCG</sub> = 5.5 V, I <sub>OH</sub> = - 0.5 mA | V <sub>DCG</sub> - 0.4 | - | - | | | | | Output law valtage | IOL = 1 mA, VCC = 1.8 V | - | 0.28 | 0.4 | | | | V <sub>OL</sub> _GPO_OD | Output low voltage<br>(GPO open drain) | IOL = 1 mA, VCC = 3.3 V | - | 0.22 | 0.4 | V | | | | (Or O open drain) | IOL = 1 mA, VCC = 5.5 V | - | 0.21 | 0.4 | | | | IGPO_OD | Output leakage<br>(GPO open drain) | CDO: V or V | | 0.06 | 0.15 | μA | | | I <sub>LI</sub> _V <sub>DGC</sub> | Input leakage (V <sub>DGC</sub> ) | V <sub>DGC</sub> = 5.5 V | - | - | 0.1 | μA | | Table 252. GPO AC characteristics | Symbol | Parameter | Condition | Min | Max | Unit | |--------------------------|------------------|-------------------------------------------|-----|-----|------| | t <sub>r</sub> _GPO_CMOS | Output rise time | $C_L$ = 30 pF, $V_{DCG}$ = 1.8 V to 5.5 V | - | 50 | no | | t <sub>f</sub> _GPO_CMOS | Output fall time | $C_L$ = 30 pF, $V_{DCG}$ = 1.8 V to 5.5 V | - | 50 | ns | DS10925 - Rev 9 page 146/200 ### 9.4 RF electrical parameters This section summarizes the operating and measurement conditions, and the DC and AC characteristics of the device in RF mode. The parameters in the DC and AC characteristics tables that follow are derived from tests performed under the Measurement Conditions summarized in the relevant tables. Designers should check that the operating conditions in their circuit match the measurement conditions when relying on the quoted parameters. Table 253. RF characteristics | Symbol | Parameter | ( | Condition | Min | Тур | Max | Unit | | | |----------------------------------------------|------------------------------------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------|------------------------------|--------|--------|------|----|---| | f <sub>CC</sub> External RF signal frequency | | | - | 13.553 | 13.56 | 13.567 | MHz | | | | H_ISO | Operating field according to ISO | Range 6 | $T_A = -40 ^{\circ}\text{C} \text{ to } 85 ^{\circ}\text{C}$ $T_A = -40 ^{\circ}\text{C} \text{ to } 105 ^{\circ}\text{C}$ | 150 | - | 5000 | mA/m | | | | MI <sub>CARRIE</sub> R | 10% carrier modulation index <sup>(1)</sup> $MI=(A-B)/(A+B)$ | 150 mA/m > H_ISO > 1000 mA/m | | 150 mA/m > H_ISO > 1000 mA/m | | 10 | - | 30 | % | | | 100% carrier modulation index | MI=( | A-B)/(A+B) <sup>(2)</sup> | 95 | - | 100 | | | | | t <sub>MIN</sub> CD | Minimum time from carrier generation to first data | Fro | m H-field min | - | - | 1 | ms | | | | f <sub>SH</sub> | Subcarrier frequency high | | F <sub>CC</sub> /32 | - | 423.75 | - | kHz | | | | f <sub>SL</sub> | Subcarrier frequency low | | F <sub>CC</sub> /28 | - | 484.28 | - | kHz | | | | t <sub>1</sub> | Time for ST25DVxxx response | | 4352/F <sub>C</sub> | 318.6 | 320.9 | 323.3 | μs | | | | t <sub>2</sub> | Time between commands | 4192/F <sub>C</sub> | | 309 | 311.5 | 314 | μs | | | | t <sub>3</sub> | Time between commands | 4384/F <sub>C</sub> | | 323.3 | - | - | μs | | | | W <sub>f</sub> Block | RF User memory write time (including | | 1 Block | - | 5.2 | - | ms | | | | VV_DIOCK | internal Verify) (3) | 4 Blocks | | - | 19.7 | - | ms | | | | W <sub>t</sub> _Byte | RF system memory write time including internal Verify) <sup>(3)</sup> | | 1 Byte | - | 4.9 | - | ms | | | | W <sub>t</sub> _MB | RF Mailbox write time (from VCD request SOF to ST25DVxxx response EOF) <sup>(3)(4)</sup> | | 256 Byte | - | 80.7 | - | ms | | | | Read_MB | RF Mailbox read time (from VCD request SOF to ST25DVxxx response EOF) (3)(4) | - | 256 Bytes | - | 81 | - | ms | | | | C <sub>TUN</sub> | Internal tuning capacitor <sup>(4)</sup> | f = | 13.56 MHz | 26.5 | 28.5 | 30.5 | pF | | | | V <sub>BACK</sub> | Backscattered level as defined by ISO test | | - | 10 | - | - | mV | | | | (4) | RF input voltage amplitude between AC0 | Inventory a | nd Read operations | - | 4.8 | - | V | | | | V <sub>MIN_1</sub> (1) | and AC1, V <sub>SS</sub> pin left floating, VAC0-VAC1 peak to peak <sup>(1)</sup> | | Write operations | | 5.25 | - | V | | | | V 5 (1) | AC voltage between AC0 and V <sub>SS</sub> or | Inventory a | nd Read operations | - | 2.25 | - | V | | | | V <sub>MIN_2</sub> (1) | between AC1 and V <sub>SS</sub> <sup>(1)</sup> | Write operations | | - | 2.7 | - | V | | | | t <sub>BootRF</sub> | Without DC supply (No V <sub>CC</sub> ) | S | et up time | - | 0.6 | - | ms | | | | t <sub>RF_OFF</sub> | RF OFF time | Chip reset | | 2 | _ | _ | ms | | | - 1. Characterized on bench. - 2. Characterized at room temperature only, on wafer at POR Level. - 3. For VCD request coded in 1 out of 4 and ST25DVxxx response in high data rate, single sub carrier. - 4. The tuning capacitance value is measured with ST characterization equipment at chip Power On Reset. This value is used as reference for antenna design. Minimum and Maximum values come from correlation with industrial tester limits. DS10925 - Rev 9 page 147/200 Note: $T_A$ =-40 to 105°C. Characterized only. All timing characterization where performed on a reference antenna witht the following characteristics: - ISO antenna class 1 - Tuning frequency = 13.7 MHz. **Table 254. Operating conditions** | Symbol | Parameter | Min. | Max. | Unit | | |--------|-------------------------------|---------|------|------|----| | т. | Ambient enerating temperature | Range 6 | -40 | 85 | °C | | 'A | Ambient operating temperature | Range 8 | -40 | 105 | | Figure 77 shows an ASK modulated signal from the VCD to the ST25DVxxx. The test conditions for the AC/DC parameters are: - Close coupling condition with tester antenna (1 mm) - ST25DVxxx performance measured at the tag antenna - ST25DVxxx synchronous timing, transmit and receive Figure 77. ASK modulated signal DS10925 - Rev 9 page 148/200 ## 10 Package information In order to meet environmental requirements, ST offers these devices in different grades of ECOPACK® packages, depending on their level of environmental compliance. ECOPACK® specifications, grade definitions and product status are available at: www.st.com. ECOPACK® is an ST trademark. ### 10.1 SO8N package information SO8N is an 8-lead, 4.9 x 6 mm, plastic small outline, 150 mils body width, package. Figure 78. SO8N - Outline 1. Drawing is not to scale. Table 255. SO8N - Mechanical data | Symbol | millimeters | | | inches (1) | | | | |--------|-------------|-------|-------|------------|--------|--------|--| | Symbol | Min. | Тур. | Max. | Min. | Тур. | Max. | | | А | - | - | 1.750 | - | - | 0.0689 | | | A1 | 0.100 | - | 0.250 | 0.0039 | - | 0.0098 | | | A2 | 1.250 | - | - | 0.0492 | - | - | | | b | 0.280 | - | 0.480 | 0.0110 | - | 0.0189 | | | С | 0.170 | - | 0.230 | 0.0067 | - | 0.0091 | | | D | 4.800 | 4.900 | 5.000 | 0.1890 | 0.1929 | 0.1969 | | | E | 5.800 | 6.000 | 6.200 | 0.2283 | 0.2362 | 0.2441 | | | E1 | 3.800 | 3.900 | 4.000 | 0.1496 | 0.1535 | 0.1575 | | | е | - | 1.270 | - | - | 0.0500 | - | | | h | 0.250 | - | 0.500 | 0.0098 | - | 0.0197 | | | k | 0° | - | 8° | 0° | - | 8° | | | L | 0.400 | - | 1.270 | 0.0157 | - | 0.0500 | | | L1 | - | 1.040 | - | - | 0.0409 | - | | | CCC | - | - | 0.100 | - | - | 0.0039 | | 1. Values in inches are converted from mm and rounded to four decimal digits. DS10925 - Rev 9 page 149/200 0.6 (x8) 3.6 2.9 Figure 79. SO8N - Recommended footprint 1. Dimensions are expressed in millimeters. ## 10.2 TSSOP8 package information TSSOP8 is an 8-lead thin shrink small outline, 3 x 6.4 mm, 0.65 mm pitch, package. B 5 E1 E A1 LI Figure 80. TSSOP8 - Outline 1. Drawing is not to scale. DS10925 - Rev 9 page 150/200 8° | Symbol | | millimeters | | | inches <sup>(1)</sup> | | | |--------|-------|-------------|-------|--------|-----------------------|--------|--| | Symbol | Min. | Тур. | Max. | Min. | Тур. | Max. | | | А | - | - | 1.200 | - | - | 0.0472 | | | A1 | 0.050 | - | 0.150 | 0.0020 | - | 0.0059 | | | A2 | 0.800 | 1.000 | 1.050 | 0.0315 | 0.0394 | 0.0413 | | | b | 0.190 | - | 0.300 | 0.0075 | - | 0.0118 | | | С | 0.090 | - | 0.200 | 0.0035 | - | 0.0079 | | | СР | - | - | 0.100 | - | - | 0.0039 | | | D | 2.900 | 3.000 | 3.100 | 0.1142 | 0.1181 | 0.1220 | | | е | - | 0.650 | - | - | 0.0256 | - | | | Е | 6.200 | 6.400 | 6.600 | 0.2441 | 0.2520 | 0.2598 | | | E1 | 4.300 | 4.400 | 4.500 | 0.1693 | 0.1732 | 0.1772 | | | L | 0.450 | 0.600 | 0.750 | 0.0177 | 0.0236 | 0.0295 | | | L1 | - | 1.000 | - | - | 0.0394 | - | | Table 256. TSSOP8 - Mechanical data 7.0 Figure 81. TSSOP8 – Recommended footprint 1. Dimensions are expressed in millimeters. DS10925 - Rev 9 page 151/200 <sup>1.</sup> Values in inches are converted from mm and rounded to four decimal digits. ### 10.3 UFDFN8 package information UFDFPN8 is an 8-lead, 2 × 3 mm, 0.5 mm pitch ultra thin profile fine pitch dual flat package. Figure 82. UFDFN8 - Outline - 1. Max. package warpage is 0.05 mm. - 2. Exposed copper is not systematic and can appear partially or totally according to the cross section. - 3. Drawing is not to scale. Table 257. UFDFN8 - Mechanical data | Symbol | | millimeters | | | inches <sup>(1)</sup> | | | | |--------|-------|-------------|-------|--------|-----------------------|--------|--|--| | Symbol | Min | Тур | Max | Min | Тур | Max | | | | Α | 0.450 | 0.550 | 0.600 | 0.0177 | 0.0217 | 0.0236 | | | | A1 | 0.000 | 0.020 | 0.050 | 0.0000 | 0.0008 | 0.0020 | | | | b (2) | 0.200 | 0.250 | 0.300 | 0.0079 | 0.0098 | 0.0118 | | | | D | 1.900 | 2.000 | 2.100 | 0.0748 | 0.0787 | 0.0827 | | | | D2 | 1.200 | - | 1.600 | 0.0472 | - | 0.0630 | | | | E | 2.900 | 3.000 | 3.100 | 0.1142 | 0.1181 | 0.1220 | | | | E2 | 1.200 | - | 1.600 | 0.0472 | - | 0.0630 | | | | е | - | 0.500 | - | 0.0197 | | | | | | K | 0.300 | - | - | 0.0118 | - | - | | | | L | 0.300 | - | 0.500 | 0.0118 | - | 0.0197 | | | DS10925 - Rev 9 page 152/200 | Symbol | millimeters | | | inches <sup>(1)</sup> | | | | |---------|-------------|-----|-------|-----------------------|-----|--------|--| | Symbol | Min | Тур | Max | Min | Тур | Max | | | L1 | - | - | 0.150 | - | - | 0.0059 | | | L3 | 0.300 | - | - | 0.0118 | - | - | | | aaa | - | - | 0.150 | - | - | 0.0059 | | | bbb | - | - | 0.100 | - | - | 0.0039 | | | ccc | - | - | 0.100 | - | - | 0.0039 | | | ddd | - | - | 0.050 | - | - | 0.0020 | | | eee (3) | - | - | 0.080 | - | - | 0.0031 | | 1. Values in inches are converted from mm and rounded to 4 decimal digits. SIDE VIEW - 2. Dimension b applies to plated terminal and is measured between 0.15 and 0.30 mm from the terminal tip. - 3. Applied for exposed die paddle and terminals. Exclude embedding part of exposed die paddle from measuring. ### 10.4 UFDFPN12 package information UFDFPN12 is an 12-lead, 3 x 3 mm, 0.5 mm pitch ultra thin profile fine pitch dual flat package. Figure 83. UFDFPN12 - Outline 1. Drawing is not to scale. Table 258. UFDFPN12 - Mechanical data | Symbol | millimeters | | | inches <sup>(1)</sup> | | | |--------|-------------|------|------|-----------------------|--------|--------| | Symbol | Min | Тур | Max | Min | Тур | Max | | A (2) | 0.45 | 0.55 | 0.60 | 0.0177 | 0.0217 | 0.0236 | | b | 0.20 | 0.25 | 0.30 | 0.0079 | 0.0098 | 0.0118 | | D | 2.95 | 3.00 | 3.10 | 0.1161 | 0.1181 | 0.1220 | | D2 | 1.35 | 1.40 | 1.45 | 0.0531 | 0.0551 | 0.0571 | DS10925 - Rev 9 page 153/200 | Symbol | millimeters | | | inches <sup>(1)</sup> | | | | |--------|-------------|------|------|-----------------------|--------|--------|--| | Symbol | Min | Тур | Max | Min | Тур | Max | | | е | 0.50 | | | 0.0197 | | | | | E | 2.95 | 3.00 | 3.10 | 0.1161 | 0.1181 | 0.1220 | | | E2 | 2.50 | 2.55 | 2.60 | 0.0984 | 0.1004 | 0.1024 | | | L | 0.25 | 0.30 | 0.35 | 0.0098 | 0.0118 | 0.0138 | | | k | 0.40 | | | 0.0157 | | | | - 1. Values in inches are converted from mm and rounded to 4 decimal digits. - 2. Package total thickness. ### 10.5 WLCSP10 package information Figure 84. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale package outline - 1. Drawing is not to scale. - 2. Dimension is measured at the maximum bump diameter parallel to primary datum Z. - 3. Primary datum Z and seating plane are defined by the spherical crowns of the bump. - 4. Bump position designation per JESD 95-1, SPP-010. Table 259. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale mechanical data | Symbol | millimeters inches | | | inches <sup>(1)</sup> | | | | |--------|--------------------|-------|-------|-----------------------|--------|--------|--------| | | Зушьог | Min | Тур | Max | Min | Тур | Max | | | A | 0.265 | 0.295 | 0.325 | 0.0104 | 0.0116 | 0.0128 | DS10925 - Rev 9 page 154/200 | Symbol | | millimeters | | | inches <sup>(1)</sup> | | | |--------|-----|-------------|-------|-----|-----------------------|--------|--| | | Min | Тур | Max | Min | Тур | Max | | | A1 | - | 0.095 | - | - | 0.0037 | - | | | A2 | - | 0.175 | - | - | 0.0069 | - | | | A3 | - | 0.025 | - | - | 0.0010 | - | | | b | - | 0.185 | - | - | 0.0073 | - | | | D | - | 1.649 | 1.669 | - | 0.0649 | 0.0657 | | | E | - | 1.483 | 1.503 | - | 0.0584 | 0.0592 | | | е | - | 0.400 | - | - | 0.0157 | - | | | e1 | - | 0.800 | - | - | 0.0315 | - | | | Н | - | 0.346 | - | - | 0.0136 | - | | | I | - | 1.039 | - | - | 0.0409 | - | | | J | - | 0.200 | - | - | 0.0079 | - | | | F | - | 0.314 | - | - | 0.0124 | - | | | G | - | 0.342 | - | - | 0.0135 | - | | | aaa | - | 0.110 | - | - | 0.0043 | - | | | bbb | - | 0.110 | - | - | 0.0043 | - | | | ccc | - | 0.110 | - | - | 0.0043 | - | | | ddd | - | 0.060 | - | - | 0.0024 | - | | | eee | - | 0.060 | - | - | 0.0024 | - | | <sup>1.</sup> Values in inches are converted from mm and rounded to 4 decimal digits. Figure 85. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale recommended footprint Table 260. WLCSP10 recommended PCB design rules | Dimension | Recommended values | |-------------------|--------------------------------------------------------------| | Pitch | 0.4 mm | | Dpad | 0,225 mm | | Dsm | 0.290 mm typ. (depends on soldermask registration tolerance) | | Stencil opening | 0.250 mm | | Stencil thickness | 0.100 mm | DS10925 - Rev 9 page 155/200 ## 11 Ordering information Table 261. Ordering information scheme ST25DV 64K -JF R Example: D 3 **Device type** ST25DV = Dynamic NFC/RFID tag based on ISO 15693 and NFC T5T **Memory size** 04K = 4 Kbits 16K = 16 Kbits 64K = 64 Kbits **Device Features** $IE = I^2C$ & GPO open drain, fast transfer mode & Energy Harvesting JF = I<sup>2</sup>C & GPO CMOS, fast transfer mode, energy harvesting & low power mode **Operating voltage** $R = V_{CC} = 1.8 \text{ to } 5.5 \text{ V}$ **Device grade** 6 = industrial: device tested with standard test flow over - 40 to 85 °C 8 = industrial device tested with standard test flow over -40 to 105 °C (UFDFPN8 and UFDFPN12 only) or over -40 to 125 °C (SO8N and TSSOP8 only, 105 °C only for RF interface) **Package** D = UFDFPN12 S = S08N T = TSSOP8 C = UFDFPN8 (Only for 04K version) U = 725 μm +/- 20 μm unsawn wafer (Only for 04K version) Capacitance 3 = 28.5 pF L = WLCSP (thin 10 balls) (Only for 04K version) Note: Parts marked as "ES" or "E" are not yet qualified and therefore not approved for use in production. ST is not responsible for any consequences resulting from such use. In no event will ST be liable for the customer using any of these engineering samples in production. ST's Quality department must be contacted prior to any decision to use these engineering samples to run a qualification activity. DS10925 - Rev 9 page 156/200 ## Appendix A Bit representation and coding for fast commands Data bits are encoded using Manchester coding, according to the following schemes. For the low data rate, same subcarrier frequency or frequencies is/are used. In this case, the number of pulses is multiplied by 4 and all times increase by this factor. For the Fast commands using one subcarrier, all pulse numbers and times are divided by 2. ### A.1 Bit coding using one subcarrier #### A.1.1 High data rate For the fast commands, a logic 0 starts with four pulses at 423.75 kHz ( $f_C/32$ ) followed by an unmodulated time of 9.44 $\mu$ s, as shown in Figure 86. Figure 86. Logic 0, high data rate, fast commands For the Fast commands, a logic 1 starts with an unmodulated time of 9.44 $\mu$ s followed by four pulses of 423.75 kHz (f<sub>C</sub>/32), as shown in Figure 87. Figure 87. Logic 1, high data rate, fast commands #### A.1.2 Low data rate For the Fast commands, a logic 0 starts with 16 pulses at 423.75 kHz ( $f_C/32$ ) followed by an unmodulated time of 37.76 $\mu$ s, as shown in Figure 88. Figure 88. Logic 0, low data rate, fast commands For the Fast commands, a logic 1 starts with an unmodulated time of 37.76 $\mu$ s followed by 16 pulses at 423.75 kHz ( $f_{\rm C}/32$ ), as shown in Figure 89. DS10925 - Rev 9 page 157/200 Figure 89. Logic 1, low data rate, fast commands Note: For fast commands, bit coding using two subcarriers is not supported. #### A.2 ST25DVxxx to VCD frames Frames are delimited by an SOF and an EOF. They are implemented using code violation. Unused options are reserved for future use. For the low data rate, the same subcarrier frequency or frequencies is/are used. In this case, the number of pulses is multiplied by 4. For the Fast commands using one subcarrier, all pulse numbers and times are divided by 2. #### A.3 SOF when using one subcarrier #### A.3.1 High data rate For the Fast commands, the SOF comprises an unmodulated time of $28.32 \,\mu s$ , followed by 12 pulses at $423.75 \,kHz$ (f<sub>C</sub>/32), and a logic 1 that consists of an unmodulated time of $9.44 \,\mu s$ followed by four pulses at $423.75 \,kHz$ , as shown in Figure 90. Figure 90. Start of frame, high data rate, one subcarrier, fast commands #### A.3.2 Low data rate For the Fast commands, the SOF comprises an unmodulated time of 113.28 $\mu$ s, followed by 48 pulses at 423.75 kHz (f<sub>C</sub>/32), and a logic 1 that includes an unmodulated time of 37.76 $\mu$ s followed by 16 pulses at 423.75 kHz, as shown in Figure 91. Figure 91. Start of frame, low data rate, one subcarrier, fast commands DS10925 - Rev 9 page 158/200 ### A.4 EOF when using one subcarrier #### A.4.1 High data rate For the Fast commands, the EOF comprises a logic 0 that includes four pulses at 423.75 kHz and an unmodulated time of 9.44 $\mu$ s, followed by 12 pulses at 423.75 kHz (f<sub>C</sub>/32) and an unmodulated time of 37.76 $\mu$ s, as shown in Figure 92. Figure 92. End of frame, high data rate, one subcarrier, fast commands #### A.4.2 Low data rate For the Fast commands, the EOF comprises a logic 0 that includes 16 pulses at 423.75 kHz and an unmodulated time of 37.76 $\mu$ s, followed by 48 pulses at 423.75 kHz (f<sub>C</sub>/32) and an unmodulated time of 113.28 $\mu$ s, as shown in Figure 93. Figure 93. End of frame, low data rate, one subcarrier, fast commands Note: For SOF and EOF in fast commands, bit coding using two subcarriers is not supported. DS10925 - Rev 9 page 159/200 # **Appendix B I2C sequences** ### B.1 Device select codes Table 262. Device select usage | Device select value | | - Comment | | |---------------------|---------------|-----------------------------------------------------|--| | Hexadecimal | Binary | Comment | | | | | Device select generic | | | - | 1010 E211 R/W | E2 = 0b User memory, Dynamic registers, FTM mailbox | | | | | E2 = 1b System memory | | | A6h | 1010 0110b | User memory, Dynamic registers, FTM mailbox writing | | | A7h | 1010 0111b | User memory, Dynamic registers, FTM mailbox reading | | | AEh | 1010 1110b | System memory writing | | | AFh | 1010 1111b | System memory reading | | ## B.2 I2C Byte writing and polling ### B.2.1 I2C byte write in user memory Table 263. Byte Write in user memory when write operation allowed | Request/Respo | onse Frame | Comment | | |-------------------|------------------|---------------------------|--| | Master drives SDA | Slave drives SDA | Comment | | | Start A6h | - | Device select for writing | | | - | ACK | 9th bit | | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | | - | ACK | 9th bit | | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | | - | ACK | 9th bit | | | DATA | - | Send Data (1 Byte) | | | - | ACK | 9th bit | | | Stop | - | Start of Programming | | DS10925 - Rev 9 page 160/200 Table 264. Polling during programming after byte writing in user memory | Request/Resp | onse Frame | Comment | | |-------------------|------------------|---------------------------|--| | Master drives SDA | Slave drives SDA | | | | Start A6h | - | Device select for writing | | | - | NoACK | 9th bit Device Busy | | | Start A6h | - | Device select for writing | | | - | NoACK | 9th bit Device Busy | | | | | Device select for writing | | | | | 9th bit Device Busy | | | Start A6h | - | Device select for writing | | | | ACK | 9th bit Device ready | | | - | ACK | Programing completed | | | Stop | - | End of Polling | | Table 265. Byte Write in user memory when write operation is not allowed | Request/Response Frame | | - Comment | |------------------------|------------------|-----------------------------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | DATA | - | Send Data | | - | NoACK | 9th bit: Write access not granted or FTM activated. | | Ston | - | No Programming | | Stop | | Device return in Standby | DS10925 - Rev 9 page 161/200 ### **B.2.2** I2C byte writing in dynamic registers and polling Table 266. Byte Write in Dynamic Register (if not Read Only) | Request/Response | e Frame | Comment | | |------------------------------------|---------|--------------------------------------------------------------------------------------------------------------|--| | Master drives SDA Slave drives SDA | | Comment | | | Start A6h | - | Device select for writing | | | - | ACK | 9th bit | | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | | - | ACK | 9th bit | | | Dynamic Register ADDRESS_LSB | - | Send Address LSB (1 Byte) Dynamic register are located from address 2000h to 2007h, some are only readable | | | - | ACK | 9th bit | | | DATA | - | Send Data | | | - | ACK | 9th bit | | | Stop | - | Immediate update of Dynamic register | | Table 267. Polling during programming after byte write in Dynamic Register | Request/Resp | onse Frame | - Comment | | |------------------------------------|------------|---------------------------------------|--| | Master drives SDA Slave drives SDA | | Comment | | | Start A6h | - | Device select for writing | | | | ACK | 9th bit Device Busy | | | - | | Dynamic register updates is immediate | | | Stop | - | End of Polling | | Table 268. Byte Write in Dynamic Register if Read Only | Request/Response Fra | ame | Comment | | |------------------------------------|-------|------------------------------------------------------------------|--| | Master drives SDA Slave drives SDA | | | | | Start A6h | - | Device select for writing | | | - | ACK | 9th bit | | | 20h | - | Send Address MSB (1 Byte) | | | - | NoACK | 9th bit | | | | | Send Address LSB (1 Byte) | | | RO Dynamic Register ADDRESS_LSB | - | Addresses 2001h, 2004h, 2005h and 2007h are Read Only registers. | | | - | ACK | 9th bit | | | DATA | - | Send Data | | | - | NoACK | 9th bit | | | Stop | _ | No Programming | | | Otop | _ | Device return in Standby | | DS10925 - Rev 9 page 162/200 ### B.2.3 I2C byte write in mailbox and polling Table 269. Byte Write in mailbox when mailbox is free from RF message and fast transfer mode is activated | Request/Response Frame | | Communit | | |------------------------|------------------|--------------------------------------------------------------------------|--| | Master drives SDA | Slave drives SDA | - Comment | | | Start A6h | - | Device select for writing | | | - | ACK | 9th bit | | | 20h | - | Send mailbox address MSB (1 Byte) | | | - | ACK | 9th bit | | | 08h | - | Send Address LSB (1 Byte) Write must be done at first address of mailbox | | | - | ACK | 9th bit | | | DATA | - | Send Data | | | - | ACK | 9th bit | | | Stop | - | Immediate update of mailbox | | Table 270. Byte Write in mailbox when mailbox is not free from RF message fast transfer mode is not activated | Request/Resp | oonse Frame | Comment | | |-------------------|------------------|------------------------------------------------|--| | Master drives SDA | Slave drives SDA | Comment | | | Start A6h | - | Device select for writing | | | - | ACK | 9th bit | | | 20h | - | Send mailbox address MSB (1 Byte) | | | - | ACK | 9th bit | | | 08h | - | Send Address LSB (1 Byte) | | | VOII | | Write must be done at first address of mailbox | | | - | ACK | 9th bit | | | DATA | - | Send Data | | | | NoACK | 9th bit Access | | | - | | Mailbox busy or FTM not activated | | | Ston | _ | No Programming | | | Stop | - | Device return in Standby | | DS10925 - Rev 9 page 163/200 ### B.2.4 I2C byte write and polling in system memory Table 271. Byte Write in System memory if I<sup>2</sup>C security session is open and register is not RO | Request/Resp | onse Frame | Comment | |-------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start AEh | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | DATA | - | Send Data | | - | ACK | 9th bit | | Stop | - | Start of Programming | Table 272. Polling during programing after byte write in System memory if I<sup>2</sup>C security session is open and register is not RO | Request/Response Frame | | Commont | | |------------------------|------------------|---------------------------|--| | Master drives SDA | Slave drives SDA | Comment | | | Start AEh | - | Device select for writing | | | - | NoACK | 9th bit Device Busy | | | Start AEh | - | Device select for writing | | | - | NoACK | 9th bit Device Busy | | | Start AEh | - | Device select for writing | | | - | | 9th bit | | | Start AEh | - | Device select for writing | | | | ACK | 9th bit Device ready | | | - | | Programing completed | | | Stop | - | end of Polling | | DS10925 - Rev 9 page 164/200 Table 273. Byte Write in System memory if I<sup>2</sup>C security session is closed or register is RO | Request/Response Frame | | Comment | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start AEh | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | DATA | - | Send Data | | - | NoACK | 9th bit | | Stop | - | No Programming | | | | Device return in Standby | ## B.3 I2C sequential writing and polling ### B.3.1 I2C sequential write in user memory and polling Table 274. Sequential write User memory when write operation allowed and all bytes belong to same area | Request/Response Frame | | Comment | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | DATA 0 | - | Send Data 0 | | - | ACK | 9th bit | | DATA 1 | - | Send Data 1 | | - | ACK | 9th bit | | | - | | | - | | | | DATA n | _ | Send Data n | | שמאו | _ | n ≤ 256 | | - | ACK | 9th bit | | Stop | - | Start of Programming | DS10925 - Rev 9 page 165/200 Table 275. Polling during programing after sequential write in User memory when write operation allowed and all bytes belong to same area. | Request/Response Frame | | Comment | | |------------------------|------------------|---------------------------|--| | Master drives SDA | Slave drives SDA | Comment | | | Start A6h | - | Device select for writing | | | - | NoACK | 9th bit Device Busy | | | Start A6h | - | Device select for writing | | | - | NoACK | 9th bit Device Busy | | | Start A6h | - | Device select for writing | | | - | | 9th bit Device Busy | | | Start A6h | - | Device select for writing | | | | ACK | 9th bit Device ready | | | _ | | Programing completed | | | Stop | - | End of Polling | | Table 276. Sequential write in User memory when write operation allowed and crossing over area border | Request/Response Frame | | Comment | |------------------------|------------------|----------------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | DATA 0 | - | Send Data 0 | | - | ACK | 9th bit | | DATA 1 | - | Send Data 1 | | - | ACK | 9th bit | | | - | | | - | | | | DATA n | | Send Data n | | DAIATI | AIA n - | Address is located in next memory area | | - | NoACK | 9th bit | | Stop | _ | No programming | | этор | - | Device return in Standby | DS10925 - Rev 9 page 166/200 Table 277. Polling during programming after sequential write in User memory when write operation allowed and crossing over area border | Master drives SDA | Slave drives SDA | Comment | |------------------------|------------------|---------------------------| | Request/Response Frame | | Comment | | Start A6h | - | Device select for writing | | | ACK | 9th bit Device ready | | - | | No programming | | Stop | - | End of Polling | ### B.3.2 I2C sequential write in mailbox and polling Table 278. Sequential write in mailbox when mailbox is free from RF message and fast transfer mode is activated | Request/Response Frame | | 0 | | |------------------------|------------------|-----------------------------------|--| | Master drives SDA | Slave drives SDA | Comment | | | Start A6h | - | Device select for writing | | | - | ACK | 9th bit | | | ADDRESS_MSB | - | Send mailbox Address MSB (1 Byte) | | | - | ACK | 9th bit | | | ADDRESS_LSB | - | Send mailbox Address LSB (1 Byte) | | | - | ACK | 9th bit | | | DATA 0 | - | Send Data 0 | | | - | ACK | 9th bit | | | DATA 1 | - | Send Data 1 | | | - | ACK | 9th bit | | | | - | | | | - | | | | | DATA n | | Send Data n | | | DAIAII | - | n ≤ 256 | | | - | ACK | 9th bit | | | Stop | - | Immediate mailbox content update | | Table 279. Polling during programing after sequential write in mailbox | Request/Response Frame | | Comment | | |------------------------|------------------|--------------------------------|--| | Master drives SDA | Slave drives SDA | Comment | | | Start A6h | - | Device select for writing | | | | ACK | 9th bit Device ready | | | - | | Mailbox is immediately updated | | | Stop | - | End of Polling | | DS10925 - Rev 9 page 167/200 ### B.4 I2C Read current address #### B.4.1 I2C current address read in User memory Table 280. Current byte Read in User memory if read operation allowed (depending on area protection and RF user security session) | Request/Response Frame | | Comment | | |------------------------|------------------|------------------------------------------------------------------------------------------------|--| | Master drives SDA | Slave drives SDA | | | | Start A7h | - | Device select for reading | | | - | ACK | 9th bit | | | | DATA | Receive Data located on last pointed address+1, or at address 0 after power-up, in user memory | | | NO_ACK | - | 9th bit | | | Stop | - | End of Reading | | Table 281. Current Read in User memory if read operation not allowed (depending on area protection and RF user security session) | Request/Response Frame | | Comment | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | | FFh | Read of data not allowed | | | | ST25DV release SDA | | NO_ACK | | 9th bit | | Stop | - | End of Reading | DS10925 - Rev 9 page 168/200 #### B.5 I2C random address read ### B.5.1 I2C random address read in user memory Table 282. Random byte read in User memory if read operation allowed (depending on area protection and RF user security session) | Request/Response Frame | | Comment | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | - | DATA | Receive Data | | NO_ACK | - | 9th bit | | Stop | - | End of Reading | Table 283. Random byte read in User memory if operation not allowed (depending on area protection and RF user security) | Request/Response Frame | | Command | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | | FFh | Read of data not allowed | | - | | release SDA | | NO_ACK | - | 9th bit | | Stop | - | End of Reading | DS10925 - Rev 9 page 169/200 ### B.5.2 I2C Random address read in system memory Table 284. Byte Read System memory (Static register or I2C Password after a valid Present I2C Password) | Request/Resp | onse Frame | - Comment | |-------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start AEh | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start AFh | - | Device select for reading | | - | ACK | 9th bit | | - | DATA | Receive Data | | NO_ACK | - | 9th bit | | Stop | - | End of reading | ## B.5.3 I2C Random address read in dynamic registers Table 285. Random byte read in Dynamic registers | onse Frame | Comment | |------------------|-----------------------------------------------------------------------------------------| | Slave drives SDA | Comment | | - | Device select for writing | | ACK | 9th bit | | - | Send Address MSB (1 Byte) | | ACK | 9th bit | | - | Send Adress LSB (1 Byte) | | ACK | 9th bit | | - | Device select for reading | | ACK | 9th bit | | DATA | Receive Data | | - | 9th bit | | - | End of reading | | | Slave drives SDA - ACK ACK | DS10925 - Rev 9 page 170/200 ## B.6 I2C sequential read ### B.6.1 I2C sequential read in user memory Table 286. Sequential Read User memory if read operation allowed (depending on area protection and RF user security session) and all bytes belong to the same area | Request/Resp | oonse Frame | Commont | |-------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start A7h0 | - | Device select for reading | | - | ACK | 9th bit | | - | DATA 0 | Receive Data 0 | | ACK | - | 9th bit | | - | DATA 1 | Receive Data 1 | | ACK | - | 9th bit | | - | | | | | - | | | - | DATA n | Receive Data n | | NO_ACK | - | 9th bit | | Stop | - | End of Reading | DS10925 - Rev 9 page 171/200 Table 287. Sequential Read User memory if read operation allowed (depending on area protection and RF user security session) but crossing area border | Request/Response Frame | | Comment | |------------------------|------------------|-------------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | - | DATA 0 | Receive Data 0 | | ACK | - | 9th bit | | - | DATA 1 | Receive Data 1 | | ACK | - | 9th bit | | - | | | | | - | | | - | DATA n | Receive Data last Address available | | ACK | - | 9th bit | | | FFh | Data is located in next memory area | | - | FFII | ST25DV release SDA | | ACK | - | 9th bit | | - | | | | | - | | | _ | FFh | Data is located in next memory area | | - | FFN | ST25DV release SDA | | Stop | - | End of reading | DS10925 - Rev 9 page 172/200 Table 288. Sequential Read User memory if read operation allowed (depending on area protection and RF user security session) | Request/Response Frame | | Commont | |------------------------|------------------|----------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | _ | FFh | ST25DV release SDA | | - | | Reading access not granted | | ACK | - | 9th bit | | - | | | | | - | | | _ | FFh | ST25DV release SDA | | _ | 1111 | Reading access not granted | | NO_ACK | - | 9th bit | | Stop | - | End of reading | DS10925 - Rev 9 page 173/200 ## B.6.2 I2C sequential read in system memory Table 289. Sequential in Read System memory (I<sup>2</sup>C security session open if reading I2C\_PWD) | Request/Response Frame | | C | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start AEh | - | Device select for writing | | - | ACK | 9th bit | | ADDRESS_MSB | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start AF7h | - | Device select for reading | | - | ACK | 9th bit | | - | DATA | Receive Data 0 | | ACK | - | 9th bit | | - | DATA | Receive Data 1 | | ACK | - | 9th bit | | - | | | | | - | | | - | DATA | Receive Data n | | NO_ACK | - | 9th bit | | Stop | - | End of Reading | DS10925 - Rev 9 page 174/200 Table 290. Sequential Read system memory when access is not granted (I<sup>2</sup>C password I2C\_PWD) | Request/Response Frame | | Comment | |------------------------|------------------|-------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start AEh | - | Device select for writing | | - | ACK | 9th bit | | 90h | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | ADDRESS_LSB | - | Send Address LSB (1 Byte) | | - | ACK | 9th bit | | Start AFh | - | Device select for reading | | - | ACK | 9th bit | | - | DATA | Receive Data 0 | | | FFh | ST25DV release SDA | | - | | Reading access is not granted | | ACK | - | 9th bit | | - | | | | | - | | | _ | FFh | ST25DV release SDA | | _ | | Reading access is not granted | | NO_ACK | - | 9th bit | | Stop | - | End of reading | DS10925 - Rev 9 page 175/200 ## B.6.3 I2C sequential read in dynamic registers Table 291. Sequential read in dynamic register | Request/Response Frame | | 0 | |------------------------------|------------------|-------------------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | 20h | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | | | Send Address LSB (1 Byte) | | Dynamic register ADDRESS_LSB | - | Fynamic register are located form address | | | | 2000h to 2007 | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | - | DATA | Receive Data 0 | | ACK | - | 9th bit | | - | DATA | Receive Data 1 | | ACK | - | 9th bit | | - | | | | | - | | | - | Data | Receive Data n | | NO_ACK | - | 9th bit | | Stop | - | End of reading | DS10925 - Rev 9 page 176/200 Table 292. Sequential read in Dynamic register and mailbox continuously if fast transfer mode is activated | Request/Response Frame | | Comment | |------------------------------|------------------|-------------------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | 20h | - | Send Address MSB (1 Byte) | | - | ACK | 9th bit | | Dynamia Bogistor | | Send Address LSB (1 Byte) | | Dynamic Register ADDRESS_LSB | - | Dynamic register are located from address | | ADDRESS_LSB | | 2000h to 2007h | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | - | DATA 0 | Receive Data 0 | | ACK | - | 9th bit | | - | DATA 1 | Receive Data 1 | | ACK | - | 9th bit | | - | | | | | - | | | | DATA n | Receive Data n (n ≤ 8) | | - | DAIATI | Last Dynamic register address 2007h | | ACK | - | 9th bit | | - | DATA n + 1 | Mailbox byte 0 | | ACK | - | 9th bit | | - | DATA n + 2 | Mailbox byte 1 | | ACK | - | 9th bit | | - | | | | ••• | - | | | - | Data n + i | Mailbox byte i (i < 256) | | NO_ACK | - | 9th bit | | Stop | - | End of reading | DS10925 - Rev 9 page 177/200 ## B.6.4 I2C sequential read in mailbox Table 293. Sequential in mailbox if fast transfer mode is activated | Request/Resp | oonse Frame | Q | |-------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | - Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | 20h or 21h | | Send Address MSB (1 Byte) | | 2011 01 2111 | - | 2007h < @ 2108h | | - | ACK | 9th bit | | ADDRESS_LSB | | Send Address LSB (1 Byte) | | ADDRESS_LSB | - | 2007h < @ 2108h | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | - | DATA 0 | Receive Data 0 | | ACK | - | 9th bit | | - | DATA 1 | Receive Data 1 | | ACK | - | 9th bit | | - | | | | | - | | | - | Data n | Receive Data n | | NO_ACK | - | 9th bit | | Stop | - | End of reading | DS10925 - Rev 9 page 178/200 Table 294. Sequential read in mailbox if fast transfer mode is not activated | Request/Response Frame | | Commont | |------------------------|------------------|---------------------------| | Master drives SDA | Slave drives SDA | — Comment | | Start A6h | - | Device select for writing | | - | ACK | 9th bit | | 20h or 21h | | Send Address MSB (1 Byte) | | 2011 01 2 111 | - | 2007h < @ 2108h | | - | ACK | 9th bit | | ADDRESS_LSB | _ | Send Address LSB (1 Byte) | | ADDRESS_ESB | - | 2007h < @ 2108h | | - | ACK | 9th bit | | Start A7h | - | Device select for reading | | - | ACK | 9th bit | | - | FFh | release SDA | | ACK | - | 9th bit | | - | FFh | release SDA | | ACK | - | 9th bit | | - | | | | | - | | | - | FFh | release SDA | | NO_ACK | - | 9th bit | | Stop | - | End of reading | DS10925 - Rev 9 page 179/200 ## B.7 I2C password relative sequences ### B.7.1 I2C write password Table 295. Write Password when I2C security session is already open and fast transfer mode is not activated | Request/Response Frame | | 0 | |------------------------|------------------|------------------------------------------------| | Master drives SDA | Slave drives SDA | Comment | | Start AEh | - | Device select for writing | | - | ACK | 9th bit | | 09h | - | Send I2C_PWD MSB address | | - | ACK | 9th bit | | 00h | - | Send I2C_PWD LSB address | | - | ACK | 9th bit | | I2C_PWD_BYTE_7 | - | Send I2C_PWD MSB | | - | ACK | 9th bit | | I2C_PWD_BYTE_6 | DATA 0 | Send Data | | - | ACK | 9th bit | | | - | | | - | | | | I2C_PWD_BYTE_0 | - | Send I2C_PWD LSB | | - | ACK | 9th bit | | 07h | - | Write password command | | - | ACK | 9th bit | | I2C_PWD_BYTE_7 | - | Send I2C_PWD MSB | | - | ACK | 9th bit | | I2C_PWD_BYTE_6 | DATA 0 | Send Data | | - | ACK | 9th bit | | | - | | | - | | | | I2C_PWD_BYTE_0 | - | Send I2C_PWD LSB | | - | ACK | 9th bit | | Stop | - | Start of I <sup>2</sup> C password programming | DS10925 - Rev 9 page 180/200 Table 296. Write Password when I2C security session is not open or fast transfer mode activated | Request/Resp | onse Frame | Comment | | |-------------------|------------------|---------------------------|--| | Master drives SDA | Slave drives SDA | | | | Start AEh | - | Device select for writing | | | - | ACK | 9th bit | | | 09h | - | Send I2C_PWD MSB address | | | - | ACK | 9th bit | | | 00h | - | Send I2C_PWD LSB address | | | - | NoACK | 9th bit | | | Stop | _ | No PWD Programming | | | Glop | - | Device return in Standby | | DS10925 - Rev 9 page 181/200 ### B.7.2 I2C present password Table 297. Present Password (whatever status of I<sup>2</sup>C security session or fast transfer mode) | Request/Response Frame | | Comment | | | |------------------------|------------------|-----------------------------|--|--| | Master drives SDA | Slave drives SDA | Comment | | | | Start AEh | - | Device select for writing | | | | - | ACK | 9th bit | | | | 09h | - | Send I2C_PWD MSB address | | | | - | ACK | 9th bit | | | | 00h | - | Send I2C_PWD LSB address | | | | - | ACK | 9th bit | | | | I2C_PWD_BYTE_7 | - | Send I2C_PWD MSB | | | | - | ACK | 9th bit | | | | I2C_PWD_BYTE_6 | DATA 0 | Send Data | | | | - | ACK | 9th bit | | | | | - | | | | | - | | | | | | I2C_PWD_BYTE_0 | - | Send I2C_PWD LSB | | | | - | ACK | 9th bit | | | | 09h | - | Present password command | | | | - | ACK | 9th bit | | | | I2C_PWD_BYTE_7 | - | Send I2C_PWD MSB | | | | - | ACK | 9th bit | | | | I2C_PWD_BYTE_6 | - | Send Data | | | | - | ACK | 9th bit | | | | | - | | | | | - | | | | | | I2C_PWD_BYTE_0 | - | Send I2C_PWD LSB | | | | - | ACK | 9th bit | | | | Stop | | ST25DV with active I2C_PWD. | | | | σιορ | - | Result is immediate. | | | DS10925 - Rev 9 page 182/200 ## **Revision history** Table 298. Document revision history | Date | Revision | Changes | |-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23-Feb-2017 | 1 | Initial release. | | 20-Sep-2017 | 2 | Updated: Features Section 4 Memory management Section 5 ST25DVxxx specific features Section 5.6.4 System memory protection Section 6.4.2 I2C Sequential write Section 6 I2C operation Section 7 RF operations Section 9.1 Maximum rating Table 158. Get System Info response format Error_flag is NOT set Table 242. Absolute maximum ratings Table 244. AC test measurement conditions Table 246. I <sup>2</sup> C DC characteristics up to 85°C Table 248. I <sup>2</sup> C AC characteristics up to 85°C Table 250. GPO DC characteristics up to 85°C Table 253. RF characteristics Table 254. Operating conditions Table 256. TSSOP8 – Mechanical data Table 261. Ordering information scheme Figure 30. I <sup>2</sup> C Present Password Sequence Figure 80. TSSOP8 – Outline Added: Table 159. Memory size Table 243. I <sup>2</sup> C OC characteristics up to 125°C Table 249. I <sup>2</sup> C AC characteristics up to 125°C Table 251. GPO DC characteristics up to 125°C | | 04-Oct-2017 | 3 | Updated: Features Section 10 Package information Added: NFC certified logo | | 19-Dec-2017 | 4 | Added: Figure 4. ST25DVxxx 10-ball WLCSP package connections with Cmos interrupt output (GPO) Section 10.5 WLCSP10 package information Table 259. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale mechanical data Figure 84. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale package outline Figure 85. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale recommended footprint Updated: Features Section 1 Description | DS10925 - Rev 9 page 183/200 | Date | Revision | Changes | |-------------|----------|----------------------------------------------------------------------------------------------------------------| | Date | Revision | Section 2.5 Energy harvesting analog output (V_EH) | | | | Section 5.3.2 Energy harvesting arrange output (V_ETI) Section 5.3.2 Energy harvesting feature description | | | | | | | | • Figure 21. ST25DVxxx, Arbitration between RF and I <sup>2</sup> C | | | | Section 6.4.1 I2C Byte write Section 6.4.2 I2C Sequential write | | | | <ul> <li>Section 6.4.2 I2C Sequential write</li> <li>Table 242. Absolute maximum ratings</li> </ul> | | | | | | | | Table 243. I <sup>2</sup> C operating conditions Table 201. Ordering information ashares. | | | | Table 261. Ordering information scheme | | | | Deleted: | | | | Device summary | | | | Updated: | | | | Table 21. MB_LEN_Dyn | | | | Section 5.1.2 Fast transfer mode usage | | | | Section 5.6.2 Passwords and security sessions | | | | Section 7.6.2 Command codes list | | 44 5 0040 | _ | Section 7.6.35 Write Password | | 14-Jun-2018 | 5 | Section 10.5 WLCSP10 package information | | | | • Figure 84. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale package outline | | | | Figure 85. WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale | | | | recommended footprint | | | | Added: | | | | Table 260. WLCSP10 recommended PCB design rules | | | | Updated: | | | | Section 2.2.2 Low Power Down (LPD) | | | | Section 5.1.2 Fast transfer mode usage | | | | Section 5.2.3 GPO registers | | | | Figure 22. RF security sessions management | | | | Section 7.6.7 Extended Read Single Block | | | | Section 7.6.9 Extended Write Single Block | | 01-Aug-2018 | 6 | Section 7.6.10 Lock Block | | | | Section 7.6.11 Extended Lock block | | | | Section 7.6.13 Extended Read Multiple Blocks | | | | Section 7.6.15 Extended Write Multiple Blocks | | | | Section 7.6.25 Extended Get Multiple Block Security Status | | | | Section 7.6.38 Fast Extended Read Single Block | | | | Section 7.6.40 Fast Extended Read Multiple Block | | | | Section 9.1 Maximum rating | | | | Updated: | | 08-Nov-2018 | 7 | Table 205. Fast Read Message request format | | | | Table 206. Fast Read Message response format when Error_flag is NOT set | | | | Updated: | | | | Section 2.2.2 Low Power Down (LPD) | | | | Section 5.4.2 RF management feature description | | 04-May-2020 | 8 | Section 5.6.2 Passwords and security sessions | | | | Table 79. MEM_SIZE | | | | Table 161. Extended Get System Info request format | | | | Table 231. Fast Write Message response format when Error_flag is set | | | | Updated: | | 19-Feb-2021 | 9 | Section 4.2.1 User memory areas | | | | Section 5.2.2 GPO and power supply | DS10925 - Rev 9 page 184/200 | Date | Revision | Changes | |------|----------|--------------------------------------------------------| | | | Section 5.2.3 GPO registers | | | | Section 5.4.2 RF management feature description | | | | Section 6.4 I2C Write operations | | | | Section 6.6.1 I2C present password command description | | | | Table 253. RF characteristics | DS10925 - Rev 9 page 185/200 ### **Contents** | 1 | Desc | ription | | 3 | | | | |---|------|----------------------------|-----------------------------------|----|--|--|--| | | 1.1 | ST25D | OVxxx block diagram | 3 | | | | | | 1.2 | ST25D | OVxxx packaging | 4 | | | | | 2 | Sign | Signal descriptions | | | | | | | | 2.1 | Serial I | link (SCL, SDA) | 6 | | | | | | | 2.1.1 | Serial clock (SCL) | 6 | | | | | | | 2.1.2 | Serial data (SDA) | 6 | | | | | | 2.2 | Power | control (VCC, LPD,VSS) | 6 | | | | | | | 2.2.1 | Supply voltage (VCC) | 6 | | | | | | | 2.2.2 | Low Power Down (LPD) | 6 | | | | | | | 2.2.3 | Ground (VSS) | 6 | | | | | | 2.3 | RF link | k (AC0 AC1) | 7 | | | | | | | 2.3.1 | Antenna coil (AC0, AC1) | 7 | | | | | | 2.4 | Proces | ss control (VDCG, GPO) | 7 | | | | | | | 2.4.1 | Driver Supply voltage (VDCG) | 7 | | | | | | | 2.4.2 | General purpose output (GPO) | 7 | | | | | | 2.5 | Energy | y harvesting analog output (V_EH) | 7 | | | | | 3 | Pow | er mana | agement | 8 | | | | | | 3.1 | Wired interface | | | | | | | | 3.2 | Contac | Contactless interface | | | | | | 4 | Mem | ory ma | nagement | 10 | | | | | | 4.1 | Memoi | ry organization overview | 10 | | | | | | 4.2 | User m | nemory | 11 | | | | | | | 4.2.1 | User memory areas | 13 | | | | | | 4.3 | Systen | n configuration area | 17 | | | | | | 4.4 | Dynamic configuration | | | | | | | | 4.5 | Fast transfer mode mailbox | | | | | | | 5 | ST25 | <b>DV</b> xxx | specific features | 21 | | | | | | 5.1 | Fast tra | ansfer mode (FTM) | 22 | | | | | | | 5.1.1 | Fast transfer mode registers | 22 | | | | | | | 5.1.2 | rast transfer mode usage | . 24 | |---|-------|----------|-----------------------------------------------|------| | | 5.2 | GPO | | . 27 | | | | 5.2.1 | ST25DVxxx interrupt capabilities on RF events | . 27 | | | | 5.2.2 | GPO and power supply | . 35 | | | | 5.2.3 | GPO registers | . 36 | | | | 5.2.4 | Configuring GPO | . 40 | | | 5.3 | Energy | Harvesting (EH) | .41 | | | | 5.3.1 | Energy harvesting registers | . 41 | | | | 5.3.2 | Energy harvesting feature description | . 42 | | | | 5.3.3 | EH delivery state diagram | . 43 | | | | 5.3.4 | EH delivery sequence | . 44 | | | 5.4 | RF mar | nagement feature | . 45 | | | | 5.4.1 | RF management registers | . 45 | | | | 5.4.2 | RF management feature description | . 46 | | | 5.5 | Interfac | e Arbitration | . 47 | | | 5.6 | Data Pr | otection | . 48 | | | | 5.6.1 | Data protection registers | . 48 | | | | 5.6.2 | Passwords and security sessions | . 55 | | | | 5.6.3 | User memory protection | . 58 | | | | 5.6.4 | System memory protection | . 59 | | | 5.7 | Device | Parameter Registers | . 60 | | 6 | I2C o | peratio | n | .64 | | | 6.1 | I2C pro | tocol | . 64 | | | | 6.1.1 | Start condition | . 64 | | | | 6.1.2 | Stop condition | . 65 | | | | 6.1.3 | Acknowledge bit (ACK) | . 65 | | | | 6.1.4 | Data input | . 65 | | | 6.2 | I2C time | eout | . 65 | | | | 6.2.1 | I2C timeout on Start condition | . 65 | | | | 6.2.2 | I2C timeout on clock period | . 65 | | | 6.3 | Device | addressing | . 66 | | | 6.4 | I2C Wri | te operations | . 66 | | | | | | | | | | 6.4.1 | I2C Byte write | 67 | |---|------|----------|--------------------------------------------|----| | | | 6.4.2 | I2C Sequential write | 67 | | | | 6.4.3 | Minimizing system delays by polling on ACK | 69 | | | 6.5 | I2C rea | d operations | 70 | | | | 6.5.1 | Random Address Read | 70 | | | | 6.5.2 | Current Address Read | 70 | | | | 6.5.3 | Sequential Read access | 71 | | | | 6.5.4 | Acknowledge in Read mode | 72 | | | 6.6 | I2C pas | ssword management | 72 | | | | 6.6.1 | I2C present password command description | 72 | | | | 6.6.2 | I2C write password command description | 72 | | 7 | RF o | peratior | าร | 74 | | | 7.1 | RF com | nmunication | 74 | | | | 7.1.1 | Access to a ISO/IEC 15693 device | 74 | | | 7.2 | RF com | nmunication and energy harvesting | 74 | | | 7.3 | Fast tra | insfer mode mailbox access in RF | 74 | | | 7.4 | RF prot | cocol description | 75 | | | | 7.4.1 | Protocol description | 75 | | | | 7.4.2 | ST25DVxxx states referring to RF protocol | 75 | | | | 7.4.3 | Modes | 77 | | | | 7.4.4 | Request format | 77 | | | | 7.4.5 | Request flags | 77 | | | | 7.4.6 | Response format | 79 | | | | 7.4.7 | Response flags | 79 | | | | 7.4.8 | Response and error code | 80 | | | 7.5 | Timing | definition | 80 | | | 7.6 | RF com | nmands | 82 | | | | 7.6.1 | RF command code list | 82 | | | | 7.6.2 | Command codes list | 83 | | | | 7.6.3 | General command rules | 83 | | | | 7.6.4 | Inventory | 84 | | | | 7.6.5 | Stay Quiet | 84 | | | | | | | | 7.6.6 | Read Single Block85 | |--------|---------------------------------------------| | 7.6.7 | Extended Read Single Block | | 7.6.8 | Write Single Block | | 7.6.9 | Extended Write Single Block | | 7.6.10 | Lock Block | | 7.6.11 | Extended Lock block | | 7.6.12 | Read Multiple Blocks | | 7.6.13 | Extended Read Multiple Blocks | | 7.6.14 | Write Multiple Blocks | | 7.6.15 | Extended Write Multiple Blocks | | 7.6.16 | Select | | 7.6.17 | Reset to Ready | | 7.6.18 | Write AFI | | 7.6.19 | Lock AFI | | 7.6.20 | Write DSFID | | 7.6.21 | Lock DSFID | | 7.6.22 | Get System Info | | 7.6.23 | Extended Get System Info | | 7.6.24 | Get Multiple Block Security Status | | 7.6.25 | Extended Get Multiple Block Security Status | | 7.6.26 | Read Configuration | | 7.6.27 | Write Configuration | | 7.6.28 | Read Dynamic Configuration | | 7.6.29 | Write Dynamic Configuration | | 7.6.30 | Manage GPO | | 7.6.31 | Write Message | | 7.6.32 | Read Message Length | | 7.6.33 | Read Message | | 7.6.34 | Fast Read Message | | 7.6.35 | Write Password | | 7.6.36 | Present Password | | 7.6.37 | Fast Read Single Block | | 7.6.38 | Fast Extended Read Single Block | | | | | | | 7.6.39 | Fast Read Multiple Blocks | 129 | |-----|-------|----------|---------------------------------------------|-----| | | | 7.6.40 | Fast Extended Read Multiple Block | 131 | | | | 7.6.41 | Fast Write Message | 132 | | | | 7.6.42 | Fast Read Message Length | 133 | | | | 7.6.43 | Fast Read Dynamic Configuration | 134 | | | | 7.6.44 | Fast Write Dynamic Configuration | 135 | | 8 | Uniq | ue iden | tifier (UID) | 137 | | 9 | Devi | ce para | meters | 138 | | | 9.1 | Maximu | um rating | | | | 9.2 | I2C DC | and AC parameters | 139 | | | 9.3 | GPO cl | haracteristics | 146 | | | 9.4 | RF elec | ctrical parameters | 147 | | 10 | Pack | age info | ormation | 149 | | | 10.1 | SO8N | package information | 149 | | | 10.2 | TSSOF | P8 package information | | | | 10.3 | UFDFN | N8 package information | | | | 10.4 | UFDFF | PN12 package information | | | | 10.5 | WLCSF | P10 package information | | | 11 | Orde | ring inf | formation | 156 | | Apr | endix | A Bit | representation and coding for fast commands | 157 | | | A.1 | | ing using one subcarrier | | | | 7 | A.1.1 | High data rate | | | | | A.1.2 | Low data rate | | | | A.2 | ST25D | Vxxx to VCD frames | | | | A.3 | SOF w | hen using one subcarrier | | | | | A.3.1 | High data rate | | | | | A.3.2 | Low data rate | 158 | | | A.4 | EOF w | hen using one subcarrier | 159 | | | | A.4.1 | High data rate | | | | | A.4.2 | Low data rate | | | App | endix | B I2C | sequences | 160 | | | | | • | | | B.1 | Device | select codes | | |------------|---------|---------------------------------------------------|-----| | B.2 | I2C Byt | te writing and polling | 160 | | | B.2.1 | I2C byte write in user memory | 160 | | | B.2.2 | I2C byte writing in dynamic registers and polling | 162 | | | B.2.3 | I2C byte write in mailbox and polling | 163 | | | B.2.4 | I2C byte write and polling in system memory | 164 | | B.3 | I2C sec | quential writing and polling | 165 | | | B.3.1 | I2C sequential write in user memory and polling | 165 | | | B.3.2 | I2C sequential write in mailbox and polling | 167 | | B.4 | I2C Re | ead current address | 168 | | | B.4.1 | I2C current address read in User memory | 168 | | B.5 | I2C ran | ndom address read | | | | B.5.1 | I2C random address read in user memory | 169 | | | B.5.2 | I2C Random address read in system memory | 170 | | | B.5.3 | I2C Random address read in dynamic registers | 170 | | B.6 | I2C sec | quential read | | | | B.6.1 | I2C sequential read in user memory | 171 | | | B.6.2 | I2C sequential read in system memory | 174 | | | B.6.3 | I2C sequential read in dynamic registers | 176 | | | B.6.4 | I2C sequential read in mailbox | 178 | | B.7 | I2C pas | ssword relative sequences | | | | B.7.1 | I2C write password | 180 | | | B.7.2 | I2C present password | 182 | | Revision h | nistory | | 183 | ## **List of tables** | Table 1. | Signal names | . 4 | |-----------|--------------------------------------------------------------------------|-----| | Table 2. | User memory as seen by RF and by I <sup>2</sup> C | 12 | | | Maximum user memory Block and Byte addresses and ENDA <sub>i</sub> value | | | Table 4. | Areas and limit calculation from ENDA <sub>i</sub> registers | 14 | | Table 5. | ENDA1 access | 15 | | Table 6. | ENDA1 | 16 | | Table 7. | ENDA2 access | 16 | | Table 8. | ENDA2 | 16 | | Table 9. | ENDA3 access | | | Table 10. | ENDA3 | 16 | | Table 11. | System configuration memory map | 17 | | Table 12. | Dynamic registers memory map | | | Table 13. | Fast transfer mode mailbox memory map | | | Table 14. | MB MODE access | | | Table 15. | MB_MODE | 22 | | Table 16. | MB WDG access | 22 | | Table 17. | MB_WDG | 22 | | Table 18. | MB_CTRL_Dyn access | 23 | | | MB_CTRL_Dyn | | | | MB_LEN_Dyn access | | | | MB LEN Dyn | | | Table 22. | FIELD_CHANGE when RF is disabled or in sleep mode | 31 | | Table 23. | GPO interrupt capabilities in function of RF field. | 35 | | | GPO interrupt capabilities in function of V <sub>CC</sub> power supply | | | | GPO access | | | | GPO | | | | IT TIME access. | | | | IT TIME | | | | GPO_CTRL_Dyn access | | | | GPO_CTRL_Dyn | | | | IT_STS_Dyn access. | | | | IT STS Dyn | | | | Enabling or disabling GPO interruptions | | | | EH MODE access | | | | EH MODE | | | | <del>-</del> | | | Table 37. | EH CTRL Dyn | 41 | | Table 38. | Energy harvesting at power-up | 42 | | Table 39. | RF_MNGT access | 45 | | Table 40. | RF_MNGT | 45 | | Table 41. | RF_MNGT_Dyn access | 45 | | Table 42. | RF_MNGT_Dyn | 45 | | Table 43. | RFA1SS access. | 48 | | Table 44. | RFA1SS | 48 | | Table 45. | RFA2SS access | 48 | | Table 46. | RFA2SS | 49 | | Table 47. | RFA3SS access | 49 | | Table 48. | RFA3SS | 49 | | Table 49. | RFA4SS access | 49 | | Table 50. | RFA4SS | 50 | | Table 51. | I2CSS access | 50 | | Table 52. | I2CSS | 51 | DS10925 - Rev 9 page 192/200 #### List of tables | LOCK_CCFILE access | 32 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LOCK_CCFILE | 52 | | LOCK_CFG access | 52 | | LOCK_CFG | 52 | | I2C_PWD access | 53 | | I2C_PWD | 53 | | RF_PWD_0 access | 53 | | RF_PWD_0 | 53 | | RF_PWD_1 access | 54 | | RF_PWD_1 | 54 | | RF_PWD_2 access | 54 | | RF PWD 2 | 54 | | RF PWD 3 access | 55 | | <del></del> | | | | | | · | | | | | | | | | | | | | | | <del>-</del> | | | <del>-</del> | | | | | | | | | | | | | | | <del>-</del> | | | | | | <del>-</del> | | | | | | | | | UID access | | | UID | | | | | | | 63 | | IC_REV access | 63<br>63 | | IC_REV access | 63<br>63<br>63 | | IC_REV access IC_REV Device select code | 63<br>63<br>66 | | IC_REV access IC_REV Device select code Operating modes | 63<br>63<br>63<br>66<br>66 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte | 63<br>63<br>66<br>66<br>66 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte | 63<br>63<br>66<br>66<br>66<br>66 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags | 63<br>63<br>66<br>66<br>66<br>66<br>76 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format | 63<br>63<br>66<br>66<br>66<br>66<br>76<br>77 | | IC_REV access IC_REV Device select code. Operating modes. Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format. Definition of request flags 1 to 4. | 63<br>63<br>66<br>66<br>66<br>76<br>77<br>78 | | IC_REV access IC_REV Device select code. Operating modes. Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format. Definition of request flags 1 to 4. Request flags 5 to 8 when inventory_flag, Bit 3 = 0. | 63<br>63<br>66<br>66<br>66<br>76<br>77<br>78<br>78 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. | 63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>78 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4. Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format | 63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>78<br>79 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. | 63<br>63<br>66<br>66<br>66<br>76<br>77<br>78<br>78<br>79 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1 General response format Definitions of response flags 1 to 8. Response error code definition | 63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>79<br>80 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format. Definition of request flags 1 to 4. Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. Response error code definition Timing values | 63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>79<br>80<br>81 | | IC_REV access IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. Response error code definition Timing values Command codes | 63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>79<br>80<br>81<br>83 | | IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format. Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. Response error code definition Timing values Command codes Inventory request format | 63<br>63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>80<br>81<br>83<br>84 | | IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. Response error code definition Timing values Command codes Inventory request format. Inventory response format. | 63<br>63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>79<br>80<br>81<br>83<br>84<br>84 | | IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format. Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. Response error code definition Timing values Command codes Inventory request format. Inventory response format. Stay Quiet request format | 63<br>63<br>66<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>80<br>81<br>83<br>84<br>84<br>85 | | IC_REV Device select code Operating modes Address most significant byte Address least significant byte ST25DVxxx response depending on Request_flags General request format Definition of request flags 1 to 4 Request flags 5 to 8 when inventory_flag, Bit 3 = 0. Request flags 5 to 8 when inventory_flag, Bit 3 = 1. General response format Definitions of response flags 1 to 8. Response error code definition Timing values Command codes Inventory request format. Inventory response format. | 63<br>63<br>66<br>66<br>66<br>77<br>78<br>78<br>79<br>79<br>80<br>81<br>83<br>84<br>85<br>85 | | | IZC_PWD access IZC_PWD RF_PWD_0 access RF_PWD_0 access RF_PWD_1 access RF_PWD_1 access RF_PWD_1 RF_PWD_2 access RF_PWD_2 access RF_PWD_3 access RF_PWD_3 access RF_PWD_3 IZC_SSO_Dyn access | DS10925 - Rev 9 page 193/200 | | Block security status | | |-------------------|--------------------------------------------------------------------------|-----| | <b>Table 108.</b> | Read Single Block response format when Error_flag is set | 86 | | | Extended Read Single Block request format | | | | Extended Read Single Block response format when Error_flag is NOT set | | | | Block security status | | | <b>Table 112.</b> | Extended Read Single Block response format when Error_flag is set | 87 | | <b>Table 113.</b> | Write Single Block request format | 88 | | <b>Table 114.</b> | Write Single Block response format when Error_flag is NOT set | 88 | | <b>Table 115.</b> | Write Single Block response format when Error_flag is set | 88 | | | Extended Write Single request format | | | <b>Table 117.</b> | Extended Write Single response format when Error_flag is NOT set | 89 | | <b>Table 118.</b> | Extended Write Single response format when Error_flag is set | 89 | | <b>Table 119.</b> | Lock block request format | 90 | | <b>Table 120.</b> | Lock block response format when Error_flag is NOT set | 90 | | <b>Table 121.</b> | Lock block response format when Error_flag is set | 90 | | | Extended Lock block request format | | | <b>Table 123.</b> | Extended Lock block response format when Error_flag is NOT set | 91 | | <b>Table 124.</b> | Extended Lock block response format when Error_flag is set | 92 | | | Read Multiple Block request format | | | <b>Table 126.</b> | Read Multiple Block response format when Error_flag is NOT set | 93 | | | Block security status | | | <b>Table 128.</b> | Read Multiple Block response format when Error_flag is set | 93 | | | Extended Read Multiple Block request format | | | <b>Table 130.</b> | Extended Read Multiple Block response format when Error_flag is NOT set | 94 | | <b>Table 131.</b> | Block security status | 94 | | <b>Table 132.</b> | Extended Read Multiple Block response format when Error_flag is set | 94 | | <b>Table 133.</b> | Write Multiple Block request format | 95 | | <b>Table 134.</b> | Write Multiple Block response format when Error_flag is NOT set | 96 | | <b>Table 135.</b> | Write Multiple Block response format when Error_flag is set | 96 | | <b>Table 136.</b> | Extended Write Multiple Block request format | 97 | | <b>Table 137.</b> | Extended Write Multiple Block response format when Error_flag is NOT set | 97 | | <b>Table 138.</b> | Extended Write Multiple Block response format when Error_flag is set | 97 | | <b>Table 139.</b> | Select request format | 98 | | Table 140. | Select Block response format when Error_flag is NOT set | 98 | | <b>Table 141.</b> | Select response format when Error_flag is set | 98 | | <b>Table 142.</b> | Reset to Ready request format | 100 | | <b>Table 143.</b> | Reset to Ready response format when Error_flag is NOT set | 100 | | <b>Table 144.</b> | Reset to ready response format when Error_flag is set | 100 | | <b>Table 145.</b> | Write AFI request format | 101 | | <b>Table 146.</b> | Write AFI response format when Error_flag is NOT set | 101 | | <b>Table 147.</b> | Write AFI response format when Error_flag is set | 101 | | <b>Table 148.</b> | Lock AFI request format | 102 | | <b>Table 149.</b> | Lock AFI response format when Error_flag is NOT set | 102 | | <b>Table 150.</b> | Lock AFI response format when Error_flag is set | 102 | | <b>Table 151.</b> | Write DSFID request format | 103 | | <b>Table 152.</b> | Write DSFID response format when Error_flag is NOT set | 103 | | <b>Table 153.</b> | Write DSFID response format when Error_flag is set | 104 | | | Lock DSFID request format | | | <b>Table 155.</b> | Lock DSFID response format when Error_flag is NOT set | 104 | | <b>Table 156.</b> | Lock DSFID response format when Error_flag is set | 105 | | | Get System Info request format | | | <b>Table 158.</b> | Get System Info response format Error_flag is NOT set | 106 | | | Memory size | | | <b>Table 160.</b> | Get System Info response format when Error_flag is set | 106 | | | | | DS10925 - Rev 9 page 194/200 | | Extended Get System Info request format | | |-------------------|--------------------------------------------------------------------------------------|-------| | | Parameter request list | | | | Extended Get System Info response format when Error_flag is NOT set | | | | Response Information Flag | | | | Response other field: ST25DVxxx VICC memory size. | | | | Response other field: ST25DVxxx IC Ref | | | | Response other field: ST25DVxxx VICC command list | | | | Response other field: ST25DVxxx VICC command list Byte 1 | | | | Response other field: ST25DVxxx VICC command list Byte 2 | | | <b>Table 170.</b> | Response other field: ST25DVxxx VICC command list Byte 3 | .110 | | | Response other field: ST25DVxxx VICC command list Byte 4 | | | <b>Table 172.</b> | Extended Get System Info response format when Error_flag is set | .110 | | | Get Multiple Block Security Status request format | | | <b>Table 174.</b> | Get Multiple Block Security Status response format when Error_flag is NOT set | . 111 | | | Block security status | | | <b>Table 176.</b> | Get Multiple Block Security Status response format when Error_flag is set | . 111 | | <b>Table 177.</b> | Extended Get Multiple Block Security Status request format | .112 | | | Extended Get Multiple Block Security Status response format when Error_flags NOT set | | | | Block security status | | | <b>Table 180.</b> | Extended Get Multiple Block Security Status response format when Error_flag is set | .113 | | | Read Configuration request format | | | <b>Table 182.</b> | Read Configuration response format when Error_flag is NOT set | .114 | | <b>Table 183.</b> | Read Configuration response format when Error_flag is set | .114 | | <b>Table 184.</b> | Write Configuration request format | .115 | | <b>Table 185.</b> | Write Configuration response format when Error_flag is NOT set | .115 | | <b>Table 186.</b> | Write configuration response format when Error_flag is set | .115 | | | Read Dynamic Configuration request format | | | <b>Table 188.</b> | Read Dynamic Configuration response format when Error_flag is NOT set | .116 | | <b>Table 189.</b> | Read Dynamic Configuration response format when Error_flag is set | .116 | | | Write Dynamic Configuration request format | | | | Write Dynamic Configuration response format when Error_flag is NOT set | | | | Write Dynamic Configuration response format when Error_flag is set | | | <b>Table 193.</b> | ManageGPO request format | .118 | | | GPOVAL | | | | ManageGPO response format when Error_flag is NOT set | | | <b>Table 196.</b> | ManageGPO response format when Error_flag is set | .119 | | | | .119 | | | Write Message response format when Error_flag is NOT set | | | | Write Message response format when Error_flag is set | | | | Read Message Length request format | | | | Read Message Length response format when Error_flag is NOT set | | | | Read Message Length response format when Error_flag is set | | | | Read Message request format | | | | Read Message response format when Error_flag is NOT set | | | | Fast Read Message request format | | | | Fast Read Message response format when Error_flag is NOT set | | | | Write Password request format | | | | Write Password response format when Error_flag is NOT set | | | | Write Password response format when Error_flag is set | | | | Present Password request format | | | | Present Password response format when Error_flag is NOT set | | | | Present Password response format when Error_flag is set | | | | Fast Read Single Block request format | | | <b>Table 214.</b> | Fast Read Single Block response format when Error_flag is NOT set | 126 | | | | | DS10925 - Rev 9 page 195/200 #### List of tables | <b>Table 215.</b> | Block security status | 127 | |-------------------|----------------------------------------------------------------------------------------|-----| | <b>Table 216.</b> | Fast Read Single Block response format when Error_flag is set | 127 | | <b>Table 217.</b> | Fast Extended Read Single Block request format | 128 | | <b>Table 218.</b> | Fast Extended Read Single Block response format when Error_flag is NOT set | 128 | | <b>Table 219.</b> | Block security status | 128 | | <b>Table 220.</b> | Fast Extended Read Single Block response format when Error_flag is set | 128 | | <b>Table 221.</b> | Fast Read Multiple Block request format | 129 | | <b>Table 222.</b> | Fast Read Multiple Block response format when Error_flag is NOT set | 129 | | <b>Table 223.</b> | Block security status if Option_flag is set | 130 | | <b>Table 224.</b> | Fast Read Multiple Block response format when Error_flag is set | 130 | | <b>Table 225.</b> | Fast Extended Read Multiple Block request format | 131 | | <b>Table 226.</b> | Fast Extended Read Multiple Block response format when Error_flag is NOT set | 131 | | <b>Table 227.</b> | Block security status if Option_flag is set | 131 | | <b>Table 228.</b> | Fast Read Multiple Block response format when Error_flag is set | 131 | | <b>Table 229.</b> | Fast Write Message request format | 132 | | <b>Table 230.</b> | Fast Write Message response format when Error_flag is NOT set | 132 | | <b>Table 231.</b> | Fast Write Message response format when Error_flag is set | 133 | | <b>Table 232.</b> | Fast Read Message Length request format | 133 | | <b>Table 233.</b> | Fast Read Message Length response format when Error_flag is NOT set | 134 | | <b>Table 234.</b> | Fast Read Message Length response format when Error_flag is set | 134 | | <b>Table 235.</b> | Fast Read Dynamic configuration request format | 134 | | <b>Table 236.</b> | Fast Read Dynamic configuration response format when Error_flag is NOT set | 135 | | <b>Table 237.</b> | Fast Read Dynamic configuration response format when Error_flag is set | 135 | | | Fast Write Dynamic Configuration request format | | | <b>Table 239.</b> | Fast Write Dynamic Configuration response format when Error_flag is NOT set | 136 | | <b>Table 240.</b> | Fast Write Dynamic Configuration response format when Error_flag is set | 136 | | | UID format | | | <b>Table 242.</b> | Absolute maximum ratings | 138 | | <b>Table 243.</b> | I <sup>2</sup> C operating conditions | 139 | | <b>Table 244.</b> | AC test measurement conditions | 139 | | <b>Table 245.</b> | Input parameters | 139 | | <b>Table 246.</b> | I <sup>2</sup> C DC characteristics up to 85°C | 139 | | | I <sup>2</sup> C DC characteristics up to 125°C | | | | I <sup>2</sup> C AC characteristics up to 85°C. | | | | I <sup>2</sup> C AC characteristics up to 125°C. | | | | GPO DC characteristics up to 85°C | | | | GPO DC characteristics up to 125°C | | | | GPO AC characteristics | | | | RF characteristics | | | | Operating conditions | | | | SO8N – Mechanical data | | | | TSSOP8 – Mechanical data | | | | UFDFN8 - Mechanical data | | | | UFDFPN12 - Mechanical data | | | | WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale mechanical data | | | | WLCSP10 recommended PCB design rules | | | | Ordering information scheme. | | | | Device select usage | | | | Byte Write in user memory when write operation allowed | | | | Polling during programming after byte writing in user memory | | | | Byte Write in user memory when write operation is not allowed | | | | Byte Write in Dynamic Register (if not Read Only) | | | | Polling during programming after byte write in Dynamic Register | | | | Byte Write in Dynamic Register if Read Only | | | | | | DS10925 - Rev 9 page 196/200 | <b>Table 269.</b> | Byte Write in mailbox when mailbox is free from RF message and fast transfer mode is activated | 163 | |-------------------|---------------------------------------------------------------------------------------------------------------------------------|------------| | <b>Table 270.</b> | Byte Write in mailbox when mailbox is not free from RF message fast transfer mode is not activated | 163 | | <b>Table 271.</b> | Byte Write in System memory if I <sup>2</sup> C security session is open and register is not RO | 164 | | <b>Table 272.</b> | Polling during programing after byte write in System memory if I <sup>2</sup> C security session is open and register is not RC | ) | | | | 164 | | <b>Table 273.</b> | Byte Write in System memory if I <sup>2</sup> C security session is closed or register is RO | 165 | | <b>Table 274.</b> | Sequential write User memory when write operation allowed and all bytes belong to same area | 165 | | <b>Table 275.</b> | Polling during programing after sequential write in User memory when write operation allowed and all bytes belon | ıg | | | | 166 | | | Sequential write in User memory when write operation allowed and crossing over area border | | | <b>Table 277.</b> | Polling during programming after sequential write in User memory when write operation allowed and crossing over | | | Table 279 | area border | 167<br>167 | | | Polling during programing after sequential write in mailbox | | | | Current byte Read in User memory if read operation allowed (depending on area protection and RF user security | | | Table 200. | | 168 | | <b>Table 281.</b> | Current Read in User memory if read operation not allowed (depending on area protection and RF user security | | | | | 168 | | <b>Table 282.</b> | Random byte read in User memory if read operation allowed (depending on area protection and RF user security | | | | , | 169 | | | Random byte read in User memory if operation not allowed (depending on area protection and RF user security) | | | | , | 170 | | | , , , | 170 | | Table 286. | Sequential Read User memory if read operation allowed (depending on area protection and RF user security | 171 | | Table 207 | session) and all bytes belong to the same area | 171 | | Table 201. | session) but crossing area border | 172 | | Table 288. | Sequential Read User memory if read operation allowed (depending on area protection and RF user security | | | | session) | 173 | | <b>Table 289.</b> | Sequential in Read System memory (I <sup>2</sup> C security session open if reading I2C_PWD) | 174 | | | Sequential Read system memory when access is not granted (I <sup>2</sup> C password I2C_PWD) | | | | | 176 | | | | 177 | | | | 178 | | <b>Table 294.</b> | Sequential read in mailbox if fast transfer mode is not activated | 179 | | <b>Table 295.</b> | Write Password when I2C security session is already open and fast transfer mode is not activated | 180 | | <b>Table 296.</b> | Write Password when I2C security session is not open or fast transfer mode activated | 181 | | <b>Table 297.</b> | Present Password (whatever status of I <sup>2</sup> C security session or fast transfer mode) | 182 | | <b>Table 298.</b> | Document revision history | 183 | | | | | DS10925 - Rev 9 page 197/200 # **List of figures** | Figure 1. | ST25DVXXX block diagram | | |------------|------------------------------------------------------------------------------------------------|------| | Figure 2. | ST25DVxxx 8-pin packages connections with open drain Interruption Output | 4 | | Figure 3. | ST25DVxxx 12-pin package connections with Cmos interrupt output (GPO) | | | Figure 4. | ST25DVxxx 10-ball WLCSP package connections with Cmos interrupt output (GPO) | | | Figure 5. | ST25DVxxx power-up sequence (No RF field, LPD pin tied to $V_{SS}$ or package without LPD pin) | 8 | | Figure 6. | ST25DVxxx RF power-up sequence (No DC supply) | 9 | | Figure 7. | Memory organization | . 11 | | Figure 8. | ST25DVxxx user memory areas | . 13 | | Figure 9. | RF to I <sup>2</sup> C fast transfer mode operation | . 24 | | Figure 10. | I <sup>2</sup> C to RF fast transfer mode operation | | | Figure 11. | Fast transfer mode mailbox access management. | | | Figure 12. | RF_USER chronogram | | | Figure 13. | RF_ACTIVITY chronogram | | | Figure 14. | RF_INTERRUPT chronogram. | | | Figure 15. | FIELD_CHANGE chronogram | | | Figure 16. | RF_PUT_MSG chronogram | | | Figure 17. | RF_GET_MSG chronogram | | | Figure 17. | RF_WRITE chronogram | | | Figure 19. | EH delivery state diagram | | | Figure 20. | ST25DVxxx Energy Harvesting Delivery Sequence | | | | | | | Figure 21. | ST25DVxxx, Arbitration between RF and I <sup>2</sup> C | | | Figure 22. | RF security sessions management | | | Figure 23. | I <sup>2</sup> C security sessions management | | | Figure 24. | I <sup>2</sup> C bus protocol | | | Figure 25. | I <sup>2</sup> C timeout on Start condition | | | Figure 26. | Write mode sequences when write is not inhibited | | | Figure 27. | Write mode sequences when write is inhibited | | | Figure 28. | Write cycle polling flowchart using ACK | . 69 | | Figure 29. | Read mode sequences | . 71 | | Figure 30. | I <sup>2</sup> C Present Password Sequence | . 72 | | Figure 31. | I <sup>2</sup> C Write Password Sequence | . 73 | | Figure 32. | ST25DVxxx protocol timing | | | Figure 33. | ST25DVxxx state transition diagram | | | Figure 34. | Stay Quiet frame exchange between VCD and ST25DVxxx | . 85 | | Figure 35. | Read Single Block frame exchange between VCD and ST25DVxxx | | | Figure 36. | Extended Read Single Block frame exchange between VCD and ST25DVxxx | | | Figure 37. | Write Single Block frame exchange between VCD and ST25DVxxx | | | Figure 38. | Extended Write Single frame exchange between VCD and ST25DVxxx | | | Figure 39. | Lock Block frame exchange between VCD and ST25DVxxx | | | Figure 40. | Extended Lock block frame exchange between VCD and ST25DVxxx | | | Figure 41. | Read Multiple Block frame exchange between VCD and ST25DVxxx | | | Figure 42. | Extended Read Multiple Block frame exchange between VCD and ST25DVxxx | | | Figure 43. | Write Multiple Block frame exchange between VCD and ST25DVxxx | | | Figure 44. | Extended Write Multiple Block frame exchange between VCD and ST25DVxxx | | | Figure 45. | Select frame exchange between VCD and ST25DVxxx | | | Figure 46. | Reset to Ready frame exchange between VCD and ST25DVxxx | | | Figure 47. | Write AFI frame exchange between VCD and ST25DVxxx | | | Figure 48. | Lock AFI frame exchange between VCD and ST25DVxxx | | | Figure 49. | Write DSFID frame exchange between VCD and ST25DVxxx. | | | Figure 50. | Lock DSFID frame exchange between VCD and ST25DVxxx | | | Figure 51. | Get System Info frame exchange between VCD and ST25DVxxx | | | | Cot Cycles. and Marie Charles States 1700 and C1200 VAVA | .01 | DS10925 - Rev 9 page 198/200 | Figure 52. | Extended Get System Info frame exchange between VCD and ST25DVxxx | .110 | |------------|-----------------------------------------------------------------------------------------------------------|------| | Figure 53. | Get Multiple Block Security Status frame exchange between VCD and ST25DVxxx | .112 | | Figure 54. | Extended Get Multiple Block Security Status frame exchange between VCD and ST25DVxxx | .113 | | Figure 55. | Read Configuration frame exchange between VCD and ST25DVxxx | .114 | | Figure 56. | Write Configuration exchange between VCD and ST25DVxxx | .116 | | Figure 57. | Read Dynamic Configuration frame exchange between VCD and ST25DVxxx | .117 | | Figure 58. | Write Dynamic Configuration frame exchange between VCD and ST25DVxxx | .118 | | Figure 59. | Manage GPO frame exchange between VCD and ST25DVxxx | .119 | | Figure 60. | Write Message frame exchange between VCD and ST25DVxxx | 120 | | Figure 61. | Read Message Length frame exchange between VCD and ST25DVxxx | 121 | | Figure 62. | Read Message frame exchange between VCD and ST25DVxxx | 122 | | Figure 63. | Fast Read Message frame exchange between VCD and ST25DVxxx | 123 | | Figure 64. | Write Password frame exchange between VCD and ST25DVxxx | 125 | | Figure 65. | Present Password frame exchange between VCD and ST25DVxxx | 126 | | Figure 66. | Fast Read Single Block frame exchange between VCD and ST25DVxxx | 127 | | Figure 67. | Fast Extended Read Single Block frame exchange between VCD and ST25DVxxx | 129 | | Figure 68. | Fast Read Multiple Block frame exchange between VCD and ST25DVxxx | 130 | | Figure 69. | Fast Extended Read Multiple Block frame exchange between VCD and ST25DVxxx | 132 | | Figure 70. | Fast Write Message frame exchange between VCD and ST25DVxxx | 133 | | Figure 71. | Fast Read Message Length frame exchange between VCD and ST25DVxxx | 134 | | Figure 72. | Fast Read Dynamic configuration frame exchange between VCD and ST25DVxxx | 135 | | Figure 73. | Fast Write Dynamic Configuration frame exchange between VCD and ST25DVxxx | 136 | | Figure 74. | AC test measurement I/O waveform | 139 | | Figure 75. | I <sup>2</sup> C AC waveforms | 145 | | Figure 76. | $I^2C$ Fast mode ( $f_C = 1$ MHz): maximum $R_{bus}$ value versus bus parasitic capacitance ( $C_{bus}$ ) | 145 | | Figure 77. | ASK modulated signal | 148 | | Figure 78. | SO8N – Outline | | | Figure 79. | SO8N - Recommended footprint | 150 | | Figure 80. | TSSOP8 – Outline | 150 | | Figure 81. | TSSOP8 – Recommended footprint | 151 | | Figure 82. | UFDFN8 - Outline | 152 | | Figure 83. | UFDFPN12 - Outline | 153 | | Figure 84. | WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale package outline | 154 | | Figure 85. | WLCSP - 10 balls, 1.649x1.483 mm, 0.4 mm pitch, wafer level chip scale recommended footprint | 155 | | Figure 86. | Logic 0, high data rate, fast commands | 157 | | Figure 87. | Logic 1, high data rate, fast commands | 157 | | Figure 88. | Logic 0, low data rate, fast commands | 157 | | Figure 89. | Logic 1, low data rate, fast commands | 158 | | Figure 90. | Start of frame, high data rate, one subcarrier, fast commands | 158 | | Figure 91. | Start of frame, low data rate, one subcarrier, fast commands | 158 | | Figure 92. | End of frame, high data rate, one subcarrier, fast commands | 159 | | Figure 93. | End of frame, low data rate, one subcarrier, fast commands | | | | | | DS10925 - Rev 9 page 199/200 #### **IMPORTANT NOTICE - PLEASE READ CAREFULLY** STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. For additional information about ST trademarks, please refer to www.st.com/trademarks. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. © 2021 STMicroelectronics - All rights reserved DS10925 - Rev 9 page 200/200