

# Datasheet

## Scope

This technical document contains 3ALogics 13.56MHz Multi-Protocol Reader IC (TRH031M-S) features and structure.

## **Related 3ALogics Document**

TRH03XM-S Cookbook Firmware User Manual

## Application

Access Control / Home Network & Digital Door Lock POS Terminal / Public Transportation Electronic Library / Intelligent Toys E-Parking / Product Authentication Distribution, Logistics

# **Revision history**

| Date                      | Version      | CR      | Revisor  | Description                    |
|---------------------------|--------------|---------|----------|--------------------------------|
| 2010 10 05                | 0.1          | 01      | S.H Chun |                                |
| 2010. 10.05               | 0.1          | 01      | S.W Kim  | Preliminary version release    |
|                           |              |         |          |                                |
|                           |              |         |          |                                |
|                           |              |         |          |                                |
|                           |              |         |          |                                |
|                           |              |         |          |                                |
|                           |              |         |          |                                |
| Dept. Manger<br>Authors : | : Sung H     | un Chui | 1        | Title :<br>TRH031M-S Datasheet |
| Sung Hun Chun             |              |         |          | Contents :                     |
| Sung Wan Kim              | Sung Wan Kim |         |          | Chapter 1 ~ 14                 |
|                           |              |         |          | Page : 78                      |

#### Important notice

All referenced brands, product names, service name and trademarks are the property of their respective owners.

Any Read<sup>™</sup> - is a trademark of 3ALogics.

#### Copyright © 2010 3ALogics Inc.

This draft document is a copyright-protected by 3ALogics. Except as permitted under the applicable laws of the user's country, neither this draft document nor any extract from it may be reproduced, stored in a retrieval system or transmitted in any form or by any means, electronic, photocopying, recording or otherwise, without prior written permission.

#### Disclaimer

3ALogics accepts no liability for the content of this document, or for the consequences of any actions taken on the basis of the information provided, unless that information is subsequently confirmed in writing. If you are not the intended recipient you are notified that disclosing, copying, distributing or taking any action in reliance on the contents of this information is strictly prohibited.

#### Contact

3ALogics Inc.

7<sup>th</sup> Floor, Hyundai-office Bldg., 9-4, Sunae-dong. Bundang-gu, Seongnam-si, Gyeonggi-do, 463-783,Korea

TEL : (82)-(31)-715-7117 FAX : (82)-(31)-719-7551

homepage: <u>http://www.3ALogics.com</u> E-mail : rfid@3ALogics.com

Printed in the Republic of Korea.

# **Document Contents**

| CHAPTER1 INTRODUCTION                             | 8  |
|---------------------------------------------------|----|
| 1.1 FEATURES                                      | 8  |
| 1.2 Block Diagram                                 | 9  |
| 1.3 PIN DIAGRAMS                                  |    |
| 1.4 Pin Description                               |    |
| 1.5 Special Function Register Group               |    |
| 1.6 Special Function Register Group (Continue)    |    |
| CHAPTER2 TRH031M-S FUNCTIONALITY                  |    |
| 2.1 INTRODUCTION                                  |    |
| 2.2 RFID Reader                                   |    |
| 2.3 ROLE OF TRH031M-S                             |    |
| 2.3.1 Modulation / Demodulation                   |    |
| 2.3.2 Encoding / Decoding                         |    |
| 2.3.3 Framing                                     |    |
| 2.3.4 Data integrity                              |    |
| 2.3.5 Timer and Interrupt                         |    |
| CHAPTER3 HOST INTERFACE                           | 19 |
| 3.1 INTRODUCTION                                  |    |
| 3.2 PARALLEL INTERFACE                            |    |
| 3.2.1 Using Dedicated Address                     |    |
| 3.3 Parallel Interface Hardware Configuration     |    |
| 3.4 SPI Serial Interface                          |    |
| 3.4.1 SPI Serial Interface Hardware Configuration |    |
| 3.4.2 SPI Serial Interface Data Format            |    |
| CHAPTER4 COMMAND                                  | 26 |
| 4.1 Introduction                                  |    |
| 4.2 Command Explanation                           |    |
| 4.3 Transmit/Receive Status Check                 |    |
| 4.4 Control                                       |    |
| 4.5 Error Check                                   |    |

| CHAPTER5 PROTOCOL                   |    |
|-------------------------------------|----|
| 5.1 Introduction                    |    |
| 5.2 Transmit Data Format Select     |    |
| 5.3 Receiver Data Format Select     |    |
| 5.3.1 Receive Delay Time            |    |
| 5.3.2 Bit Level Receiving           |    |
| 5.4 ANTI-COLLISION                  |    |
| 5.4.1 Collision Detection           |    |
| 5.5 Bit Level data Transmit/Receive |    |
| 5.6 Protocol                        |    |
| 5.6.1 ISO/IEC 14443A Protocol       |    |
| 5.6.2 ISO/IEC 14443B Protocol       |    |
| CHAPTER6 FIFO BUFFER                |    |
| 6.1 INTRODUCTION                    |    |
| 6.2 FIFO Buffer Data Input/Output   |    |
| 6.3 FIFO BUFFER RELATED FUNCTIONS   |    |
| 6.3.1 FIFO Buffer Data Deletion     |    |
| 6.3.2 FIFO Buffer Error             |    |
| 6.3.3 FIFO Buffer caused Interrupt  |    |
| CHAPTER7 SIGNAL INTEGRITY           |    |
| 7.1 INTRODUCTION.                   |    |
| 7.2 Signal Integrity Setting Method |    |
| CHAPTER8 INTERRUPT                  |    |
| 8.1 Introduction                    |    |
| 8.2 Interrupt Use Method            |    |
| CHAPTER9 POWER MANAGEMENT           | 54 |
| 9.1 INTRODUCTION                    |    |
| 9.2 Power down Mode Effect          |    |
| 9.3 Powerdown Mode Directions       |    |
| 9.3.1 Hardware PowerDown Mode       |    |
| 9.3.2 Software PowerDown Mode       |    |

| CHAPTER10 TIMER                                   | 56 |
|---------------------------------------------------|----|
| 10.1 Introduction                                 | 56 |
| 10.2 TIMER SETTING                                |    |
| 10.3 Timer Function                               |    |
| CHAPTER11 ANALOG                                  | 59 |
| 11.1 TRANSMITTER                                  |    |
| 11.2 Transmitter Structure                        |    |
| 11.3 Transmitter Function                         |    |
| 11.3.1 TX1 and TX2 Function Setting               |    |
| 11.3.2 TX1 and TX2 Output Power Setting           |    |
| 11.3.3 TX1 and TX2 Modulation Index Adjustment    |    |
| 11.3.4 Recognition Distance and Power Consumption |    |
| 11.4 RECEIVER                                     |    |
| 11.5 Receiver Structure                           |    |
| 11.6 Receiver Functions                           |    |
| 11.6.1 Envelope Detector                          |    |
| 11.6.2 Offset Collection                          |    |
| 11.6.3 Variable Gain Amplifier: VGA               |    |
| 11.6.4 Comparator                                 |    |
| CHAPTER12 RECEIVER CALIBRATION                    |    |
| CHAPTER13 TEST                                    | 69 |
| 13.1 INTRODUCTION                                 |    |
| 13.2 How to use test pin                          |    |

| CHAPTER14 ELECTRICAL CHARACTERISTICS       | 71 |
|--------------------------------------------|----|
| 14.1 Operating condition range             |    |
| 14.2 Current consumption                   |    |
| 14.3 External Oscillator characteristics   |    |
| 14.4 Receiver characteristics              |    |
| 14.5 Receiver Calibration characteristics  |    |
| 14.6 Standard I/O Pin DC characteristics   |    |
| 14.7 Schmitt Trigger Input Threshold       |    |
| 14.8 Timing specification                  |    |
| 14.8.1 Timing for Read/Write Strobe        |    |
| 14.8.2 Timing for SPI compatible interface |    |
| 14.9 Package Information                   |    |
|                                            |    |

7

# Chapter1 Introduction

#### **1.1 Features**

#### **Basic information**

- 13.56MHz Multi-protocol RFID Reader chip
- 3.3V operation voltage
- 32pin LQFP Package

#### **Supported Protocols:**

- ISO/IEC 14443 A/B Type, ISO/IEC 15693
- Tag-it (Texas Instrument)

#### Performs Analog and Digital mixed operation as standards indicated

- Modulation/Demodulation, Encoding/Decoding
- Framing and Collision Detection for Anti-collision
- Automatic Data integrity check

#### Functions for microprocessor interface

- 128 bytes FIFO buffer for immediate data storage
- 4 types of Parallel interface and SPI Serial interface
- Configurable interrupt can inform event to microprocessor
- Configurable and Adjustable timer function can cooperated with transceive state and interrupt

#### Power consumption minimization

- Hardware/Software power down function
- Minimized leakage and stand-by current

#### **Other functions**

- Receiver auto calibration function (Offset cancellation)
- Transmit power and modulation index configuration
- Two Transmit drivers can be configured
- Adjustable receiver sensitivity depends on noise condition
- Data rate and pulse width configuration according to protocol standards
- Test pins for operation check

# 1.2 Block Diagram

Picture 1-1 displays TRH031M-S block diagram that is divided by digital and analog parts.



Picture 1-1 TRH031M-S Block Diagram

# 1.3 Pin Diagrams



Picture 1-2 TRH031M-S Pin Diagrams

# **1.4 Pin Description**

| Number | Pin Name   | Description                                 | Directio |
|--------|------------|---------------------------------------------|----------|
| 1      | TESTOUT    | Test Output (for factory test)              | Output   |
| 2      | TESTIN     | Test Input (for factory test)               | Input    |
| 3      | WRB        | Write Bar (Active low)                      | Input    |
| 4      | RDB        | Read Bar (Active low)                       | Input    |
| 5      | XOUT       | Crystal Oscillator Output                   | Output   |
| 6      | XIN        | Crystal Oscillator Input                    | Input    |
| 7      | DVSS       | Digital Ground                              | Ground   |
| 8      | DVDD       | Digital Power                               | Power    |
| 9-16   | DATA <0:7> | 8-Bit Data Bus                              | Inout    |
| 17-19  | ADDR <0:2> | 3-bit Address Bus                           | Input    |
| 20     | PALE       | Positive Address Latch Enable (Active High) | Input    |
| 21     | IRQ        | Interrupt Request                           | Output   |
| 22     | RST        | Reset (Active High)                         | Input    |
| 23     | AVDD       | Analog Power                                | Power    |
| 24     | AVSS       | Analog Ground                               | Ground   |
| 25     | TEST2O     | Test Output (for factory test)              | Output   |
| 26     | RX         | Receiver Input (Analog)                     | Input    |
| 27     | VMID       | Receive Reference Voltage (Analog)          | Output   |
| 28     | CSB        | Chip Select Bar (Active Low)                | Input    |
| 29     | TX1        | Transmit Driver #1 (Analog)                 | Output   |
| 30     | TVDD       | Transmitter Power                           | Power    |
| 31     | TX2        | Transmit Driver #2 (Analog)                 | Output   |
| 32     | TVSS       | Transmitter Ground                          | Ground   |

## Table 1-1 TRH031M-S Pin Map

# **1.5 Special Function Register Group**

| Address | Name              |            |              |                               | Va        | lue        |             |            |            |
|---------|-------------------|------------|--------------|-------------------------------|-----------|------------|-------------|------------|------------|
| 0x00    | PAGE              | UsePage    |              |                               |           |            |             | PageSelect |            |
| 0x01    | COMMAND           |            |              | Command                       |           |            |             |            |            |
| 0x02    | FIFODATA          |            |              |                               | FIFC      | Data       |             |            |            |
| 0x03    | STATUS1           |            |              | ModemStat                     | te        | IRQ        | ERR         | HiAlert    | LoAlert    |
| 0x04    | <b>FIFOLENGTH</b> |            |              |                               |           | FIFOLength |             |            |            |
| 0x05    | STATUS2           | TRunning   | Lock         | Status                        | TerrFlag  | TadFlag    |             | RxLastBits |            |
| 0x06    | IEN               | SetIEn     |              | TimerIEn                      | TxIEn     | RxIEn      | IdleIEn     | HiAlertIEn | LoAlertIEn |
| 0x07    | IRQ               | SetIRq     |              | TimerIRq                      | TxIRq     | RxIRq      | IdleIRq     | HiAlertIRq | LoAlertIRq |
| 0x08    | RFU               |            |              |                               |           |            |             |            |            |
| 0x09    | <u>CONTROL</u>    | Irqpin_inv |              |                               | PowerDown |            | TStopNow    | TStartNow  | FlushFIFO  |
| 0x0A    | ERRFLAG           |            |              |                               | FIFOOvfl  | CRCErr     |             | ParityErr  | CollErr    |
| 0x0B    | COLLPOS           | CollPos    |              |                               |           |            |             |            |            |
| 0x0C    | TIMERVALUE        |            | TimerValue   |                               |           |            |             |            |            |
| 0x0D    | CRCRESULTLSB      |            | CRCResultLSB |                               |           |            |             |            |            |
| 0x0E    | CRCRESULTMSB      |            |              |                               | CRCRe     | sultMSB    |             |            |            |
| 0x0F    | BITFRAME          |            |              | RxAlign                       |           | TMaskFlag  |             | TxLastBits |            |
| 0x10    | RFU               |            |              |                               |           |            |             |            |            |
| 0x11    | TXCONTROL         | TxPwdn     | Modula       | torSource                     | F100ASK   | TX2Inv     | TX2Cw       | TX2RFEn    | TX1RFEn    |
| 0x12    |                   |            |              | ExtraD                        |           |            | CwConductan | се         |            |
| 0x13    | MODCONDUCTANCE    |            |              |                               |           | ModCone    | ductance    |            |            |
| 0x14    |                   |            |              |                               |           | TI_Addr    |             | TxCoding   |            |
| 0x15    | MODWIDTH          |            |              |                               |           | ModV       | Vidth       |            |            |
| 0x16    | RFU               |            |              |                               |           |            |             |            |            |
| 0x17    | BFRAMING          |            |              | EOFWidth CharSpacing SOFWidth |           |            | Vidth       |            |            |
| 0x18    | RFU               |            |              |                               |           |            |             |            |            |
| 0x19    | RXCONTROL1        | RxPwdn     | VmidPwdn     | RxForce                       | 0         | 0          |             | VGAGain    |            |
| 0x1A    | DECODCONTROL      |            |              | ZrAfColl                      |           | RxFraming  |             |            |            |
| 0x1B    | RFU               |            |              |                               |           |            |             |            |            |
| 0x1C    | RXTHRESHOLD       |            |              |                               |           |            |             | Н          | YR         |

Table 1-2 TRH031M-S Special Function Register Group 1

# **1.6 Special Function Register Group (Continue)**

| Address | Name         |        |       |          |   | Value        |            |             |            |
|---------|--------------|--------|-------|----------|---|--------------|------------|-------------|------------|
| 0x1D    | RFU          |        |       |          |   |              |            |             |            |
| 0x1E    | RXCONTROL2   | ADcdMd |       |          |   |              |            | Dcdsrc      |            |
| 0x1F    | RFU          |        |       |          |   |              |            |             |            |
| 0x20    | RFU          |        |       |          |   |              |            |             |            |
| 0x21    | RXWAIT       |        |       |          |   | I            | RxWait     |             |            |
| 0x22    | REDUNDANCY   |        | CRCWr | CRCB     |   | RxCRCEn      | TxCRCEn    | ParityOdd   | ParityEn   |
| 0x23    | CRCPRESETLSB |        |       |          | ( | CRCPresetLSB |            |             |            |
| 0x24    | CRCPRESETMSB |        |       |          | C | CRCPresetMSB |            |             |            |
| 0x25    | RFU          |        |       |          |   |              |            |             |            |
| 0x26    | TESTOUTSEL   |        |       |          |   |              |            | TestSel     |            |
| 0x27    | RFU          |        |       |          |   |              |            |             |            |
| 0x28    | RFU          |        |       |          |   |              |            |             |            |
| 0x29    | FIFOLEVEL    |        |       |          |   | Wa           | aterLevel  |             |            |
| 0x2A    | TIMERCLK     |        |       | TRestart |   |              | TPreScaler |             |            |
| 0x2B    | TCONTROL     |        |       |          |   | TStopRxEnd   | TStopRxBe  | TStartTxEnd | TStartTxBe |
| 0x2C    | TRELOADVALUE |        |       |          |   | TReloadValue |            |             |            |
| 0x2D    | DTCCTRL      |        |       |          |   | Sel_ca       | al_clk     | DTCTX2En    | DTCTX1En   |
| 0x31    | RFU          |        |       |          |   |              |            |             |            |
| 0x32    | RFU          |        |       |          |   |              |            |             |            |
| 0x33    | RFU          |        |       |          |   |              |            |             |            |
| 0x3A    | RFU          |        |       |          |   |              |            |             |            |

Table 1-3 TRH031M-S Special Function Register Group 2

# Chapter2 TRH031M-S Functionality

# 2.1 Introduction

This chapter will explain RFID communication process and role of TRH031M-S instead of detailed functions of TRH31M.

### 2.2 RFID Reader



Picture 2-1 RFID Reader

Picture 2-1 displays 13.56MHz RFID reader structure using TRH031M-S. As displayed on picture, TRH031M-S is placed between antenna and microprocessor. TRH031M-S, from microprocessor, receives both command and data per each protocol format to tag through antenna. Receiving process works conversely. TRH031M-S converts data from the antenna by digitizing, and microprocessor verifies data received from TRH031M-S. Therefore, microprocessor communicates with RFID tag through TRH031M-S. In other words, TRH031M-S provides wireless communication interface between microprocessor and RFID tag.

# 2.3 Role of TRH031M-S

#### 2.3.1 Modulation / Demodulation



Picture 2-2 Modulation / Demodulation

Key functions of TRH031M-S are modulation and demodulation. Modulation is sending data through carrier (as seen on picture 2-2 from B to A). Demodulation is conversely receiving signal (such as A on picture 2-2) by removing carrier and converting to B. Therefore, modulation occurs in transmit mode (TX) and demodulation occurs in receiving mode (RX).

#### 2.3.2 Encoding / Decoding



Picture 2-3 Encoding / Decoding

Picture 2-3 is an example of ISO 14443A type tag and reader encoding/decoding signal. Encoding/decoding process differs by different protocol used; therefore, detailed information should follow standard specification.

Encoding is creating waveform (Seen as picture 2-3(a) or 2-3(c)) for data transmission and decoding is process of distinguishing waveform (Seen as picture 2-3(a) or picture 2-3(c)) as data 0 or data 1.

First, decoding process is as follows. From analog part, demodulation completed signal is shaped as picture 2-3(a) and picture 2-3(c).

As seen in picture 2-3(a) and picture 2-3(c), carrier is eliminated but subcarrier remains. Thus, eliminate subcarrier. From picture 2-3(a) to picture 2-3(b) transformation process and picture 2-3(c) to picture 2-3(d) transformation process are subcarrier elimination process. Eliminated subcarrier signal (Seen as picture 2-3(b) and picture 2-3(d)) will take shape of Manchester Coding. TRH031M-S digital part in the end finish the data decoding process by distinguishing the signal (Picture 2-3(b)) as data 0 and (Picture 2-3(d)) as data 1. In case of encoding, conversely, transmit data value stored in FIFO will impact the shape as seen on picture 2-3(a) and picture 2-3(c). All these processes will be performed automatically when user selects protocol type.

#### 2.3.3 Framing



Picture 2-4 displays ISO 14443A frame structure. Framing means simply making frame. Frame is data transmission unit in communication and word 'packet' is used very frequently. Frame structure differs based on each protocol, and TRH031M-S performs framing once user selects protocol type. Frame structure is simply divided into SOF (Start Of Frame) and EOF (End of Frame). For ISO14443A, parity is included after 8-bit data for data integrity.

#### 2.3.4 Data integrity

Data integrity signifies data error status during transmission. To check data integrity, ordinary protocols during transmit/receiving mode attaches surplus data for error checking. CRC is one of the major errors checking method. TRH031M-S has hardware check capability for CRC, parity error status check for data integrity during wireless interface. As other features, error checking is performed automatically by setting couple of features and result is sent to microprocessor through register.

#### 2.3.5 Timer and Interrupt



Picture 2-5 Status of Tx/Rx signal

Interrupt and timer instruction is not fixed. User can improve program efficiency by using timer and interrupt. The following is an example of program using interrupt and timer.

Picture 2-5 is end of TX and beginning of RX in RFID communication. Picture 2-5(a) is analog signal waveform from antenna, and picture 2-5(b) is a signal transmitting from digital part to analog part for modulation after encoding. Picture 2-5(c) is a received signal from analog part after demodulation. As seen on picture 2-5, there is a time delay between ending TX and beginning RX. Also TX and RX do not occur normally because it is not possible to receive response when tag is outside of antenna recognition distance. Therefore, software is developed for normal transmission, TRH031M-S will idle waiting for receiving signal when no response from tag. Consequently, timer and interrupt should be used in case failed receiving signal after transmission.

From above example using receiving interrupt and timer interrupt, if completing receiving it activates receiving interrupt. If signal is not received in given time, timer interrupt occurs. For these action to happen, set from IEN(0x06) to use timer interrupt and receive interrupt and set TReloadValue to applicable distance Interval (Picture 2-5). Lastly, set TCONTOL(0x2B) register to TStartTxEnd, thereafter, set the timer to count after signal transmission. From microprocessor normal completion of transmitting and receiving can be determined very simply by type of interrupt generated after completion of transmitting and receiving.

# Chapter3 Host Interface

## **3.1 Introduction**

Host typically means microprocessor. TRH031M-S supports 4 types of parallel interface and SPI serial interface to host.

## 3.2 Parallel Interface

TRH031M-S supports total of 4 types of parallel interface. All 4 interfaces support 8 bit data bus differentiated by read/write execution methods and allotted address methods. User can select any one of 4 interfaces that is more convenient and efficient. Picture 3-1 displays 4 interface types supported by TRH031M-S.



Picture 3-1 Shape of TRH031M-S supported microprocessor interface

There is 2 ways to delivery address. Picture 3-1(a) and picture 3-1(b) display the difference of Multiplexed Addressing and Dedicated Addressing. When using Multiplexed Addressing (Picture 3-1(a)), address is delivered through data bus. When address is read is determined by PALE pin. Dedicated Addressing is used by dividing data bus and address bus. Instead of using PALE pin, address is controlled by WRB and RDB pin.

Picture 3-1(c) and picture 3-1(d) are differences of Common Mode control method and Separated Mode control method. Differences of two methods are how to designate Read and Write using two pins, WRB and RDB In Common mode, WRB value being High implies Read and Low value implies Write. Also in Common Mode, Read/Write point is indicated when RDB falls to Low value in either Read/Write situation. For Separate Mode, Read/Write is allotted in each pin. WRB falling to Low value means Write, and RDB falling to Low value means Read.

#### 3.2.1 Using Dedicated Address

Using Dedicated Address, address line constitutes in 3 bits, thus, not able to designate all TRH031M-S memory map having total 6 bits. Therefore, TRH031M-S utilizes low level 3 bits of PAGE(0x00) register to designate upper level 3 bits of address. MSB of PAGE(0x00) register is set to 1 when using PAGE(0x00) register low level bit for address. PAGE(0x00) register value is to set ADDR pin to all 0 and Write.



Picture 3-2 Dedicated Address Configuration

Picture 3-2 displays Dedicated Address configuration. ADDR implies data entered from TRH031M-S input pin, and Address implies to TRH031M-S last used address.

| Name | Address | Reset |         |       |       | Val   | ue    |       |            |       |
|------|---------|-------|---------|-------|-------|-------|-------|-------|------------|-------|
| DACE |         | 000   | 7-bit   | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit      | 0-bit |
| PAGE | 0x00    | 0x80  | UsePage | 0     | 0     | 0     | 0     |       | PageSelect |       |

| Table | 3-1 | PAGE  | register |
|-------|-----|-------|----------|
| iubic | 5 1 | TITUE | register |

| Number | Name       | Description                                                                            |
|--------|------------|----------------------------------------------------------------------------------------|
| 7      | UsePage    | 0: The PageSelect is not in use for register address setting.                          |
|        |            | 1: The PageSelect is in use for register address setting.                              |
| 2-0    | PageSelect | If UsePage value is 1, upper level of register address 3 bit PageSelect value is used. |

## 3.3 Parallel Interface Hardware Configuration

Parallel interface are divided into 4 different types by address allocation methods and control signal use methods. However, difference in control methods do not impact hardware configuration. Whether user selects Separated mode or Common mode, hardware configuration is the same and control method is determined using software. TRH031M-S control method is based on first executed write command after reset. Basically if Separated mode is used to write after reset then until next reset Separate mode is used continuously.

Hardware configuration for address delivery method is as below. In case of Dedicated Address, PALE pin is not used. In Multiplexed, ADDR pin is not used. Table 3-2 displays each value when not using PALE or ADDR.

| PIN Name | Dedicated Address Bus | Multiplexed Address Bus |
|----------|-----------------------|-------------------------|
| PALE     | HIGH                  | PALE                    |
| ADDR2    | ADDR2                 | LOW                     |
| ADDR1    | ADDR1                 | HIGH                    |
| ADDR0    | ADDR0                 | HIGH                    |

Table 3-2 Allocation of signal based on Addressing methods

#### 3.4 SPI Serial Interface

TRH031M-S also supports SPI serial interface in addition to parallel interface. SPI (Serial Peripheral Interface) can send and receive data through 3 to 4 bus lines. TRH031M-S is ideal for small quantity bus control or control many TRH031M-Ss with one microprocessor. SPI is divided by master and slave. Master gives commands from SPI protocol and slave follows the commands. TRH031M-S functions as slave during communication.

SPI clock (SCK) is created by master, and use MOSI (Master-Out Slave-In) during communication from master to slave and MISO (Master-Out Slave-In) during communication from slave to master. NSS (Negative Slave Select) is similar to Chip Select being used during one master controlling multiple slaves and wanting to select specific slave to set command.



Picture 3-3 SPI Serial interface operation

Picture 3-3 displays 1 byte (8bit) delivery process using SPI interface. To initiate SPI communication, first NSS need to change to Low value. MSB of MISO begins output from negative edge of NSS. Then, MOSI signal transfers from master to slave. Slave reads MOSI signal from positive edge of SCK. Up to this point is the process of 1 bit data transaction. Basically from positive edge of SCK enter 1 bit of data from master to slave, and from negative edge of SCK and negative edge of NSS slave outputs 1 bit of data to master. This process is repeated 8 times to send and receive 8 bits of data and completes 1 byte transaction. To send or receive more than 1 byte of data, maintain NSS to low and send and receive by byte. After all data is sent NSS returns to High value.

#### 3.4.1 SPI Serial Interface Hardware Configuration

SPI interface, unlike parallel interface, is determined during reset process. Therefore, to use SPI modes, before sending reset signal assign inputs as below table 4-2.

| PIN Name    | SPI Interface |
|-------------|---------------|
| PALE        | NSS           |
| ADDR2       | SCK           |
| ADDR1       | LOW           |
| ADDR0       | MOSI          |
| RDB         | HIGH          |
| WRB         | HIGH          |
| CSB         | LOW           |
| DATA7 DATA1 | 1100001       |
| DATA0       | MISO          |

Table 3-3 SPI SPI Interface Configuration

#### 3.4.2 SPI Serial Interface Data Format

Picture 3-4 displays SPI command structure (Example: Master reading 4 registers). When executing Read command, master must send to slave the register address wanted to read. End byte is dummy thus to read 4 registers 5 bytes are entered. Consequently, to read n number of registers, user must enter n+1 number of bytes. Typically dummy uses 8 continuous 0 values. One additional point of caution is that after address input, data output occurs when next byte is entered. As seen in the picture, when addr1 is entered data0 output occur not data1.

In write command there is not output through MISO, but through MOSI, address and data types of signal should be entered. Entry steps are first byte recognizes as address, and before NSS becomes High, previously entered bytes are recognized as data. From the picture, data0 to data3 4bytes are written in address addr0. To execute write to other registers initialize NSS to High then change to Low and re-enter address then write data.



Picture 3-4 SPI Command Structure

In SPI communication determining whether it is Read or Write command depends on first byte of MSB. If first byte of MSB is 0 then it is Write command, and if 1 then it is Read command. If MSB is bit 7 and LSB is bit 0 then Read/Write is determined by MSB then address is located from bit6~bit1. Picture 3-5 is address structure for SPI communication. (a) is first address of Read command. Basically it is addr0 of Read command in Picture 3-4. As explained above MSB value is 1. (b) is address format from addr1 to addr3. MSB and LSB are all RFU. (c) is Write command address that is Write command addr0 in Picture 3-4. As explained above MSB value is 0. RFU is meaningless value and user can set it at his own discretion.



# Chapter4 Command

# **4.1 Introduction**

TRH031M-S actions are initiated by commands. Writing command to address COMMAND(0x01) register, TRH031M-S functions based on current register setting value and FIFO data value.

## **4.2 Command Explanation**

Table 4-1 displays commands available in TRH031M-S.

| Table 4-1 | COMMAND | register |  |
|-----------|---------|----------|--|
|           |         |          |  |

| Name      | Address | Reset |       |       |         | V     | alue  |       |       |       |
|-----------|---------|-------|-------|-------|---------|-------|-------|-------|-------|-------|
| COMMAND   | 0.01    | 0.05  | 7-bit | 6-bit | 5-bit   | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |
| COMINIAND | 0x01    | 0x3F  | 0     | 0     | Command |       |       |       |       |       |

| Number | Name    | Description                                                            |
|--------|---------|------------------------------------------------------------------------|
| 5-0    | Command | Command register for operating the TRH031M-S                           |
|        |         | INIT (3Fh): Initializing system after reset.                           |
|        |         | IDLE (00h): Remains in IDLE mode. (Writing 00 to Command register will |
|        |         | stop actions.)                                                         |
|        |         | TRANSMIT (1Ah): Transmit FIFO data then remains IDLE.                  |
|        |         | RECEIVE (16h): Store received data to FIFO then remains IDLE.          |
|        |         | TRANSCEIVE (1E): Transmit FIFO data then store received data to FIFO.  |
|        |         | Then, IDLE.                                                            |

INIT(3Fh) command is executed automatically when TRH031M-S is initializing system after reset. Therefore, this command does not execute by microprocessor. INIT(3Fh) command automatically stops after set time and becomes IDLE(00h) status.

IDLE(00h) command means idle status. Basically TRH031M-S is not executing any activities. However, this command can activate by microprocessor unlike INIT(3Fh). When IDLE(00h) command is activated by microprocessor, it means discontinuing of any command in action. For

example, when RECEIVE(16h) is being executed, writing IDLE(00h) to command register then TRH031M-S stops receiving and remains idle mode.

TRANSMIT(1Eh) command encodes FIFO stored data and after modulation, then transmits through TX1 and TX2 pins. When there is no data in FIFO, it does not transmit but remains in IDLE(00h) mode. TRANSMIT(1Eh) command sends no response command for test purpose at times.

RECEIVE(16h) command is a command to demodulate/decode response signal from antenna then stores in FIFO. This command also activates by microprocessor and used mainly for test purpose.

TRANCEIVE(1Eh) command executes TRANSMIT(1Ah) and RECEIVE(16h) commands continuously. TRANCEIVE(1Eh) command transmits data in FIFO after encoding/modulation and stores response signal after demodulation/decoding. All these actions are performed continuously, and when no response from tags, it remains in receiving mode thus using IDLE(00h) command to remain in idle status. Activating TRANCEIVE(1Eh) command when there is no data in FIFO, all protocols except ISO/IEC 15693 cannot execute commands, but for ISO/IEC 15693, after transmitting EOF signal then receive.

## 4.3 Transmit/Receive Status Check

Microprocessor checks transmission status by reading TRH031M-S register. Not only execution of transmit/receive status but also error occurrence and other status checks are possible. Microprocessor occasionally checks information on TRH031M-S transmit/receive status and determines next course of action.

#### Table 4-2 STATUS1 register

| Name         | Address | Reset |            |       |       |       | Value   |         |       |       |
|--------------|---------|-------|------------|-------|-------|-------|---------|---------|-------|-------|
| STATUS1 0x03 | 0,02    | 0.01  | 7-bit      | 6-bit | 5-bit | 4-bit | 3-bit   | 2-bit   | 1-bit | 0-bit |
|              | 0x01    | 0     | ModemState |       | IRQ   | ERR   | HiAlert | LoAlert |       |       |

| Number | Name       | Description                                                                 |
|--------|------------|-----------------------------------------------------------------------------|
| 6-4    | ModemState | 000: Idle - ready status.                                                   |
|        |            | 001: TxSOF - transmitting the SOF(Start of flame).                          |
|        |            | 010: TxData - transmitting data of FIFO buffer.                             |
|        |            | 011: TxEOF - transmitting the EOF(End of flame).                            |
|        |            | 100: GoToRx - starting receive.                                             |
|        |            | 101: PrepareRx - waiting till selected period in the RXWAIT register is     |
|        |            | expired.                                                                    |
|        |            | 110: AwaitingRx - waiting for the receiving signal.                         |
|        |            | 111: Receiving - receiving the signal.                                      |
| 3      | IRQ        | Displays interrupt occurrence. Set interrupt use by utilizing IEN register. |
| 2      | ERR        | Showing an error state. When ERRFLAG register value is 0 then ERR value is  |
|        |            | 0.                                                                          |
| 1      | HiAlert    | When FIFO stored data size is above certain level then value become 1.      |
| 0      | LoAlert    | When FIFO stored data size is below certain level then value become 1.      |

STAUS1 register is a register confirming overall transmit/receive status. Also current executed transmit/receive process can be verified by ModemState of STATUS1 register. One transmit Frame is configured by SOF(Start of Frame), data and EOF(End of Flame) following ISO standard. Through ModemState flag of STATUS1 register, can verify which step of Frame is being transmitted by transmitter. Table 4-2 explains definition of *ModemState* value.

IRQ flag of STATUS1 (0x03) register obtain High value when interrupt occurs by IEN (0x06) register setting. When interrupt request completes, it automatically changes to Low value. IRQ flag of STATUS1 (0x03) register perform Active High irrelevant of IRQInv value of CONTROL (0x09) register.

ERR flag of STATUS1 (0x03) register becomes High value when any error occurs from ERRFLAG (0x0A) register. This flag as well as IRQ flag automatically clears when ERRFLAG (0x0A) register flags are cleared.

HiAlert and LoAlert flag are registers to check data size in FIFO. For detailed explanations please referred "6.3.3 FIFO buffer related functions".

| Name         | Address | Reset    | Value      |       |          |         |            |       |       |       |
|--------------|---------|----------|------------|-------|----------|---------|------------|-------|-------|-------|
| STATUS2 0x05 |         | 0.00     | 7-bit      | 6-bit | 5-bit    | 4-bit   | 3-bit      | 2-bit | 1-bit | 0-bit |
|              | 0x00    | TRunning | LockStatus |       | TerrFlag | TadFlag | RxLastBits |       |       |       |

Table 4-3 STATUS2 register

| Number | Name       | Description                                                                   |
|--------|------------|-------------------------------------------------------------------------------|
| 7      | TRunning   | When timer is running value is 1. When stopped value is 0.                    |
| 6-5    | LockStatus | During operating Tag-It protocol, LockStatus of Memory Block save in GetBlock |
|        |            | Response.                                                                     |
| 4      | TerrFlag   | During operating Tag-It protocol, Saving ErrorFlag from tag response.         |
| 3      | TadFlag    | During operating Tag-It protocol, Saving Address Flag from tag response.      |
| 2-0    | RxLastBits | When using ISO 14443A protocol, store valid bit quantity when Collision       |
|        |            | occurs.                                                                       |

STATUS2(0x05) register (same as STATUS1(0x03)) is a register to confirm activating status. STATUS2 register displays timer status. TRunning flag of STATUS2 register maintains High value even during timer counting.

RxLastBitflag of STATUS2 register indicates number of valid bits location of last byte received. For example, if conflict occurs in 6th bit after RECEIVE command, RxLastBits become 5 and valid bits become 5 bits. Every bits of last received byte are received normally, RxLastBits becomes 0. Please refer to "5.4 Anti-Collision".

LockStatus, TerrFlag, and TadFlag are flags to support TI (Texas Instruments) Tag-It protocol. In case of Tag-It protocol, tag response cannot be divided 8 bits evenly. Therefore, TRH031M-S from tag response stores LockStatus, TerrFlag, and TadFlag data not store by FIFO. LockStatus is Lock Status per specification and TerrFlag is Error Flag. Lastly, TadFlag is Address Flag.

#### 4.4 Control

CONTROL (0x09) register is a register to execute various functions. *PowerDown* of CONTROL (0x09) register leads TRH031M-S to Stand-by mode using software. During power down mode, TRH031M-S cannot execute transmit/receiving but power consumption is minimized. (For detailed explanations, please refer to 9.3.2)

*TStopNow* and *TStartNow* flag are used to execute timer. When writing 1 to *TStartNow* flag, timer begins counting, and when writing 1 to *TStopNow* flag, timer counting stops. (For detailed explanations, please refer to 10.3)

*FlushFIFO* function is to delete data remaining in FIFO buffer. When tag is not responding, noise can be a cause. Sometimes noise can be recognized as data and stored in FIFO. When transmit/receiving without deleting FIFO data, incorrect data caused by noise can be transmitted. Therefore, before storing transmitted data to FIFO, use *FlushFIFO* to delete all FIFO data and store data to be transmitted.

In *PowerDown*, when set as value 1, the value stays the same. However, *FlushFIFO*, *TStopNow* and *TStartNow* commands clear to 0 automatically.

| Name         | Address | Reset |            |       |       |           | Value |          |           |           |
|--------------|---------|-------|------------|-------|-------|-----------|-------|----------|-----------|-----------|
| CONTROL 0x09 | 000     | 0x00  | 7-bit      | 6-bit | 5-bit | 4-bit     | 3-bit | 2-bit    | 1-bit     | 0-bit     |
|              | 0x09    |       | Inqpin_inv | 0     | 0     | PowerDown | 0     | TStopNow | TStartNow | FlushFIFO |

| Table 4-4 | CONTROL | register |
|-----------|---------|----------|
|           |         |          |

| Number | Name       | Description                                                                     |
|--------|------------|---------------------------------------------------------------------------------|
| 7      | Irqpin_inv | Set Polarity of IRQ pin.                                                        |
|        |            | 0: Active High (1 when interrupt occurs)                                        |
|        |            | 1: Active Low (0 when interrupt occurs)                                         |
| 4      | PowerDown  | Setting value to 1, internal power consumption is minimized and remains         |
|        |            | waiting mode.                                                                   |
| 2      | TStopNow   | Setting this value to 1 will initiate timer count. This value automatically     |
|        |            | changes to 0.                                                                   |
| 1      | TStartNow  | Setting this value to 1 will stop timer. This value automatically changes to 0. |
| 0      | FlushFIFO  | Delete all FIFO stored data. This value automatically changes to 0.             |

## 4.5 Error Check

ERRFLAG (0x0A) register is a register to check error during transmit/receiving. If FIFO buffer data is full than *FIFOOvfl* flag changes to value 1. When *FIFOOvfl* occurs, using *FlushFIFO* eliminates FIFO buffer data and *FIFOOvfl* error clears automatically. *CRCErr* displays CRC error during transmission, and *ParityErr* displays parity error for ISO14443 type A. These two value update automatically when Transceive command restart. *CollErr* flag sets when Collision error occurs. *CollErr* also as *ParityErr* and *CRCErr* automatically updates when command start. (For detailed information on Collision, please refer to "5.4 Anti-Collision", and detailed information on *ParityErr* and *CRCErr*, please refer to "7.2 signal integrity").

| Table 4-5 ERRFLAG | register |
|-------------------|----------|
|-------------------|----------|

| Name         | Address | Reset | Value |       |       |          |        |       |           |         |
|--------------|---------|-------|-------|-------|-------|----------|--------|-------|-----------|---------|
|              |         | 0,00  | 7-bit | 6-bit | 5-bit | 4-bit    | 3-bit  | 2-bit | 1-bit     | 0-bit   |
| ERRFLAG 0x0A | UXUA    | 0x00  | 0     | 0     | 0     | FIFOOvfl | CRCErr | 0     | ParityErr | CollErr |

| Number                                                 | r Name Description |                                                 |  |  |  |
|--------------------------------------------------------|--------------------|-------------------------------------------------|--|--|--|
| 4 FIFOOvfl When FIFO data is overflow then value is 1. |                    | When FIFO data is overflow then value is 1.     |  |  |  |
| 3 CRCErr When CRC Check error occurs then value is 1.  |                    | When CRC Check error occurs then value is 1.    |  |  |  |
| 1                                                      | ParityErr          | When Parity Check error occurs then value is 1. |  |  |  |
| 0                                                      | CollErr            | When Collision occurs then value is 1.          |  |  |  |

www.3ALogics.com | Confidential 31

# Chapter5 Protocol

# **5.1 Introduction**

This chapter explains protocols (ISO/IEC 14443 A/B, ISO15693, Tag-It) and use methods supported by TRH031M-S. Changing protocols are done by changing registers related to protocols.

## 5.2 Transmit Data Format Select

To choose a protocol, user must select Transmit data format. Format implies Encoding method and Framing method and do not include Analog Modulation. TRH031M-S supports total 4 types of protocol and for ISO15693, 2 Encoding methods are available. Therefore, user can select up to 5 formats.

| Name       | Address | Reset | Value |       |       |       |         |          |       |       |
|------------|---------|-------|-------|-------|-------|-------|---------|----------|-------|-------|
| CODCONTROL | 0x14    | 0x01  | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit   | 2-bit    | 1-bit | 0-bit |
|            |         |       | 0     | 0     | 0     | 0     | TI_Addr | TxCoding |       |       |

| lable | 2-T | CODC | ONTROL | register |
|-------|-----|------|--------|----------|
|       |     |      |        | -        |

| Number | Name     | Description                                                        |
|--------|----------|--------------------------------------------------------------------|
| 3      | TI_Addr  | Used to select Address mode type during Tag-It protocol Request    |
|        |          | command.                                                           |
| 2-0    | TxCoding | Set TX Encoding method.                                            |
|        |          | 000: Set coder to ISO 14443 B type mode.                           |
|        |          | 001: Set coder to ISO 14443 A Type mode.                           |
|        |          | 010: Set coder to Tag-It Protocol mode.                            |
|        |          | 110: Set coder to ISO 15693 standard mode ( 1 out of 256 coding ). |
|        |          | 111: Set coder to ISO 15693 standard mode ( 1 out of 4 coding).    |

TxCoding flag of CODCONT (0x14) register is a flag to select Transmit data format. Below table is transmitting data format based on TxCoding value. TI\_Addr flag is used to store Address Flag value to be transmitted from Tag-It protocol.

| TxCoding | Standard                        | Format                    |
|----------|---------------------------------|---------------------------|
| 000      | ISO 14443B                      | NRZ                       |
| 001      | ISO 14443A                      | Modified Miller           |
| 010      | Tag-It                          | Pulse Width Modulation    |
| 110      | ISO 15693 (1 out of 256 coding) | Pulse Position Modulation |
| 111      | ISO 15693 (1out of 4 coding)    | Pulse Position Modulation |

Table 5-2 Transmit data format by TxCoding value



www.3ALogics.com | Confidential

33

Picture 5-1 displays Encoding method by protocol. ISO 14443A type (Picture 5-1(a)) encode by Modified Miller form and two data formats to display 0. ISO 14443B type (Picture 5-1(b)) is the most standard encoding method, NRZ coding. ISO 15693 two forms of PPM (Pulse Position Modulation) method to indicate data. Picture 5-1(c) and picture 5-1(d) display two Encoding method for ISO 15693. PPM format is a method of data value to tabularize as pulse location. Reader can select either one of these two formats, and tag responds by both data format. Tag-It protocol use PWM (Pulse Width Modulation) method. PWM method distinguishes data by pulse length.

### 5.3 Receiver Data Format Select

Receiver data format is determined by registers same as Transmit data. *RxFraming* flag of DECODCONTROL(0x1A) register performs this activity. Table 5-3 displays Receiver data format by *RxFraming* value.

| Name         | Address | Reset | Value |       |          |           |       |       |       |       |
|--------------|---------|-------|-------|-------|----------|-----------|-------|-------|-------|-------|
|              | 0.14    | 0,00  | 7-bit | 6-bit | 5-bit    | 4-bit     | 3-bit | 2-bit | 1-bit | 0-bit |
| DECODCONTROL | 0x1A    | 0x08  | 0     | 0     | ZrAfColl | RxFraming |       | g     | 0     | 0     |

| Table | 5-3 | DECODCONTROL | register |
|-------|-----|--------------|----------|
|-------|-----|--------------|----------|

| Number | Name      | Description                                |  |  |  |  |  |
|--------|-----------|--------------------------------------------|--|--|--|--|--|
| 5      | ZrAfColl  | Store received data after Collision as 0.  |  |  |  |  |  |
| 4-2    | RxFraming | 000: Set decoder to Tag-It Protocol mode.  |  |  |  |  |  |
|        |           | 01x: Set decoder to ISO 14443 A Type mode. |  |  |  |  |  |
|        |           | 10x: Set decoder to ISO 15693 mode.        |  |  |  |  |  |
|        |           | 11x: Set decoder to ISO 14443 B Type mode. |  |  |  |  |  |

Picture 5-2 displays Receiver data format by protocol. All protocols use sub-carrier, and they use Manchester coding method except ISO 14443B type. ISO 14443A type and ISO 14443B type use 847 KHz subcarrier, and ISO 14443B type use BPSK modulation. BPSK modulation is a method changing phase 180° when data is changed. ISO 15693 use same format with ISO 14443A type, and subcarrier speed is half of ISO 14443A, 423 KHz. For Tag-it, change subcarrier speed to tabularize data. For data 1, subcarrier changes from 484 KHz to 423 KHz, and for data 0, changes from 423 KHz to 484 KHz conversely.

*ZrAfColl* flag of DECODCONTROL(0x1A) register used only by ISO 14443A type. When *ZrAfColl* flag is set to 1, after Collision error received data is saved in FIFO as 0. This function simplifies use of ISO14443A Anti-Collision.





#### 5.3.1 Receive Delay Time

RXWAIT(0x21) register is a register to set the delay time between begin receiving after Transmit ends. Using RXWAIT(0x21) can block noise after Transmit. However, if delay time is set too long than may not able to receive response from tag thus set the proper value through testing. Delay time is a value *RxWait* multiplied by 128/fc.

Table 5-4 RXWAIT register

| Name   | Address   | Reset | Value |       |        |       |       |       |       |       |
|--------|-----------|-------|-------|-------|--------|-------|-------|-------|-------|-------|
| RXWAIT | 0x21 0x00 | 0.00  | 7-bit | 6-bit | 5-bit  | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |
|        |           | 0x06  |       |       | RxWait |       |       |       |       |       |

| Number | Name   | Description                                                    |
|--------|--------|----------------------------------------------------------------|
| 5-0    | RxWait | Setting the interval time after transmission before receiving. |

#### 5.3.2 Bit Level Receiving

Collision occurrence from tag during data receiving or if less than 1 byte data is received, to display the number of normal received bits from last received bytes, *RxLastBits* of STATUS2 register is used. *RxLastBits* are in 3 bits, and value are 0 when all bytes are Received normally.

Confidential | www.3ALogics.com

36

### 5.4 Anti-Collision

If multiple tags are in RF field, all tags respond at same time, and tag signals are mixed in RF field making it difficult to distinguish data. Therefore, reader must read tags in RF field sequentially. In order to avoid tag collision, anti-collision algorithm is used. For ISO 14443B and ISO 15693 tag collision detection is required for anti-collision to function. However, ISO 14443A requires hardware detection of collision location and collision occurrence to activate anti-collision function. TRH031M-S has ability to detect collision and its location when collision occurs.



Picture 5-3 Collision Detection

#### 5.4.1 Collision Detection

Picture 5-3 displays how TRH031M-S detects collision. Tag A and tag B have different value from 4<sup>th</sup> bit. When tag A and tag B have different value (as seen on picture 5-3), receiver cannot determine whether Received data is 0 or 1. When TRH031M-S receives a signal undetermined whether 0 or 1 (Seen as picture 6-3), location is stored at *CollPos* flag of COLLPOS(0x0B) register and set to 1 on *CollErr* flag of ERRFLAG(0x0A) register thus microprocessor can accomplish anticollision functions. Parity bit is excluded from *CollPos* calculation.

| Table 5-5 | COLLPOS | register |
|-----------|---------|----------|
|-----------|---------|----------|

| Name    | Address | Reset |       |       |       | Va    | lue   |       |       |       |
|---------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| COLLBOS | 0v0P    | 0,00  | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |
| COLLPOS | 0x0B    | 0x00  |       |       |       | Col   | IPos  |       |       |       |

| Number | Name    | Description                                         |
|--------|---------|-----------------------------------------------------|
| 7-0    | CollPos | Indicate a position where first collision occurred. |

When collision is detected *ZrAfColl* is set and all data after first collision are stored in FIFO as 0. This type of data processing is very convenient to develop software to handle anti-collision meeting ISO standard.



Picture 5-4 Register value during collision occurrence

Above picture 5-4 displays an example of two tags collision. Picture 5-4(a) is UID of two tags. First byte has same value of 74 but from second byte each value of 5B and 07 are given. Picture 5-4 (b) is tabularized UID in binary numbers. Picture 5-4(c) displays actual receiving steps. For ISO 14443A, LSB is received first and steps as picture 5-4(c) occurs. When TRH031M-S terminates receiving, collision occurs in 11<sup>th</sup> Receiver bit, therefore, *CollPos*flag value becomes B and *RxLastBits* value becomes 0.

If *ZrAfColl* is set as 1, 2<sup>nd</sup> byte is stored to FIFO as 03h and lower level 3 bytes are stored as 00h. If *ZrAfColl* is set to 0, data value after Collision becomes unpredictable value different from original UID.

## 5.5 Bit Level data Transmit/Receive

#### Table 5-6 BITFRAME register

| Name     | Address | Reset |       |       |         | ١     | Value     |       |           |       |
|----------|---------|-------|-------|-------|---------|-------|-----------|-------|-----------|-------|
|          | 0x0F    | 0,00  | 7-bit | 6-bit | 5-bit   | 4-bit | 3-bit     | 2-bit | 1-bit     | 0-bit |
| BITFRAME | UXUF    | 0x00  |       |       | RxAlign |       | TMaskFlag |       | TxLastBit | S     |

| Number | Name       | Description                                                          |
|--------|------------|----------------------------------------------------------------------|
| 6-0    | RxAlign    | Align bit for received data.                                         |
| 3      | TMaskFlag  | Used for Tag-It protocol. From SID Request command it is used when   |
|        |            | using Mask Bit and Mask Length value is stored in TxLastBits, then,  |
|        |            | selected Mask value from data stored in FIFO and transmitted to Tag- |
|        |            | It tag.                                                              |
| 2-0    | TxLastBits | Use when transmitting less than a byte.                              |
|        |            | TxLastBits is a bit value for data to be transmitted.                |

TRH031M-S can Transmit/Receive data by bit level. For bit level Transmit, *TxLastBits* flag of BITFRAME(0x0F) register is used and for bit level receiving *RxAlign* flag is used.





Above picture 5-5 displays bit level Transmit. If FIFO stored data is same as picture 5-5(a), data is tabularized in binary numbers as seen in picture 5-5(b). If TxLastBits is set to 3 and Transmit command carries out, then first byte 74 is all transmitted and second data 03 is transmitted up to 3 bits.



Picture 5-6 Bit Level Receive

Picture 5-6 displays bit level Receiver steps. When Receiver data (On picture 5-6(a)) RxAlign value is set to 3, data is stored in FIFO as picture 5-6 (b) beginning 4<sup>th</sup> bit. Picture 5-6(c) displays hexadecimal data stored in FIFO.

## 5.6 Protocol

This section describes each protocol and related register functions.

#### 5.6.1 ISO/IEC 14443A Protocol

#### Setting Decoding Method

Decoding function improvement setting is possible with ISO 14443A type. 3ALogics highly recommends this function since there are many advantages with virtually no disadvantage. To use this function, *ADcdMd* flag of RXCONTROL2(0x1E) register must be set to 1.

| Name       | Address | Reset | Value  |       |       |       |       |       |        |       |
|------------|---------|-------|--------|-------|-------|-------|-------|-------|--------|-------|
|            | 0.15    | 001   | 7-bit  | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit  | 0-bit |
| RXCONTROL2 | 0x1E    | 0x01  | ADcdMd | 0     | 0     | 0     | 0     | 0     | Dcdsrc | 1     |

| Table 5-7 | RXCONTROL2 | register |
|-----------|------------|----------|
|-----------|------------|----------|

| Number | Name   | Description                                           |
|--------|--------|-------------------------------------------------------|
| 7      | ADcdMd | Set ISO 14443A decoding method.                       |
| 1      | Dcdsrc | Use to define input signal of receiver decoder logic. |
|        |        | 0: Use response signal from card as input.            |
|        |        | 1: Use signal through TESTIN pin as input.            |
|        |        |                                                       |

*Dcdsrc* flag of RXCONTROL2(0x1E) register is a flag to determine which signal to decode. When *Dcdscr* is 0, signal from receiver is decoded and when it is 1, signal from TESTIN pin is decoded. Signal received from TESTIN pin is decoding function testing purpose and typically is set to 0 when used for transmit/receive purpose.

#### Modulation Width Changes

ISO 14443A type protocol communication from reader to tag utilize 100% ASK Modulation Modified Miller coding method. Modified Miller tabularize data value by pulse location, and TRH031M-S allows functionality to adjust pulse width. *ModWidth* flag of MODWIDTH(0x15)register is used for 14443A type pulse width adjustment in transmit signal. *ModWidth* unit is 128/fc.

#### Table 5-8 MODWIDTH register

| Name     | Address | Reset | Value |       |       |       |       |       |       |       |
|----------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| MODWIDTH | 0.15    | 0x10  | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |
| MODWIDTH | 0x15    | 0110  | 0     | 0     |       |       | Mod   | Width |       |       |

| Number | Name     | Description                                                                                                                           |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------|
| 5-0    | ModWidth | Set 100% modulation width for ISO14443A.                                                                                              |
|        |          | $T_{mod} = 2(ModWidth_Dec+1) \times (1/f_c)$<br>EX) 1/fc = 1/13.56MHz = 73.7nsec<br>ModWidth_Hex = 10 $\rightarrow$ ModWidth_Dec = 16 |
|        |          | **MODWIDTH(0x15) = 0x10 ,                                                                                                             |
|        |          | Tmod = 2(16+1) X 73.7n = 2.5usec                                                                                                      |



Picture 5-7 Modulation Width

#### 5.6.2 ISO/IEC 14443B Protocol

#### ISO/IEC 14443B Type Frame Setting

TRH031M-S contains functionality for frame adjustment using 14443B type protocol. Using ISO 1444B type, from frame SOF, EOF and EGT length are predetermined. Through BFRAMING (0x17) register user can adjust values within specification.

| Name     | Address | Reset |       |       |          | Valu  | е         |       |       |       |
|----------|---------|-------|-------|-------|----------|-------|-----------|-------|-------|-------|
|          | 0.17    | 000   | 7-bit | 6-bit | 5-bit    | 4-bit | 3-bit     | 2-bit | 1-bit | 0-bit |
| BFRAMING | 0x17    | 0x00  | 0     | 0     | EOFWidth | С     | harSpacir | ng    | SOFV  | Vidth |
|          |         |       |       |       |          |       |           |       |       |       |

| Table | 5-9 | BFRAMING | register |
|-------|-----|----------|----------|
|-------|-----|----------|----------|

| Number | Name        | Description                                         |
|--------|-------------|-----------------------------------------------------|
| 5      | EOFWidth    | 0: Set the EOF to length of 10 ETU.                 |
|        |             | 1: Set the EOF to length of 11 ETU.                 |
| 4-2    | CharSpacing | Set EGT width. Set in 128 / fc multiples.           |
| 1-0    | SOFWidth    | 00: Set the SOF to length of 10 ETU Low 2 ETU High. |
|        |             | 01: Set the SOF to length of 10 ETU Low 3 ETU High. |
|        |             | 10: Set the SOF to length of 11 ETU Low 2 ETU High. |
|        |             | 11: Set the SOF to length of 11 ETU Low 3 ETU High. |

www.3ALogics.com | Confidential 43

(a) Frame format



Picture 5-8 SOF and EOF length

Character Format

Picture 5-8 displays SOF and EOF used in ISO 14443B type. Picture 5-8(a) is frame architecture of ISO 14443B type. Frame begins with SOF and ends with EOF, and characters are located in between. Picture 5-8(b) displays form of SOF. SOF is a signal with low section length is 10~11etu and high section length is 2~3etu. This value can be adjusted through *SOFWidth* flag. Picture 5-8(c) displays EOF signal. EOF length is10~11etu and can be adjusted using *EOFWidth* flag.





Picture 5-9 explains EGT(extra guard time). Same as picture 5-8, character comprise of start bit and stop bit with total of 8 binary data. Delay time between two characters is called EGT. From specification EGT value is 0~57us when transmitting and 0~19us when receiving. User can adjust EGT length by 128/fc using *CharSpacing* flag of BFRAMING(0x17) register.

# Chapter6 FIFO Buffer

## 6.1 Introduction

TRH031M-S has 128-Byte FIFO buffer. This FIFO buffer stores data temporarily while data transfer between microprocessor and TRH031M-S. When microprocessor sends receive command, data is written to FIFO buffer, and if transmit command is sent then received data is stored in FIFO. FIFO related functions, same as other TRH031M-S functions, are executed through register.

## 6.2 FIFO Buffer Data Input/Output

FIFO buffer input/output is accomplished using FIFODATA(0x02) register. Microprocessor write to FIFODATA(0x02) register the data to be transmitted and read data received through FIFODATA(0x02) register. FIFODATA(0x02) register outputs first data stored in FIFO. Again, FIFODATA(0x02) register read data sequentially based on first in first out basis.

| Name     | Address | Reset | Value |       |       |       |       |       |       |       |  |
|----------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--|
| FIFODATA | 0x02    | 0xXX  | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |  |
|          |         |       |       |       |       | FIFO  | Data  |       |       |       |  |
|          |         |       |       |       |       |       |       |       |       |       |  |

| Tal | ole | 6-1 | FIF | ODA | ΓA | registe | er |
|-----|-----|-----|-----|-----|----|---------|----|
|     |     |     |     |     |    |         |    |

| Number | Name     | Description                       |
|--------|----------|-----------------------------------|
| 7-0    | FIFOData | FIFO buffer input/output register |

*FIFOLength* flag of FIFOLENGTH(0x04) register is a register expressing FIFO buffer stored data in byte level. *FIFOLength* flag comprises of 7 bits to express up to 128 bytes.

#### Table 6-2 FIFOLENGTH register

| Name            | Address | Reset |            | Value |       |       |       |       |       |       |  |  |
|-----------------|---------|-------|------------|-------|-------|-------|-------|-------|-------|-------|--|--|
| FIFOLENGTH 0x04 | 0.04    | 0.00  | 7-bit      | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |  |  |
|                 | 0x00    | 0     | FIFOLength |       |       |       |       |       |       |       |  |  |

| Number | Name       | Description                                         |
|--------|------------|-----------------------------------------------------|
| 6-0    | FIFOLength | Show the number of bytes stored in the FIFO buffer. |

## **6.3 FIFO Buffer Related Functions**

#### 6.3.1 FIFO Buffer Data Deletion

FIFO buffer data can be deleted by *FlushFIFO* flag of CONTROL(0x09) register. Finally FIFOLENGTH(0x04) becomes 0 and FIFO can store up to 128 bytes. *FlushFIFO* command allows inaccurate data deletion due to noise before transmit/receive function.

#### 6.3.2 FIFO Buffer Error

When data is full in FIFO buffer, error occurs and sets *FIFOOvfl* of ERRFLAG(0x0A)register to 1. *FIFOOvfl* error can be cleared using *FlushFIFO* command.

#### 6.3.3 FIFO Buffer caused Interrupt

There can be interrupts due to TRH031M-S FIFO buffer stored data quantity, and these interrupts occurs by *WaterLevel* flag of FIFOLEVEL(0x29) register value.

| Table 6-3 FIFOLEVEL | register |
|---------------------|----------|
|---------------------|----------|

| Name      | Address | Reset   |                                                                                                               |           |           | Va                        | lue           |         |       |        |  |  |
|-----------|---------|---------|---------------------------------------------------------------------------------------------------------------|-----------|-----------|---------------------------|---------------|---------|-------|--------|--|--|
| FIFOLEVEL | 0x29    | 0x08    | 7-bit                                                                                                         | 6-bit     | 5-bit     | 4-bit                     | 3-bit         | 2-bit   | 1-bit | 0-bit  |  |  |
|           | 0725    | 0,00    | 0                                                                                                             | 0         | rLevel    |                           |               |         |       |        |  |  |
| Ni        | Niews   |         |                                                                                                               |           |           | Deer                      |               |         | 4     |        |  |  |
| Number    | Nam     |         | C L LIA                                                                                                       |           |           |                           | ription       |         | _     |        |  |  |
| 5-0       | WaterL  | evel    | Set HiAlert and LoAlert alert level.<br>HiAlert occurs when FIFO available space is below WaterLevel. LoAlert |           |           |                           |               |         |       |        |  |  |
|           |         |         |                                                                                                               | vhen FIFO |           |                           |               |         |       | OAlert |  |  |
|           |         |         | occurs v                                                                                                      |           | stored ud | ata quanti                | ty is belo    |         | evel. |        |  |  |
|           | Water   | Level = | 4<br>Byte                                                                                                     | 1         |           |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          |           | -         |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          |           | -         | LoAlert Interrupt Request |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          |           |           |                           | LoAlert Thr   | eshold  |       |        |  |  |
|           |         |         | Byte                                                                                                          |           | -         |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          | ~         |           |                           |               |         |       |        |  |  |
|           |         |         |                                                                                                               |           |           | No Interrupt Request      |               |         |       |        |  |  |
|           |         |         |                                                                                                               |           |           |                           |               |         |       |        |  |  |
|           |         |         | -                                                                                                             |           |           |                           |               |         |       |        |  |  |
|           |         |         |                                                                                                               |           | 7         |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          |           | _         |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          |           | _         |                           | HiAlert Thr   | ashold  |       |        |  |  |
|           |         |         | Byte                                                                                                          |           |           |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          |           | -         | HiAle                     | ert Interrupt | Request |       |        |  |  |
|           |         |         | Dyie                                                                                                          |           | _         |                           |               |         |       |        |  |  |
|           |         |         | Byte                                                                                                          | 64        |           |                           |               |         |       |        |  |  |

Picture 6-1 displays FIFO buffer stored data quantity and interrupt occurrence due to *WaterLevel* value. Total of 128 bytes can be stored in FIFO. *LoAlert* interrupt occurs when FIFO data is less than *WaterLevel* specified value and *HiAlert* interrupt occurs when less space is

available in FIFO then WaterLevel specified value. Other occasions, interrupt do not occur.

# Chapter7 Signal Integrity

## 7.1 Introduction

Wireless communication has number of insecure elements. Electromagnetic waves from other peripherals, natural environment changes and other elements impact communication error. Therefore, all protocols contain methods to detect error, and TRH031M-S provides error correction methods by hardware.

## 7.2 Signal Integrity Setting Method

| Protocol Type | Redundancy Check Method             | CRCB Flag | ParityOdd Flag | ParityEn Flag |
|---------------|-------------------------------------|-----------|----------------|---------------|
| ISO 14443A    | 16-bit CRC (ISO 14443A), Odd Parity | 0         | 1              | 1             |
| ISO 14443B    | 16-bit CRC (ISO/IEC3309)            | 1         | 0              | 0             |
| ISO 15693     | 16-bit CRC (ISO/IEC3309)            | 1         | 0              | 0             |
| Tag-It        | 16-bit CRC (ISO/IEC3309)            | 1         | 0              | 0             |

Table 7-1 Signal integrity check method by Protocol and its register setting method

Table 7-1 tabularizes signal integrity checking method by protocol and its register setting methods. *CRCB* flag of register REDUNDANCY(0x22) is a flag to activate CRC method. *ParityEn* is a flag to determine parity check use. *ParityOdd* flag determines to use Odd parity or Even Parity. As seen on above table, all protocols except ISO 14443A type do not use parity error check method and also CRC type use different format for ISO 14443A type.

| Name       | Address | Reset |       |       |       |           | Value   |         |           |          |
|------------|---------|-------|-------|-------|-------|-----------|---------|---------|-----------|----------|
| REDUNDANCY | 0x22    | 0x03  | 7-bit | 6-bit | 5-bit | 4-<br>bit | 3-bit   | 2-bit   | 1-bit     | 0-bit    |
|            |         |       | 0     | CRCWr | CRCB  | 0         | RxCRCEn | TxCRCEn | ParityOdd | ParityEn |

Table 7-2 REDUNDANCY register

| Number | Name      | Description                                                                                          |
|--------|-----------|------------------------------------------------------------------------------------------------------|
| 6      | CRCWr     | Store received CRC value on FIFO.                                                                    |
| 5      | CRCB      | Setting CRC calculation type.<br>0: ISO 14443A Type<br>1: ISO/IEC3309 (ISO14443B Type and ISO 15693) |
| 3      | RxCRCEn   | Processing CRC calculation for received data.                                                        |
| 2      | TxCRCEn   | Adding CRC calculation for transmission data.                                                        |
| 1      | ParityOdd | Setting Parity calculation. 14443 A-type only.<br>0: Even Parity<br>1: Odd Parity                    |
| 0      | ParityEn  | Setting parity error detecting code. 14443 A-type only.                                              |

*CRCWr* flag of REDUNDANCY(0x22) register writes received CRC value to FIFO buffer. When *CRCWr* is set to 1, microprocessor reads CRC value from FIFO and calculates CRC value in software level to confirm signal integrity.

*RxCRCEn* and *TxCRCEn* are flags to determine to use CRC during Transmit/Receive. When *TxCRCEn* is set to 1, CRC is sent with transmit data, and when *RxCRCEn* is set to 1 then data is received and calculates CRC for signal integrity. ISO 14443A may not use CRC based on command type, thus, user should confirm CRC use and may need to set *RxCRCEn* and *TxCRCEn*.

#### Table 7-3 CRCPRESETLSB register

| Name         | Address | Reset | Value |       |       |        |         |       |       |       |
|--------------|---------|-------|-------|-------|-------|--------|---------|-------|-------|-------|
| CRCPRESETLSB | 0       | 0.62  | 7-bit | 6-bit | 5-bit | 4-bit  | 3-bit   | 2-bit | 1-bit | 0-bit |
|              | 0x23    | 0x63  |       |       |       | CRCPre | esetLSB |       |       |       |

| Number | Name         | Description                      |
|--------|--------------|----------------------------------|
| 7-0    | CRCPresetLSB | Store CRC preset value LSB 8bit. |

#### Table 7-4 CRCPRESETMSB register

| Name         | Address | Reset |              |       |       | Va    | lue   |       |       |       |
|--------------|---------|-------|--------------|-------|-------|-------|-------|-------|-------|-------|
| CDCDDFCFTMCD | 024     | 0(2)  | 7-bit        | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |
| CRCPRESETMSB | 0x24    | 0x63  | CRCPresetMSB |       |       |       |       |       |       |       |

| Number | Name         | Description                      |  |
|--------|--------------|----------------------------------|--|
| 7-0    | CRCPresetMSB | Store CRC preset value MSB 8bit. |  |

CRCPRESETLSB(0x23) and CRCPRESETMSB(0x24) register are registers determining initial value of CRC calculation. CRC preset value are 8 bits each through 2 registers since 16-bit CRC is used. This register can change by microprocessor. Therefore, user can set CRC operation initial value.

#### Table 7-5 CRCRESULTLSB register

| Name         | Address | Reset |       |       |       | Va    | ue      |       |       |       |
|--------------|---------|-------|-------|-------|-------|-------|---------|-------|-------|-------|
|              | 0.05    | 0.104 | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit   | 2-bit | 1-bit | 0-bit |
| CRCRESULTLSB | 0x0D    | 0xXX  |       |       |       | CRCRe | sultLSB |       |       |       |

| Number | Name         | Description                            |
|--------|--------------|----------------------------------------|
| 7-0    | CRCResultLSB | Store CRC calculation result LSB 8bit. |

#### Table 7-6 CRCRESULTMSB register

| Name         | Address | Reset |       |       |       | Va     | lue     |       |       |       |
|--------------|---------|-------|-------|-------|-------|--------|---------|-------|-------|-------|
|              |         | 0.104 | 7-bit | 6-bit | 5-bit | 4-bit  | 3-bit   | 2-bit | 1-bit | 0-bit |
| CRCRESULTMSB | 0x0E    | 0xXX  |       |       |       | CRCRes | sultMSB |       |       |       |

| Number | Name         | Description                            |
|--------|--------------|----------------------------------------|
| 7-0    | CRCResultMSB | Store CRC calculation result MSB 8bit. |

CRCRESULTLSB(0x0D) and CRCRESULTMSB(0x0E) register are registers to store CRC calculation result. CRCErr flag of ERRFLAG(0x0A) register can be confirmed by microprocessor. Also microprocessor uses CRCResultLSB and CRCResultMSB to confirm error occurrence.

# Chapter8 Interrupt

## 8.1 Introduction

TRH031M-S supports various types of interrupt. Using interrupt benefits for microprocessor to control TRH031M-S. First, processing speed enhancement can be expected and second, efficiency in microprocessor calculation. If microprocessor controls more than 2 devices, benefits of interrupt enhance. TRH031M-S supports total of 6 interrupts and user can select choose to use any interrupt.

## 8.2 Interrupt Use Method

| Name | Address | Reset |        |       |          |       | Value |         |            |            |
|------|---------|-------|--------|-------|----------|-------|-------|---------|------------|------------|
| TEN  | 0.000   | 0.00  | 7-bit  | 6-bit | 5-bit    | 4-bit | 3-bit | 2-bit   | 1-bit      | 0-bit      |
| IEN  | 0x06    | 0x00  | SetIEn | 0     | TimerIEn | TxIEn | RxIEn | IdleIEn | HiAlertIEn | LoAlertIEn |
|      |         |       |        |       |          |       |       |         |            |            |

Table 8-1 IEN register

| Number | Name       | Description                                             |
|--------|------------|---------------------------------------------------------|
| 7      | SetIEn     | 0: Clear Bit. From 0~5, set marked bit as 0.            |
|        |            | 1: Set Bit. 0~5 set marked bit as 1.                    |
| 5      | TimerIEn   | 0: Not transfer TimerIRq interrupt signal to IRQ pin    |
|        |            | 1: Transfer TimerIRq interrupt signal to IRQ pin.       |
| 4      | TxIEn      | 0: Not transfer TxIRq interrupt signal to IRQ pin.      |
|        |            | 1: Transfer TxIRq interrupt signal to IRQ pin.          |
| 3      | RxIEn      | 0: Not transfer RxIRq interrupt signal to IRQ pin.      |
|        |            | 1: Transfer RxIRq interrupt signal to IRQ pin.          |
| 2      | IdleIEn    | 0: Not transfer IdleIRq interrupt signal to IRQ pin.    |
|        |            | 1: Transfer IdleIRq interrupt signal to IRQ pin.        |
| 1      | HiAlertIEn | 0: Not transfer HiAlertIRq signal to IRQ pin.           |
|        |            | 1: Transfer HiAlertIRq signal to IRQ pin.               |
| 0      | LoAlertIEn | 0: Not transfer LoAlertIRq interrupt signal to IRQ pin. |
|        |            | 1: Transfer LoAlertIRq interrupt signal to IRQ pin.     |

TRH031M-S alerts microprocessor through IRQ pin when interrupt occurs in IEN(0x06) register setting. Therefore, user must select interrupts to be used set in IEN(0x06) register.

Microprocessor through IRQ pin is alerted of interrupt occurrence but to know which interrupt must confirm by reading from IRQ(0x07) register. When microprocessor set the interrupt in IEN(0x06) and verify interrupt occurrence through IRQ pin, microprocessor read IRQ(0x07)register. IRQ(0x07)register is automatically set to 1 when interrupt occurs but maintains the value until microprocessor change the value to 0. When multiple interrupt occur, if not microprocessor initialize interrupt to 0, despite additional interrupt occurrence IRQ pin has no impact thus microprocessor is not aware of interrupt occurrence. Therefore, interrupt request is recommended to re-initialize after occurrence. Occurred interrupt request is modified in IRQ(0x07)register and other values to be maintained as previous value, IEN(0x06)register and IRQ(0x07)register have different read/write methods than other registers.

IEN(0x06) and IRQ(0x07) registers are changeable by bit level. Basically user can change specific bit value and keep others as is. This function is useful when initializing single interrupt.

| Name | Address | Reset |        |       |          |       | Value |         |            |            |
|------|---------|-------|--------|-------|----------|-------|-------|---------|------------|------------|
| IRO  | 0.07    | 0.00  | 7-bit  | 6-bit | 5-bit    | 4-bit | 3-bit | 2-bit   | 1-bit      | 0-bit      |
| IRQ  | 0x07    | 0x00  | SetIRq | 0     | TimerIRq | TxIRq | RxIRq | IdleIRq | HiAlertIRq | LoAlertIRq |

| Tabl | е | 8-2 | IRQ | register |
|------|---|-----|-----|----------|
|------|---|-----|-----|----------|

| Number | Name       | Description                                             |
|--------|------------|---------------------------------------------------------|
| 7      | SetIRq     | 0: Clear Bit. From 0~5, set marked bit as 0.            |
|        |            | 1: Set Bit. 0~5 set marked bit as 1.                    |
| 5      | TimerIRq   | 0: TIMERVALUE register is not '0'.                      |
|        |            | 1: TIMERVALUE register is '0'.                          |
| 4      | TxIRq      | 0: FIFO data not transmitted.                           |
|        |            | 1: FIFO data transmitted.                               |
| 3      | RxIRq      | 0: Receiving not complete.                              |
|        |            | 1: Receiving complete.                                  |
| 2      | IdleIRq    | 0: Not in Idle mode.                                    |
|        |            | 1: Command execution complete and remains in Idle mode. |
| 1      | HiAlertIRq | 0: FIFO available space is more than WaterLevel.        |
|        |            | 1: FIFO available space is less than WaterLevel.        |
| 0      | LoAlertIRq | 0: FIFO data is more than WaterLevel.                   |
|        |            | 1: FIFO data is less than WaterLevel.                   |

| (a) Bit Setting |                                                    | 7-bit      | 6-bit      | 5-bit      | 4-bit      | 3-bit      | 2-bit      | 1-bit      | 0-bit      |
|-----------------|----------------------------------------------------|------------|------------|------------|------------|------------|------------|------------|------------|
| (u) bit Setting | Register Value (before Write)                      | 0          | 0          | 0          | 0          | 1          | 0          | 0          | 1          |
|                 | Write Data (0x9C)                                  | 1          | 0          | 0          | 1          | 1          | 1          | 0          | 0          |
|                 | Register Value (After Write)                       | 0          | 0          | 0          | 1          | 1          | 1          | 0          | 1          |
|                 |                                                    |            |            |            |            |            |            |            |            |
|                 |                                                    |            |            |            |            |            |            |            |            |
| (b) Bit Clear   |                                                    | 7-bit      | 6-bit      | 5-bit      | 4-bit      | 3-bit      | 2-bit      | 1-bit      | 0-bit      |
| (b) Bit Clear   | Register Value (before Write)                      | 7-bit<br>0 | 6-bit<br>0 | 5-bit<br>0 | 4-bit<br>0 | 3-bit<br>1 | 2-bit<br>0 | 1-bit<br>0 | 0-bit<br>1 |
| (b) Bit Clear   | Register Value (before Write)<br>Write Data (0x1C) |            |            |            |            |            |            |            |            |
| (b) Bit Clear   |                                                    | 0          | 0          | 0          | 0          | 1          | 0          | 0          | 1          |

Picture 8-1 IEN and IRQ register setting method

Above picture 8-1 displays IEN(0x06) register and IRQ(0x07) register setting method. Picture 8-1(a) displays register setting of bit value 1, and picture 8-1(b) displays register bit setting of 0. From picture 8-1 (a) and (b) if first byte data is previous data before written, 2<sup>nd</sup> byte is IEN(0x06) or IRQ(0x07) written data. Lastly 3<sup>rd</sup> byte changed value after it is written. As seen on picture 8-1, when setting IEN(0x6) or IRQ(0x07)register as either 1 or 0 is determined by MSB then only bit 1 is changed and other bits maintains previous value.

CONTROL (0x09) register 7-bit is a register to set polarity of interrupt. When *IRQInv* is set to 1, IRQ pin maintains the value 1 during idle and changes to 0 when interrupt occurs. When *IRQInv* is set to 0, conversely IRQ pin maintains 0 value during idle mode and changes to 1 during interrupt occurrence.

# Chapter9 Power Management

## 9.1 Introduction

TRH031M-S provide power down mode to minimize power consumption. User can minimize power consumption during reader chip idle mode using power down mode.

### 9.2 Power down Mode Effect

When power down mode is executed, TRH031M-S stops all devices consuming power and maintain idle until wake-up. Below table displays pin status during power down mode. For optimum performance of power down mode entry pin must assign different value other than high-Z.

| Symbol              | I/O | Description         |
|---------------------|-----|---------------------|
| XIN                 | Ι   | Oscillator disabled |
| IRQ                 | 0   | Output High         |
| TX1                 | 0   | Output Low          |
| TX2                 | 0   | Output Low          |
| CSB, WRB, RDB       | Ι   | Input               |
| DATA7 – DATA0       | Ι   | Input               |
| PALE, TESTIN        | Ι   | Input               |
| ADDR2, ADDR1, ADDR0 | Ι   | Input               |
| TESTOUT, TEST2O     | 0   | Output Low          |
| RX                  | Ι   | Input               |
| VMID                | Ι   | Input               |
| XOUT                | 0   | Oscillator disabled |
| RST                 | Ι   | Input (High)        |

#### Table 9-1 Pin assignment in power down mode

54

### 9.3 Powerdown Mode Directions

#### 9.3.1 Hardware PowerDown Mode

Hardware power down mode is a method to minimize power consumption using TRH031M-S RST pin. TRH031M-S activates power down mode when RST pin is 1. During power down mode, TRH031M-S internal main clock does not oscillate and needs some time after RST is given low value and to re-activate. It's because stopped oscillation to resume clock and to stabilize requires a certain time. This required time is less than 500us.

#### 9.3.2 Software PowerDown Mode

Software power down mode activates when CONTROL(0x09) register sets as *PowerDown* flag to 1, and during software power down mode, all internal current consumption is minimized. This process is actually the same as hardware power down mode. In software power down mode, host interface remains in action mode to release from power down mode. Same as hardware power down mode, in software power down mode clock does not oscillate.

# Chapter10 Timer

## **10.1 Introduction**

Microprocessor executes various timer operations. Using timer related registers, timer speed, timer control by event and timer interrupt occurrence are possible.

### **10.2 Timer Setting**

Timer speed is determined by *TPreScaler* flag value of TIMERCLK(0x2A) register. Timer speed implies changes in speed of timer actual value. *TPreScaler* is divided into total of 5 bits. Timer speed is determined by 13.56MHz cycle. In below equation, T<sub>TimerClock</sub> implies timer speed.

$$T_{TimerClock} = 2^{T \operatorname{PreScaler}} \times 73.7 ns = \frac{2^{T \operatorname{PreScaler}}}{13.56 \operatorname{MHz}}$$

*TPreScaler* value can be set from 0 to 21, therefore, possible  $T_{Timerclock}$  value is from 74ns to 150ms.

| Name     | Address | Reset | Value |       |          |       |       |           |       |       |
|----------|---------|-------|-------|-------|----------|-------|-------|-----------|-------|-------|
|          |         | 0.07  | 7-bit | 6-bit | 5-bit    | 4-bit | 3-bit | 2-bit     | 1-bit | 0-bit |
| TIMERCLK | 0x2A    | 0x07  | 0     | 0     | TRestart |       |       | TPreScale | r     |       |

#### Table 10-1 TIMERCLK register

| Number | Name       | Description                                                                |
|--------|------------|----------------------------------------------------------------------------|
| 5      | TRestart   | If this value is 1, timer count is completed to 0 then reload TReloadValue |
|        |            | to automatically restart timer.                                            |
| 4-0    | TPreScalar | Set timer count speed.                                                     |

From TIMERCLK(0x2A) register, *TRestart* is a register to auto re-start timer automatically. If *TRestart* is already set, do not reduce the timer value to 0, and when timer value is 1, *TReloadValue* value is reloaded and begins re-counting.

TRH031M-S timer begins counting from designated value. User can set timer start value using *TReloadValue* flag of TRELOADVALUE(0x2C) register.

| Name         | Address | Reset |       |       |       | Va     | lue    |       |       |       |
|--------------|---------|-------|-------|-------|-------|--------|--------|-------|-------|-------|
|              | 0x2C    | 0,000 | 7-bit | 6-bit | 5-bit | 4-bit  | 3-bit  | 2-bit | 1-bit | 0-bit |
| TRELOADVALUE | UXZC    | 0x0A  |       |       |       | TReloa | dValue |       |       |       |

| Number | Name         | Description                                |
|--------|--------------|--------------------------------------------|
| 7-0    | TReloadValue | The timer loads this value, when it works. |

From timer start event to timer to have specific timer value, can be obtained using below equation. *TReloadValue* implies timer start value, and *TimerValue* is current timer value.

$$T_{Timer} = T_{TimerClock} \times (T \operatorname{Re} loadValue - TimerValue)$$

Subsequently,  $\rm T_{\rm Timer}$  value is estimated from 74ns to 40s.

#### Table 10-3 TIMERVALUE register

| Name       | Address | Reset |       |       |       | Va    | lue    |       |       |       |
|------------|---------|-------|-------|-------|-------|-------|--------|-------|-------|-------|
| TIMERVALUE |         |       | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit  | 2-bit | 1-bit | 0-bit |
| TIMERVALUE | 0x0C    | 0x05  |       |       |       | Time  | rValue |       |       |       |

| Number | Name       | Description                          |
|--------|------------|--------------------------------------|
| 7-0    | TimerValue | Show the current value of the timer. |

*TimerValue* flag of TIMERVALUE is a register to display current timer value. *TimerValue* flag comprises of 8 bits. *TimerValue* is made of total 8 bits thus timer can count from 0 to 2<sup>64</sup>.

### **10.3 Timer Function**

Basically timer can start or stop using *TStartNow* and *TStopNow* flag of CONTROL(0x09) register. Setting *TStartNow* to 1, timer load *TReloadValue* value to *TimerValue* flag and begin counting as reducing *TimerValue* value by 1. When timer is counting, user sets *TStartNow* to 1. Then, timer stops and displays consumed time through *TimerValue* value.

Other than timer function through CONTROL(0x09) register to utilize timer for transmit/receive select TCONTROL (0x2B) register. TCONTROL(0x2B) register controls timer count, and it is used when transmit/receive begin or end. For example, if user wants to know the amount of time after transmit complete, *TStartTxEnd of* TCONTROL(0x2B) register set to 1.

| Name     | Address | Reset |     |     |     |       | Valu       | ie        |             |            |
|----------|---------|-------|-----|-----|-----|-------|------------|-----------|-------------|------------|
|          |         |       | 7-  | 6-  | 5-  | 4-bit | 3-bit      | 2-bit     | 1-bit       | 0-bit      |
| TCONTROL | 0x2B    | 0x06  | bit | bit | bit |       |            |           |             |            |
|          |         |       | 0   | 0   | 0   | 0     | TStopRxEnd | TStopRxBe | TStartTxEnd | TStartTxBe |

| Table 10-4 | TCONTROL | register |
|------------|----------|----------|
|------------|----------|----------|

| Number | Name        | Description                                |
|--------|-------------|--------------------------------------------|
| 3      | TStopRxEnd  | When finished data receiving, timer end.   |
| 2      | TStopRxBe   | When starting data receiving, timer start. |
| 1      | TStartTxEnd | When finished data sending, timer end.     |
| 0      | TStartTxBe  | When starting data sending, timer start.   |

*TStopRxEnd* is a flag to stop timer after transmit completion, and *TStopRxBe* is a flag to start timer when receiver begins. *TRunning* flag of *SecondaryStatus* register displays current timer status.

When start event begins, timer begins to count and *TRunning* flag becomes 1. Also when end event begins, timer stops counting and *TRunning* flag returns to 0.

Timer is set to create interrupt. *TimerIRq* flag of IRQ register is an interrupt request when timer value becomes 0.

# Chapter11 Analog

## 11.1 Transmitter

Analog transmitter comprise of control block, ASK Modulator and driver. Transmitter transmits modulated 13.56MHz carrier frequency simultaneously controls TX1 and TX2 pin output signals.

## **11.2 Transmitter Structure**





Picture 11-1 displays transmitter configuration. TRH031M-S use two transmitter drivers for antenna signal efficiency.

## **11.3 Transmitter Function**

Transmitter setting can be divided into signal type selection and output power selection. Next chapter explains transmitter setting method.

#### 11.3.1 TX1 and TX2 Function Setting

Transmitter transmit TX\_I (Transferred digital signal for modulation) modulated 13.56MHz carrier signal through TX1 and TX2. Also output signal from TX1 and TX2 for filtering and matching activate antenna through few external elements. TX1 and TX2 output signal can be set in various format through TXCONTROL(0x11) register.

| Table 11-1 | TXCONTROL | register |
|------------|-----------|----------|
|------------|-----------|----------|

| Name      | Address | Reset |        | Value           |       |         |        |       |         |         |  |  |  |  |
|-----------|---------|-------|--------|-----------------|-------|---------|--------|-------|---------|---------|--|--|--|--|
| TYCONTROL | 0.11    |       | 7-bit  | 6-bit           | 5-bit | 4-bit   | 3-bit  | 2-bit | 1-bit   | 0-bit   |  |  |  |  |
| TXCONTROL | 0x11    | 0x58  | TxPwdn | ModulatorSource |       | F100ASK | TX2Inv | TX2Cw | TX2RFEn | TX1RFEn |  |  |  |  |

| Number | Name            | Description                                                             |
|--------|-----------------|-------------------------------------------------------------------------|
| 7      | TxPwdn          | Transmitter Power down signal                                           |
| 6-5    | ModulatorSource | Select the modulator source                                             |
|        |                 | 00: Constant Low                                                        |
|        |                 | 01: Constant High                                                       |
|        |                 | 10: Internal coder source                                               |
|        |                 | 11: TESTIN pin source                                                   |
| 4      | F100ASK         | 0: ASK modulation depth is determined by ModConductance value.          |
|        |                 | 1: Fix ASK modulation depth to 100%.                                    |
| 3      | TX2Inv          | 0: TX2 pin and TX1 pin output carrier signals are inphase.              |
|        |                 | 1: TX2 pin output carrier signal is 180° phase to TX1.                  |
| 2      | TX2Cw           | 0: TX2 pin and TX1 pin output signals are modulated.                    |
|        |                 | 1: TX2 pin output signal is not modulated.                              |
| 1      | TX2RFEn         | 0: TX2 pin not used. (Output Constant Low value)                        |
|        |                 | 1: TX2 pin used. (Output RF signal) **0x2D Register control in parallel |
| 0      | TX1RFEn         | 0: TX1 pin not used. (Output Constant Low value)                        |
|        |                 | 1: TX1 pin used. (Output RF signal) **0x2D Register control in parallel |

#### Table 11-2 TX1 related settings

| 1 | TX1RFEn | F100ASK | TX_I | Signal on TX1                        |  |  |  |  |  |
|---|---------|---------|------|--------------------------------------|--|--|--|--|--|
|   | 0       | х       | Х    | LOW                                  |  |  |  |  |  |
| Ī | 1       | 0       | 0    | 13.56MHz carrier frequency modulated |  |  |  |  |  |
|   |         |         | 1    | 13.56MHz carrier frequency           |  |  |  |  |  |
|   | 1       | 1       | 0    | LOW                                  |  |  |  |  |  |
|   |         |         | 1    | 13.56MHz energy carrier              |  |  |  |  |  |

Table 11-2 displays *TX1RFEn* and *F100ASK* flag of TXCONTROL(0x11) register and TX1 output signal by TX\_I (Transferred digital signal for modulation). *TX1RFEn* flag of TXCONTROL(0x11) register is a flag for TX1 operation. Until *TX1RFEn* is set to 1, there is no output signal from TX1. When *TX1RFEn* set to 1, transmitter modulates TX\_I (Transferred digital signal for modulation) based on *F100ASK* value. When *F100ASK* is set to 1, 100% ASK modulation occurs and when *F100ASK* is set to 0, user can modify modulation index based on *ModConductance* value. (6 ~50% ASK)

| TX2RFEn | F100ASK | TX2Cw | TX2Inv | TX_I | Signal on TX2                                                         |  |  |  |  |  |
|---------|---------|-------|--------|------|-----------------------------------------------------------------------|--|--|--|--|--|
| 0       | х       | х     | Х      | х    | LOW                                                                   |  |  |  |  |  |
|         |         |       | 0      | 0    | 13.56MHz carrier frequency modulated                                  |  |  |  |  |  |
|         |         |       | 0      | 1    | 13.56MHz carrier frequency                                            |  |  |  |  |  |
|         |         | 0     | 1      | 0    | 13.56MHz carrier frequency modulated, 180°phase shift relative to TX1 |  |  |  |  |  |
|         | 0       |       | 1      | 1    | 13.56MHz carrier frequency, 180°phase shift relative to TX1           |  |  |  |  |  |
|         |         | 1     | 0      | х    | 13.56MHz carrier frequency                                            |  |  |  |  |  |
| 1       |         |       | 1      | x    | 13.56MHz carrier frequency, 180°phase shift relative to TX1           |  |  |  |  |  |
|         |         |       | 0      | 0    | LOW                                                                   |  |  |  |  |  |
|         |         |       |        | 1    | 13.56MHz carrier frequency                                            |  |  |  |  |  |
|         |         |       |        | 0    | HIGH                                                                  |  |  |  |  |  |
|         |         |       |        | 1    | 13.56MHz carrier frequency, 180°phase shift relative to TX1           |  |  |  |  |  |
|         |         | 1     | 0      | х    | 13.56MHz carrier frequency                                            |  |  |  |  |  |
|         |         |       | 1      | х    | 13.56MHz carrier frequency, 180°phase shift relative to TX1           |  |  |  |  |  |

Table 11-3 displays flag value of TXCONTROL(0x11) register and TX2 output signal by TX\_I (Transferred digital signal for modulation). TX2 as well as TX1 output signal only when TX2RFEn is set to 1 and select modulation method by F100ASK value.

However, TX2 has two additional setting compared to TX1. TX2Cw regardless of TX\_I (Transferred digital signal for modulation) signal to TX2 is a flag to output as same as when TX\_I value is 1. Lastly, TX2Inv is a flag to output TX1 and TX2 phase in 180° reverse.

#### 11.3.2 TX1 and TX2 Output Power Setting

TX1 and TX2 output drivability change by conductance value. As conductance value rise, TX1 and TX2 output rise as well. TX1 and TX2 driver conductance use CwConductance of CWCONDUCTANCE(0x12) register and can be adjusted. (R<sub>p</sub>: p-channel resistance)

| Name          | Address | Reset | Value |       |        |               |       |       |       |       |  |
|---------------|---------|-------|-------|-------|--------|---------------|-------|-------|-------|-------|--|
| CWCONDUCTANCE | 0x12    | 0x3F  | 7-bit | 6-bit | 5-bit  | 4-bit         | 3-bit | 2-bit | 1-bit | 0-bit |  |
|               |         |       | 0     | 0     | ExtraD | CwConductance |       |       |       |       |  |

| Number | Name          | Description                                                       |
|--------|---------------|-------------------------------------------------------------------|
| 5      | ExtraD        | Extra Driver                                                      |
| 4-0    | CwConductance | This register value defines the output driver conductance of pins |
|        |               | TX1 and TX2.                                                      |

Table 11-5 TX1 and TX2 P-channel resistance

| R <sub>p</sub> [Ohm] |
|----------------------|
| ∞                    |
| 17                   |
| 8.5                  |
| 4.25                 |
| 2.12                 |
| 1.06                 |
| 3.19                 |
|                      |

Table 12-3 is a table to display TX1 and TX2 Pchannel resistance. P-channel resistance is inverse to driver conductance. If CwConductance value is set to 3, P-channel resistance value becomes 5.7 with parallel calculated considering when CwConductance 1 value is 17 and when CwConductance 2 value is 8.5.

#### 11.3.3 TX1 and TX2 Modulation Index Adjustment

If *F100ASK* is not set to 1, TX1 and TX2 modulation index is impacted by *ModConductance* of MODCONDUCTANCE (0x13) register value. The role of *ModConductance* is to adjust driver conductance when TX1 and TX2 process modulation and impacts ASK modulation index changes. ( $R_{n}$ : p-channel resistance)

| Table 11-6 MODCONDUCTANCE register |
|------------------------------------|
|------------------------------------|

| Name           | Address | Reset   | Value                                                      |       |       |       |        |          |       |       |  |  |
|----------------|---------|---------|------------------------------------------------------------|-------|-------|-------|--------|----------|-------|-------|--|--|
| MODCONDUCTANCE | 0,12    | 0.07    | 7-bit                                                      | 6-bit | 5-bit | 4-bit | 3-bit  | 2-bit    | 1-bit | 0-bit |  |  |
| MODCONDUCTANCE | 0x13    | 0x07    | 0                                                          | 0     |       |       | ModCon | ductance | j     |       |  |  |
|                |         |         |                                                            |       |       |       |        |          |       |       |  |  |
| Number         | Nam     | ie      | Description                                                |       |       |       |        |          |       |       |  |  |
| 5-0            | ModCond | uctance | Determine Modulation Conductance value between TX1 pin and |       |       |       |        |          |       |       |  |  |
|                |         |         | TX2 pin.                                                   |       |       |       |        |          |       |       |  |  |

Table 11-7 TX1 and TX2 modulation P-channel resistance

| ModConductance | R <sub>p</sub> [Ohm] |   |
|----------------|----------------------|---|
| 0              | $\infty$             |   |
| 1              | 102                  |   |
| 2              | 51                   | • |
| 4              | 25.5                 |   |
| 8              | 12.75                |   |
| 16             | 6.37                 |   |
| 32             | 3.19                 |   |

Table 11-7 is a table displaying TX1 and TX2 modulation P-channel resistance. Same as *CwConductance*, when two or more bits are set *ModConducatance* also result in adding each Rp value in parallel. Changes in Rp change modulation index but it is impacted by Rp value and matching circuit simultaneously, therefore, there can be minor changes based on matching methods. Changes in modulation index due to *ModConducatance* value change, please refer to "TRH03XM-S CookBook".

#### 11.3.4 Recognition Distance and Power Consumption

Recognition distance and power consumption have proportional relationship. As transmitter power consumption increase recognition distance also increases. Therefore, there is a trade-off between Recognition distance and power consumption. User should consider this fact when designing.

## **11.4 Receiver**

Receiver execute converting 13.56MHz tag signal through RX pin and sensing envelop to convert to digital signal. This process is called demodulation.

## **11.5 Receiver Structure**



Picture 11-2 Receiver Structure

Receiver configuration is displayed in Picture 11-2. Receiver performs demodulation process through Envelop detector, VGA and Comparator. VMID informs to comparator signal distinction standard level.

## **11.6 Receiver Functions**

Receiving process can be divided into various levels. Next sections will describe each role and possible settings.

#### 11.6.1 Envelope Detector

Envelop detection is a level to delete carrier from received signal and output envelop changes. TRH031M-S suggest PMOS diode structure for more stable data receiving.

#### 11.6.2 Offset Collection

In this level, Offset collection for more clear and ideal DC biasing. To find this DC bias point, standard methods such as Pass Filtering and AC coupling were used.

#### 11.6.3 Variable Gain Amplifier: VGA

Demodulated signals are amplified for improved performance. VGA Gain can be controlled using VGAGain flag of RXCONTROL1(0x19) register. Table 11-9 displays VGA Gain based on VGAGain flag value.

#### Table 11-8 RXCONTROL1 register

| Name       | Address  | Reset |        | Value    |         |       |       |       |         |       |
|------------|----------|-------|--------|----------|---------|-------|-------|-------|---------|-------|
| RXCONTROL1 | 0x19 0x0 | 0.00  | 7-bit  | 6-bit    | 5-bit   | 4-bit | 3-bit | 2-bit | 1-bit   | 0-bit |
|            |          | 0x02  | RxPwdn | VmidPwdn | RxForce | 0     | 0     |       | VGAGair | า     |

| Number | Name     | Description                                                         |
|--------|----------|---------------------------------------------------------------------|
| 7      | RxPwdn   | Receiver Power down                                                 |
| 6      | VmidPwdn | Vmid Power down, Connects Vmid to AVDD                              |
| 5      | RxForce  | Receiver data Enable signal                                         |
| 2-0    | VGAGain  | Adjust RX amp gain.                                                 |
|        |          | This value can be changed by protocol type and working environment. |

| VGAGain     | Gain [dB] (Simulation Results)     |  |  |  |  |  |  |  |
|-------------|------------------------------------|--|--|--|--|--|--|--|
| 0           | 27.6                               |  |  |  |  |  |  |  |
| 1           | <b>1</b> 33.62                     |  |  |  |  |  |  |  |
| 2           | 37.14                              |  |  |  |  |  |  |  |
| 3           | 39.64                              |  |  |  |  |  |  |  |
|             | MSB: high → +6dB                   |  |  |  |  |  |  |  |
| EX) VGAGair | n[2:0] : 111 → 39.64 + 6 = 45.64dB |  |  |  |  |  |  |  |

Table 11-9 Gain value by VGA Gain setting

#### 11.6.4 Comparator

Comparator is a last step to convert output signal through envelop detector and VGA to digital signal. If comparator (As seen on picture 11-3 (a)) transforms very fast at certain threshold point, inaccurate signals will output in noise environment. In this type of situation, comparator transformation characteristics should be modified. Thus, TRH031M-S allows hysteresis range (Picture 12-3(b)) in comparator. Hysteresis range can be modified by HYR of RXTHRESHOLD(0x1C) register.

#### Table 11-10 RXTHRESHOLD register

| Name        | Address  | Reset | Value |       |       |       |       |       |       |       |
|-------------|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| RXTHRESHOLD | 0x1C 0x1 | 0.10  | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit | 2-bit | 1-bit | 0-bit |
|             |          | 0110  | 0     | 0     | 0     | 0     | 0     | 0     | H     | YR    |

| Number | Name | Description                        |
|--------|------|------------------------------------|
| 1-0    | HYR  | Set Hysteresis Range.              |
|        |      | ** After 0x36 Register AAh setting |



Picture 11-3 (a) Ordinary comparator noise impact (b) Hysteresis added comparator noise impact

| Hysteresis Range<br>Control | Hysteresis ranges/V <sub>TRP±</sub> [mV]<br>(Simulation Results) |
|-----------------------------|------------------------------------------------------------------|
| 0                           | 53                                                               |
| 1                           | 72                                                               |
| 2                           | 90                                                               |
| 3                           | 108                                                              |

Table 11-11 Hysteresis range of comparator based on HYR value

Table 11-11 displays hysteresis range based on *HYR* flag value. As seen on above table, hysteresis range of comparator can be modified from 53mV to 108mV.

# Chapter12 Receiver Calibration

TRH031M-S are internal calibration for maximum optimized operation. TRH031M-S offers calibration function for optimized performance by reader configuration and environment, card type and location.

Calibration is useful since various antenna size, type and reader system environment impact card reading and detection performance negatively. It is mainly due to TRH031M-S internal RF/Analog circuit reference point is impacted by this environment, and calibration allows optimized performance despite changes in reader system environment. Thus calibration allows TRH031M-S to perform at its maximum wherever possible.

| Table 12-1 | DETECTCTRL | Register |
|------------|------------|----------|
|------------|------------|----------|

| Name       | Address | Reset |       | Value |       |       |           |       |          |          |  |
|------------|---------|-------|-------|-------|-------|-------|-----------|-------|----------|----------|--|
| DETECTOR   | 0.05    | 002   | 7-bit | 6-bit | 5-bit | 4-bit | 3-bit     | 2-bit | 1-bit    | 0-bit    |  |
| DETECTCTRL | 0x2D    | 0x03  | 0     | 0     | 0     | 0     | SelCalClk |       | DTCTX2En | DTCTX1En |  |

| Number | Name      | Description                                      |
|--------|-----------|--------------------------------------------------|
| 3-2    | SelCalClk | Set Calibration operation time, 0 setting        |
| 1      | DTCTX2En  | 1: TX2 RF Carrier On (at Calibration operating)  |
|        |           | 0: TX2 RF Carrier OFF (at Calibration operating) |
|        |           | TX2 Port enable : 1 setting                      |
| 0      | DTCTX1En  | 1: TX1 RF Carrier On (at Calibration operating)  |
|        |           | 0: TX1 RF Carrier OFF (at Calibration operating) |
|        |           | TX1 Port enable : 1 setting                      |

# Chapter13 Test

## **13.1 Introduction**

TRH031M-S supports debugging process after design completion using various test features. Using TESTOUT pin for signal output from TRH031M-S, user can test functionality.

## 13.2 How to use test pin





| Name       | Address | Reset |             |                            |            | Va       | lue   |       |         |       |  |  |
|------------|---------|-------|-------------|----------------------------|------------|----------|-------|-------|---------|-------|--|--|
| TESTOUTSEL | 0x26    | 0,00  | 7-bit       | 6-bit                      | 5-bit      | 4-bit    | 3-bit | 2-bit | 1-bit   | 0-bit |  |  |
| TESTOUTSEL | 0x26    | 0x00  | 0           | 0                          | 0          | 0        | 0     |       | TestSel |       |  |  |
|            |         |       |             |                            |            |          |       |       |         |       |  |  |
| Number     | Nam     | ne    | Description |                            |            |          |       |       |         |       |  |  |
| 2-0        | TestS   | el    | Select se   | end out si                 | ignal to T | estout p | oin.  |       |         |       |  |  |
|            |         |       | 000: Co     | nstant low                 | /          |          |       |       |         |       |  |  |
|            |         |       | 001: Co     | nstant hig                 | h          |          |       |       |         |       |  |  |
|            |         |       | 010: De     | 010: Demodulated RX Signal |            |          |       |       |         |       |  |  |
|            |         |       | 100: No     | t modulat                  | ed TX Sic  | nal      |       |       |         |       |  |  |

#### Table 13-1 TESTOUTSEL register

Picture 13-1 displays transmit/receive process. Picture 12-1(a) is actual signal on antenna. Picture 12-1(b) is transmitted digital signal from digital block to analog block for alteration. Picture 12-1(c) is digital signal originally received from tag and demodulated from analog block and sent to digital block. User can confirm activation using TESTOUT pin to observe picture 12-1(b) and picture 12-1(c) signal. TESTOUT pin output can be set using *TestSel* flag of TESTOUTSEL(0x00) and if the value is 4, then picture 12-1(b) and value is 2 then picture 12-1(c) signal output occur.

# Chapter14 Electrical Characteristics

## 14.1 Operating condition range

| Symbol          | Parameter                   | MIN | ТҮР | MAX | UNIT |
|-----------------|-----------------------------|-----|-----|-----|------|
| T <sub>op</sub> | Operating temperature range | -25 | +25 | +85 | °C   |
| DVDD            | Digital power supply        | 2.9 | 3.3 | 3.6 | V    |
| AVDD            | Analog power supply         | 2.9 | 3.3 | 3.6 | V    |
| TVDD            | Transmitter power supply    | 2.9 | 3.3 | 3.6 | V    |

## 14.2 Current consumption

| Symbol            | Parameter                  | Conditions                | MIN  | ТҮР  | MAX  | UNIT |
|-------------------|----------------------------|---------------------------|------|------|------|------|
| Ţ                 | Disital Susalu sument      | Idle Command              | 5.0  | 7.5  | 9.5  | mA   |
| I <sub>DVDD</sub> | Digital Supply current     | Power Down mode           | 0.1  | 0.2  | 0.4  | uA   |
| т                 | Apples Cupply surrent      | Receiver On               | 2.5  | 3.15 | 4.5  | mA   |
| I <sub>avdd</sub> | Analog Supply current      | Power Down mode           | 0.01 | 0.05 | 0.5  | uA   |
|                   |                            | Continuous Wave           |      |      |      |      |
|                   |                            | Antenna unconnected       | 110  | 120  | 150  |      |
|                   |                            | (TX1 and TX2 On,          | 110  | 130  | 150  | mA   |
|                   |                            | CwConductance = 3F)       |      |      |      |      |
|                   |                            | Continuous Wave           |      |      |      |      |
| т                 | Transmittar Supply surrant | Antenna unconnected       | 24   | 28   | 33   | mA   |
| I <sub>tvdd</sub> | Transmitter Supply current | (TX1 On and TX2 Off,      | 24   | 20   | 22   | ША   |
|                   |                            | CwConductance = 01)       |      |      |      |      |
|                   |                            | TX1 and TX2 unconnected,  | 7.0  | 9    | 11.0 |      |
|                   |                            | TX1,2 disable / clock on  | 7.0  | 5    | 11.0 | uA   |
|                   |                            | TX1 and TX2 unconnected,  | 0.05 | 0.1  | 0.2  |      |
|                   |                            | TX1,2 disable / clock off | 0.05 | 0.1  | 0.3  | uA   |

| I <sub>ek</sub> | Total Leakage current   | Power Down mode        | 0.1  | 0.35 | 1.0  | uA |
|-----------------|-------------------------|------------------------|------|------|------|----|
|                 |                         | Operating mode         |      |      |      |    |
| т               | Total Operating current | (* Minimum powerTX1 On | 130  | 140  | 150  | m۸ |
| L <sub>op</sub> | Total Operating current | TX2 Off,               | (34) | (38) | (44) | mA |
|                 |                         | CwConductance = 01)    |      |      |      |    |

## **14.3 External Oscillator characteristics**

| Symbol            | Parameter                                                            | MIN | ТҮР   | MAX | UNIT |
|-------------------|----------------------------------------------------------------------|-----|-------|-----|------|
| F <sub>xtal</sub> | Frequency range                                                      | -   | 13.56 | -   | MHz  |
| R <sub>xtal</sub> | Crystal Oscillator Resistor value                                    | -   | 1M    | -   | Ohm  |
| C <sub>xtal</sub> | Crystal Oscillator Capacitor value                                   | -   | 10p   | -   | F    |
| S <sub>xtal</sub> | Crystal Oscillator settling(start-up) time<br>: XOUT Pin, *see note1 | -   | -     | 0.5 | ms   |



Picture 14-1 External Crystal Oscillator circuit

| Symbol            | Param                                | MIN                 | ТҮР  | MAX  | UNIT               |     |
|-------------------|--------------------------------------|---------------------|------|------|--------------------|-----|
| RX <sub>in</sub>  | Receiver input d                     | -                   | -    | 3.3  | V <sub>pk-pk</sub> |     |
| RX <sub>sen</sub> | Receiver Demodulation sensitivity    |                     | 3    | -    | -                  | mV  |
| RX <sub>cf</sub>  | Receiver IF filter cut-off frequency |                     | 100k | -    | 1M                 | Hz  |
| VMID              | Vmid outpu                           | Vmid output voltage |      | 1.65 | -                  | V   |
|                   |                                      | No load             | -    | -    | 0.2u               |     |
| VM <sub>st</sub>  | VM <sub>st</sub><br>Time *see note1  | Output load 47nF    | -    | -    | 0.4m               | sec |
|                   |                                      | Output load 100nF   | -    | -    | 1.0m               | •   |

## **14.4 Receiver characteristics**

Notes

1. Settling time depends on the surround environments.

# (PCB board capacitance, Capacitor device variation, Soldering, ETC)

## **14.5 Receiver Calibration characteristics**

| Symbol  | Parameter                           | MIN | ТҮР | MAX  | UNIT |
|---------|-------------------------------------|-----|-----|------|------|
| т.      | Receiver Calibration time           | _   | _   | 100u | sec  |
| l rxcal | DTCCTRL(0x2D) <i>SelCalClk=00</i> , |     |     | 1000 | Sec  |

## 14.6 Standard I/O Pin DC characteristics

| SYMBOL   | PARAMETER                 | MIN        | NAAV       | Co           | nditions                         |
|----------|---------------------------|------------|------------|--------------|----------------------------------|
| STIVIDUL | PARAMETER                 | IVILIN     | ΜΑΧ        | VDD          | Remark                           |
| VIL      | Low level input voltage   | -0.5V      | 0.3 X VDD  | 2.7V to 3.6V | Guaranteed Input<br>Low Voltage  |
| VIH      | High level input voltage  | 0.7 X VDD  | VDD + 0.5V | 2.7V to 3.6V | Guaranteed Input<br>High Voltage |
| VOL      | Low level output voltage  |            | VSS + 0.1V | 2.7V         |                                  |
| VOH      | High level output voltage | VDD - 0.1V |            | 2.7V         |                                  |

# 14.7 Schmitt Trigger Input Threshold

|      | VT+  |      |     | VT-  |      | Hysteresis |     |      | Unit |
|------|------|------|-----|------|------|------------|-----|------|------|
| MIN  | MAX  | ТҮР  | MIN | MAX  | ТҮР  | MIN        | MAX | ТҮР  | Unit |
| 1.39 | 2.06 | 1.82 | 0.9 | 1.46 | 1.24 | 0.49       | 0.6 | 0.58 | V    |

## 14.8 Timing specification

## 14.8.1 Timing for Read/Write Strobe

| SYMBOL            | PARAMETER                             | MIN | MAX | UNIT |
|-------------------|---------------------------------------|-----|-----|------|
| t <sub>LHLL</sub> | PALE pulse width                      | 10  |     | ns   |
| t <sub>AVLL</sub> | Multiplexed Address Bus Setup Time    | 4   |     | ns   |
| t <sub>LLAX</sub> | Multiplexed Address Bus Hold Time     | 6   |     | ns   |
| t <sub>LLWL</sub> | PALE low to WRB, RDB low              | 5   |     | ns   |
| t <sub>CLWL</sub> | CSB low to WRB, RDB low               | 0   |     | ns   |
| t <sub>whCH</sub> | WRB, NWR high to CSB high             | 0   |     | ns   |
| t <sub>RLDZ</sub> | RDB low to DATA valid                 |     | 35  | ns   |
| t <sub>RHDZ</sub> | RDB high to DATA high impedance       |     | 20  | ns   |
| t <sub>WLDV</sub> | WRB low to DATA valid                 |     | 35  | ns   |
| t <sub>WHDX</sub> | DATA Bus Hold Time                    |     | 6   | ns   |
| t <sub>wLWH</sub> | WRB, RDB pulse width                  | 41  |     | ns   |
| t <sub>AVWL</sub> | Separated Address Bus Setup Time      | 5   |     | ns   |
| t <sub>WHAX</sub> | Separated Address Bus Hold Time       | 6   |     | ns   |
| t <sub>WHWL</sub> | Period between sequenced R/W accesses | 150 |     | ns   |





## 14.8.2 Timing for SPI compatible interface

| SYMBOL            | PARAMETER                | MIN | MAX | UNIT |
|-------------------|--------------------------|-----|-----|------|
| t <sub>SCKL</sub> | SCK low pulse width      | 100 |     | ns   |
| t <sub>SCKH</sub> | SCK high pulse width     | 100 |     | ns   |
| t <sub>shdx</sub> | SCK high to data changes | 20  |     | ns   |
| t <sub>DXSH</sub> | data changes to SCK high | 20  |     | ns   |
| t <sub>SLDX</sub> | SCK low to data changes  |     | 15  | ns   |
| t <sub>SLNH</sub> | SCK low to NSS high      | 20  |     | ns   |



PICTURE 14-3 Timing for SPI compatible interface

## 14.9 Package Information



3ALogics 13.56MHz Muti-protocol RFID reader IC Data sheet (3AD-D-006)

It's RFID

**RFID & Mobile SoC for Ubiquitous Technology** 

Tel : (82) - (31) - 715 - 7117 Fax : (82) - (31) - 719 - 7551 Homepage : <u>http://www.3alogics.com</u> Email : rfid@3alogics.com

7<sup>th</sup> Floor, Hyundai-office Bldg., 9-4, Sunae-dong. Bundang-gu, Seongnam-si, Gyeonggi-do,463-783,Korea

78