# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





# STMPE610

# S-Touch<sup>®</sup>: advanced touchscreen controller with 6-bit port expander

### Features

- 6 GPIOs
- 1.8 3.3 V operating voltage
- Integrated 4-wire touchscreen controller
- Interrupt output pin
- Wakeup feature on each I/O
- SPI and I<sup>2</sup>C interface
- Up to 2 devices sharing the same bus in I<sup>2</sup>C mode (1 address line)
- 6-input 12-bit ADC
- 128-depth buffer touchscreen controller
- Touchscreen movement detection algorithm
- 25 kV air-gap ESD protection (system level)
- 4 kV HBM ESD protection (device level)

## Applications

- Portable media players
- Game consoles
- Mobile and smartphones
- GPS



## Description

The STMPE610 is a GPIO (general purpose input/output) port expander able to interface a main digital ASIC via the two-line bidirectional bus (I<sup>2</sup>C). A separate GPIO expander is often used in mobile multimedia platforms to solve the problems of the limited amount of GPIOs typically available on the digital engine.

The STMPE610 offers great flexibility, as each I/O can be configured as input, output or specific functions. The device has been designed with very low quiescent current and includes a wakeup feature for each I/O, to optimize the power consumption of the device.

A 4-wire touchscreen controller is built into the STMPE610. The touchscreen controller is enhanced with a movement tracking algorithm to avoid excessive data, 128 x 32 bit buffer and a programmable active window feature.

#### Table 1. Device summary

| Order code  | Package | Packaging     |
|-------------|---------|---------------|
| STMPE610QTR | QFN16   | Tape and reel |

# Contents

| 1  | STMF                            | STMPE610 functional overview4      |  |  |
|----|---------------------------------|------------------------------------|--|--|
| 2  | Pin configuration and functions |                                    |  |  |
|    | 2.1                             | Pin functions                      |  |  |
| 3  | I2C ai                          | nd SPI interface                   |  |  |
|    | 3.1                             | Interface selection                |  |  |
| 4  | I2C in                          | iterface                           |  |  |
|    | 4.1                             | I2C features                       |  |  |
|    | 4.2                             | Data input                         |  |  |
|    | 4.3                             | Read operation                     |  |  |
|    | 4.4                             | Write operations 12                |  |  |
| 5  | SPI in                          | nterface                           |  |  |
|    | 5.1                             | SPI protocol definition            |  |  |
|    |                                 | 5.1.1 Register read                |  |  |
|    |                                 | 5.1.2 Register write               |  |  |
|    |                                 | 5.1.3 Termination of data transfer |  |  |
|    | 5.2                             | SPI timing modes                   |  |  |
|    |                                 | 5.2.1 SPI timing definition        |  |  |
| 6  | STMP                            | PE610 registers                    |  |  |
| 7  | Syste                           | m and identification registers 18  |  |  |
| 8  | Interr                          | upt system                         |  |  |
| 9  | Analog-to-digital converter 24  |                                    |  |  |
| 10 | Touch                           | nscreen controller                 |  |  |
|    | 10.1                            | Driver and switch control unit     |  |  |
|    | 10.2                            | Touch detect delay                 |  |  |



#### STMPE610

| 11 | Touchscreen controller programming sequence                        | 40              |
|----|--------------------------------------------------------------------|-----------------|
| 12 | GPIO controller                                                    | <b>42</b><br>44 |
| 13 | Maximum rating         13.1       Recommended operating conditions | <b>45</b><br>45 |
| 14 | Electrical specifications                                          | 47              |
| 15 | Package mechanical data                                            | 49              |
| 16 | Revision history                                                   | 55              |



# **1** STMPE610 functional overview

The STMPE610 consists of the following blocks:

- I<sup>2</sup>C and SPI interface
- Analog-to-digital converver (ADC)
- Touchscreen controller (TSC)
- Driver and switch control unit
- GPIO controller

#### Figure 1. STMPE610 functional block diagram



# 2 Pin configuration and functions

### Figure 2. STMPE610 pin configuration (top through view)



#### Table 2.Pin assignments

| Pin | Name            | Function                                                                                                 |
|-----|-----------------|----------------------------------------------------------------------------------------------------------|
| 1   | Y-              | Y-/GPIO-7                                                                                                |
| 2   | INT             | Interrupt output (V <sub>CC</sub> domain, open drain)                                                    |
| 3   | A0/Data Out     | I <sup>2</sup> C address in Reset, Data out in SPI mode (V <sub>CC</sub> domain)                         |
| 4   | SCLK            | I <sup>2</sup> C/SPI clock (V <sub>CC</sub> domain)                                                      |
| 5   | SDAT            | I <sup>2</sup> C data/SPI CS (V <sub>CC</sub> domain)                                                    |
| 6   | V <sub>CC</sub> | 1.8 -3.3 V supply voltage                                                                                |
| 7   | Data in         | SPI Data In (V <sub>CC</sub> domain)                                                                     |
| 8   | NC              | -                                                                                                        |
| 9   | Mode            | MODE<br>In RESET state, MODE selects the type of serial interface<br>"0" - I <sup>2</sup> C<br>"1" - SPI |
| 10  | GND             | Ground                                                                                                   |
| 11  | IN2             | IN2/GPIO-2                                                                                               |
| 12  | IN3             | IN3/GPIO-3                                                                                               |
| 13  | X+              | X+/GPIO-4                                                                                                |
| 14  | Vio             | Supply for touchscreen driver and GPIO                                                                   |
| 15  | Y+              | Y+/GPIO-5                                                                                                |
| 16  | X-              | X-/GPIO-6                                                                                                |



### 2.1 Pin functions

The STMPE610 is designed to provide maximum features and flexibility in a very small pincount package. Most of the pins are multi-functional. The following table shows how to select the pin's function.

Table 3. IN2, IN3 pin configuration

| Din / control | GPIO_AF = 1                         | GPIO_AF = 0                |                            |  |
|---------------|-------------------------------------|----------------------------|----------------------------|--|
| register      | ADC control 1 bit<br>1 = don't care | ADC control 1 bit<br>1 = 0 | ADC control 1 bit<br>1 = 1 |  |
| IN2           | GPIO-2                              | ADC                        | External reference +       |  |
| IN3           | GPIO-3                              | ADC                        | External reference -       |  |

Table 4.X, Y pin configuration

| Pin / control | GPIO_AF = 1                         | GPIO_AF = 0                |                            |  |
|---------------|-------------------------------------|----------------------------|----------------------------|--|
| register      | TSC control 1 bit<br>0 = don't care | TSC control 1 bit<br>0 = 0 | TSC control 1 bit<br>0 = 1 |  |
| X+            | GPIO-4                              | ADC                        | TSC X+                     |  |
| Y+            | GPIO-5                              | ADC                        | TSC Y+                     |  |
| Х-            | GPIO-6                              | ADC                        | TSC X-                     |  |
| Y-            | GPIO-7                              | ADC                        | TSC Y-                     |  |



# 3 I<sup>2</sup>C and SPI interface

### 3.1 Interface selection

The STMPE610 interfaces with the host CPU via a  $I^2C$  or SPI interface. The pin IN\_1 allows the selection of interface protocol at reset state.





#### Table 5.Interface selection pins

| Pin | I <sup>2</sup> C function | SPI function                | Reset state        |
|-----|---------------------------|-----------------------------|--------------------|
| 3   | Address 0                 | Data out                    | CPHA for SPI       |
| 4   | Clock                     | Clock                       | _                  |
| 5   | SDATA                     | CS                          | CPOL_N for SPI     |
| 7   | _                         | Data in                     | _                  |
| 9   | MODE                      | I <sup>2</sup> C set to '0' | Set to '1' for SPI |



# 4 I<sup>2</sup>C interface

The addressing scheme of STMPE610 is designed to allow up to 2 devices to be connected to the same  $I^2C$  bus.



Figure 4. STMPE610 I<sup>2</sup>C interface



| ADDR0 | Address |  |
|-------|---------|--|
| 0     | 0 x 82  |  |
| 1     | 0 x 88  |  |

For the bus master to communicate to the slave device, the bus master must initiate a Start condition and be followed by the slave device address. Accompanying the slave device adress, is a read/write bit (R/W). The bit is set to 1 for read and 0 for write operation. If a match occurs on the slave device address, the corresponding device gives an acknowledge on the SDA during the 9<sup>th</sup> bit time. If there is no match, it deselects itself from the bus by not responding to the transaction.

Figure 5. I<sup>2</sup>C timing diagram





| Symbol              | Parameter                                                                  | Min | Тур | Max | Unit |
|---------------------|----------------------------------------------------------------------------|-----|-----|-----|------|
| f <sub>SCL</sub>    | SCL clock frequency                                                        | 0   | _   | 400 | kHz  |
| t <sub>LOW</sub>    | Clock low period                                                           | 1.3 | -   | -   | μs   |
| t <sub>HIGH</sub>   | Clock high period                                                          | 600 | Ι   | Ι   | ns   |
| t <sub>F</sub>      | SDA and SCL fall time                                                      | Ι   | Ι   | 300 | ns   |
| t <sub>HD:STA</sub> | START condition hold time (after this period the first clock is generated) | 600 | _   | _   | ns   |
| t <sub>SU:STA</sub> | START condition setup time (only relevant for a repeated start period)     | 600 | _   | _   | ns   |
| t <sub>SU:DAT</sub> | Data setup time                                                            | 100 | Ι   | Ι   | ns   |
| t <sub>HD:DAT</sub> | Data hold time                                                             | 0   | -   | Ι   | μs   |
| t <sub>SU:STO</sub> | STOP condition setup time                                                  | 600 | Ι   | Ι   | ns   |
| t <sub>BUF</sub>    | Time the bus must be free before a new transmission can start              | 1.3 | -   | _   | μs   |

Table 7. I<sup>2</sup>C timing

## 4.1 I<sup>2</sup>C features

The features that are supported by the I<sup>2</sup>C interface are listed below:

- I<sup>2</sup>C slave device
- Operates at 1.8 V
- Compliant to Philips I<sup>2</sup>C specification version 2.1
- Supports standard (up to 100 Kbps) and fast (up to 400 Kbps) modes

#### Start condition

A Start condition is identified by a falling edge of SDATA while SCLK is stable at high state. A Start condition must precede any data/command transfer. The device continuously monitors for a Start condition and does not respond to any transaction unless one is encountered.

#### **Stop condition**

A Stop condition is identified by a rising edge of SDATA while SCLK is stable at high state. A Stop condition terminates communication between the slave device and the bus master. A read command that is followed by NoAck can be followed by a Stop condition to force the slave device into idle mode. When the slave device is in idle mode, it is ready to receive the next I<sup>2</sup>C transaction. A Stop condition at the end of a write command stops the write operation to registers.

#### Acknowledge bit

The acknowledge bit is used to indicate a successful byte transfer. The bus transmitter releases the SDATA after sending eight bits of data. During the ninth bit, the receiver pulls



the SDATA low to acknowledge the receipt of the eight bits of data. The receiver may leave the SDATA in high state if it does not acknowledge the receipt of the data.

### 4.2 Data input

The device samples the data input on SDATA on the rising edge of the SCLK. The SDATA signal must be stable during the rising edge of SCLK and the SDATA signal must change only when SCLK is driven low.

| Mode    | Byte | Programming sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|         |      | Start, Device address, $R/\overline{W} = 0$ , Register address to be read                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|         |      | Restart, Device address, $R/\overline{W} = 1$ , Data Read, Stop                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| Read ≥1 | ≥1   | If no Stop is issued, the Data Read can be continuously performed. If<br>the register address falls within the range that allows an address auto-<br>increment, then the register address auto-increments internally after<br>every byte of data being read.                                                                                                                                                                                                                                                          |  |
|         | ≥1   | Start, Device address, $R/\overline{W} = 0$ , Register address to be written, Data Write, Stop                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Write   |      | If no Stop is issued, the Data Write can be continuously performed. If<br>the register address falls within the range that allows address auto-<br>increment, then the register address auto-increments internally after<br>every byte of data being written in. For those register addresses that<br>fall within a non-incremental address range, the address will be kept<br>static throughout the entire write operation. Refer to the memory map<br>table for the address ranges that are auto and non-increment. |  |

Table 8.Operating modes







Figure 6. Read and write modes (random and sequential)

### 4.3 Read operation

A write is first performed to load the register address into the Address Counter but without sending a Stop condition. Then, the bus master sends a reStart condition and repeats the Device Address with the R/W bit set to 1. The slave device acknowledges and outputs the content of the addressed byte. If no additional data is to be read, the bus master must not acknowledge the byte and terminates the transfer with a Stop condition.

If the bus master acknowledges the data byte, then it can continue to perform the data reading. To terminate the stream of data bytes, the bus master must not acknowledge the last output byte, and be followed by a Stop condition. If the address of the register written into the Address Counter falls within the range of addresses that has the auto-increment function, the data being read will be coming from consecutive addresses, which the internal Address Counter automatically increments after each byte output. After the last memory address, the Address Counter 'rolls-over' and the device continues to output data from the memory addresses, the output data byte comes from the same address (which is the address referred by the Address Counter).

#### Acknowledgement in read operation

For the above read command, the slave device waits, after each byte read, for an acknowledgement during the ninth bit time. If the bus master does not drive the SDA to a low state, then the slave device terminates and switches back to its idle mode, waiting for the next command.



### 4.4 Write operations

A write is first performed to load the register address into the Address Counter without sending a Stop condition. After the bus master receives an acknowledgement from the slave device, it may start to send a data byte to the register (referred by the Address Counter). The slave device again acknowledges and the bus master terminates the transfer with a Stop condition.

If the bus master needs to write more data, it can continue the write operation without issuing the Stop condition. Whether the Address Counter autoincrements or not after each data byte write depends on the address of the register written into the Address Counter. After the bus master writes the last data byte and the slave device acknowledges the receipt of the last data, the bus master may terminate the write operation by sending a Stop condition. When the Address Counter reaches the last memory address, it 'rolls-over' to the next data byte write.



### 5 SPI interface

The SPI interface in STMPE610 uses a 4-wire communication connection (DATA IN, DATA OUT, CLK, CS). In the diagram, "Data in" is referred to as MOSI (master out slave in) and "DATA out" is referred to as MISO (master in slave out).

### 5.1 SPI protocol definition

The SPI (serial peripheral interface) follows a byte sized transfer protocol. All transfers begin with an assertion of CS\_n signal (falling edge). The protocol for reading and writing is different and the selection between a read and a write cycle is dependent on the first captured bit on the slave device. A '1' denotes a read operation and a '0' denotes a write operation. The SPI protocol defined in this section is shown in Figure 3.

The following are the main features supported by this SPI implementation.

- Support of 1 MHz maximum clock frequency.
- Support for autoincrement of address for both read and write.
- Full duplex support for read operation.
- Daisy chain configuration support for write operation.
- Robust implementation that can filter glitches of up to 50 ns on the CS\_n and SCL pins.
- Support for all 4 modes of SPI as defined by the CPHA, CPOL bits on SPICON.

#### 5.1.1 Register read

The following steps need to be followed for register read through SPI.

- 1. Assert CS\_n by driving a '0' on this pin.
- 2. Drive a '1' on the first SCL launch clock on MOSI to select a read operation.
- 3. The next 7 bits on MOSI denote the 7-bit register address (MSB first).
- 4. The next address byte can now be transmitted on the MOSI. If the autoincrement bit is set, the following address transmitted on the MOSI is ignored. Internally, the address is incremented. If the autoincrement bit is not set, then the following byte denotes the address of the register to be read next.
- 5. Read data is transmitted by the slave device on the MISO (MSB first), starting from the launch clock following the last address bit on the MOSI.
- 6. Full duplex read operation is achieved by transmitting the next address on MOSI while the data from the previous address is available on MISO.
- 7. To end the read operation, a dummy address of all 0's is sent on MOSI.



#### 5.1.2 Register write

The following steps need to be followed for register write through SPI.

- 1. Assert CS\_n by driving a '0' on this pin.
- 2. Drive a '0' on the first SCL launch clock on MOSI to select a write operation.
- 3. The next 7 bits on MOSI denote the 7-bit register address (MSB first).
- 4. The next byte on the MOSI denotes data to be written.
- 5. The following transmissions on MOSI are considered byte-sized data. The register address to which the following data is written depends on whether the autoincrement bit in the SPICON register is set. If this bit has been set previously, the register address is incremented for data writes.

#### 5.1.3 Termination of data transfer

A transfer can be terminated before the last launch edge by deasserting the CS\_n signal. If the last launch clock is detected, it is assumed that the data transfer is successful.

### 5.2 SPI timing modes

The SPI timing modes are defined by CPHA and CPOL,CPHA and CPOL are read from the "SDAT" and "A0" pins during power-up reset. The following four modes are defined according to this setting.

| Table 9. | SPI timing modes |
|----------|------------------|
|----------|------------------|

| CPOL_N (SDAT pin) | CPOL | CPHA (ADDR pin) | Mode |
|-------------------|------|-----------------|------|
| 1                 | 0    | 0               | 0    |
| 1                 | 0    | 1               | 1    |
| 0                 | 1    | 0               | 2    |
| 0                 | 1    | 1               | 3    |

The clocking diagrams of these modes are shown in ON reset. The device always operates in mode 0. Once the bits are set in the SPICON register, the mode change takes effect on the next transaction defined by the CS\_n pin being deasserted and asserted.

#### 5.2.1 SPI timing definition

#### Table 10.SPI timing specification

| Symbol           | Description                               |     | Unit |     |      |
|------------------|-------------------------------------------|-----|------|-----|------|
|                  | Description                               | Min | Тур  | Мах | Onit |
| t <sub>CSS</sub> | CS_n falling to<br>first capture<br>clock | 1   | _    | _   | μs   |
| t <sub>CL</sub>  | Clock low<br>period                       | 500 | _    | _   | ns   |
| t <sub>CH</sub>  | Clock high<br>period                      | 500 | _    | _   | ns   |



| Symbol            | Description                           |     | Unit |     |      |
|-------------------|---------------------------------------|-----|------|-----|------|
| Symbol            | Description                           | Min | Тур  | Мах | Unit |
| t <sub>LDI</sub>  | Launch clock<br>to MOSI data<br>valid | _   | _    | 20  | ns   |
| t <sub>LDO</sub>  | Launch clock<br>to MISO data<br>valid | _   | _    | 330 | μs   |
| t <sub>DI</sub>   | Data on MOSI<br>valid                 | 1   | _    | _   | μs   |
| t <sub>ccs</sub>  | Last clock<br>edge to CS_n<br>high    | 1   | _    | _   | μs   |
| t <sub>CSH</sub>  | CS_n high<br>period                   | 2   | _    | _   | μs   |
| t <sub>CSCL</sub> | CS_n high to<br>first clock edge      | 300 | _    | _   | ns   |
| t <sub>CSZ</sub>  | CS_n high to<br>tri-state on<br>MISO  | 1   | _    | _   | μs   |

 Table 10.
 SPI timing specification (continued)

#### Figure 7. SPI timing specification



# 6 STMPE610 registers

This section lists and describes the registers of the STMPE610 device, starting with a register map and then provides detailed descriptions of register types.

| Address | Register name | Bit | Туре | Reset value | Function                                                                 |
|---------|---------------|-----|------|-------------|--------------------------------------------------------------------------|
| 0x00    | CHIP_ID       | 16  | R    | 0x0811      | Device identification                                                    |
| 0x02    | ID_VER        | 8   | R    | 0x03        | Revision number<br>0x01 for engineering sample<br>0x03 for final silicon |
| 0x03    | SYS_CTRL1     | 8   | R/W  | 0x00        | Reset control                                                            |
| 0x04    | SYS_CTRL2     | 8   | R/W  | 0x0F        | Clock control                                                            |
| 0x08    | SPI_CFG       | 8   | R/W  | 0x01        | SPI interface configuration                                              |
| 0x09    | INT_CTRL      | 8   | R/W  | 0x00        | Interrupt control register                                               |
| 0x0A    | INT_EN        | 8   | R/W  | 0x00        | Interrupt enable register                                                |
| 0x0B    | INT_STA       | 8   | R    | 0x10        | interrupt status register                                                |
| 0x0C    | GPIO_EN       | 8   | R/W  | 0x00        | GPIO interrupt enable register                                           |
| 0x0D    | GPIO_INT_STA  | 8   | R    | 0x00        | GPIO interrupt status register                                           |
| 0x0E    | ADC_INT_EN    | 8   | R/W  | 0x00        | ADC interrupt enable register                                            |
| 0x0F    | ADC_INT_STA   | 8   | R    | 0x00        | ADC interrupt status register                                            |
| 0x10    | GPIO_SET_PIN  | 8   | R/W  | 0x00        | GPIO set pin register                                                    |
| 0x11    | GPIO_CLR_PIN  | 8   | R/W  | 0x00        | GPIO clear pin register                                                  |
| 0x12    | GPIO_MP_STA   | 8   | R/W  | 0x00        | GPIO monitor pin state register                                          |
| 0x13    | GPIO_DIR      | 8   | R/W  | 0x00        | GPIO direction register                                                  |
| 0x14    | GPIO_ED       | 8   | R/W  | 0x00        | GPIO edge detect register                                                |
| 0x15    | GPIO_RE       | 8   | R/W  | 0x00        | GPIO rising edge register                                                |
| 0x16    | GPIO_FE       | 8   | R/W  | 0x00        | GPIO falling edge register                                               |
| 0x17    | GPIO_AF       | 8   | R/W  | 0x00        | Alternate function register                                              |
| 0x20    | ADC_CTRL1     | 8   | R/W  | 0x9C        | ADC control                                                              |
| 0x21    | ADC_CTRL2     | 8   | R/W  | 0x01        | ADC control                                                              |
| 0x22    | ADC_CAPT      | 8   | R/W  | 0xFF        | To initiate ADC data acquisition                                         |
| 0x30    | ADC_DATA_CH0  | 16  | R    | 0x0000      | ADC channel 0                                                            |
| 0x32    | ADC_DATA_CH1  | 16  | R    | 0x0000      | ADC channel 1                                                            |

Table 11. Register summary map table



| Address | Register name     | Bit | Туре | Reset value | Function                                                        |
|---------|-------------------|-----|------|-------------|-----------------------------------------------------------------|
| 0x38    | ADC_DATA_CH4      | 16  | R    | 0x0000      | ADC channel 4                                                   |
| 0x3A    | ADC_DATA_CH5      | 16  | R    | 0x0000      | ADC channel 5                                                   |
| 0x3C    | ADC_DATA_CH6      | 16  | R    | 0x0000      | ADC channel 6                                                   |
| 0x3E    | ADC_DATA_CH7      | 16  | R    | 0x0000      | ADC channel 7                                                   |
| 0x40    | TSC_CTRL          | 8   | R/W  | 0x90        | 4-wire touchscreen<br>controller setup                          |
| 0x41    | TSC_CFG           | 8   | R/W  | 0x00        | Touchscreen controller configuration                            |
| 0x42    | WDW_TR_X          | 16  | R/W  | 0x0FFF      | Window setup for top right X                                    |
| 0x44    | WDW_TR_Y          | 16  | R/W  | 0x0FFF      | Window setup for top right Y                                    |
| 0x46    | WDW_BL_X          | 16  | R/W  | 0x0000      | Window setup for bottom left X                                  |
| 0x48    | WDW_BL_Y          | 16  | R/W  | 0x0000      | Window setup for bottom left<br>Y                               |
| 0x4A    | FIFO_TH           | 8   | R/W  | 0x00        | FIFO level to generate<br>interrupt                             |
| 0x4B    | FIFO_STA          | 8   | R/W  | 0x20        | Current status of FIFO                                          |
| 0x4C    | FIFO_SIZE         | 8   | R    | 0x00        | Current filled level of FIFO                                    |
| 0x4D    | TSC_DATA_X        | 16  | R    | 0x0000      | Data port for touchscreen controller data access                |
| 0x4F    | TSC_DATA_Y        | 16  | R    | 0x0000      | Data port for touchscreen controller data access                |
| 0x51    | TSC_DATA_Z        | 8   | R    | 0x0000      | Data port for touchscreen controller data access                |
| 0x52    | TSC_DATA_XYZ      | 32  | R    | 0x00000000  | Data port for touchscreen controller data access                |
| 0x56    | TSC_FRACT_X<br>YZ | 8   | RW   | 0x00        | Select the range and<br>accuracy of the pressure<br>measurement |
| 0x57    | TSC_DATA          | 8   | R    | 0x00        | Data port for touchscreen controller data access                |
| 0x58    | TSC_I_DRIVE       | 8   | R/W  | 0x00        | Touchscreen controller drive                                    |
| 0x59    | TSC_SHIELD        | 8   | R/W  | 0x00        | Touchscreen controller<br>shield                                |

 Table 11.
 Register summary map table (continued)



# 7 System and identification registers

| Table 12.         System and identification registers map |               |     |      |        |                                                                          |  |  |  |  |  |  |  |
|-----------------------------------------------------------|---------------|-----|------|--------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Address                                                   | Register name | Bit | Туре | Reset  | Function                                                                 |  |  |  |  |  |  |  |
| 0x00                                                      | CHIP_ID       | 16  | R    | 0x0811 | Device identification                                                    |  |  |  |  |  |  |  |
| 0x02                                                      | ID_VER        | 8   | R    | 0x03   | Revision number<br>0x01 for engineering sample<br>0x03 for final silicon |  |  |  |  |  |  |  |
| 0x03                                                      | SYS_CTRL1     | 8   | R/W  | 0x00   | Reset control                                                            |  |  |  |  |  |  |  |
| 0x04                                                      | SYS_CTRL2     | 8   | R/W  | 0x0F   | Clock control                                                            |  |  |  |  |  |  |  |
| 0x08                                                      | SPI_CFG       | 8   | R/W  | 0x01   | SPI interface configuration                                              |  |  |  |  |  |  |  |

### CHIP\_ID

| Address:     | 0x00                         |
|--------------|------------------------------|
| Туре:        | R                            |
| Reset:       | 0x0811                       |
| Description: | 16-bit device identification |

### ID\_VER

| Address:     | 0x02                   |
|--------------|------------------------|
| Туре:        | R                      |
| Reset:       | 0x03                   |
| Description: | 16-bit revision number |

### SYS\_CTRL1

# Revision number

**Device identification** 

### **Reset control**

| 7           | 6                                                                                                                                                                                                                                           | 5              | 4            | 3           | 2                  | 1                   | 0  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------|-------------|--------------------|---------------------|----|--|--|--|--|--|
|             |                                                                                                                                                                                                                                             | RE             | SERVED       | SOFT_RESET  | HIBERNATE          |                     |    |  |  |  |  |  |
| Address:    |                                                                                                                                                                                                                                             | 0x03           |              |             |                    |                     |    |  |  |  |  |  |
| Туре:       |                                                                                                                                                                                                                                             | R/W            |              |             |                    |                     |    |  |  |  |  |  |
| Reset:      |                                                                                                                                                                                                                                             | 0x00           | )x00         |             |                    |                     |    |  |  |  |  |  |
| Description | :                                                                                                                                                                                                                                           | The reset cont | rol register | enables to  | reset the device   | e                   |    |  |  |  |  |  |
|             | [7:2]                                                                                                                                                                                                                                       | RESERVED       |              |             |                    |                     |    |  |  |  |  |  |
|             | [1]                                                                                                                                                                                                                                         | SOFT_RESET:    | Reset the S  | TMPE610 usi | ing the serial con | nmunication interfa | ce |  |  |  |  |  |
|             | [0] HIBERNATE: Force the device into hibernation mode.<br>Forcing the device into hibernation mode by writing '1' to this bit would disable the hot-<br>feature. If the hot-key feature is required, use the default auto-hibernation mode. |                |              |             |                    |                     |    |  |  |  |  |  |



### SYS\_CTRL2

#### **Clock control**

| 7                                                                                                                                                              | 6           | 5                               | 4                               | 3                                | 2                  | 1       | 0       |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------|---------------------------------|----------------------------------|--------------------|---------|---------|--|--|--|--|--|--|--|
| -                                                                                                                                                              | -           | -                               | -                               | RESERVED                         | GPIO_OFF           | TSC_OFF | ADC_OFF |  |  |  |  |  |  |  |
| Address:                                                                                                                                                       |             | 0x04                            |                                 |                                  |                    |         |         |  |  |  |  |  |  |  |
| Туре:                                                                                                                                                          |             | R/W                             | /W                              |                                  |                    |         |         |  |  |  |  |  |  |  |
| Reset:                                                                                                                                                         |             | 0x0F                            |                                 |                                  |                    |         |         |  |  |  |  |  |  |  |
| Descriptior                                                                                                                                                    | n:<br>[7:3] | This register e                 | enables to s                    | switch off th                    | e clock supply     |         |         |  |  |  |  |  |  |  |
|                                                                                                                                                                | [2]         | GPIO_OFF: Sv<br>1: Switches off | vitch off the o<br>the clock su | clock supply t<br>pply to the G  | to the GPIO<br>PIO |         |         |  |  |  |  |  |  |  |
| <ul><li>[1] TSC_OFF: Switch off the clock supplyto the touchscreen controller</li><li>1: Switches off the clock supply to the touchscreen controller</li></ul> |             |                                 |                                 |                                  |                    |         |         |  |  |  |  |  |  |  |
|                                                                                                                                                                | [0]         | ADC_OFF: Sw<br>1: Switches off  | itch off the cl<br>the clock su | lock supply to<br>pply to the Al | o the ADC<br>DC    |         |         |  |  |  |  |  |  |  |

### SPI\_CFG

### SPI interface configuration

| 7           | 6                                                                                                               | 5               | 4           | 3           | 2         | 1            | 0            |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------|-----------------|-------------|-------------|-----------|--------------|--------------|--|--|--|
|             |                                                                                                                 | RESERVED        |             |             | AUTO_INCR | SPI_CLK_MOD1 | SPI_CLK_MOD0 |  |  |  |
| Address:    |                                                                                                                 | 0x08            |             |             |           |              |              |  |  |  |
| Туре:       |                                                                                                                 | R/W             |             |             |           |              |              |  |  |  |
| Reset:      |                                                                                                                 | 0x01            |             |             |           |              |              |  |  |  |
| Description | :                                                                                                               | SPI interface c | onfiguratio | on register |           |              |              |  |  |  |
|             | [7:3]                                                                                                           | RESERVED        |             |             |           |              |              |  |  |  |
|             | [2]                                                                                                             | AUTO_INCR:      |             |             |           |              |              |  |  |  |
|             | This bit defines whether the SPI transaction follows an addressing scheme that internally autoincrements or not |                 |             |             |           |              |              |  |  |  |

- [1] SPI\_CLK\_MOD1: This bit reflects the value of the SCAD/A0 pin during power-up reset
- [0] SPI\_CLK\_MOD0: This bit reflects the value of the SCAD/A0 pin during power-up reset



# 8 Interrupt system

The STMPE610 uses a 2-tier interrupt structure. The ADC interrupts and GPIO interrupts are ganged as a single bit in the "interrupt status register". The interrupts from the touchscreen controller can be seen directly in the interrupt status register.



Figure 8. Interrupt system diagram



INT\_CTRL

Interrupt control register

#### 7 6 5 2 0 4 3 1 RESERVED INT\_POLARITY INT\_TYPE GLOBAL\_INT Address: 0x09 R/W Type: **Reset:** 0x00 **Description:** The interrupt control register is used to enable the interruption from a system-related interrupt source to the host. [7:3] RESERVED [2] INT\_POLARITY: This bit sets the INT pin polarity 1: Active high/rising edge 0: Active low/falling edge [1] INT\_TYPE: This bit sets the type of interrupt signal required by the host 1: Edge interrupt 0: Level interrupt [0] GLOBAL\_INT: This is master enable for the interrupt system 1: Global interrupt

0: Stops all interrupts

#### INT\_EN

#### Interrupt enable register

| 7           | 6   | 5             | 4               | 3                   | 2                  | 1                 | 0              |
|-------------|-----|---------------|-----------------|---------------------|--------------------|-------------------|----------------|
| GPIO        | ADC | RESERVED      | FIFO_EMPTY      | FIFO_FULL           | FIFO_0FLOW         | FIFO_TH           | TOUCH_DET      |
| Address:    |     | 0x0A          |                 |                     |                    |                   |                |
| Туре:       |     | R/W           |                 |                     |                    |                   |                |
| Reset:      |     | 0x00          |                 |                     |                    |                   |                |
| Descriptior | n:  | The interrupt | enable regis    | ster is used<br>st. | l to enable the in | terruption from a | system related |
|             | [7] | GPIO: Any ena | bled GPIO in    | iterrupts           |                    |                   |                |
|             | [6] | ADC: Any enab | led ADC inte    | errupts             |                    |                   |                |
|             | [5] | RESERVED      |                 |                     |                    |                   |                |
|             | [4] | FIFO_EMPTY:   | FIFO is emp     | ty                  |                    |                   |                |
|             | [3] | FIFO_FULL: FI | FO is full      |                     |                    |                   |                |
|             | [2] | FIFO_OFLOW:   | FIFO is over    | rflowed             |                    |                   |                |
|             | [1] | FIFO_TH: FIFC | ) is equal or a | above thresh        | nold value         |                   |                |
|             | [0] | TOUCH_DET:    | Touch is dete   | ected               |                    |                   |                |



### INT\_STA

### Interrupt status register

| 7            | 6                  | 5                                                                                                                                                                                                                                                                                                   | 4                                              | 3                                              | 2                                                         | 1                                   | 0                 |  |  |  |  |
|--------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------|-----------------------------------------------------------|-------------------------------------|-------------------|--|--|--|--|
| GPIO         | ADC                | RESERVED                                                                                                                                                                                                                                                                                            | FIFO_EMPTY                                     | FIFO_FULL                                      | FIFO_OFLOW                                                | FIFO_TH                             | TOUCH_DET         |  |  |  |  |
| Address:     | 0                  | x0B                                                                                                                                                                                                                                                                                                 |                                                |                                                |                                                           |                                     |                   |  |  |  |  |
| Туре:        | R                  |                                                                                                                                                                                                                                                                                                     |                                                |                                                |                                                           |                                     |                   |  |  |  |  |
| Reset:       | 0                  | x10                                                                                                                                                                                                                                                                                                 |                                                |                                                |                                                           |                                     |                   |  |  |  |  |
| Description: | T<br>ir<br>II<br>b | The interrupt status register monitors the status of the interruption from a particular interrupt source to the host. Regardless of whether the INT_EN bits are enabled, the INT_STA bits are still updated. Writing '1' to this register clears the corresponding bits. Writing '0' has no effect. |                                                |                                                |                                                           |                                     |                   |  |  |  |  |
|              | [7] G              | PIO: Any ena                                                                                                                                                                                                                                                                                        | bled GPIO ir                                   | nterrupts                                      |                                                           |                                     |                   |  |  |  |  |
|              | [6] A              | DC: Any enab                                                                                                                                                                                                                                                                                        | led ADC inte                                   | errupts                                        |                                                           |                                     |                   |  |  |  |  |
|              | [5] R              | ESERVED                                                                                                                                                                                                                                                                                             |                                                |                                                |                                                           |                                     |                   |  |  |  |  |
|              | [4] F              | FO_EMPTY:                                                                                                                                                                                                                                                                                           | FIFO is emp                                    | ty                                             |                                                           |                                     |                   |  |  |  |  |
|              | [3] F              | IFO_FULL: FI                                                                                                                                                                                                                                                                                        | FO is full                                     |                                                |                                                           |                                     |                   |  |  |  |  |
|              | [2] F              | FO_OFLOW:                                                                                                                                                                                                                                                                                           | FIFO is ove                                    | rflowed                                        |                                                           |                                     |                   |  |  |  |  |
|              | [1] F<br>T<br>le   | IFO_TH: FIFC<br>his bit is set w<br>vel drops to <                                                                                                                                                                                                                                                  | ) is equal or<br>then FIFO lev<br>threshold va | above thresh<br>vel equals to<br>alue, and inc | nold value.<br>threshold value. It<br>reased back to thre | will only be asser<br>eshold value. | ted again if FIFO |  |  |  |  |
|              | [0] T              | OUCH_DET:                                                                                                                                                                                                                                                                                           | Touch is dete                                  | ected                                          |                                                           |                                     |                   |  |  |  |  |



### **GPIO\_INT\_EN**

## GPIO interrupt enable register

| 7            | 6                         | 5                                                                                                                                                                                                                                                                                            | 4 | 3      | 2 | 1 | 0 |
|--------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|---|---|---|
|              |                           |                                                                                                                                                                                                                                                                                              |   | IEG[x] |   |   |   |
| Address:     | 0x(                       | OC                                                                                                                                                                                                                                                                                           |   |        |   |   |   |
| Туре:        | R/                        | W                                                                                                                                                                                                                                                                                            |   |        |   |   |   |
| Reset:       | 0x                        | 10                                                                                                                                                                                                                                                                                           |   |        |   |   |   |
| Description: | Th<br>inte<br>bits<br>'0' | The interrupt status register monitors the status of the interruption from a particular interrupt source to the host. Regardless of whether the IER bits are enabled, the ISR bits are still updated. Writing '1' to this register clears the corresponding bits. Writing '0' has no effect. |   |        |   |   |   |

<sup>[7:0]</sup> IEG[x]: Interrupt enable GPIO mask (where x = 7 to 0)1: Writing '1' to the IE[x] bit enables the interruption to the host

### GPIO\_INT\_STA

### **GPIO** interrupt status register

| 7            | 6     | 5                                                                                                                                                                                                                                     | 4                                                                           | 3                                                                               | 2                                                                                       | 1                                                                                                | 0                                                                     |  |
|--------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--|
|              |       |                                                                                                                                                                                                                                       |                                                                             | ISG[x]                                                                          |                                                                                         |                                                                                                  |                                                                       |  |
| Address:     |       | 0x0D                                                                                                                                                                                                                                  |                                                                             |                                                                                 |                                                                                         |                                                                                                  |                                                                       |  |
| Туре:        |       | R/W                                                                                                                                                                                                                                   |                                                                             |                                                                                 |                                                                                         |                                                                                                  |                                                                       |  |
| Reset:       |       | 0x00                                                                                                                                                                                                                                  |                                                                             |                                                                                 |                                                                                         |                                                                                                  |                                                                       |  |
| Description: |       | The GPIO interparticular GPI<br>GPIO_STA bin<br>are the interru<br>register clears                                                                                                                                                    | errupt status<br>O pin interr<br>ts are enabl<br>pt status bi<br>the corres | s register mo<br>upt source to<br>led, the GPI0<br>ts correspon<br>ponding bits | nitors the statu<br>the host. Re<br>D_STA bits are<br>ding to the GP<br>Writing '0' has | us of the interrup<br>gardless of whet<br>still updated. TI<br>IO[7:0] pins. Wri<br>s no effect. | tion from a<br>her or not the<br>he ISG[7:0] bits<br>ting '1' to this |  |
|              | [7:0] | <ul> <li>:0] ISG[x]: GPIO interrupt status (where x = 7 to 0)</li> <li>Read:<br/>Interrupt status of the GPIO[x]. Reading the register will clear any bits that have<br/>Write:<br/>Writing to this register has no effect</li> </ul> |                                                                             |                                                                                 |                                                                                         |                                                                                                  |                                                                       |  |



# 9 Analog-to-digital converter

An 8-input, 12-bit analog-to-digital converter (ADC) is integrated in the STMPE610. The ADC can be used as a generic analog-to-digital converter, or as a touchscreen controller capable of controlling a 4-wire resistive touchscreen.

| Address | Register name | Size | Description                      |
|---------|---------------|------|----------------------------------|
| 0x20    | ADC_CTRL1     | 8    | ADC control                      |
| 0x21    | ADC_CTRL2     | 8    | ADC control                      |
| 0x22    | ADCCapture    | 8    | To initiate ADC data acquisition |
| 0x30    | ADC_DATA_CH0  | 8    | ADC channel 0 (IN3/GPIO-3)       |
| 0x32    | ADC_DATA_CH1  | 8    | ADC channel 1 (IN2/GPIO-2)       |
| 0x38    | ADC_DATA_CH4  | 8    | ADC channel 4 (TSC)              |
| 0x3A    | ADC_DATA_CH5  | 8    | ADC channel 5 (TSC)              |
| 0x3C    | ADC_DATA_CH6  | 8    | ADC channel 6 (TSC)              |
| 0x3E    | ADC_DATA_CH7  | 8    | ADC channel 7 (TSC)              |

 Table 13.
 ADC controller register summary table



ADC\_CTRL1

**ADC control 1** 

| 7          | 6                                                                         | 5                                                                     | 4               | 3               | 2                 | 1       | 0        |
|------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------|-----------------|-------------------|---------|----------|
| RESERVED   | SAMPLE_TIME2                                                              | SAMPLE_TIME1                                                          | SAMPLE_TIME0    | MOD_12B         | RESERVED          | REF_SEL | RESERVED |
| Address:   | 0x20                                                                      | 1                                                                     |                 |                 |                   |         |          |
| Туре:      | R/W                                                                       |                                                                       |                 |                 |                   |         |          |
| Reset:     | 0x9C                                                                      | ;                                                                     |                 |                 |                   |         |          |
| Descriptio | n: ADC                                                                    | control regist                                                        | er              |                 |                   |         |          |
|            | [6:4] SAM<br>000:<br>010:<br>010:<br>011:<br>100:<br>101:<br>110:<br>111: | PLE_TIMEn: AD<br>36<br>44<br>56<br>64<br>80<br>96<br>124<br>Not valid | DC conversion t | ime in numb     | er of clock       |         |          |
|            | [3] MOD<br>1: 12<br>0: 10                                                 | _12B: Selects 1<br>bit ADC<br>bit ADC                                 | 0 or 12-bit AD  | C operation     |                   |         |          |
|            | [2] RESI                                                                  | ERVED                                                                 |                 |                 |                   |         |          |
|            | [1] REF_<br>1: Ex<br>0: Int                                               | _SEL: Selects b<br>ternal reference<br>ernal reference                | etween interna  | l or external ı | reference for the | ADC     |          |
|            | [0] RESI                                                                  | ERVED                                                                 |                 |                 |                   |         |          |

### ADC\_CTRL2

### ADC control 2

| 7            | 6   | 5            | 4       | 3          | 2          | 1 | 0 |
|--------------|-----|--------------|---------|------------|------------|---|---|
|              |     | R            | ESERVED | ADC_FREQ_1 | ADC_FREQ_0 |   |   |
| Address:     |     | 0x21         |         |            |            |   |   |
| Туре:        |     | R/W          |         |            |            |   |   |
| Reset:       |     | 0x01         |         |            |            |   |   |
| Description: |     | ADC control. |         |            |            |   |   |
|              | [7] | RESERVED     |         |            |            |   |   |
|              | [6] | RESERVED     |         |            |            |   |   |
|              | [5] | RESERVED     |         |            |            |   |   |
|              | [4] | RESERVED     |         |            |            |   |   |
|              | [3] | RESERVED     |         |            |            |   |   |
|              | [2] | RESERVED     |         |            |            |   |   |

