

# LM8328 Mobile I/O Companion Supporting Keyscan, I/O Expansion, PWM, and ACCESS.bus Host Interface

Check for Samples: LM8328

# FEATURES

- KEY FEATURES
  - Internal RC Oscillator, No External Clock Required
  - Internal PWM Clock Generation, No External Clock Required
  - External Reset for System Control
  - Programmable I<sup>2</sup>C-compatible ACCESS.bus Address (Default 0x88)
  - Support for Keypad Matrices of up to of 8 x 12 Keys, Plus 8 Special Function (SF) Keys, for a Full 104 Key Support
  - I<sup>2</sup>C-compatible ACCESS.bus Slave Interface at 100 kHz (Standard-Mode) and 400 kHz (Fast-Mode)
  - Three Host-programmable PWM Outputs for Smooth LED Brightness Modulation
  - Supports General-purpose I/O Expansion on Pins Not Otherwise Used for Keypad or PWM Output
  - 15 byte Key Event Buffer
  - Multiple Key Event Storage
  - Key Events, Errors, and Dedicated Hardware Interrupts Request Host Service by Asserting an IRQ Output
  - Automatic HALT Mode for Low Power Operation
  - Wake-up from HALT Mode on Any Interface (Rising Edge, Falling Edge or Pulse)
  - Three PWM Outputs with Dedicated Script Buffer for up to 32 Commands
  - Register-based Command Interpreter with Auto Increment Address
- HOST-CONTROLLED FEATURES
  - Reset Input for System Control
  - PWM Scripting for Three PWM Outputs
  - Period of Inactivity that Triggers Entry into HALT Mode
  - Debounce Time for Reliable Key Event Polling

- Configuration of General Purpose I/O Ports
- Various Initialization Options (Keypad Size, etc.)
- KEY DEVICE FEATURES
  - 1.8V ± 10% Single-supply Operation
  - On-chip Power-on Reset (POR)
  - Watchdog Timer
  - -40°C to +85°C Temperature Range
  - 25-pin DSBGA Package

# **APPLICATIONS:**

- Cordless Phones
- Smart Handheld Devices
- Keyboard Applications

# DESCRIPTION

The LM8328 Genl/O - Expander and Keypad Controller is a dedicated device to unburden a host processor from scanning a matrix-addressed keypad and to provide flexible and general purpose, host programmable input/output functions. Three independent PWM timer outputs are provided for dynamic LED brightness modulation.

It communicates with a host processor through an I<sup>2</sup>C-compatible ACCESS.bus serial interface. It can communicate in Standard (100 kHz) - and Fast-Mode (400 kHz) in slave Mode only.

All available input/output pins can alternately be used as an input or an output in a keypad matrix or as a host programmable general purpose input or output.

Any pin programmed as an input can also sense hardware interrupts. The interrupt polarity ("high to low" or "low to high" transition) is thereby programmable.

The LM8328 follows a predefined register based set of commands. Upon start-up (power - on) a configuration file must be sent from the host to setup the hardware of the device.

Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet. All trademarks are the property of their respective owners.



www.ti.com

# LM8328 FUNCTION BLOCKS



Figure 1. LM8328 Pinout - Top View (balls underneath): Y = Outputs; X = Inputs



### SIGNAL DESCRIPTIONS

### **DEVICE PIN FUNCTIONS**

|      | KEY A                        | ND ALTERNAT | E FUNCTIONS ( | OF ALL DEVICE | PINS      |           |
|------|------------------------------|-------------|---------------|---------------|-----------|-----------|
| Ball | Function 0                   | Function 1  | Function 2    | Function 3    | Pin Count | Ball Name |
| C1   | Reset Active Low<br>Input    |             |               |               | 1         | RESETN    |
| C4   | Supply Voltage               |             |               |               | 1         | VCC       |
| D1   | Main I <sup>2</sup> C - Clk  |             |               |               | 1         | SCL       |
| E1   | Main I <sup>2</sup> C - Data |             |               |               | 1         | SDA       |
| A5   | Keypad-I/O X0                | Genio0      |               |               | 1         | KPX0      |
| B4   | Keypad-I/O X1                | Genio1      |               |               | 1         | KPX1      |
| D2   | Keypad-I/O X2                | Genio2      |               |               | 1         | KPX2      |
| E2   | Keypad-I/O X3                | Genio3      |               |               | 1         | KPX3      |
| A1   | Keypad-I/O X4                | Genio4      |               |               | 1         | KPX4      |
| B1   | Keypad-I/O X5                | Genio5      |               |               | 1         | KPX5      |
| A3   | Keypad-I/O X6                | Genio6      |               |               | 1         | KPX6      |
| A4   | Keypad-I/O X7                | Genio7      |               |               | 1         | KPX7      |
| D5   | Keypad-I/O Y0                | Genio8      |               |               | 1         | KPY0      |
| C5   | Keypad-I/O Y1                | Genio9      |               |               | 1         | KPY1      |
| B5   | Keypad-I/O Y2                | Genio10     |               |               | 1         | KPY2      |
| D4   | Keypad-I/O Y3                | Genio11     |               |               | 1         | KPY3      |
| B2   | Keypad-I/O Y4                | Genio12     |               |               | 1         | KPY4      |
| A2   | Keypad-I/O Y5                | Genio13     |               |               | 1         | KPY5      |
| B3   | Keypad-I/O Y6                | Genio14     |               |               | 1         | KPY6      |
| C2   | Keypad-I/O Y7                | Genio15     |               |               | 1         | KPY7      |
| D3   | Keypad-I/O Y8                | Genio16     | ClockOut      | PWM2          | 1         | KPY8      |
|      |                              |             |               |               |           | PWM2      |
| E4   | Keypad-I/O Y9                | Genio17     |               | PWM1          | 1         | KPY9      |
|      |                              |             |               |               |           | PWM1      |
| E5   | Keypad-I/O Y10               | Genio18     |               | PWM0          | 1         | KPY10     |
|      |                              |             |               |               |           | PWM0      |
|      |                              |             | 1             | 1             | 1         |           |

### **KEY AND ALTERNATE FUNCTIONS OF ALL DEVICE PINS**

### **PIN CONFIGURATION AFTER RESET**

Interrupt

Ground

TOTAL

Keypad-I/O Y11

E3

C3

Upon power-up or RESET the LM8328 will have defined states on all pins. Pin configuration after reset provides a comprehensive overview on the states of all functional pins.

Product Folder Links: LM8328

Genio19

PWM2

1

1

25

IRQN KPY11 PWM2

GND

SNLS328A-AUGUST 2011-REVISED MARCH 2013

STRUMENTS

**EXAS** 

### PIN CONFIGURATION AFTER RESET

| Dia -               |                                                                                  |
|---------------------|----------------------------------------------------------------------------------|
| Pins                | Pin States                                                                       |
| KPX0                |                                                                                  |
| KPX1                |                                                                                  |
| KPX2                |                                                                                  |
| КРХ3                | Full Buffer mode with an on-chip pull up resistor enabled.                       |
| KPX4                |                                                                                  |
| KPX5                |                                                                                  |
| KPX6                |                                                                                  |
| KPX7                |                                                                                  |
| KPY0                |                                                                                  |
| KPY1                |                                                                                  |
| KPY2                |                                                                                  |
| KPY3                |                                                                                  |
| KPY4                |                                                                                  |
| KPY5                | Full Buffer mode with an on-chip pull down resistor enabled.                     |
| KPY6                |                                                                                  |
| KPY7                |                                                                                  |
| KPY8 / PWM2         |                                                                                  |
| KPY9 / PWM1         |                                                                                  |
| KPY10 / PWM0        |                                                                                  |
| KPY11 / IRQN / PWM2 | Open Drain mode with no pull resistor enabled, driven low (IRQN). <sup>(1)</sup> |
| SCL<br>SDA          | Open Drain mode with no pull resistor enabled.                                   |

(1) The IRQN is driven low after Power-On Reset due to PORIRQ signal. The value 0x01 must be written to the RSTINTCLR register (0x84) to release the IRQN pin.



www.ti.com



# Figure 2. LM8328 in a Typical Setup with Standard Handset Keypad

# FEATURES

The following features are supported with the application example shown in example above:

### Hardware

Hardware

- 4 x 8 keys and 8 Special Function (SF) keys for 40 keys.
- ACCESS.bus interface for communication with a host device.
- - communication speeds supported are: 100 kHz and 400 kHz fast mode of operation.
- Interrupt signal (IRQN) to indicate any keypad or hardware interrupt events to the host.
- Sophisticated PWM function block with 3 independent channels to control color LED.
- External reset input for system control.
- Two host programmable dedicated general-purpose output pins (GPIOs) supporting IO-expansion capabilities for host device.
- Two host programmable dedicated general-purpose input pins with wake-up supporting IO-expansion capabilities for host device.

### **Communication Layer**

- Versatile register-based command integration supported from on-chip command interpreter.
- Keypad event storage.
- Individual PWM script file storage and execution control for 3 PWM channels.

# HALT MODE

# HALT MODE DESCRIPTION

The fully static architecture of the LM8328 allows stopping the internal RC clock in Halt mode, which reduces power consumption to the minimum level. Figure 3 shows the current in Halt mode at the maximum VCC (1.98V) from 25°C to +85°C.



Figure 3. Halt Current vs. Temperature at 1.98V

Halt mode is entered when no key-press event, key-release event, or ACCESS.bus activity is detected for a certain period of time (by default, 1020 milliseconds). The mechanism for entering Halt mode is always enabled in hardware, but the host can program the period of inactivity which triggers entry into Halt mode using the autosleep function. (See Table 47.)

# ACCESS.BUS ACTIVITY

When the LM8328 is in Halt mode, only activity on the ACCESS.bus interface that matches its Slave Address will cause the LM8328 to exit from Halt mode. However, the LM8328 will not be able to acknowledge the first bus cycle immediately following wake-up from Halt mode. It will respond with a negative acknowledgement, and the host should then repeat the cycle. A peripheral that is continuously active can share the bus since this activity will not prevent the LM8328 from entering Halt mode.

# LM8328 PROGRAMMING INTERFACE

The LM8328 operation is controlled from a host device by a complete register set, accessed via the  $l^2$ C-compatible ACCESS.bus interface. The ACCESS.bus communication is based on a READ/WRITE structure, following the  $l^2$ C transmission protocol. All functions can be controlled by configuring one or multiple registers. Please refer to LM8328 REGISTER SET for the complete register set.

### ACCESS.BUS COMMUNICATION

Figure 4 shows a typical read cycle initiated by the host.)

| S ADDRESS R/W=0 ACK REG ACK RS ADDRESS R/W=1 ACK DATA NAC |
|-----------------------------------------------------------|
|-----------------------------------------------------------|

| Figure 4. | Master/Slave | Serial | Communication | (Host to | LM8328) |
|-----------|--------------|--------|---------------|----------|---------|
|-----------|--------------|--------|---------------|----------|---------|

#### SNLS328A - AUGUST 2011 - REVISED MARCH 2013

| Term    | Bits | Description                                                                                                                                                                                                                     |
|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S       |      | START Condition (always generated from the master device)                                                                                                                                                                       |
| ADDRESS | 7    | Slave address of LM8328 sent from the host                                                                                                                                                                                      |
| R/W     | 1    | This bit determines if the following data transfer is from master to slave (data write) or from slave to master (data read).<br>0: Write<br>1: Read                                                                             |
| ACK     | 1    | An acknowledge bit is mandatory and must be appended on each byte transfer. The Acknowledge status is actually provided from the slave and indicates to the master, that the byte transfer was successful.                      |
| REG     | 8    | The first byte after sending the slave address is the REGISTER byte which contains the physical address the host wants to read from or write to.                                                                                |
| RS      |      | Repeated START condition                                                                                                                                                                                                        |
| DATA    | 8    | The DATA field contains information to be stored into a register or information read from a register.                                                                                                                           |
| NACK    | 1    | Not Acknowledge Bit. The Not Acknowledge status is assigned from the Master receiving data from a slave. The NACK status will actually be assigned from the master in order to signal the end of a communication cycle transfer |
| Р       |      | STOP condition (always generated from the master device)                                                                                                                                                                        |

### Table 1. Definition of Terms used in Serial Command Example

All actions associated with the non-shaded boxes in Figure 4 are controlled from the master (host) device.

All actions associated with the shaded boxes in Figure 4 are controlled from the slave (LM8328) device.

The master device can send subsequent REGISTER addresses separated by Repeated START conditions. A STOP condition must be set from the master at the very end of a communication cycle.

It is recommended to use Repeated START conditions in multi-Master systems when sending subsequent REGISTER addresses. This technique will make sure that the master device communicating with the LM8328 will not loose bus arbitration.

### Starting a Communication Cycle

There are two reasons for the host device to start communication to the LM8328:

- 1. The LM8328 device has set the IRQN line low in order to signal a key event or any other condition which initializes a hardware interrupt from LM8328 to the host.
- 2. The host device wants to set a GENIO port, read from a GENIO port, configure a GENIO port, and read the status from a register or initialize any other function which is supported from the LM8328. In case a GENIO shall be read it will be most likely, that the LM8328 device will be residing in "sleep mode". In this mode the system clock will be off to establish the lowest possible current consumption. If the host device starts the communication under this condition the LM8328 device will not be able to acknowledge the first attempt of sending the slave address. The LM8328 will wake up because of the START condition but it can't establish the internal timing to scan the first byte received. The master device must therefore apply a second attempt to start the communication with the LM8328 device.

### Communication Initialized from Host (Restart from Sleep Mode)



LM8328

SNLS328A - AUGUST 2011 - REVISED MARCH 2013



www.ti.com

- In the timing diagram shown in Figure 5 the LM8328 resides in sleep mode. Since the LM8328 device can't
  acknowledge the slave address the host must generate a STOP condition followed by a second START
  condition.
- On the second attempt the slave address is being acknowledged from the LM8328 device because it is in active mode now.
- The host can send different WRITE and/or READ commands subsequently after each other.
- The host must finally free the bus by generating a STOP condition.

### ACCESS.Bus Communication Flow

The LM8328 will only be driven in slave mode. The maximum communication speed supported is Fast Mode (FS) which is 400 kHz. The device can be heavily loaded as it is processing different kind of events caused from the human interface and the host device. In such cases the LM8328 may temporarily be unable to accept new commands and data sent from the host device.

### NOTE

"It is a legitimate measure of the slave device to hold SCL line low in such cases in order to force the master device into a waiting state. It is therefore the obligation of the host device to detect such cases. Typically there is a control bit set in the master device indicating the Busy status of the bus. As soon as the SCL line is released the host can continue sending commands and data."

### **Further Remarks:**

- In systems with multiple masters it is recommended to separate commands with Repeat START conditions rather than sending a STOP and another START condition to communicate with the LM8328 device.
- Delays enforced by the LM8328 during very busy phases of operation should typically not exceed a duration of 100 usec.
- Normally the LM8328 will clock stretch after the acknowledge bit Is transmitted; however, there are some conditions where the LM8328 will clock stretch between the SDA Start bit and the first rising edge of SCL.

### Auto Increment

In order to improve multi-byte register access, the LM8328 supports the auto increment of the address pointer.

A typical protocol access sequence to the LM8328 starts with the I<sup>2</sup>C-compatible ACCESS.bus address, followed by REG, the register to access (see Figure 4). After a REPEATED START condition the host reads/writes a data byte from/to this address location. If more than one byte is transmitted, the LM8328 automatically increments the address pointer for each data byte by 1. The address pointer keeps the status until the STOP condition is received.

The LM8328 always uses auto increments unless otherwise noted.

Please refer to Table 2 and Table 3 for the typical ACCESS.bus flow of reading and writing multiple data bytes.

### Reserved Registers and Bits

The LM8328 includes reserved registers for future implementation options. Please use value 0 on a write to all reserved register bits.

### Global Call Reset

The LM8328 supports the Global Call Reset as defined in the I<sup>2</sup>C Specification, which can be used by the host to reset all devices connected to interface. The Global call reset is a single byte ACCESS.bus/I<sup>2</sup>C write of data byte 0x06 to slave address 0x00.

The Global Call Reset changes the I<sup>2</sup>C-compatible ACCESS.bus Slave address of the LM8328 back to its default value of 0x88.



#### www.ti.com

|      | Table 2. Multi-Byte Write with Auto Increment |                       |       |                 |                                                |  |  |  |  |  |  |  |  |
|------|-----------------------------------------------|-----------------------|-------|-----------------|------------------------------------------------|--|--|--|--|--|--|--|--|
| Step | Master/Slave                                  | I <sup>2</sup> C Com. | Value | Address Pointer | Comment                                        |  |  |  |  |  |  |  |  |
| 1    | М                                             | S                     |       |                 | START condition                                |  |  |  |  |  |  |  |  |
| 2    | М                                             | ADDR.                 | 0x88  |                 | I <sup>2</sup> C-compatible ACCESS.bus Address |  |  |  |  |  |  |  |  |
| 3    | М                                             | R/W                   | 0     |                 | Write                                          |  |  |  |  |  |  |  |  |
| 4    | S                                             | ACK                   |       |                 | Acknowledge                                    |  |  |  |  |  |  |  |  |
| 5    | М                                             | REG                   | 0xAA  | 0xAA            | Register Address, used as Address Pointer      |  |  |  |  |  |  |  |  |
| 6    | S                                             | ACK                   |       | 0xAA            | Acknowledge                                    |  |  |  |  |  |  |  |  |
| 7    | М                                             | DATA                  | 0x01  | 0xAA            | Write Data to Address in Pointer               |  |  |  |  |  |  |  |  |
| 8    | S                                             | ACK                   | 0     | 0xAB            | Acknowledge, Address pointer incremented       |  |  |  |  |  |  |  |  |
| 9    | М                                             | DATA                  | 0x05  | 0xAB            | Write Data to address 0xAB                     |  |  |  |  |  |  |  |  |
| 10   | S                                             | ACK                   | 0     | 0xAC            | Acknowledge, Address pointer incremented       |  |  |  |  |  |  |  |  |
| 11   | М                                             | Р                     |       |                 | STOP condition                                 |  |  |  |  |  |  |  |  |

# Table 3. Multi-Byte Read with Auto Increment

| Step | Master/Slave | I <sup>2</sup> C Com. | Value | Address Pointer | Comment                                        |
|------|--------------|-----------------------|-------|-----------------|------------------------------------------------|
| 1    | М            | S                     |       |                 | START condition                                |
| 2    | М            | ADDR.                 | 0x88  |                 | I <sup>2</sup> C-compatible ACCESS.bus Address |
| 3    | М            | R/W                   | 0     |                 | Write                                          |
| 4    | S            | ACK                   |       |                 | Acknowledge                                    |
| 5    | М            | REG                   | 0xAA  | 0xAA            | Register Address, used as Address pointer      |
| 6    | S            | ACK                   |       | 0xAA            | Acknowledge                                    |
| 7    | М            | RS                    |       | 0xAA            | Repeated Start                                 |
| 8    | М            | ADDR.                 | 0x88  | 0xAA            | I <sup>2</sup> C-compatible ACCESS.bus Address |
| 9    | М            | R/W                   | 1     |                 | Read                                           |
| 10   | S            | ACK                   | 0     | 0xAA            | Acknowledge                                    |
| 11   | S            | DATA                  | 0x01  | 0xAA            | Read Data from Address in Pointer              |
| 12   | М            | ACK                   | 0     | 0xAB            | Acknowledge, Address Pointer incremented       |
| 13   | S            | DATA                  | 0x05  | 0xAB            | Read Data from Address in Pointer              |
| 14   | М            | NACK                  | 0     | 0xAC            | No Acknowledge, stops transmission             |
| 15   | М            | Р                     |       |                 | STOP condition                                 |

Texas Instruments

www.ti.com

# **KEYSCAN OPERATION**

### **KEYSCAN INITIALIZATION**



Figure 6. Keyscan Initialization

### **KEYSCAN INITIALIZATION EXAMPLE**

Table 4 shows all the LM8328 register configurations to initialize keyscan:

• Keypad matrix configuration is 8 rows x 8 columns.

| Table 4. | Keyscan | Initialization | Example |
|----------|---------|----------------|---------|
|----------|---------|----------------|---------|

| Register name | adress | Access Type | Value  | Comment                                                   |
|---------------|--------|-------------|--------|-----------------------------------------------------------|
| CLKEN         | 0x8A   | byte        | 0x01   | enable keyscan clock                                      |
| KBDSETTLE     | 0x01   | byte        | 0x80   | set the keyscan settle time to 12 msec                    |
| KBDBOUNCE     | 0x02   | byte        | 0x80   | set the keyscan debounce time to 12 msec                  |
| KBDSIZE       | 0x03   | byte        | 0x88   | set the keyscan matrix size to 8 rows x 8 columns         |
| KBDDEDCFG     | 0x04   | word        | 0xFC3F | configure KPX[7:2] and KPY[7:2] pins as keyboard matrix   |
| IOCFG         | 0xA7   | byte        | 0xF8   | write default value to enable all pins as keyboard matrix |
| IOPC0         | 0xAA   | word        | 0xAAAA | configure pull-up resistors for KPX[7:0]                  |
| IOPC1         | 0xAC   | word        | 0x5555 | configure pull-down resistors for KPY[7:0]                |
| KBDIC         | 0x08   | byte        | 0x03   | clear any pending interrupts                              |
| KBDMSK        | 0x09   | byte        | 0x03   | enable keyboard interrupts                                |



### **KEYSCAN PROCESS**

The LM8328 keyscan functionality is based on a specific scanning procedure performed in a 4ms interval. On each scan all assigned key matrix pins are evaluated for state changes.

In case a key event has been identified, the event is stored in the key event FIFO, accessible via the EVTCODE register. A key event can either be a key press or a key release. In addition, key presses are also stored in the KBDCODE[3:0] registers. As soon as the EVTCODE FIFO includes a event, the device sets the RAW keyboard event interrupt REVTINT. The RSINT interrupt is set anytime the keyboard status has changed.

Depending on the interrupt masking for the keyboard events (KBDMSK) and the masked interrupt handling (KBDMIS), the pin IRQN/KPY11/PWM2 will follow the IRQST.KBDIRQ status, which is set as soon as one interrupt in KBDRIS is set.

Figure 7 shows the basic flow of a scanning process and which registers are affected.



Figure 7. Example Keyscan Operation for 1 Key Press and Release

### **READING KEYSCAN STATUS BY THE HOST**

In order to keep track of the keyscan status, the host either needs to regularly poll the EVTCODE register or needs to react on the Interrupt signaled by the IRQN/KPY11/PWM2 pin, in case the ball is configured for interrupt functionality. (See GPIO Feature Mapping).

Figure 8 gives an example on which registers to read to get the keyboard events from the LM8328 and how they influence the interrupt event registers. The example is based on the assumption that the LM8328 has indicated the keyboard event by the IRQN/KPY11/PWM2 pin.

Since the interrupt pin has various sources, the host first checks the IRQST register for the interrupt source. If KBDIRQ is set, the host can check the KBDMIS register to define the exact interrupt source. KBDMIS contains the masked status of KBDRIS and reflects the source for raising the interrupt pin. The interrupt mask is defined by KBDMSK. The complete status of all pending keyboard interrupts is available in the raw interrupt register KBDRIS.

After evaluating the interrupt source the host starts reading the EVTCODE or KBDCODE register. In this example the host first reads the KBDCODE to get possible key press events and afterwards reads the complete event list by reading the EVTCODE register until all events are captured (0x7F indicates end of buffer).

Reading KBDCODE clears the RSINT interrupt bit if all keyboards events are emptied. In the same way, REVTINT is cleared in case the EVTCODE FIFO reaches its empty state on read.

The event buffer content and the REVTINT and RELINT (lost event) interrupt bits are also cleared if the KBDIC.EVTIC bit is set.

Interrupt bits in the masked interrupt register KBDMIS follow the masked KBDRIS status.

In order to support efficient Multi-byte reads from EVTCODE, the autoincrement feature is turned off for this register. Therefore the host can continuously read the complete EVTCODE buffer by sending one command.



Figure 8. Example Host Reacting to Interrupt for Keypad Event

### MULTIPLE KEY PRESSES

The LM8328 supports up to four simultaneous key presses. Any time a single key is pressed KBDCODE0 is set with the appropriate key code. If a second key is pressed, the key is stored in KBDCODE1 and the MULTIKEY flag of KBDCODE0 is set. Additional key presses are stored in KBDCODE2 and KBDCODE3 accordingly. The four registers signal the last multi key press events.

All events are stored in parallel in the EVTCODE register for the complete set of events.

All KBDCODE[3:0] registers are cleared on read.





Figure 9. Example Keyscan Operation for 2 Key Press Events and 1 Key Release Event

### **PWM TIMER**

The LM8328 supports a timer module dedicated to smooth LED control techniques (lighting controls).

The PWM timer module consists of three independent timer units of which each can generate a PWM output with a fixed period and automatically incrementing or decrementing variable duty cycle. The timer units are all clocked with a slow (32.768 kHz) clock whereas the interface operates with the main system clock.

### **OVERVIEW OF PWM FEATURES**

- Each PWM can establish fixed or variable duty-cycle signal sequences on its output.
- Each PWM can trigger execution of any pre-programmed task on another PWM channel.
- The execution of any pre-programmed task is self-sustaining and does not require further interaction from the host.
- 64-byte script buffer for each PWM for up to 32 consecutive instructions.
- Direct addressing within script buffer to support multiple PWM tasks in one buffer.

### **OVERVIEW ON PWM SCRIPT COMMANDS**

The commands listed in Table 5 are dedicated to the slow PWM timers.

### NOTE

The PWM Script commands are not part of the command set supported by the LM8328 command interpreter. These commands must be transferred from the host with help of the register-based command set.



|         |    | Table 5. PWM Script Commands |    |                           |         |      |     |   |      |      |    |      |       |      |   |   |
|---------|----|------------------------------|----|---------------------------|---------|------|-----|---|------|------|----|------|-------|------|---|---|
| Command | 15 | 14                           | 13 | 12                        | 11      | 10   | 9   | 8 | 7    | 6    | 5  | 4    | 3     | 2    | 1 | 0 |
| RAMP    | 0  | PRESCALE                     |    |                           | STEPTIN | IE   |     |   | SIGN |      |    | INCR | EMENT |      |   |   |
| SET_PWM | 0  | 1                            |    |                           | 0       |      |     |   |      |      | P٧ | MVAL | UE    |      |   |   |
| GO_TO_  |    |                              |    |                           |         |      |     | 0 |      |      |    |      |       |      |   |   |
| START   |    |                              |    |                           |         |      |     | 0 |      |      |    |      |       |      |   |   |
| BRANCH  | 1  | 0                            | 1  |                           | LOC     | OPCO | UNT |   |      | ADDR |    | S    | TEPNU | MBER |   |   |
| END     | 1  | 1                            | 0  | 1 INT X                   |         |      |     |   |      |      |    |      |       |      |   |   |
| TRIGGER | 1  | 1                            | 1  | WAITTRIGGER SENDTRIGGER ( |         |      |     |   |      |      | 0  |      |       |      |   |   |

### Table 5. PWM Script Commands

### RAMP COMMAND

A RAMP command will vary the duty cycle of a PWM output in either direction (up or down). The INCREMENT field specifies the amount of steps for the RAMP. The maximum amount of steps which can be executed with one RAMP Command is 126 which is equivalent to 50%. The SIGN bit field determines the direction of a RAMP (up or down). The STEPTIME field and the PRESCALE bit determine the duration of one step. Based on a 32.768 kHz clock, the minimum time resulting from these options would be 0.49 milliseconds and the maximum time for one step would be 1 second.

### Table 6. RAMP Command Bit and Building Fields

| 15 | 14       | 13 | 12       | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3     | 2  | 1 | 0 |
|----|----------|----|----------|----|----|---|---|---|---|---|----|-------|----|---|---|
| 0  | PRESCALE |    | STEPTIME |    |    |   |   |   |   |   | IN | CREME | NT |   |   |

### Table 7. Description of Bit and Building Fields of the RAMP Command

| Bit or Field | Value   | Description                                                                                            |
|--------------|---------|--------------------------------------------------------------------------------------------------------|
| PRESCALE     | 0       | Divide the 32.768 kHz clock by 16                                                                      |
| PRESCALE     | 1       | Divide the 32.768 kHz clock by 512                                                                     |
| STEPTIME     | 1 - 63  | Number of prescaled clock cycles per step                                                              |
| SIGN         | 0       | Increment ramp counter                                                                                 |
| SIGN         | 1       | Decrement ramp counter                                                                                 |
| INCREMENT    | 0 - 126 | Number of steps executed by this instruction; a value of 0 functions as a WAIT determined by STEPTIME. |

### SET\_PWM COMMAND

The SET\_PWM command will set the starting duty cycle MIN SCALE or FULL SCALE (0% or 100%). A RAMP command following the SET\_PWM command will finally establish the desired duty cycle on the PWM output.

|    |    |    | •  | Table 8. | SET_F | PWM C | omma | nd Bit | and B | uilding | Fields |      |   |   |   |
|----|----|----|----|----------|-------|-------|------|--------|-------|---------|--------|------|---|---|---|
| 15 | 14 | 13 | 12 | 11       | 10    | 9     | 8    | 7      | 6     | 5       | 4      | 3    | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0        | 0     | 0     | 0    |        |       |         | DUTYC  | YCLE |   |   |   |

### Table 9. Description of Bit and Building Fields of the SET\_PWM Command

| Bit or Field | Value | Description         |
|--------------|-------|---------------------|
| DUTYCYCLE    | 0     | Duty cycle is 0%.   |
| DOTICICLE    | 255   | Duty cycle is 100%. |

### GO\_TO\_START COMMAND

The GO\_TO\_START command jumps to the first command in the script command file.



SNLS328A - AUGUST 2011 - REVISED MARCH 2013

|    |    |    | Table | 10. GC | D_TO_S | TART | Comm | nand B | it and | Buildi | ng Fiel | ds |   |   |   |
|----|----|----|-------|--------|--------|------|------|--------|--------|--------|---------|----|---|---|---|
| 15 | 14 | 13 | 12    | 11     | 10     | 9    | 8    | 7      | 6      | 5      | 4       | 3  | 2 | 1 | 0 |
|    |    |    |       |        |        |      | 0    |        |        |        |         |    |   |   |   |

### BRANCH COMMAND

The BRANCH command jumps to the specified command in the script command file. The branch is executed with either absolute or relative addressing. In addition, the command gives the option of looping for a specified number of repetitions.

NOTE

Nested loops are not allowed.

|    |                                       |   | Та | able 11                   | I. BRA | NCH ( | Comm | and E | Bit and B | uilding | g Field | S |  |  |  |
|----|---------------------------------------|---|----|---------------------------|--------|-------|------|-------|-----------|---------|---------|---|--|--|--|
| 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |   |    |                           |        |       |      |       |           |         |         |   |  |  |  |
| 1  | 0                                     | 1 |    | LOOPCOUNT ADDR STEPNUMBER |        |       |      |       |           |         |         |   |  |  |  |

### Table 12. Description of Bit and Building Fields of the BRANCH Command

| Bit or Field                | Value | Description                                                                       |  |  |  |  |  |
|-----------------------------|-------|-----------------------------------------------------------------------------------|--|--|--|--|--|
| LOOPCOUNT 1 - 63 1          |       | Loop until a STOP PWM SCRIPT command is issued by the host.                       |  |  |  |  |  |
|                             |       | umber of loops to perform.                                                        |  |  |  |  |  |
|                             |       | Absolute addressing                                                               |  |  |  |  |  |
| ADDR                        | 1     | Relative addressing                                                               |  |  |  |  |  |
| STEPNUMBER 0 - 63 ADDR=0: A |       | Depending on ADDR:<br>ADDR=0: Addr to jump to<br>ADDR=1: Number of backward steps |  |  |  |  |  |

### TRIGGER COMMAND

Triggers are used to synchronize operations between PWM channels. A TRIGGER command that sends a trigger takes sixteen 32.768 kHz clock cycles, and a command that waits for a trigger takes at least sixteen 32.768 kHz clock cycles.

A TRIGGER command that waits for a trigger (or triggers) will stall script execution until the trigger conditions are satisfied. On trigger it will clear the trigger(s) and continue to the next command.

When a trigger is sent, it is stored by the receiving channel and can only be cleared when the receiving channel executes a TRIGGER command that waits for the trigger.

. . .

. . .. ..

\_. . .

|    |    |    | -  | Table 1                 | 3. TRI | GGER ( | Comma | nd Bit | and Buil | ding | Fields | 5 |   |   |   |
|----|----|----|----|-------------------------|--------|--------|-------|--------|----------|------|--------|---|---|---|---|
| 15 | 14 | 13 | 12 | 11                      | 10     | 9      | 8     | 7      | 6        | 5    | 4      | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  |    | WAITTRIGGER SENDTRIGGER |        |        |       |        |          |      |        | 0 |   |   |   |

Table 14. Description of Bit and Building Fields

- . . . . ---- .

| Field       | Value  | Description                     |  |  |  |  |  |  |  |  |
|-------------|--------|---------------------------------|--|--|--|--|--|--|--|--|
|             | 000xx1 | Wait for trigger from channel 0 |  |  |  |  |  |  |  |  |
| WAITTRIGGER | 000x1x | Wait for trigger from channel 1 |  |  |  |  |  |  |  |  |
|             | 0001xx | Wait for trigger from channel 2 |  |  |  |  |  |  |  |  |
|             | 000xx1 | Send trigger to channel 0       |  |  |  |  |  |  |  |  |
| SENDTRIGGER | 000x1x | Send trigger to channel 1       |  |  |  |  |  |  |  |  |
|             | 0001xx | Send trigger to channel 2       |  |  |  |  |  |  |  |  |

# END COMMAND

The END command terminates script execution. It will only assert an interrupt to the host if the INT bit is set to "1".

When the END command is executed, the PWM output will be set to the level defined by PWMCFG.PWMPOL for this channel. Also, the script counter is reset back to the beginning of the script command buffer.

### **NOTE** If a PWM channel is waiting for the trigger (last executed command was "TRIGGER") and the script execution is halted then the "END" command can't be executed because the previous command is still pending. This is an exception - in this case the IRQ signal will not be asserted.

|    |    |    |    | able 15. ENL | Com | mand | Bit a | nd B | uilding | Field | lS |   |   |   |   |
|----|----|----|----|--------------|-----|------|-------|------|---------|-------|----|---|---|---|---|
| 15 | 14 | 13 | 12 | 11           | 10  | 9    | 8     | 7    | 6       | 5     | 4  | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | INT          |     |      |       |      |         | 0     |    |   |   |   |   |

. ....

. . . .

# Table 16. Description of Bit and Building Fields of the END Command

|       | •     |                                                                         |
|-------|-------|-------------------------------------------------------------------------|
| Field | Value | Description                                                             |
| INIT  | 0     | No interrupt will be sent.                                              |
| INT   | 1     | Set TIMRIS.CDIRQ for this PWM channel to notify that program has ended. |

# LM8328 REGISTER SET

# **KEYBOARD REGISTERS AND KEYBOARD CONTROL**

Keyboard selection and control registers are mapped in the address range from 0x01 to 0x10. This paragraph describes the functions of the associated registers down to the bit level.

### KBDSETTLE - Keypad Settle Time Register

| Table 17. KBDSETTLE - Keypad Settle Time Register |
|---------------------------------------------------|
|---------------------------------------------------|

| Register - Name | Address | Туре    | Register Function                                                        |
|-----------------|---------|---------|--------------------------------------------------------------------------|
| KBDSETTLE       | 0x01    | R/W     | Initial time for keys to settle, before the key-scan process is started. |
| Bit - Name      | Bit     | Default | Bit Function                                                             |
|                 |         |         | The default value 0x80 : 0xBF sets a time target of 12 msec              |
|                 |         |         | Further time targets are as follows:                                     |
|                 |         |         | 0xC0 - 0xFF: 16 msec                                                     |
| WAIT[7:0]       | 7:0     | 0x80    | 0x80 - 0xBF: 12 msec                                                     |
|                 |         |         | 0x40 - 0x7F: 8 msec                                                      |
|                 |         |         | 0x01 - 0x3F: 4 msec                                                      |
|                 |         |         | 0x00 : no settle time                                                    |

### KBDBOUNCE - Debounce Time Register

| Register - Name | Address | Туре    | Register Function                                             |
|-----------------|---------|---------|---------------------------------------------------------------|
| KBDBOUNCE       | 0x02    | R/W     | Time between first detection of key and final sampling of key |
| Bit - Name      | Bit     | Default | Bit Function                                                  |

STRUMENTS



www.ti.com

# Table 18. KBDBOUNCE - Debounce Time Register (continued)

| Register - Name | Address | Туре | Register Function                                           |
|-----------------|---------|------|-------------------------------------------------------------|
|                 |         |      | The default value 0x80 : 0xBF sets a time target of 12 msec |
|                 |         |      | Further time targets are as follows:                        |
|                 |         |      | 0xC0 - 0xFF: 16 msec                                        |
| WAIT[7:0]       | 7:0     | 0x80 | 0x80 - 0xBF: 12 msec                                        |
|                 |         |      | 0x40 - 0x7F: 8 msec                                         |
|                 |         |      | 0x01 - 0x3F: 4 msec                                         |
|                 |         |      | 0x00: no debouncing time                                    |

### KBDSIZE - Set Keypad Size Register

| Register - Name | Address | Туре    | Register Function                                                                                             |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------------------------|
| KBDSIZE         | 0x03    | R/W     | Defines the physical keyboard matrix size                                                                     |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                  |
|                 |         |         | Number of rows in the keyboard matrix                                                                         |
| ROWSIZE[3:0]    | 7:4     | 0x2     | 0x0: free all rows to become GPIO, KPX[1:0] used as dedicated key inputs if scanning is enabled by CLKEN.KBEN |
|                 |         |         | 0x1: (illegal value)                                                                                          |
|                 |         |         | 0x2 - 0x8: Number of rows in the matrix                                                                       |
|                 | 3:0     | 0x2     | Number of columns in the keyboard matrix                                                                      |
| COLSIZE[3:0]    |         |         | 0x0: free all rows to become GPIO, KPY[1:0] used as dedicated key inputs if scanning is enabled by CLKEN.KBEN |
|                 |         |         | 0x1: (illegal value)                                                                                          |
|                 |         |         | 0x2 - 0xC: Number of columns in the matrix                                                                    |

### Table 19. KBDSIZE - Set Keypad Size Register

### KBDDEDCFG - Dedicated Key Register

### Table 20. KBDDEDCFG - Dedicated Key Register

| Register - Name | Address        | Туре                                                                                                                                          | Register Function                                                                                                                                   |
|-----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| KBDDEDCFG       | KBDDEDCFG 0x04 |                                                                                                                                               | Defines if a key is used as a standard keyboard/GPIO pin or whether it is used as dedicated key input.                                              |
| Bit - Name      | Bit            | Default                                                                                                                                       | Bit Function                                                                                                                                        |
|                 |                |                                                                                                                                               | Each bit in ROW [7:2] corresponds to ball KPX7 : KPX2.                                                                                              |
|                 |                |                                                                                                                                               | Bit=0: the dedicated key function applies.                                                                                                          |
| ROW[7:2]        | 15:10          | 0x3F                                                                                                                                          | Bit=1: no dedicated key function is selected. The standard GPIO<br>functionality applies according to register IOCFG or defined keyboard<br>matrix. |
|                 | 9:8            | 0x03                                                                                                                                          | Each bit in COL [11:10] corresponds to ball KPY11 : KPY10.                                                                                          |
|                 |                |                                                                                                                                               | Bit=0: the dedicated key function applies.                                                                                                          |
| COL[11:10]      |                |                                                                                                                                               | Bit=1: no dedicated key function is selected. The standard GPIO<br>functionality applies according to register IOCFG or defined keyboard<br>matrix. |
|                 | 7:0 0xFF       | OVEE                                                                                                                                          | Each bit in COL [9:2] corresponds to ball KPY9 : KPY2 and can be configured individually.                                                           |
| COL[9:2]        |                |                                                                                                                                               | Bit=0: the dedicated key function applies.                                                                                                          |
| 00[8.2]         |                | Bit=1: no dedicated key function is selected. The standard GPIO functionality applies according to register IOCFG or defined keyboard matrix. |                                                                                                                                                     |



### KBDRIS - Keyboard Raw Interrupt Status Register

| Register - Name | Address | Туре                                                                         | Register Function                                                                                                                                                 |
|-----------------|---------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KBDRIS          | 0x06    | R                                                                            | Returns the status of stored keyboard interrupts.                                                                                                                 |
| Bit - Name      | Bit     | Default                                                                      | Bit Function                                                                                                                                                      |
| (reserved)      | 7:4     |                                                                              | (reserved)                                                                                                                                                        |
|                 |         |                                                                              | Raw event lost interrupt.                                                                                                                                         |
| RELINT          | 3       | 0x0                                                                          | More than 8 keyboard events have been detected and caused the event buffer to overflow. This bit is cleared by setting bit EVTIC of the KBDIC register.           |
|                 | 2       | 0x0                                                                          | Raw keyboard event interrupt.                                                                                                                                     |
| REVTINT         |         |                                                                              | At least one key press or key release is in the keyboard event buffer.<br>Reading from EVTCODE until the buffer is empty will clear this interrupt.               |
|                 |         |                                                                              | Raw key lost interrupt indicates a lost key-code.                                                                                                                 |
| RKLINT          | 1       | 0x0                                                                          | This interrupt is asserted when RSINT has not been cleared upon detection of a new key press or key release, or when more than 4 keys are pressed simultaneously. |
|                 |         |                                                                              | Raw scan interrupt.                                                                                                                                               |
| RSINT           | 0 0x0   | Interrupt generated after keyboard scan, if the keyboard status has changed. |                                                                                                                                                                   |

### Table 21. KBDRIS - Keyboard Raw Interrupt Status Register

### KBDMIS - Keypad Masked Interrupt Status Register

### Table 22. KBDMIS - Keypad Masked Interrupt Status Register

| Register - Name | Address  | Туре                                                                        | Register Function                                                                                                                                                                                  |
|-----------------|----------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KBDMIS          | 0x07     | R Returns the status on masked keyboard interrupts after n KBDMSK register. |                                                                                                                                                                                                    |
| Bit - Name      | Bit      | Default                                                                     | Bit Functions                                                                                                                                                                                      |
| (reserved)      | 7:4      |                                                                             | (reserved)                                                                                                                                                                                         |
|                 |          |                                                                             | Masked event lost interrupt.                                                                                                                                                                       |
| MELINT          | MELINT 3 | 0x0                                                                         | More than 8 keyboard events have been detected and caused the event buffer to overflow. This bit is cleared by setting bit EVTIC of the KBDIC register.                                            |
|                 |          |                                                                             | Masked keyboard event interrupt.                                                                                                                                                                   |
| MEVTINT         | 2        | 0x0                                                                         | At least one key press or key release is in the keyboard event buffer.<br>Reading from EVTCODE until the buffer is empty will clear this interrupt.                                                |
|                 | NT 1     |                                                                             | Masked key lost interrupt.                                                                                                                                                                         |
| MKLINT          |          | 0x0                                                                         | Indicates a lost key-code. This interrupt is asserted when RSINT has not<br>been cleared upon detection of a new key press or key release, or when<br>more than 4 keys are pressed simultaneously. |
|                 |          |                                                                             | Masked scan interrupt.                                                                                                                                                                             |
| MSINT           | MSINT 0  | 0x0                                                                         | Interrupt generated after keyboard scan, if the keyboard status has changed, after masking process.                                                                                                |

### KBDIC - Keypad Interrupt Clear Register

### Table 23. KBDIC - Keypad Interrupt Clear Register

| Register - Name | Address | Default | Register Function                                  |
|-----------------|---------|---------|----------------------------------------------------|
| KBDIC           | 0x08    | W       | Setting these bits clears Keypad active Interrupts |
| Bit - Name      | Bit     | Default | Bit Function                                       |

www.ti.com

### Table 23. KBDIC - Keypad Interrupt Clear Register (continued)

| Register - Name | Address | Default | Register Function                                                                                      |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------|
|                 |         |         | Switches off scanning of special function (SF) keys, when keyboard has no special function layout.     |
| SFOFF           | 7       |         | 0: keyboard layout and SF keys are scanned                                                             |
|                 |         |         | 1: only keyboard layout is scanned, SF keys are not scanned                                            |
| (reserved)      | 6:2     |         | (reserved)                                                                                             |
| EVTIC           | 1       |         | Clear event buffer and corresponding interrupts REVTINT and RELINT by writing a 1 to this bit position |
| KBDIC           | 0       |         | Clear RSINT and RKLINT interrupt bits by writing a 1 to this bit position.                             |

### KBDMSK - Keypad Interrupt Mask Register

| Table 24. Ki | BDMSK - Keypad | Interrupt Ma | ask Register |
|--------------|----------------|--------------|--------------|
|--------------|----------------|--------------|--------------|

|                 |         |         | Roypad Interrupt Maex Royleton                                                                                                                                                                                                                                                               |
|-----------------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register - Name | Address | Туре    | Register Function                                                                                                                                                                                                                                                                            |
|                 |         |         | Configures masking of keyboard interrupts. Masked interrupts do not trigger an event on the Interrupt output.                                                                                                                                                                                |
| KBDMSK          | 0x09    | R/W     | In case the interrupt processes registers KBDCODE[3:0], MSKELINT and MSKEINT should be set to 1. When the Event FIFO is processed, MSKLINT and MSKSINT should be set. For keyboard polling operations, all bits should be set and the polling operation consists of reading out the EVTCODE. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                                                                                                                                                 |
| (reserved)      | 7:4     |         | (reserved)                                                                                                                                                                                                                                                                                   |
| MSKELINT        | 3       | 0x0     | 0: keyboard event lost interrupt RELINT triggers IRQ line                                                                                                                                                                                                                                    |
| WSKELINI        | 5       |         | 1: keyboard event lost interrupt RELINT is masked                                                                                                                                                                                                                                            |
| MSKEINT         | 0       | 0x0     | 0: keyboard event interrupt REVINT triggers IRQ line                                                                                                                                                                                                                                         |
| MOREINI         | 2       |         | 1: keyboard event interrupt REVINT is masked                                                                                                                                                                                                                                                 |
| MSKLINT         | 1       | 0x1     | 0: keyboard lost interrupt RKLINT triggers IRQ line                                                                                                                                                                                                                                          |
| WISTLINT        | I       | UXT     | 1: keyboard lost interrupt RKLINT is masked                                                                                                                                                                                                                                                  |
| MSKSINT         | 0       | 0×1     | 0: keyboard status interrupt RSINT triggers IRQ line                                                                                                                                                                                                                                         |
| IVIOR SIN I     | 0       | 0 0x1   | 1: keyboard status interrupt RSINT is masked                                                                                                                                                                                                                                                 |

### KBDCODE0 - Keyboard Code Register 0

The key code detected by the keyboard scan can be read from the registers KBDCODE0: KBDCODE3. Up to 4 keys can be detected simultaneously. Each KBDCODE register includes a bit (MULTIKEY) indicating if another key has been detected.

### NOTE

Reading out all key code registers (KBDCODE0 to KBDCODE3) will automatically reset the keyboard scan interrupt RSINT the same way as an active write access into bit KBDIC of the interrupt clear register does. Reading 0x7F from the KBDCODE0 register means that no key was pressed.

| Register - Name | Address | Default | Register Function                                               |
|-----------------|---------|---------|-----------------------------------------------------------------|
| KBDCODE0        | 0x0B    | R       | Holds the row and column information of the first detected key  |
| Bit - Name      | Bit     | Default | Bit Function                                                    |
| MULTIKEY        | 7       | 0x0     | if this bit is 1 another key is available in KBDCODE1 register  |
| KEYROW[2:0]     | 6:4     | 0x7     | ROW index of detected key (0 to 7)                              |
| KEYCOL[3:0]     | 3:0     | 0xF     | Column index of detected (0 to 11, 12 for special function key. |

### Table 25. KBDCODE0 - Keyboard Code Register 0

# KBDCODE1 - Keyboard Code Register 1

| Register - Name | Address | Default | Register Function                                                    |
|-----------------|---------|---------|----------------------------------------------------------------------|
| KBDCODE1        | 0x0C    | R       | Holds the row and column information of the second detected key      |
| Bit - Name      | Bit     | Default | Bit Function                                                         |
| MULTIKEY        | 7       | 0x0     | if this bit is 1 another key is available in KBDCODE2 register       |
| KEYROW[2:0]     | 6:4     | 0x7     | ROW index of detected key (0 to 7)                                   |
| KEYCOL[3:0]     | 3:0     | 0xF     | Column index of detected key (0 to 11, 12 for special function key). |

### Table 26. KBDCODE1 - Keyboard Code Register 1

# KBDCODE2 - Keyboard Code Register 2

### Table 27. KBDCODE2 - Keyboard Code Register 2

| Register - Name | Address | Default | Register Function                                                    |
|-----------------|---------|---------|----------------------------------------------------------------------|
| KBDCODE2        | 0x0D    | R       | Holds the row and column information of the third detected key       |
| Bit - Name      | Bit     | Default | Bit Function                                                         |
| MULTIKEY        | 7       | 0x0     | if this bit is 1 another key is available in KBDCODE3 register       |
| KEYROW[2:0]     | 6:4     | 0x7     | ROW index of detected key (0 to 7)                                   |
| KEYCOL[3:0]     | 3:0     | 0xF     | Column index of detected key (0 to 11, 12 for special function key). |

### KBDCODE3 - Keyboard Code Register 3

### Table 28. KBDCODE3 - Keyboard Code Register 3

|                 |         |         | , .                                                                         |
|-----------------|---------|---------|-----------------------------------------------------------------------------|
| Register - Name | Address | Default | Register Function                                                           |
| KBDCODE3        | 0x0E    | R       | Holds the row and column information of the forth detected key              |
| Bit - Name      | Bit     | Default | Bit Function                                                                |
| MULTIKEY        | 7       | 0x0     | if this bit is set to "1" then more than 4 keys are pressed simultaneously. |
| KEYROW[2:0]     | 6:4     | 0x7     | ROW index of detected key (0 to 7)                                          |
| KEYCOL[3:0]     | 3:0     | 0xF     | Column index of detected key (0 to 11, 12 for special function key).        |

### EVTCODE - Key Event Code Register

### Table 29. EVTCODE - Key Event Code Register

| Register - Name | Address | Default | Bit Function                                                                                               |
|-----------------|---------|---------|------------------------------------------------------------------------------------------------------------|
|                 | 0x10    | R       | With this register a FIFO buffer is addressed storing up to 15 consecutive events.                         |
| EVTCODE         |         |         | Reading the value 0x7F from this address means that the FIFO buffer is empty. See further details below.   |
|                 |         |         | NOTE: Auto increment is disabled on this register. Multi-byte read will always read from the same address. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                               |
|                 | 7       | 0x0     | This bit indicates, whether the keyboard event was a key press or a key release event.                     |
| RELEASE         |         |         | 0: key was pressed                                                                                         |
|                 |         |         | 1: key was released                                                                                        |
| KEYROW[2:0]     | 6:4     | 0x7     | Row index of key that is pressed or released.                                                              |
| KEYCOL[3:0]     | 3:0     | 0xF     | Column index of key that is pressed (011, 12 for special function key) or released.                        |



### **PWM TIMER CONTROL REGISTERS**

The LM8328 provides three host-programmable PWM outputs useful for smooth LED brightness modulation. All PWM timer control registers are mapped in the range from 0x60 to 0x7F. This paragraph describes the functions of the associated registers down to the bit level.

### TIMCFGx - PWM Timer 0, 1 and 2 Configuration Registers

### Table 30. TIMCFGx - PWM Timer 0, 1 and 2 Configuration Registers

| Register - Name               | Address | Туре                | Register Function                                                                                               |
|-------------------------------|---------|---------------------|-----------------------------------------------------------------------------------------------------------------|
| TIMCFG0                       | 0x60    |                     |                                                                                                                 |
| TIMCFG1                       | 0x68    | R/W                 | This register configures interrupt masking and handles PWM start/stop<br>control of the associated PWM channel. |
| TIMCFG2                       | 0x70    |                     | control of the associated I will channel.                                                                       |
| Bit - Name<br>(x = 0, 1 or 2) | Bit     | Default             | Bit Function                                                                                                    |
|                               |         |                     | Interrupt mask for PWM CYCIRQx (see register TIMRIS)                                                            |
| CYCIRQxMSK                    | 4       | 0x0                 | 0: interrupt enabled                                                                                            |
|                               |         | 1: interrupt masked |                                                                                                                 |
| (reserved)                    | 3:0     | 0x0                 | (reserved)                                                                                                      |

### PWMCFGx - PWM Timer 0, 1 and 2 Configuration Control Registers

### Table 31. PWMCFGx - PWM Timer 0, 1 and 2 Configuration Control Registers

| Register - Name               | Address | Туре    | Register Function                                                                                                                |
|-------------------------------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| PWMCFG0                       | 0x61    |         | This register defines interrupt masking and the output behavior for the associated PWM channel.                                  |
| PWMCFG1                       | 0x69    | R/W     | PGEx is used to start and stop the PWM script execution.                                                                         |
| PWMCFG2                       | 0x71    |         | PWMENx sets the PWM output to either reflect the generated pattern or the value configured in PWMPOLx.                           |
| Bit - Name<br>(x = 0, 1 or 2) | Bit     | Default | Bit Function                                                                                                                     |
|                               | 3       | 0x0     | Mask for CDIRQx                                                                                                                  |
| CDIRQxMSK                     |         |         | 0: CDIRQx enabled                                                                                                                |
|                               |         |         | 1: CDIRQx disabled/masked                                                                                                        |
|                               |         | 0x0     | Pattern Generator Enable. Start/Stop PWM command processing for this channel. Script execution is started always from beginning. |
| PGEx                          | 2       |         | 0: Pattern Generator disabled                                                                                                    |
|                               |         |         | 1: Pattern Generator enabled                                                                                                     |
| PWMENx                        | 1       | 0x0     | 0: PWM disabled. PWM timer output assumes value programmed in PWMPOL.                                                            |
|                               |         |         | 1: PWM enabled                                                                                                                   |
|                               |         |         | Off-state of PWM output, when PWMEN=0.                                                                                           |
| PWMPOLx                       | 0       | 0x0     | 0: PWM off-state is low                                                                                                          |
|                               |         |         | 1: PWM off-state is high                                                                                                         |

### TEXAS INSTRUMENTS

www.ti.com

### TIMSWRES - PWM Timer Software Reset Registers

| Register - Name | Address | Туре    | Register Function                                                                                                                                                            |
|-----------------|---------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |         |         | Reset control on all PWM timers                                                                                                                                              |
| TIMSWRES        | 0x78    | w       | A reset forces the pattern generator to fetch the first pattern and stops it. Each reset stops all state-machines and timer.                                                 |
|                 | 0,70    |         | Patterns stored in the pattern configuration register remain unaffected.<br>Interrupts on each timer are not cleared, they need to be cleared writing<br>into register TIMIC |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                                 |
| (reserved)      | 7:3     |         | (reserved)                                                                                                                                                                   |
|                 |         |         | Software reset of timer 2.                                                                                                                                                   |
| SWRES2          | 2       |         | 0: no action                                                                                                                                                                 |
|                 |         |         | 1: Software reset on timer 2, needs not to be written back to 0.                                                                                                             |
|                 |         |         | Software reset of timer 1.                                                                                                                                                   |
| SWRES1          | 1       |         | 0: no action                                                                                                                                                                 |
|                 |         |         | 1: Software reset on timer 1, needs not to be written back to 0.                                                                                                             |
|                 |         |         | Software reset of timer 0.                                                                                                                                                   |
| SWRES0          | 0       |         | 0: no action                                                                                                                                                                 |
|                 |         |         | 1: software reset on timer 0, needs not to be written back to 0.                                                                                                             |

### Table 32. TIMSWRES - PWM Timer Software Reset Registers

# TIMRIS - PWM Timer Interrupt Status Register

# Table 33. TIMRIS - PWM Timer Interrupt Status Register

| Register - Name | Address | Туре    | Register Function                                                                                                                                           |
|-----------------|---------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |         |         | This register returns the raw interrupt status from the PMW timers 0,1 and 2.                                                                               |
| TIMRIS          | 0x7A    | R       | CYCIRQx - Interrupt from the timers when PWM cycle is complete (applies to the current PWM command residing in the active command register of a PWM block). |
|                 |         |         | CDIRQx - Interrupt from the pattern generator when PWM pattern code is complete (applies to a completed task residing in the script buffer of a PWM block). |
| Bit - Name      | Bit     | Default | Bit Functions                                                                                                                                               |
| (reserved)      | 7:6     |         | (reserved)                                                                                                                                                  |
|                 |         |         | Raw interrupt status for CDIRQ timer2                                                                                                                       |
| CDIRQ2          | 5       | 0x0     | 0: no interrupt pending                                                                                                                                     |
|                 |         |         | 1: unmasked interrupt generated                                                                                                                             |
|                 |         |         | Raw interrupt status for CDIRQ timer1                                                                                                                       |
| CDIRQ1          | 4       | 0x0     | 0: no interrupt pending                                                                                                                                     |
|                 |         |         | 1: unmasked interrupt generated                                                                                                                             |
|                 |         |         | Raw interrupt status for CDIRQ timer0                                                                                                                       |
| CDIRQ0          | 3       | 0x0     | 0: no interrupt pending                                                                                                                                     |
|                 |         |         | 1: unmasked interrupt generated                                                                                                                             |
|                 |         |         | Raw interrupt status for CYCIRQ timer2                                                                                                                      |
| CYCIRQ2         | 2       | 0x0     | 0: no interrupt pending                                                                                                                                     |
|                 |         |         | 1: unmasked interrupt generated                                                                                                                             |
|                 |         |         | Raw interrupt status for CYCIRQ timer1                                                                                                                      |
| CYCIRQ1         | 1       | 0x0     | 0: no interrupt pending                                                                                                                                     |
|                 |         |         | 1: unmasked interrupt generated                                                                                                                             |



www.ti.com

# Table 33. TIMRIS - PWM Timer Interrupt Status Register (continued)

| Register - Name | Address | Туре | Register Function                      |  |
|-----------------|---------|------|----------------------------------------|--|
|                 |         |      | Raw interrupt status for CYCIRQ timer0 |  |
| CYCIRQ0         | 0       | 0x0  | 0: no interrupt pending                |  |
|                 |         |      | 1: unmasked interrupt generated        |  |

### TIMMIS - PWM Timer Masked Interrupt Status Register

### Table 34. TIMMIS - PWM Timer Masked Interrupt Status Register

| Register - Name | Address | Туре    | Register Function                                                                                                                                                                                                                                            |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |         |         | This register returns the masked interrupt status from the PMW timers 0,1<br>and 2. The raw interrupt status (TIMRIS) is masked with the associated<br>TIMCFGx.CYCIRQxMSK and PWMCFGx.CDIRQxMSK bits to get the<br>masked interrupt status of this register. |
| TIMMIS          | 0x7B    | R       | <b>CYCIRQ</b> - Interrupt from the timers when PWM cycle is complete (applies to the current PWM command residing in the active command register of a PWM block)                                                                                             |
|                 |         |         | <b>CDIRQ</b> - Interrupt from the pattern generator when PWM pattern code is complete (applies to a completed task residing in the script buffer of a PWM block)                                                                                             |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                                                                                                                 |
| (reserved)      | 7:6     |         | (reserved)                                                                                                                                                                                                                                                   |
|                 |         |         | Interrupt after masking, indicates active contribution to the interrupt ball, when set. Status for CDIRQ timer2.                                                                                                                                             |
| CDIRQ2          | 5       | 0x0     | 0: no interrupt pending                                                                                                                                                                                                                                      |
|                 |         |         | 1: interrupt generated                                                                                                                                                                                                                                       |
|                 | 4       | 0x0     | Interrupt after masking, indicates active contribution to the interrupt ball, when set. Status for CDIRQ timer1.                                                                                                                                             |
| CDIRQ1          |         |         | 0: no interrupt pending                                                                                                                                                                                                                                      |
|                 |         |         | 1: interrupt generated                                                                                                                                                                                                                                       |
|                 | 3       | 0x0     | Interrupt after masking, indicates active contribution to the interrupt ball, when set. Status for CDIRQ timer0.                                                                                                                                             |
| CDIRQ0          |         |         | 0: no interrupt pending                                                                                                                                                                                                                                      |
|                 |         |         | 1: interrupt generated                                                                                                                                                                                                                                       |
|                 | 0       |         | Interrupt after masking, indicates active contribution to the interrupt ball, when set. Status for CYCIRQ timer2.                                                                                                                                            |
| CYCIRQ2         | 2       | 0x0     | 0: no interrupt pending                                                                                                                                                                                                                                      |
|                 |         |         | 1: interrupt generated                                                                                                                                                                                                                                       |
|                 |         |         | Interrupt after masking, indicates active contribution to the interrupt ball, when set. Status for CYCIRQ timer1.                                                                                                                                            |
| CYCIRQ1         | 1       | 0x0     | 0: no interrupt pending                                                                                                                                                                                                                                      |
|                 |         |         | 1: interrupt generated                                                                                                                                                                                                                                       |
|                 | 0       | 0.0     | Interrupt after masking, indicates active contribution to the interrupt ball, when set. Status for CYCIRQ timer0.                                                                                                                                            |
| CYCIRQ0         | 0       | 0x0     | 0: no interrupt pending                                                                                                                                                                                                                                      |
|                 |         |         | 1: interrupt generated                                                                                                                                                                                                                                       |



# TIMIC - PWM Timer Interrupt Clear Register

| Register - Name | Address  | Туре                                    | Register Function                                                                                                                                          |
|-----------------|----------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Rame   | 71001000 | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | This register clears timer and pattern interrupts.                                                                                                         |
| TIMIC           | 0x7C     | W                                       | CYCIRQ - Interrupt from the timers when PWM cycle is complete (applies to the current PWM command residing in the active command register of a PWM block). |
|                 |          |                                         | CDIRQ - Interrupt from the pattern generator when PWM pattern code is complete (applies to a completed task residing in the script buffer of a PWM block)  |
| Bit - Name      | Bit      | Default                                 | Bit Function                                                                                                                                               |
| (reserved)      | 7:6      |                                         | (reserved)                                                                                                                                                 |
|                 |          |                                         | Clears interrupt CDIRQ timer2.                                                                                                                             |
| CDIRQ2          | 5        |                                         | 0: no effect                                                                                                                                               |
|                 |          |                                         | 1: interrupt is cleared. Does not need to be written back to 0                                                                                             |
|                 |          |                                         | Clears interrupt CDIRQ timer1.                                                                                                                             |
| CDIRQ1          | 4        |                                         | 0: no effect                                                                                                                                               |
|                 |          |                                         | 1: interrupt is cleared. Does not need to be written back to 0                                                                                             |
|                 |          |                                         | Clears interrupt CDIRQ timer0.                                                                                                                             |
| CDIRQ0          | 3        |                                         | 0: no effect                                                                                                                                               |
|                 |          |                                         | 1: interrupt is cleared. Does not need to be written back to 0                                                                                             |
|                 |          |                                         | Clears interrupt CYCIRQ timer2.                                                                                                                            |
| CYCIRQ2         | 2        |                                         | 0: no effect                                                                                                                                               |
|                 |          |                                         | 1: interrupt is cleared. Does not need to be written back to 0                                                                                             |
|                 |          |                                         | Clears interrupt CYCIRQ timer1.                                                                                                                            |
| CYCIRQ1         | 1        |                                         | 0: no effect                                                                                                                                               |
|                 |          |                                         | 1: interrupt is cleared. Does not need to be written back to 0                                                                                             |
|                 |          |                                         | Clears interrupt CYCIRQ timer0.                                                                                                                            |
| CYCIRQ0         | 0        |                                         | 0: no effect                                                                                                                                               |
|                 |          |                                         | 1: interrupt is cleared. Does not need to be written back to 0                                                                                             |

### Table 35. TIMIC - PWM Timer Interrupt Clear Register

**PWMWP - PWM Timer Pattern Pointer Register** 

# Table 36. PWMWP - PWM Timer Pattern Pointer Register

| Register - Name | Address | Туре    | Register Function                                                                                                                                                |
|-----------------|---------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 0x7D    | R/W     | Pointer to the pattern position inside the configuration register, which will be overwritten by the next write access to be PWMCFG register.                     |
| PWMWP           |         |         | NOTE: 1 pattern consist of 2 bytes and not the byte position (low or high). It is incremented by 1 every time a full PWMCFG register access (word) is performed. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                     |
| (reserved)      | 7       | 0x0     | (reserved)                                                                                                                                                       |
|                 | 6:0     | 0x0     | 0 ≤ POINTER < 32 : timer0 patterns 0 to 31                                                                                                                       |
|                 |         |         | 32 ≤ POINTER < 64 : timer1 patterns 0 to 31                                                                                                                      |
| POINTER[6:0]    |         |         | 64 ≤ POINTER < 96 : timer2 patterns 0 to 31                                                                                                                      |
|                 |         |         | 96 ≤ POINTER < 128: not valid                                                                                                                                    |



### **PWMCFG - PWM Script Register**

| Register - Name | Address | Туре    | Register Function                                                                                                |
|-----------------|---------|---------|------------------------------------------------------------------------------------------------------------------|
|                 | 0x7E    | w       | Two byte pattern storage register for a PWM script command indexed by PWMWP. PWMWP is automatically incremented. |
| PWMCFG          |         |         | To be applied by two consecutive parameter bytes in one I <sup>2</sup> C Write Transaction.                      |
|                 |         |         | NOTE:                                                                                                            |
|                 |         |         | Autoincrement is disabled on this register. Address will stay at 0x7E for each word access.                      |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                     |
| CMD[15:8]       | 15:8    |         | High byte portion of a PWM script command                                                                        |
| CMD[7:0]        | 7:0     |         | Low byte portion of a PWM script command                                                                         |

Table 37. PWMCFG - PWM Script Register

### INTERFACE CONTROL REGISTERS

The following section describes the functions of special control registers provided for the main controller.

The manufacturer code MFGCODE and the software revision number SWREV tell the main device which configuration file has to be used for this device.

# **NOTE** I2CSA and MFGCODE use the same address. They just differentiate in the access type:

- Write I2CSA
- Read MFGCODE

### *I2CSA - PC-Compatible ACCESS.bus Slave Address Register*

### Table 38. I2CSA - I<sup>2</sup>C-Compatible ACCESS.bus Slave Address Register

| Register - Name | Address | Туре                                                                    | Register Function                                                                 |
|-----------------|---------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| I2CSA 0x80      | 0,480   | W                                                                       | I <sup>2</sup> C-compatible ACCESS.bus Slave Address.                             |
|                 | vv      | The address is internally applied after the next I <sup>2</sup> C STOP. |                                                                                   |
| Bit - Name      | Bit     | Default                                                                 | Bit Function                                                                      |
| SLAVEADDR[7:1]  | 7:1     | 0x44                                                                    | 7-bit address field for the I <sup>2</sup> C-compatible ACCESS.bus slave address. |
| (reserved)      | 0       |                                                                         | (reserved)                                                                        |

### MFGCODE - Manufacturer Code Register

### Table 39. MFGCODE - Manufacturer Code Register

| Register - Name | Address | Туре    | Register Function               |
|-----------------|---------|---------|---------------------------------|
| MFGCODE         | 0x80    | R       | Manufacturer code of the LM8328 |
| Bit - Name      | Bit     | Default | Bit Function                    |
|                 |         |         |                                 |

### SWREV - Software Revision Register

### Table 40. SWREV - Software Revision Register

| Register - Name | Address | Туре | Register Function                                                                                                             |
|-----------------|---------|------|-------------------------------------------------------------------------------------------------------------------------------|
| SWREV           | 0x81    | R    | Software revision code of the LM8328.<br>NOTE: writing the SW revision with the inverted value triggers a reset (see SWRESET) |

### Table 40. SWREV - Software Revision Register (continued)

| Register - Name | Address | Туре    | Register Function                                |
|-----------------|---------|---------|--------------------------------------------------|
| Bit - Name      | Bit     | Default | Bit Function                                     |
| SWBIT           | 7:0     | 0x84    | 8 - bit field containing the SW Revision number. |

### SWRESET - Software Reset

|                 | Table 41. SWRESET - Software Reset Register |         |                                                                                            |  |
|-----------------|---------------------------------------------|---------|--------------------------------------------------------------------------------------------|--|
| Register - Name | Address                                     | Туре    | Register Function                                                                          |  |
| SWRESET 0x8     |                                             |         | Software reset                                                                             |  |
|                 | 0x81                                        | W       | NOTE: the reset is only applied if the supplied parameter has the inverted value as SWBIT. |  |
|                 |                                             |         | Reading this register provides the software revision. (see SWREV)                          |  |
| Bit - Name      | Bit                                         | Default | Bit Function                                                                               |  |
| SWBIT           | 7:0                                         |         | Reapply inverted value for software reset.                                                 |  |

### RSTCTRL - System Reset Register

This register allows to reset specific blocks of the LM8328. For global reset of the IOExpander the I<sup>2</sup>C command 'General Call reset' is used (see Global Call Reset). This will reset the slave address back to 0x88. During an active reset of a module, the LM8328 blocks the access to the module registers. A read will return 0, write commands are ignored.

| Register - Name | Address | Туре    | Register Function                                                                                                                                                   |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RSTCTRL         | 0x82    | R/W     | Software reset of specific parts of the LM8328                                                                                                                      |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                        |
| (reserved)      | 7:5     |         | (reserved)                                                                                                                                                          |
| IRQRST          | 4       | 0x0     | Interrupt controller reset. Does not change status on IRQN ball. Only controls IRQ module register. Interrupt status read out is not possible when this bit is set. |
|                 | ·       | U.V.    | 0: interrupt controller not reset                                                                                                                                   |
|                 |         |         | 1: interrupt controller reset                                                                                                                                       |
|                 |         |         | Timer reset for Timers 0, 1, 2                                                                                                                                      |
| TIMRST          | 3       | 0x0     | 0: timer not reset                                                                                                                                                  |
|                 |         |         | 1: timer is reset                                                                                                                                                   |
| (reserved)      | 2       | 0x0     | (reserved)                                                                                                                                                          |
|                 |         |         | Keyboard interface reset                                                                                                                                            |
| KBDRST          | 1       | 0x0     | 0: keyboard is not reset                                                                                                                                            |
|                 |         |         | 1: keyboard is reset                                                                                                                                                |
|                 |         |         | GENIO reset                                                                                                                                                         |
| GPIRST          | 0       | 0x0     | 0: GENIO not reset                                                                                                                                                  |
|                 |         |         | 1: GENIO is reset.                                                                                                                                                  |

### Table 42. RSTCTRL - System Reset Register

### **RSTINTCLR - Clear NO Init/Power-On Interrupt Register**

### Table 43. RSTINTCLR - Clear NO Init/Power-On Interrupt Register

| Register - Name | Address | Туре    | Register Function                                                                                                                                                                                              |
|-----------------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RSTINTCLR       | 0x84    | W       | This register allows to de-assert the POR/No Init Interrupt set every time the device returns from RESET (either POR, HW or SW Reset), the IRQN line is assigned active (low) and the IRQST.PORIRQ bit is set. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                                                                   |



### SNLS328A - AUGUST 2011 - REVISED MARCH 2013

### Table 43. RSTINTCLR - Clear NO Init/Power-On Interrupt Register (continued)

| Register - Name | Address | Туре | Register Function                                           |
|-----------------|---------|------|-------------------------------------------------------------|
| reserved        | 7:1     |      | (reserved)                                                  |
|                 | 0       |      | 1: Clears the PORIRQ Interrupt signalled in IRQST register. |
| IRQCLR          |         |      | 0: is ignored                                               |

# CLKMODE - Clock Mode Register

### Table 44. CLKMODE - Clock Mode Register

| Register - Name | Address | Туре    | Register Function                                                                                                                                                                           |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLKMODE         | 0x88    | R/W     | This register controls the current operating mode of the LM8328 device                                                                                                                      |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                                                |
| (reserved)      | 7:2     |         | (reserved)                                                                                                                                                                                  |
|                 |         | 0x01    | Writing to 00 forces the device to immediately enter sleep mode, regardless of any autosleep configuration. Reading this bit returns the current operating mode, which should always be 01. |
| MODCTL[1:0]     | 1:0     |         | 00: SLEEP Mode                                                                                                                                                                              |
|                 |         |         | 01: Operation Mode                                                                                                                                                                          |
|                 |         |         | 1x: Future modes                                                                                                                                                                            |

### CLKEN - Clock Enable Register

### Table 45. CLKEN - Clock Enable Register

| Register - Name | Address | Туре    | Register Function                                                                                                              |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| CLKEN           | 0x8A    | R/W     | Controls the clock to different functional units. It shall be used to enable the functional blocks globally and independently. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                   |
| (reserved)      | 7:3     |         | (reserved)                                                                                                                     |
|                 |         |         | PWM Timer 0, 1, 2 clock enable                                                                                                 |
| TIMEN           | 2       | 0x0     | 0: Timer 0, 1, 2 clock disabled                                                                                                |
|                 |         |         | 1: Timer 0, 1, 2 clock enabled.                                                                                                |
| (reserved)      | 1       |         | (reserved)                                                                                                                     |
|                 |         |         | Keyboard clock enable (starts/stops key scan)                                                                                  |
| KBDEN           | 0       | 0x0     | 0: Keyboard clock disabled                                                                                                     |
|                 |         |         | 1: Keyboard clock enabled                                                                                                      |

### AUTOSLIP - Autosleep Enable Register

### Table 46. AUTOSLIP - Autosleep Enable Register

| Register - Name | Address | Туре    | Register Function                                                                           |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------|
| AUTOSLP         | 0x8B    | R/W     | This register controls the Auto Sleep function of the LM8328 device                         |
| Bit - Name      | Bit     | Default | Bit Function                                                                                |
| (reserved)      | 7:1     |         | (reserved)                                                                                  |
| ENABLE          | 0       | 0x00    | Enables automatic sleep mode after a defined activity time stored in the AUTOSLPTI register |
|                 |         |         | 1: Enable entering auto sleep mode                                                          |
|                 |         |         | 0: Disable entering auto sleep mode                                                         |



# AUTOSLPTI - Auto Sleep Time Register

| Register - Name             | Address      | Туре         | Register Function                                                                                                                                                                                                                 |
|-----------------------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AUTOSLPTIL<br>AUTOSLPTIH    | 0x8C<br>0x8D | R/W          | This register defines the activity time. If this time passes without any processing events then the device enters into sleep-mode, but only if AUTOSLP.ENABLE bit is set to 1.                                                    |
| Bit - Name                  | Bit          | Default      | Bit Function                                                                                                                                                                                                                      |
| (reserved)                  | 15:11        |              | (reserved)                                                                                                                                                                                                                        |
| UPTIME[10:8]<br>UPTIME[7:0] | 10:8<br>7:0  | 0x00<br>0xFF | Values of UPTIME[10:0] match to multiples of 4ms:<br>0x00: no autosleep, regardless if AUTOSLP.ENABLE is set<br>0x01: 4ms<br>0x02: 8ms<br>0x7A: 500 ms<br>0xFF: 1020 ms (default after reset)<br>0x100: 1024 ms<br>0x7FF: 8188 ms |

### Table 47. AUTOSLPTI - Auto Sleep Time Register

### IRQST - Global Interrupt Status Register

| Table 48. IRQST - Global Interrupt Status | Register |
|-------------------------------------------|----------|
|-------------------------------------------|----------|

| Register - Name | Address | Туре    | Register Function                                                                                                                                             |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQST           | 0x91    | R       | Returns the interrupt status from various on-chip function blocks. If any of the bits is set and an IRQN line is configured, the IRQN line is asserted active |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                  |
|                 |         |         | Supply failure on VCC.                                                                                                                                        |
| PORIRQ          | 7       | 0x1     | Also power-on is considered as an initial supply failure. Therefore, after power-on, the bit is set.                                                          |
|                 |         |         | 0: no failure recorded                                                                                                                                        |
|                 |         |         | 1: Failure, device was completely reset and requires re-programming.                                                                                          |
|                 |         |         | Keyboard interrupt (further key selection in keyboard module)                                                                                                 |
| KBDIRQ          | 6       | 0x0     | 0: inactive                                                                                                                                                   |
|                 |         |         | 1: active                                                                                                                                                     |
| (reserved)      | 5:4     |         | (reserved)                                                                                                                                                    |
|                 |         |         | Timer2 expiry (CDIRQ or CYCIRQ)                                                                                                                               |
| TIM2IRQ         | 3       | 0x0     | 0: inactive                                                                                                                                                   |
|                 |         |         | 1: active                                                                                                                                                     |
|                 |         |         | Timer1 expiry (CDIRQ or CYCIRQ)                                                                                                                               |
| TIM1IRQ         | 2       | 0x0     | 0: inactive                                                                                                                                                   |
|                 |         |         | 1: active                                                                                                                                                     |
|                 |         |         | Timer0 expiry (CDIRQ or CYCIRQ)                                                                                                                               |
| TIM0IRQ         | 1       | 0x0     | 0: inactive                                                                                                                                                   |
|                 |         |         | 1: active                                                                                                                                                     |
|                 |         |         | GPIO interrupt (further selection in GPIO module)                                                                                                             |
| GPIOIRQ         | 0       | 0x0     | 0: inactive                                                                                                                                                   |
|                 |         |         | 1: active                                                                                                                                                     |

### **GPIO FEATURE CONFIGURATION**

### **GPIO Feature Mapping**

The LM8328 has a flexible IO structure which allows to dynamically assign different functionality to each ball. The functionality of each ball is determined by the complete configuration of the balls.



In general the following priority is given:

- Keypad
- GPIO/PWM/Interrupt

With this, each ball will be available as GPIO, PWM or interrupt unless it is specified to be part of the keypad matrix. The configuration for keypad or PWM/interrupt usage is defined by the following registers:

- KBDSIZE and KBDDEDCFG
  - Both registers define a ball as either part of the keypad matrix or as dedicated key input. These settings have highest priority and will overwrite settings made in other registers.
- IOCFG
  - This register is used to define the usage of KPY[11:8] if not configured to be part of the keymatrix, to be used as GPIO.

| BALL                |           | Module connectivity |                     |            |         |     |     |     |     |  |
|---------------------|-----------|---------------------|---------------------|------------|---------|-----|-----|-----|-----|--|
|                     | GPIOSEL   |                     |                     |            | BALLCFG |     |     |     |     |  |
|                     |           | 0x0                 | 0x1                 | 0x2        | 0x3     | 0x4 | 0x5 | 0x6 | 0x7 |  |
| KPX[7:0]            | not used  | GPIO[7:0]           |                     |            |         |     |     |     |     |  |
| KPY[7:0]            | not used  | GPIO[15:8]          |                     |            |         |     |     |     |     |  |
| KPY8/PWM2           | not used  | GPIO16              | PWM2 <sup>(1)</sup> | (reserved) | -       | -   | -   | -   | -   |  |
| KPY9/PWM1           | not used  | GPIO17              | PWM1                | -          | -       | -   | -   | -   | -   |  |
| KPY10/PWM0          | not used  | GPIO18              | PWM0                | -          | -       | -   | -   | -   | -   |  |
| IRQN/KPY11/PW<br>M2 | see IOCFG | GPIO19              | PWM2 <sup>(1)</sup> | PWM2       | -       | -   | -   | -   | -   |  |

### Table 49. Ball Configuration Options

(1) Note 1: PWM2 functionality is mutally exclusive — one pin at a time only (KPY8 or KPY11) depending on interrupt enable Bit 4 of IOCFG.

### IOCGF - Input/Output Pin Mapping Configuration Register

### Table 50. IOCGF - Input/Output Pin Mapping Configuration Register

| Register - Name | Address | Туре    | Register Function                                                                                                                          |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------------|
| IOCFG           | 0xA7    | W       | Configures usage of KPY[11:8] if not used for Keypad. On each write to this register, BALLCFG defines the column of Table 49 to configure. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                               |
|                 |         |         | Configures the IRQN/KPY11/PWM2 ball                                                                                                        |
| GPIOSEL         | 7:4     |         | Bit 4: Interrupt enabled                                                                                                                   |
|                 |         |         | Bit [7:5]: not used                                                                                                                        |
| (reserved)      | 3       |         | (reserved)                                                                                                                                 |
| BALLCFG         | 2:0     |         | Select column to configure, see Ball configuration options                                                                                 |

### **IOPC0 - Pull Resistor Configuration Register 0**

### Table 51. IOPC0 - Pull Resistor Configuration Register 0

| Register - Name | Address | Туре    | Register Function                                                                                                                    |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| IOPC0*          | OxAA    | R/W     | Defines the pull resistor configuration for balls KPX[7:0]                                                                           |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                         |
| KPX7PR[1:0]     | 15:14   | 0x2     | Resistor enable for KPX7 ball<br>00: no pull resistor at ball<br>01:pull down resistor programmed<br>1x: pull up resistor programmed |

www.ti.com

| Register - Name | Address | Туре | Register Function                |
|-----------------|---------|------|----------------------------------|
|                 |         |      | Resistor enable for KPX6 ball    |
|                 | 10.10   |      | 00: no pull resistor at ball     |
| KPX6PR[1:0]     | 13:12   | 0x2  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPX5 ball    |
|                 | 44.40   | 00   | 00: no pull resistor at ball     |
| KPX5PR[1:0]     | 11:10   | 0x2  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPX4 ball    |
|                 | 0.0     | 00   | 00: no pull resistor at ball     |
| KPX4PR[1:0]     | 9:8     | 0x2  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 | 7:6     | 0.0  | Resistor enable for KPX3 ball    |
|                 |         |      | 00: no pull resistor at ball     |
| KPX3PR[1:0]     | 7.0     | 0x2  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPX2 ball    |
| KPX2PR[1:0]     | 5:4     | 0x2  | 00: no pull resistor at ball     |
| KPA2PR[1:0]     | 5.4     | 0x2  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPX1 ball    |
|                 | 2.2     | 00   | 00: no pull resistor at ball     |
| KPX1PR[1:0]     | 3:2     | 0x2  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPX0 ball    |
|                 | 1.0     | 0x2  | 00: no pull resistor at ball     |
| KPX0PR[1:0]     | 1:0     | UXZ  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |

# Table 51. IOPC0 - Pull Resistor Configuration Register 0 (continued)

IOPC1 - Pull Resistor Configuration Register 1

# Table 52. IOPC1 - Pull Resistor Configuration Register 1

| Register - Name | Address | Туре    | Register Function                                          |
|-----------------|---------|---------|------------------------------------------------------------|
| IOPC1**         | 0xAC    | R/W     | Defines the pull resistor configuration for balls KPY[7:0] |
| Bit - Name      | Bit     | Default | Bit Function                                               |
|                 |         |         | Resistor enable for KPY7 ball                              |
|                 | 15.14   | 0.1     | 00: no pull resistor at ball                               |
| KPY7PR[1:0]     | 15:14   | 0x1     | 01:pull down resistor programmed                           |
|                 |         |         | 1x: pull up resistor programmed                            |
|                 |         | 0x1     | Resistor enable for KPY6 ball                              |
|                 | 40-40   |         | 00: no pull resistor at ball                               |
| KPY6PR[1:0]     | 13:12   |         | 01:pull down resistor programmed                           |
|                 |         |         | 1x: pull up resistor programmed                            |
|                 |         |         | Resistor enable for KPY5 ball                              |
|                 |         |         | 00: no pull resistor at ball                               |
| KPY5PR[1:0]     | 11:10   | 0x1     | 01:pull down resistor programmed                           |
|                 |         |         | 1x: pull up resistor programmed                            |



www.ti.com

# Table 52. IOPC1 - Pull Resistor Configuration Register 1 (continued)

| Register - Name | Address | Туре | Register Function                |
|-----------------|---------|------|----------------------------------|
|                 |         |      | Resistor enable for KPY4 ball    |
|                 | 9:8     |      | 00: no pull resistor at ball     |
| KPY4PR[1:0]     | 9.0     | 0x1  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPY3 ball    |
|                 | 7:6     | 0x1  | 00: no pull resistor at ball     |
| KPY3PR[1:0]     | 7.0     | UXI  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPY2 ball    |
|                 | 5:4     |      | 00: no pull resistor at ball     |
| KPY2PR[1:0]     | 5.4     | 0x1  | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         | 0x1  | Resistor enable for KPY1 ball    |
| KPY1PR[1:0]     | 3:2     |      | 00: no pull resistor at ball     |
| κετιεκ[1.0]     | 5.2     |      | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |
|                 |         |      | Resistor enable for KPY0 ball    |
| KPY0PR[1:0]     | 1:0     | 0x1  | 00: no pull resistor at ball     |
| KFTUFK[1.0]     | 1.0     |      | 01:pull down resistor programmed |
|                 |         |      | 1x: pull up resistor programmed  |

# **IOPC2 - Pull Resistor Configuration Register 2**

### Table 53. IOPC2 - Pull Resistor Configuration Register 2

| Register - Name | Address | Туре    | Register Function                                           |
|-----------------|---------|---------|-------------------------------------------------------------|
| IOPC2***        | 0xAE    | R/W     | Defines the pull resistor configuration for balls KPY[11:8] |
| Bit - Name      | Bit     | Default | Bit Function                                                |
| (reserved)      | 15:8    | 0x5A    | (reserved)                                                  |
|                 |         |         | Resistor enable for KPY11 ball                              |
|                 | 7:6     | 0.40    | 00: no pull resistor at ball                                |
| KPY11PR[1:0]    | 7.0     | 0x0     | 01:pull down resistor programmed                            |
|                 |         |         | 1x: pull up resistor programmed                             |
|                 |         |         | Resistor enable for KPY10 ball                              |
|                 | 5:4     | 0.41    | 00: no pull resistor at ball                                |
| KPY10PR[1:0]    | 5.4     | 0x1     | 01:pull down resistor programmed                            |
|                 |         |         | 1x: pull up resistor programmed                             |
|                 |         |         | Resistor enable for KPY9 ball                               |
|                 | 3:2     |         | 00: no pull resistor at ball                                |
| KPY9PR[1:0]     | 3:2     | 0x1     | 01:pull down resistor programmed                            |
|                 |         |         | 1x: pull up resistor programmed                             |
|                 |         |         | Resistor enable for KPY8 ball                               |
|                 | 4.0     | 0.1     | 00: no pull resistor at ball                                |
| KPY8PR[1:0]     | 1:0     | 0x1     | 01:pull down resistor programmed                            |
|                 |         |         | 1x: pull up resistor programmed                             |

### GPIOOME0 - GPIO Open Drain Mode Enable Register 0

### Table 54. GPIOOME0 - GPIO Open Drain Mode Enable Register 0

| Register - Name | Address | Туре    | Register Function                                                                                                           |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------|
| GPIOOME0        | 0xE0    | R/W     | Configures KPX[7:0] for Open Drain or standard output functionality. The Open Drain drive source is configured by GPIOOMS0. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                |
|                 |         |         | Open Drain Enable on KPX[7:0]                                                                                               |
| KPX[7:0]ODE     | 7:0     | 0x0     | 0: full buffer                                                                                                              |
|                 |         |         | 1: open drain functionality                                                                                                 |

### GPIOOMS0 - GPIO Open Drain Mode Select Register 0

### Table 55. GPIOOMS0 - GPIO Open Drain Mode Select Register 0

| Register - Name | Address | Туре    | Register Function                                                                             |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------|
| GPIOOMS0        | 0xE1    | R/W     | Configures the Open Drain drive source on KPX[7:0] if selected by GPIOOME0.                   |
| Bit - Name      | Bit     | Default | Bit Function                                                                                  |
|                 |         | 0x0     | 0: Only nmos transistor is active in output driver stage. Output can be driven to gnd or Hi-Z |
| KPX[7:0]ODM     | 7:0     |         | 1: Only pmos transistor is active in output driver stage. Output can be driven to VCC or Hi-Z |

### GPIOOME1 - GPIO Open Drain Mode Enable Register 1

### Table 56. GPIOOME1 - GPIO Open Drain Mode Enable Register 1

| Register - Name | Address | Туре    | Register Function                                                                                                           |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------|
| GPIOOME1        | 0xE2    | R/W     | Configures KPY[7:0] for Open Drain or standard output functionality. The Open Drain drive source is configured by GPIOOMS1. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                |
|                 |         |         | Open Drain Enable on KPY[7:0]                                                                                               |
| KPY[7:0]ODE     | 7:0     | 0x0     | 0: full buffer                                                                                                              |
|                 |         |         | 1: open drain functionality                                                                                                 |

### GPIOOMS1 - GPIO Open Drain Mode Select Register 1

### Table 57. GPIOOMS1 - GPIO Open Drain Mode Select Register 1

| Register - Name | Address | Туре    | Register Function                                                                             |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------|
| GPIOOMS1        | 0xE3    | R/W     | Configures the Open Drain drive source on KPY[7:0] if selected by GPIOOME1.                   |
| Bit - Name      | Bit     | Default | Bit Function                                                                                  |
|                 | 7:0     | 0x0     | 0: Only nmos transistor is active in output driver stage. Output can be driven to gnd or Hi-Z |
| KPY[7:0]ODM     | 7.0     | 0.00    | 1: Only pmos transistor is active in output driver stage. Output can be driven to VCC or Hi-Z |

### GPIOOME2 - GPIO Open Drain Mode Enable Register 2

### Table 58. GPIOOME2 - GPIO Open Drain Mode Enable Register 2

| Register - Name | Address | Туре | Register Function                                                                                                            |
|-----------------|---------|------|------------------------------------------------------------------------------------------------------------------------------|
| GPIOOME2        | 0xE4    | R/W  | Configures KPY[11:8] for Open Drain or standard output functionality. The Open Drain drive source is configured by GPIOOMS2. |

www.ti.com

www.ti.com

# Table 58. GPIOOME2 - GPIO Open Drain Mode Enable Register 2 (continued)

| Register - Name | Address | Туре    | Register Function                                                                                                                                               |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                    |
| (reserved)      | 7:4     | 0x0     | (reserved)                                                                                                                                                      |
| KPY[11:8]ODE    | 3:0     | 0x8     | Open Drain Enable on KPY[11:8]<br>0: full buffer<br>1: open drain functionality<br><b>Note:</b> KPY11/IRQN ball defaults to Open Drain Mode Enable after reset. |

### GPIOOMS2 - GPIO Open Drain Mode Select Register 2

### Table 59. GPIOOMS2 - GPIO Open Drain Mode Select Register 2

| Register - Name   | Address | Туре                                                                                          | Register Function                                                                             |
|-------------------|---------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| GPIOOMS2          | 0xE5    | R/W                                                                                           | Configures the Open Drain drive source on KPY[11:8] if selected by GPIOOME2.                  |
| Bit - Name        | Bit     | Default                                                                                       | Bit Function                                                                                  |
| (reserved         | 7:4     |                                                                                               | (reserved                                                                                     |
| KDV[141:0]ODM 2:0 | 0.40    | 0: Only nmos transistor is active in output driver stage. Output can be driven to gnd or Hi-Z |                                                                                               |
| KPY[11:8]ODM      | 3:0     | 0x0                                                                                           | 1: Only pmos transistor is active in output driver stage. Output can be driven to VCC or Hi-Z |

### **GPIO DATA INPUT/OUTPUT**



# GPIOPDATA0 - GPIO Data Register 0

### Table 60. GPIOPDATA0 - GPIO Data Register 0

| Register - Name | Address | Туре    | Register Function                                                                                                                                   |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |         |         | This register is used for data input/output of KPX[7:0]. Every data I/O is masked with the associated MASK register.                                |
| GPIODATA0       | 0xC0    | R/W     | If one of the I/Os is defined as output (see Table 63) values written to this register are masked with MASK and then applied to the associated pin. |
|                 |         |         | If one of the I/Os is defined as input (see Table 63) values read from this register hold the masked input value of the associated pin.             |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                        |
|                 |         |         | Mask Status for KPX7 when enabled as GPIO                                                                                                           |
| MASK7           | 15      | 0x0     | 1: KPX7 enabled                                                                                                                                     |
|                 |         |         | 0: KPX7 disabled                                                                                                                                    |
|                 |         |         | Mask Status for KPX6 when enabled as GPIO                                                                                                           |
| MASK6           | 14      | 0x0     | 1: KPX6 enabled                                                                                                                                     |
|                 |         |         | 0: KPX6 disabled                                                                                                                                    |
|                 |         |         | Mask Status for KPX5 when enabled as GPIO                                                                                                           |
| MASK5           | 13      | 0x0     | 1: KPX5 enabled                                                                                                                                     |
|                 |         |         | 0: KPX5 disabled                                                                                                                                    |

| Table 60. | GPIOPDATA0 - GPIO Data Register 0 (continued) |
|-----------|-----------------------------------------------|
|           |                                               |

| Register - Name | Address | Туре | Register Function                         |
|-----------------|---------|------|-------------------------------------------|
|                 |         |      | Mask Status for KPX4 when enabled as GPIO |
| MASK4           | 12      | 0x0  | 1: KPX4 enabled                           |
|                 |         |      | 0: KPX4 disabled                          |
|                 |         |      | Mask Status for KPX3 when enabled as GPIO |
| MASK3           | 11      | 0x0  | 1: KPX3 enabled                           |
|                 |         |      | 0: KPX3 disabled                          |
|                 |         |      | Mask Status for KPX2 when enabled as GPIO |
| MASK2           | 10      | 0x0  | 1: KPX2 enabled                           |
|                 |         |      | 0: KPX2 disabled                          |
|                 |         |      | Mask Status for KPX1 when enabled as GPIO |
| MASK1           | 9       | 0x0  | 1: KPX1 enabled                           |
|                 |         |      | 0: KPX1 disabled                          |
|                 |         |      | Mask Status for KPX0 when enabled as GPIO |
| MASK0           | 8       | 0x0  | 1: KPX0 enabled                           |
|                 |         |      | 0: KPX0 disabled                          |
| DATA7           | 7       | 0x0  | Pin Status for KPX7 when enabled as GPIO  |
| DATA6           | 6       | 0x0  | Pin Status for KPX6 when enabled as GPIO  |
| DATA5           | 5       | 0x0  | Pin Status for KPX5 when enabled as GPIO  |
| DATA4           | 4       | 0x0  | Pin Status for KPX4 when enabled as GPIO  |
| DATA3           | 3       | 0x0  | Pin Status for KPX3 when enabled as GPIO  |
| DATA2           | 2       | 0x0  | Pin Status for KPX2 when enabled as GPIO  |
| DATA1           | 1       | 0x0  | Pin Status for KPX1 when enabled as GPIO  |
| DATA0           | 0       | 0x0  | Pin Status for KPX0 when enabled as GPIO  |

# GPIOPDATA1 - GPIO Data Register 1

# Table 61. GPIOPDATA1 - GPIO Data Register 1

| Register - Name | Address      | Туре                         | Register Function                                                                                                                                   |
|-----------------|--------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |              |                              | This register is used for data input/output of KPY[7:0]. Every data I/O is masked with the associated MASK register.                                |
| GPIODATA1       | IODATA1 0xC2 | R/W                          | If one of the I/Os is defined as output (see Table 64) values written to this register are masked with MASK and then applied to the associated pin. |
|                 |              |                              | If one of the I/Os is defined as input (see Table 64) values read from this register hold the masked input value of the associated pin.             |
| Bit - Name      | Bit          | Default                      | Bit Function                                                                                                                                        |
|                 |              |                              | Mask Status for KPY7 when enabled as GPIO                                                                                                           |
| MASK15          | 15           | 0x0                          | 1: KPY7 enabled                                                                                                                                     |
|                 |              | 0x0                          | 0: KPY7 disabled                                                                                                                                    |
|                 |              |                              | Mask Status for KPY6 when enabled as GPIO                                                                                                           |
| MASK14          | 14           | 0x0                          | 1: KPY6 enabled                                                                                                                                     |
|                 |              | Default<br>0x0<br>0x0<br>0x0 | 0: KPY6 disabled                                                                                                                                    |
|                 |              |                              | Mask Status for KPY5 when enabled as GPIO                                                                                                           |
| MASK13          | 13           | 0x0                          | 1: KPY5 enabled                                                                                                                                     |
|                 |              |                              | 0: KPY5 disabled                                                                                                                                    |
|                 |              |                              | Mask Status for KPY4 when enabled as GPIO                                                                                                           |
| MASK12          | 12           | 0x0                          | 1: KPY4 enabled                                                                                                                                     |
|                 |              |                              | 0: KPY4 disabled                                                                                                                                    |





LM8328

www.ti.com

### SNLS328A - AUGUST 2011 - REVISED MARCH 2013

| Register - Name | Address | Туре | Register Function                         |  |
|-----------------|---------|------|-------------------------------------------|--|
|                 |         |      | Mask Status for KPY3 when enabled as GPIO |  |
| MASK11          | 11      | 0x0  | 1: KPY3 enabled                           |  |
|                 |         |      | 0: KPY3 disabled                          |  |
|                 |         |      | Mask Status for KPY2 when enabled as GPIO |  |
| MASK10          | 10      | 0x0  | 1: KPY2 enabled                           |  |
|                 |         |      | 0: KPY2 disabled                          |  |
|                 |         |      | Mask Status for KPY1 when enabled as GPIO |  |
| MASK9           | 9       | 0x0  | 1: KPY1 enabled                           |  |
|                 |         |      | 0: KPY1 disabled                          |  |
|                 |         |      | Mask Status for KPY0 when enabled as GPIO |  |
| MASK8           | 8       | 0x0  | 1: KPY0 enabled                           |  |
|                 |         |      | 0: KPY0 disabled                          |  |
| DATA15          | 7       | 0x0  | Pin Status for KPY7 when enabled as GPIO  |  |
| DATA14          | 6       | 0x0  | Pin Status for KPY6 when enabled as GPIO  |  |
| DATA13          | 5       | 0x0  | Pin Status for KPY5 when enabled as GPIO  |  |
| DATA12          | 4       | 0x0  | Pin Status for KPY4 when enabled as GPIO  |  |
| DATA11          | 3       | 0x0  | Pin Status for KPY3 when enabled as GPIO  |  |
| DATA10          | 2       | 0x0  | Pin Status for KPY2 when enabled as GPIO  |  |
| DATA9           | 1       | 0x0  | Pin Status for KPY1 when enabled as GPIO  |  |
| DATA8           | 0       | 0x0  | Pin Status for KPY0 when enabled as GPIO  |  |
|                 |         |      |                                           |  |

# Table 61. GPIOPDATA1 - GPIO Data Register 1 (continued)

# GPIOPDATA2 - GPIO Data Register 2

# Table 62. GPIOPDATA2 - GPIO Data Register 2

| Register - Name | Address | Туре    | Register Function                                                                                                                                   |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |         |         | This register is used for data input/output of KPY[11:8]. Every data I/O is masked with the associated MASK register.                               |
| GPIODATA2       | 0xC4    | R/W     | If one of the I/Os is defined as output (see Table 65) values written to this register are masked with MASK and then applied to the associated pin. |
|                 |         |         | If one of the I/Os is defined as input (see Table 65) values read from this register hold the masked input value of the associated pin.             |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                        |
| (reserved)      | 15:12   | 0x0     | (reserved)                                                                                                                                          |
|                 |         |         | Mask Status for KPY11 when enabled as GPIO                                                                                                          |
| MASK19          | 11      | 0x0     | 1: KPY11 enabled                                                                                                                                    |
|                 |         |         | 0: KPY11 disabled                                                                                                                                   |
|                 |         |         | Mask Status for KPY10 when enabled as GPIO                                                                                                          |
| MASK18          | 10      | 0x0     | 1: KPY10 enabled                                                                                                                                    |
|                 |         |         | 0: KPY10 disabled                                                                                                                                   |
|                 |         |         | Mask Status for KPY9 when enabled as GPIO                                                                                                           |
| MASK17          | 9       | 0x0     | 1: KPY9 enabled                                                                                                                                     |
|                 |         |         | 0: KPY9 disabled                                                                                                                                    |
|                 |         |         | Mask Status for KPY8 when enabled as GPIO                                                                                                           |
| MASK16          | 8       | 0x0     | 1: KPY8 enabled                                                                                                                                     |
|                 |         |         | 0: KPY8 disabled                                                                                                                                    |
| reserved        | 7:4     | 0x0     | (reserved)                                                                                                                                          |
| DATA19          | 3       | 0x0     | Pin Status for KPY11 when enabled as GPIO                                                                                                           |
| DATA18          | 2       | 0x0     | Pin Status for KPY10 when enabled as GPIO                                                                                                           |

Copyright © 2011–2013, Texas Instruments Incorporated

TEXAS INSTRUMENTS

### SNLS328A - AUGUST 2011 - REVISED MARCH 2013

www.ti.com

### Table 62. GPIOPDATA2 - GPIO Data Register 2 (continued)

| Register - Name | Address | Туре | Register Function                        |
|-----------------|---------|------|------------------------------------------|
| DATA17          | 1       | 0x0  | Pin Status for KPY9 when enabled as GPIO |
| DATA16          | 0       | 0x0  | Pin Status for KPY8 when enabled as GPIO |

### GPIOPDIR0 - GPIO Port Direction Register 0

### Table 63. GPIOPDIR0 - GPIO Port Direction Register 0

| Register - Name | Address | Туре    | Register Function           |
|-----------------|---------|---------|-----------------------------|
| GPIODIR0        | 0xC6    | R/W     | Port direction for KPX[7:0] |
| Bit - Name      | Bit     | Default | Bit Function                |
|                 |         |         | Direction bits for KPX[7:0] |
| KPX[7:0]DIR     | 7:0     | 0x00    | 0: input mode               |
|                 |         |         | 1: output mode              |

# **GPIOPDIR1 - GPIO Port Direction Register 1**

### Table 64. GPIOPDIR1 - GPIO Port Direction Register 1

| Register - Name | Address | Туре    | Register Function           |
|-----------------|---------|---------|-----------------------------|
| GPIODIR1        | 0xC7    | R/W     | Port direction for KPY[7:0] |
| Bit - Name      | Bit     | Default | Bit Function                |
|                 |         |         | Direction bits for KPY[7:0] |
| KPY[7:0]DIR     | 7:0     | 0x00    | 0: input mode               |
|                 |         |         | 1: output mode              |

### **GPIOPDIR2 - GPIO Port Direction Register 2**

### Table 65. GPIOPDIR2 - GPIO Port Direction Register 2

| Register - Name | Address | Туре    | Register Function            |  |
|-----------------|---------|---------|------------------------------|--|
| GPIODIR2        | 0xC8    | R/W     | Port direction for KPY[11:8] |  |
| Bit - Name      | Bit     | Default | Bit Function                 |  |
| (reserved)      | 7:4     |         | (reserved)                   |  |
|                 |         |         | Direction bits for KPY[11:8] |  |
| KPY[11:8]DIR    | 3:0     | 0x08    | 0: input mode                |  |
|                 |         |         | 1: output mode               |  |

### **GPIO INTERRUPT CONTROL**

### **GPIOIS0 - Interrupt Sense Configuration Register 0**

### Table 66. GPIOIS0 - Interrupt Sense Configuration Register 0

| Register - Name | Address | Туре    | Register Function                |
|-----------------|---------|---------|----------------------------------|
| GPIOIS0         | 0xC9    | R/W     | Interrupt type on KPX[7:0]       |
| Bit - Name      | Bit     | Default | Bit Function                     |
|                 |         |         | Interrupt type bits for KPX[7:0] |
| KPX[7:0]IS      | 7:0     | 0x0     | 0: edge sensitive interrupt      |
|                 |         |         | 1: level sensitive interrupt     |

#### **GPIOIS1 - Interrupt Sense Configuration Register 1**

| Register - Name | Address | Туре    | Register Function                |  |
|-----------------|---------|---------|----------------------------------|--|
| GPIOIS1         | 0xCA    | R/W     | Interrupt type on KPY[7:0]       |  |
| Bit - Name      | Bit     | Default | Bit Function                     |  |
|                 |         |         | Interrupt type bits for KPY[7:0] |  |
| KPY[7:0]IS      | 7:0     | 0x0     | 0: edge sensitive interrupt      |  |
|                 |         |         | 1: level sensitive interrupt     |  |

#### Table 67. GPIOIS1 - Interrupt Sense Configuration Register 1

## **GPIOIS2** - Interrupt Sense Configuration Register 2

#### Table 68. GPIOIS2 - Interrupt Sense Configuration Register 2

| Register - Name | Address | Туре    | Register Function                 |  |
|-----------------|---------|---------|-----------------------------------|--|
| GPIOIS2         | 0xCB    | R/W     | Interrupt type on KPY[11:8]       |  |
| Bit - Name      | Bit     | Default | Bit Function                      |  |
| (reserved)      | 7:4     |         | (reserved)                        |  |
|                 |         |         | Interrupt type bits for KPY[11:8] |  |
| KPY[11:8]IS     | 3:0     | 0x0     | 0: edge sensitive interrupt       |  |
|                 |         |         | 1: level sensitive interrupt      |  |

### **GPIOIBE0 - GPIO Interrupt Edge Configuration Register 0**

#### Table 69. GPIOIBE0 - GPIO Interrupt Edge Configuration Register 0

| Register - Name | Address | Туре    | Register Function                                                                                                                 |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| GPIOIBE0        | 0xCC    | R/W     | Defines whether an interrupt on KPX[7:0] is triggered on both edges or on a single edge. See Table 72 for the edge configuration. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                      |
|                 |         |         | Interrupt both edges bits for KPX[7:0]                                                                                            |
| KPX[7:0]IBE     | 7:0     | 0x0     | 0: interrupt generated at the active edge                                                                                         |
|                 |         |         | 1: interrupt generated after both edges                                                                                           |

#### **GPIOIBE1 - GPIO Interrupt Edge Configuration Register 1**

### Table 70. GPIOIBE1 - GPIO Interrupt Edge Configuration Register 1

| Register - Name | Address | Туре    | Register Function                                                                                                                 |
|-----------------|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| GPIOIBE1        | 0xCD    | R/W     | Defines whether an interrupt on KPY[7:0] is triggered on both edges or on a single edge. See Table 73 for the edge configuration. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                      |
|                 |         |         | Interrupt both edges bits for KPY[7:0]                                                                                            |
| KPY[7:0]IBE     | 7:0     | 0x0     | 0: interrupt generated at the configured edge                                                                                     |
|                 |         |         | 1: interrupt generated after both edges                                                                                           |

## GPIOIBE2 - GPIO Interrupt Edge Configuration Register 2

## Table 71. GPIOIBE2 - GPIO Interrupt Edge Configuration Register 2

| Register - Name | Address | Туре    | Register Function                                                                                                                     |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------|
| GPIOIBE2        | 0xCE    | R/W     | Defines whether an interrupt on KPY[11:8] is triggered on both edges or<br>on a single edge. See Table 74 for the edge configuration. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                          |

## SNLS328A - AUGUST 2011 - REVISED MARCH 2013

# Table 71. GPIOIBE2 - GPIO Interrupt Edge Configuration Register 2 (continued)

| Register - Name | Address | Туре | Register Function                         |
|-----------------|---------|------|-------------------------------------------|
| (reserved       | 7:4     |      | (reserved)                                |
|                 |         |      | Interrupt both edges bits for KPY[11:8]   |
| KPY[11:8]IBE    | 3:0     | 0x0  | 0: interrupt generated at the active edge |
|                 |         |      | 1: interrupt generated after both edges   |

# GPIOIEV0 - GPIO Interrupt Edge Select Register 0

# Table 72. GPIOIEV0 - GPIO Interrupt Edge Select Register 0

| Register - Name | Address | Туре    | Register Function                         |
|-----------------|---------|---------|-------------------------------------------|
| GPIOIEV0        | 0xCF    | R/W     | Select Interrupt edge for KPX[7:0].       |
| Bit - Name      | Bit     | Default | Bit Function                              |
|                 |         |         | Interrupt edge select from KPX[7:0]       |
| KPX[7:0]EV      | 7:0     | 0xFF    | 0: interrupt at low level or falling edge |
|                 |         |         | 1: interrupt at high level or rising edge |

## GPIOIEV1 - GPIO Interrupt Edge Select Register 1

## Table 73. GPIOIEV1 - GPIO Interrupt Edge Select Register 1

| Register - Name | Address | Туре    | Register Function                         |
|-----------------|---------|---------|-------------------------------------------|
| GPIOIEV1        | 0xD0    | R/W     | Select Interrupt edge for KPY[7:0].       |
| Bit - Name      | Bit     | Default | Bit Function                              |
|                 |         |         | Interrupt edge select from KPY[7:0]       |
| KPY[7:0]EV      | 7:0     | 0xFF    | 0: interrupt at low level or falling edge |
|                 |         |         | 1: interrupt at high level or rising edge |

# GPIOIEV2 - GPIO Interrupt Edge Select Register 2

## Table 74. GPIOIEV2 - GPIO Interrupt Edge Select Register 2

| Register - Name | Address | Туре    | Register Function                         |
|-----------------|---------|---------|-------------------------------------------|
| GPIOIEV2        | 0xD1    | R/W     | Select Interrupt edge for KPY[11:8].      |
| Bit - Name      | Bit     | Default | Bit Function                              |
| (reserved)      | 7:4     |         | (reserved)                                |
|                 |         |         | Interrupt edge select from KPY[11:8]      |
| KPY[11:8]EV     | 3:0     | 0xFF    | 0: interrupt at low level or falling edge |
|                 |         |         | 1: interrupt at high level or rising edge |

## GPIOIE0 - GPIO Interrupt Enable Register 0

## Table 75. GPIOIE0 - GPIO Interrupt Enable Register 0

| Register - Name | Address | Туре    | Register Function                     |  |
|-----------------|---------|---------|---------------------------------------|--|
| GPIOIE0         | 0xD2    | R/W     | Enable/disable interrupts on KPX[7:0] |  |
| Bit - Name      | Bit     | Default | Bit Function                          |  |
|                 |         |         | Interrupt enable on KPX[7:0]          |  |
| KPX[7:0]IE      | 7:0     | 0x0     | 0: disable interrupt                  |  |
|                 |         |         | 1: enable interrupt                   |  |

#### **GPIOIE1 - GPIO Interrupt Enable Register 1**

| Register - Name | Address | Туре    | Register Function                     |  |
|-----------------|---------|---------|---------------------------------------|--|
| GPIOIE1         | 0xD3    | R/W     | Enable/disable interrupts on KPY[7:0] |  |
| Bit - Name      | Bit     | Default | Bit Function                          |  |
|                 |         |         | Interrupt enable on KPY[7:0]          |  |
| KPY[7:0]IE      | 7:0     | 0x0     | 0: disable interrupt                  |  |
|                 |         |         | 1: enable interrupt                   |  |

#### Table 76. GPIOIE1 - GPIO Interrupt Enable Register 1

## GPIOIE2 - GPIO Interrupt Enable Register 2

#### Table 77. GPIOIE2 - GPIO Interrupt Enable Register 2

| Register - Name | Address | Туре    | Register Function                                                            |  |
|-----------------|---------|---------|------------------------------------------------------------------------------|--|
| GPIOIE2         | 0xD4    | R/W     | Enable/disable interrupts on KPY[11:8]                                       |  |
| Bit - Name      | Bit     | Default | Bit Function                                                                 |  |
| (reserved)      | 7:4     |         | (reserved)                                                                   |  |
| KPY[11:8]IE     | 3:0     | 0x0     | Interrupt enable on KPY[11:8]<br>0: disable interrupt<br>1: enable interrupt |  |

## GPIOIC0 - GPIO Clear Interrupt Register 0

#### Table 78. GPIOIC0 - GPIO Clear Interrupt Register 0

| Register - Name | Address | Туре    | Register Function                |
|-----------------|---------|---------|----------------------------------|
| GPIOIC0         | 0xDC    | W       | Clears the interrupt on KPX[7:0] |
| Bit - Name      | Bit     | Default | Bit Function                     |
|                 |         |         | Clear Interrupt on KPX[7:0]      |
| KPX[7:0]IC      | 7:0     |         | 0: no effect                     |
|                 |         |         | 1: Clear corresponding interrupt |

## **GPIOIC1 - GPIO Clear Interrupt Register 1**

#### Table 79. GPIOIC1 - GPIO Clear Interrupt Register 1

| Register - Name | Address | Туре    | Register Function                |
|-----------------|---------|---------|----------------------------------|
| GPIOIC1         | 0xDD    | W       | Clears the interrupt on KPY[7:0] |
| Bit - Name      | Bit     | Default | Bit Function                     |
|                 |         |         | Clear Interrupt on KPY[7:0]      |
| KPY[7:0]IC      | 7:0     |         | 0: no effect                     |
|                 |         |         | 1: Clear corresponding interrupt |

### **GPIOIC2 - GPIO Clear Interrupt Register 2**

#### Table 80. GPIOIC2 - GPIO Clear Interrupt Register 2

| Register - Name | Address | Туре    | Register Function                 |
|-----------------|---------|---------|-----------------------------------|
| GPIOIC2         | 0xDE    | W       | Clears the interrupt on KPY[11:8] |
| Bit - Name      | Bit     | Default | Bit Function                      |
| (reserved)      | 7:4     |         | (reserved)                        |

SNLS328A - AUGUST 2011 - REVISED MARCH 2013

# Table 80. GPIOIC2 - GPIO Clear Interrupt Register 2 (continued)

| Register - Name | Address | Туре | Register Function                |
|-----------------|---------|------|----------------------------------|
|                 |         |      | Clear Interrupt on KPY[11:8]     |
| KPY[11:8]IC     | 3:0     |      | 0: no effect                     |
|                 |         |      | 1: Clear corresponding interrupt |

# **GPIO INTERRUPT STATUS**

## GPIORIS0 - Raw Interrupt Status Register 0

## Table 81. GPIORIS0 - Raw Interrupt Status Register 0

| Register - Name | Address | Туре    | Register Function                                                                                            |  |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------------|--|
| GPIORIS0        | 0xD6    | R       | Raw interrupt status on KPX[7:0]                                                                             |  |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                 |  |
| KPX[7:0]RIS     | 7:0     | 0x0     | Raw Interrupt status data on KPX[7:0]<br>0: no interrupt condition at GPIO<br>1: interrupt condition at GPIO |  |

# GPIORIS1 - Raw Interrupt Status Register 1

# Table 82. GPIORIS1 - Raw Interrupt Status Register 1

| Register - Name | Address | Туре    | Register Function                                                          |  |
|-----------------|---------|---------|----------------------------------------------------------------------------|--|
| GPIORIS1        | 0xD7    | R       | Raw interrupt status on KPY[7:0]                                           |  |
| Bit - Name      | Bit     | Default | Bit Function                                                               |  |
| KPY[7:0]RIS     | 7:0     | 0x0     | Raw Interrupt status data on KPY[7:0]<br>0: no interrupt condition at GPIO |  |
|                 | 1.0     | 0.00    | 1: interrupt condition at GPIO                                             |  |

# **GPIORIS2 - Raw Interrupt Status Register 2**

# Table 83. GPIORIS2 - Raw Interrupt Status Register 2

| Register - Name | Address | Туре    | Register Function                                                                                             |  |
|-----------------|---------|---------|---------------------------------------------------------------------------------------------------------------|--|
| GPIORIS2        | 0xD8    | R       | Raw interrupt status on KPY[11:8]                                                                             |  |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                  |  |
| (reserved)      | 7:4     |         | (reserved)                                                                                                    |  |
| KPY[11:8]RIS    | 3:0     | 0x0     | Raw Interrupt status data on KPY[11:8]<br>0: no interrupt condition at GPIO<br>1: interrupt condition at GPIO |  |

# GPIOMIS0 - Masked Interrupt Status Register 0

# Table 84. GPIOMIS0 - Masked Interrupt Status Register 0

| Register - Name | Address | Туре    | Register Function                        |  |
|-----------------|---------|---------|------------------------------------------|--|
| GPIOMIS0        | 0xD9    | R       | Masked interrupt status on KPX[7:0]      |  |
| Bit - Name      | Bit     | Default | Bit Function                             |  |
|                 |         |         | Masked Interrupt status data on KPX[7:0] |  |
| KPX[7:0]MIS     | 7:0     | 0x0     | 0: no interrupt contribution from GPIO   |  |
|                 |         |         | 1: interrupt GPIO is active              |  |

#### **GPIOMIS1 - Masked Interrupt Status Register 1**

| Register - Name | Address | Туре    | Register Function                        |  |
|-----------------|---------|---------|------------------------------------------|--|
| GPIOMIS1        | 0xDA    | R       | Masked interrupt status on KPY[7:0]      |  |
| Bit - Name      | Bit     | Default | Bit Function                             |  |
|                 |         |         | Masked Interrupt status data on KPY[7:0] |  |
| KPY[7:0]MIS     | 7:0     | 0x0     | 0: no interrupt contribution from GPIO   |  |
|                 |         |         | 1: interrupt GPIO is active              |  |

#### Table 85. GPIOMIS1 - Masked Interrupt Status Register 1

## **GPIOMIS2 - Masked Interrupt Status Register 2**

#### Table 86. GPIOMIS2 - Masked Interrupt Status Register 2

| Register - Name | Address | Туре    | Register Function                                                                                                  |  |
|-----------------|---------|---------|--------------------------------------------------------------------------------------------------------------------|--|
| GPIOMIS2        | 0xDB    | R       | Masked interrupt status on KPY[11:8]                                                                               |  |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                       |  |
| (reserved)      | 7:4     |         | (reserved)                                                                                                         |  |
| KPY[11:8]MIS    | 3:0     | 0x0     | Masked Interrupt status data on KPY[11:8]<br>0: no interrupt contribution from GPIO<br>1: interrupt GPIO is active |  |

## GPIO WAKE-UP CONTROL

#### GPIOWAKE0 - GPIO Wake-Up Register 0

#### Table 87. GPIOWAKE0 - GPIO Wake-Up Register 0

| Register - Name | Address | Туре    | Register Function                                                                                                                                                 |
|-----------------|---------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIOWAKE0       | 0xE9    | R/W     | Configures wake-up conditions for KPX[7:0]<br>Each bit corresponds to a ball. When bit set, the corresponding ball<br>contributes to wakeup from auto sleep mode. |
| Bit - Name      | Bit     | Default | Bit Function                                                                                                                                                      |
| KPX[7:0]WAKE    | 7:0     | 0x0     | Bit 7: KPX7<br><br>Bit 0: KPX0                                                                                                                                    |

## GPIOWAKE1 - GPIO Wake-Up Register 1

#### Table 88. GPIOWAKE1 - GPIO Wake-Up Register 1

| Register - Name | Address | Туре                                                                                                             | Register Function                          |
|-----------------|---------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
|                 |         |                                                                                                                  | Configures wake-up conditions for KPY[7:0] |
| GPIOWAKE1 0xEA  | R/W     | Each bit corresponds to a ball. When bit set, the corresponding ball contributes to wakeup from auto sleep mode. |                                            |
| Bit - Name      | Bit     | Default                                                                                                          | Bit Function                               |
| KPY[7:0]WAKE 7  |         |                                                                                                                  | Bit 7: KPY7                                |
|                 | 7:00    | 0x0                                                                                                              | <br>Bit 0: KPY0                            |



## GPIOWAKE2 - GPIO Wake-Up Register 2

#### Table 89. GPIOWAKE2 - GPIO Wake-Up Register 2

| Register - Name | Address | Type Register Function |                                                                                                                  |
|-----------------|---------|------------------------|------------------------------------------------------------------------------------------------------------------|
|                 |         |                        | Configures wake-up conditions for KPY[11:8]                                                                      |
| GPIOWAKE2       | 0xEB    | R/W                    | Each bit corresponds to a ball. When bit set, the corresponding ball contributes to wakeup from auto sleep mode. |
| Bit - Name      | Bit     | Default                | Bit Function                                                                                                     |
| (reserved)      | 7:4     |                        | (reserved)                                                                                                       |
|                 |         |                        | Bit 3: KPY11                                                                                                     |
| KPY[11:8]WAKE   | 3:0     | 0x0                    | <br>Bit 0: KPY8                                                                                                  |



These devices have limited built-in ESD protection. The leads should be shorted together or the device placed in conductive foam during storage or handling to prevent electrostatic damage to the MOS gates.

## ABSOLUTE MAXIMUM RATINGS (1)(2)

| Supply Voltage (V <sub>CC</sub> )               |                       | -0.3V to 2.2V                  |
|-------------------------------------------------|-----------------------|--------------------------------|
| Voltage at Generic IOs                          |                       | -0.2V to V <sub>CC</sub> +0.2V |
| Voltage at Backdrive/Overvoltage IOs            |                       | -0.3V to +.4.25V               |
| Maximum Input Current Without Latchup           |                       | ±100 mA                        |
| ESD Protection Level                            | (Human Body Model)    | 2kV                            |
|                                                 | (Machine Model)       | 200V                           |
|                                                 | (Charge Device Model) | 750V                           |
| Total Current into V <sub>CC</sub> Pin (Source) |                       | 100 mA                         |
| Total Current out of GND Pin (Sink)             |                       | 100 mA                         |
| Storage Temperature Range                       |                       | −65°C to +140°C                |

(1) Absolute Maximum Ratings indicate limits beyond which damage to the device may occur. Operating Ratings indicate conditions for which the device is intended to be functional, but specific performance is not ensured. For ensured specifications and test conditions, see the Electrical Characteristics tables.

(2) If Military/Aerospace specified devices are required, please contact the TI Sales Office/ Distributors for availability and specifications.

# DC ELECTRICAL CHARACTERISTICS

Datasheet min/max specification limits are specified by design, test, or statistical analysis.

(Temperature:  $-40^{\circ}C \le T_A \le +85^{\circ}C$ , unless otherwise specified)

| Parameter                                                   | Conditions                                                                                 | Min  | Тур | Мах  | Units |
|-------------------------------------------------------------|--------------------------------------------------------------------------------------------|------|-----|------|-------|
| Operating Voltage (V <sub>CC</sub> )                        | Core Supply Voltage                                                                        | 1.62 |     | 1.98 | V     |
| Maximum Input voltage for Backdrive/Overvoltage IOs         |                                                                                            |      |     | 3.60 | V     |
|                                                             | No loads on pins; Internal Clock = ON, all internal functional blocks running              |      |     |      | _     |
| Supply Current (I <sub>DD</sub> ) <sup>(1)</sup>            | $V_{CC}$ = 1.8V, $T_{C}$ = 0.5 µs                                                          |      | 1.9 | 3.0  | mA    |
|                                                             | $T_A = 25^{\circ}C$                                                                        |      |     |      |       |
| Sleep Mode HALT Current (I <sub>HALT</sub> ) <sup>(2)</sup> | $V_{CC}$ = 1.8V, $T_A$ = 25°C; Internal Clock = OFF, no internal functional blocks running |      | <9  | 40   | μA    |
| IDLE Current                                                | Internal Clock = ON, no internal functional blocks running                                 |      | 1   |      | mA    |

(1) Supply and IDLE current is measured with inputs connected to V<sub>CC</sub> and outputs driven low but not connected to a load.

(2) In sleep mode, the internal clock is switched off. Supply current in sleep mode is measured with inputs connected to V<sub>CC</sub> and outputs driven low but not connected to a load.



## **AC ELECTRICAL CHARACTERISTICS**

(Temperature:  $-40^{\circ}C \le T_{A} \le +85^{\circ}C$ )

Data sheet specification limits are specified by design, test, or statistical analysis.

| Parameter                                                                           | Conditions                       | Min | Тур | Max | Units |
|-------------------------------------------------------------------------------------|----------------------------------|-----|-----|-----|-------|
| System Clock Frequency                                                              | Internal RC                      |     | 21  |     | MHz   |
| System Clock Period (mclk)                                                          | $1.62 V \leq V_{CC} \leq 1.98 V$ |     | 48  |     | ns    |
| Internal RC Oscillator (t <sub>C</sub> )                                            | $1.62 V \leq V_{CC} \leq 1.98 V$ |     | 0.5 |     | μs    |
| Internal RC Oscillator Frequency Variation                                          |                                  |     |     | ±7  | %     |
| ACCESS.bus Input Signals                                                            |                                  |     |     |     |       |
| Bus Free Time Between Stop and Start Condition $\left(t_{\text{BUFi}}\right)^{(1)}$ |                                  | 16  |     |     |       |
| SCL Setup Time (t <sub>CSTOsi</sub> ) <sup>(1)</sup>                                | Before Stop Condition            | 8   |     |     |       |
| SCL Hold Time (t <sub>CSTRhi</sub> ) <sup>(1)</sup>                                 | After Start Condition            | 8   |     |     |       |
| SCL Setup Time (t <sub>CSTRsi</sub> ) <sup>(1)</sup>                                | Before Start Condition           | 8   |     |     |       |
| Data High Setup Time (t <sub>DHCsi</sub> ) <sup>(1)(2)</sup>                        | Before SCL Rising Edge (RE)      | 2   |     |     | mclk  |
| Data Low Setup Time $(t_{DLCsi})^{(1)}$                                             | Before SCL RE                    | 2   |     |     |       |
| SCL Low Time (t <sub>SCLlowi</sub> ) <sup>(1)</sup>                                 | After SCL Falling Edge (FE)      | 12  |     |     |       |
| SCL High Time (t <sub>SCLhighi</sub> ) <sup>(1) (2)</sup>                           | After SCL FE                     | 12  |     |     |       |
| SDA Hold Time (t <sub>SDAhi</sub> ) <sup>(1)</sup>                                  | After SCL FE                     | 0   |     |     |       |
| SDA Setup Time ( $t_{SDAsi}$ ) <sup>(1) (2)</sup>                                   | Before SCL RE                    | 2   |     |     |       |
| ACCESS.bus Output Signals                                                           |                                  |     |     |     |       |
| SDA Hold Time (t <sub>SDAho</sub> ) <sup>(1)</sup>                                  | After SCL Falling Edge           | 2   |     |     | mclk  |

(1) Specified by design, not tested.

(2) The ACCESS.bus interface implements and meets the timings necessary for interface to the I<sup>2</sup>C and SMBus protocols at logic levels. The bus drivers have open-drain outputs for bidirectional operation. Due to Internal RC Oscillator Frequency Variation, this specification may not meet the AC timing and current/voltage drive requirements of the full-bus specifications.

## **GENERAL GPIO CHARACTERISTICS**

Characteristics for all pins except IRQN/KPY11/PWM2, SDA, and SCL in GPIO mode.

| Parameter                                                         | Conditions                                     | Min                 | Тур                                            | Max                             | Units |
|-------------------------------------------------------------------|------------------------------------------------|---------------------|------------------------------------------------|---------------------------------|-------|
| V <sub>IH</sub> (Min. Input High Voltage)                         |                                                | 0.7xV <sub>CC</sub> |                                                |                                 | V     |
| V <sub>IL</sub> (Max. Input Low Voltage)                          |                                                |                     |                                                | $0.3 \mathrm{xV}_{\mathrm{CC}}$ | V     |
| I <sub>Source</sub>                                               | $V_{CC} = 1.62$ $V_{OH} = 0.7 \text{xV}_{CC}$  |                     |                                                | -16                             | mA    |
| I <sub>Sink</sub>                                                 | $V_{CC} = 1.62$ $V_{OL} = 0.3 \text{x} V_{CC}$ | 16                  |                                                |                                 | mA    |
| Allowable Sink current per pin (1)                                |                                                |                     |                                                | 16                              | mA    |
| I <sub>PU</sub> (Weak Pull-UP Current) <sup>(2)</sup>             | V <sub>OUT</sub> = 0V                          | -30                 |                                                | -160                            |       |
| I <sub>PD</sub> (Weak Pull-Down Current) <sup>(2)</sup>           | $V_{OUT} = V_{CC}$                             | 30                  |                                                | 160                             | ۵     |
|                                                                   | GPIO output disabled                           |                     |                                                | .0                              | μA    |
| I <sub>OZ</sub> (Input Leakage Current)                           | $V_{pin} = 0$ to $V_{CC}$                      |                     | 0.3xV<br>-16<br>-16<br>-16<br>-16<br>-12<br>+2 | ±Ζ                              |       |
| $t_{\mbox{Rise}/\mbox{Fall}}$ (Max. Rise and Fall times) $^{(3)}$ | $C_{LOAD} = 50 \text{ pF}$                     |                     |                                                | 15                              | ns    |

 The sum of all I/O sink/source current must not exceed the maximum total current into V<sub>CC</sub> and out of GND as specified in the absolute maximum ratings.

(2) This is the internal weak pull-up (pull-down) current when driver output is disabled. If enabled, during receiving mode, this is the current required to switch the input from one state to another.

(3) Specified by design, not tested.

# **BACKDRIVE/OVERVOLTAGE I/O DC CHARACTERISTICS**

Characteristics for pins IRQN/KPY11/PWM2, SDA and SCL

| Parameter                                               | Conditions                                        | Min                 | Тур | Max                             | Units |
|---------------------------------------------------------|---------------------------------------------------|---------------------|-----|---------------------------------|-------|
| V <sub>IH</sub> (Min. Input High Voltage)               |                                                   | 0.7xV <sub>CC</sub> |     |                                 | V     |
| V <sub>IL</sub> (Max. Input Low Voltage)                |                                                   |                     |     | $0.3 \mathrm{xV}_{\mathrm{CC}}$ | V     |
| I <sub>Source</sub>                                     | V <sub>CC</sub> = 1.62V<br>V <sub>OH</sub> = 1.5V |                     |     | -6                              | mA    |
| I <sub>Sink1</sub> (as GPIO)                            | $V_{CC} = 1.62V$<br>$V_{OL} = 0.4V$               | 12                  |     |                                 | mA    |
| I <sub>Sink2</sub> (as ACCESS.bus)                      | $V_{CC} = 1.62V$<br>$V_{OL} = 0.4V$               | 3                   |     |                                 | mA    |
| I <sub>Sink3</sub> (as ACCESS.bus)                      | $V_{CC} = 1.62V$<br>$V_{OL} = 0.6V$               | 4                   |     |                                 | mA    |
| Allowable Sink current per pin (1)                      |                                                   |                     |     | 12                              | mA    |
| I <sub>PU</sub> (Weak Pull-UP Current) <sup>(2)</sup>   | V <sub>OUT</sub> = 0V                             | -7                  |     | -40                             |       |
| I <sub>PD</sub> (Weak Pull-Down Current) <sup>(2)</sup> | $V_{OUT} = V_{CC}$                                | 7                   |     | 40                              |       |
|                                                         | GPIO output disabled<br>$V_{CC} = 1.62V$ to 1.98V |                     |     |                                 | μA    |
| I <sub>OZ1</sub> (Input Leakage Current)                | $V_{pin} = 0$ to $V_{CC}$                         |                     |     | ±2                              |       |
|                                                         | $V_{pin} = V_{CC}$ to 3.6V                        |                     |     | ±10                             |       |
| I <sub>OZ2</sub> (Input Backdrive Leakage Current)      | $0 \le V_{CC} \le 0.5V$<br>$V_{pin} = 0$ to 3.6V  |                     |     | ±10                             | μA    |

 The sum of all I/O sink/source current must not exceed the maximum total current into V<sub>CC</sub> and out of GND as specified in the absolute maximum ratings.

(2) This is the internal weak pull-up (pull-down) current when driver output is disabled. If enabled, during receiving mode, this is the current required to switch the input from one state to another.

## **BACKDRIVE/OVERVOLTAGE I/O AC CHARACTERISTICS**

Characteristics for pins IRQN/KPY11/PWM2, SDA and SCL

| Parameter                                                          | Conditions                                                                     | Min | Тур | Max | Units |
|--------------------------------------------------------------------|--------------------------------------------------------------------------------|-----|-----|-----|-------|
| t <sub>Rise/Fall</sub><br>(Max. Rise and Fall time) <sup>(1)</sup> | C <sub>LOAD</sub> =50 pF @ 1MHz                                                |     |     | 70  |       |
| $$t_{Fall}$ (Max. Fall time) as ACCESS.bus (SDA, SCL only) ^{(1)}$ | C <sub>LOAD</sub> =10 pF to 100 pF<br>V <sub>IHmin</sub> to V <sub>ILmax</sub> | 10  |     | 120 | ns    |

(1) Specified by design, not tested.



## REGISTERS

## **REGISTER MAPPING**

### **KEYBOARD REGISTERS**

shows the register map for keyboard functionality. In addition to Global Call Reset (see GLOBAL INTERRUPT REGISTERS) or Software Reset using SWRESET (see Table 41), these registers are reset to 0x00 values by a module reset using RSTCTRL.KBDRST and should be rewritten for desired settings (see Table 42).

|               |                                   | <b>U</b> 1               |               | inotionality | 1             |                    |
|---------------|-----------------------------------|--------------------------|---------------|--------------|---------------|--------------------|
| Register Name | Description                       | Register File<br>Address | Register Type | ACCESS Size  | Default value | Next RF<br>Address |
| KBDSETTLE     | Keypad Settle<br>Time             | 0x01                     | R/W           | byte         | 0x80          | 0x02               |
| KBDBOUNCE     | Keypad Debounce<br>Time           | 0x02                     | R/W           | byte         | 0x80          | 0x03               |
| KBDSIZE       | Keypad Size<br>Configuration      | 0x03                     | R/W           | byte         | 0x22          | 0x04               |
| KBDDEDCFG0    | Keypad Dedicated<br>Key 0         | 0x04                     | R/W           | byte         | 0xFF          | 0x05               |
| KBDDEDCFG1    | Keypad Dedicated<br>Key 1         | 0x05                     | R/W           | byte         | 0xFF          | 0x06               |
| KBDRIS        | Keypad Raw<br>Interrupt Status    | 0x06                     | R             | byte         | 0x00          | 0x07               |
| KBDMIS        | Keypad Masked<br>Interrupt Status | 0x07                     | R             | byte         | 0x00          | 0x08               |
| KBDIC         | Keypad Interrupt<br>Clear         | 0x08                     | W             | byte         |               | 0x09               |
| KBDMSK        | Keypad Interrupt<br>Mask          | 0x09                     | R/W           | byte         | 0xF3          | 0x0A               |
| KBDCODE0      | Keypad Code 0                     | 0x0B                     | R             | byte         | 0x7F          | 0x0C               |
| KBDCODE1      | Keypad Code 1                     | 0x0C                     | R             | byte         | 0x7F          | 0x0D               |
| KBDCODE2      | Keypad Code 2                     | 0x0D                     | R             | byte         | 0x7F          | 0x0E               |
| KBDCODE3      | Keypad Code 3                     | 0x0E                     | R             | byte         | 0x7F          | 0x0F               |
| EVTCODE       | Key Event Code                    | 0x10                     | R             | byte         | 0x7F          | 0x10               |

#### **Register Map for Keyboard Functionality**

### **PWM TIMER REGISTERS**

shows the register map for PWM Timer functionality. In addition to Global Call Reset (see Global Call Reset) or Software Reset using SWRESET (see Table 41), these registers are reset to default values by a module reset using RSTCTRL.TIMRST (see Table 42).

|               | Register map for Pwin filler functionality |                          |               |             |               |                    |  |  |  |
|---------------|--------------------------------------------|--------------------------|---------------|-------------|---------------|--------------------|--|--|--|
| Register Name | Description                                | Register File<br>Address | Register Type | ACCESS Size | Default value | Next RF<br>Address |  |  |  |
| TIMCFG0       | PWM Timer<br>Configuration 0               | 0x60                     | R/W           | byte        | 0x00          | 0x61               |  |  |  |
| PWMCFG0       | PWM<br>Configuration 0                     | 0x61                     | R/W           | byte        | 0x00          | 0x62               |  |  |  |
| TIMCFG1       | PWM Timer<br>Configuration 1               | 0x68                     | R/W           | byte        | 0x00          | 0x69               |  |  |  |
| PWMCFG1       | PWM<br>Configuration 1                     | 0x69                     | R/W           | byte        | 0x00          | 0x6A               |  |  |  |
| TIMCFG2       | PWM Timer<br>Configuration 2               | 0x70                     | R/W           | byte        | 0x00          | 0x71               |  |  |  |
| PWMCFG2       | PWM<br>Configuration 2                     | 0x71                     | R/W           | byte        | 0x00          | 0x72               |  |  |  |

**Register Map for PWM Timer Functionality** 

Texas Instruments

SNLS328A - AUGUST 2011-REVISED MARCH 2013

www.ti.com

| Register Name | Description                     | Register File<br>Address | Register Type | ACCESS Size | Default value | Next RF<br>Address |
|---------------|---------------------------------|--------------------------|---------------|-------------|---------------|--------------------|
| TIMSWRES      | PWM Timer SW<br>Reset           | 0x78                     | W             | byte        |               | 0x79               |
| TIMRIS        | PWM Timer<br>Interrupt Status   | 0x7A                     | R             | byte        | 0x00          | 0x7B               |
| TIMMIS        | PWM Timer<br>Masked Int. Status | 0x7B                     | R             | byte        | 0x00          | 0x7C               |
| TIMIC         | Timer Interrupt<br>Clear        | 0x7C                     | W             | byte        |               | 0x7D               |
| PWMWP         | PWM Command<br>Write Pointer    | 0x7D                     | R/W           | byte        | 0x00          | 0x7E               |
| PWMCFG        | PWM Command<br>Script           | 0x7E                     | W             | word        |               | 0x7F               |

### SYSTEM REGISTERS

shows the register map for general system registers. These registers are not affected by any of the module resets addressed by RSTCTRL (see Table 42). These registers can only be reset to default values by a Global Call Reset (see Global Call Reset) or by a complete Software Reset using SWRESET (see Table 41).

|               |                                                            | 9.8.8                    | Cystem Control |             |               |                    |
|---------------|------------------------------------------------------------|--------------------------|----------------|-------------|---------------|--------------------|
| Register Name | Description                                                | Register File<br>Address | Register Type  | ACCESS Size | Default value | Next RF<br>Address |
| I2CSA         | I <sup>2</sup> C-compatible<br>ACCESS.bus<br>Slave Address | 0x80                     | w              | byte        | 0x88          | 0x81               |
| MFGCODE       | Manufacturer Code                                          | 0x80                     | R              | byte        | 0x00          | 0x81               |
| SWREV         | SW Revision                                                | 0x81                     | R              | byte        | 0x83          | 0x82               |
| SWRESET       | SW Reset                                                   | 0x81                     | W              | byte        |               | 0x82               |
| RSTCTRL       | System Reset                                               | 0x82                     | R/W            | byte        | 0x00          | 0x83               |
| RSTINTCLR     | Clear No<br>Init/Power On<br>Interrupt                     | 0x84                     | w              | byte        |               | 0x85               |
| CLKMODE       | Clock Mode                                                 | 0x88                     | R/W            | byte        | 0x01          | 0x89               |
| CLKEN         | Clock Enable                                               | 0x8A                     | R/W            | byte        | 0x00          | 0x8B               |
| AUTOSLP       | Auto Sleep Enable                                          | 0x8B                     | R/W            | byte        | 0x00          | 0x8C               |
| AUTOSLPTI     | Auto Sleep Time                                            | 0x8C                     | R/W            | word        | 0x00FF        | 0x8D               |

#### **Register Map for System Control Functionality**

### **GLOBAL INTERRUPT REGISTERS**

Table 90 shows the register map for global interrupt functionality. In addition to Global Call Reset (see Global Call Reset) or Software Reset using SWRESET (see Table 41), these registers are reset to default values by a module reset using RSTCTRL.IRQRST (see Table 42).

#### Table 90. Register Map for Global Interrupt Functionality

| Register Name | Description                | Register File<br>Address | Register Type | ACCESS Size | Default value | Next RF<br>Address |
|---------------|----------------------------|--------------------------|---------------|-------------|---------------|--------------------|
| IRQST         | Global Interrupt<br>Status | 0x91                     | R             | byte        | 0x80          | 0x92               |

### **GPIO REGISTERS**

shows the register map for GPIO functionality. In addition to Global Call Reset (see Global Call Reset) or Software Reset using SWRESET (see Table 41), these registers are reset to 0x00 values by a module reset using RSTCTRL.GPIRST and should be rewritten for desired settings (see Table 42).



#### SNLS328A - AUGUST 2011 - REVISED MARCH 2013

|               | I                                | Register Ma              | p for GPIO Fund | ctionality  |               |                    |
|---------------|----------------------------------|--------------------------|-----------------|-------------|---------------|--------------------|
| Register Name | Description                      | Register File<br>Address | Register Type   | ACCESS Size | Default value | Next RF<br>Address |
| IOCFG         | I/O Pin Mapping<br>Configuration | 0xA7                     | W               | byte        |               | 0xA8               |
| IOPC0         | Pull Resistor<br>Configuration 0 | 0xAA                     | R/W             | word        | 0xAAAA        | 0xAB               |
| IOPC1         | Pull Resistor<br>Configuration 1 | 0xAC                     | R/W             | word        | 0x5555        | 0xAD               |
| IOPC2         | Pull Resistor<br>Configuration 2 | 0xAE                     | R/W             | word        | 0x5A15        | 0xAF               |
| GPIODATA0     | GPIO I/O Data 0                  | 0xC0                     | R/W             | byte        | 0x00          | 0xC1               |
| GPIOMASK0     | GPIO I/O Mask 0                  | 0xC1                     | W               | byte        |               | 0xC2               |
| GPIODATA1     | GPIO I/O Data 1                  | 0xC2                     | R/W             | byte        | 0x00          | 0xC3               |
| GPIOMASK1     | GPIO I/O Mask 1                  | 0xC3                     | W               | byte        |               | 0xC4               |
| GPIODATA2     | GPIO I/O Data 2                  | 0xC4                     | R/W             | byte        | 0x00          | 0xC5               |
| GPIOMASK2     | GPIO I/O Mask 2                  | 0xC5                     | W               | byte        |               | 0xC6               |
| GPIODIR0      | GPIO I/O<br>Direction 0          | 0xC6                     | R/W             | byte        | 0x00          | 0xC7               |
| GPIODIR1      | GPIO I/O<br>Direction 1          | 0xC7                     | R/W             | byte        | 0x00          | 0xC8               |
| GPIODIR2      | GPIO I/O<br>Direction 2          | 0xC8                     | R/W             | byte        | 0x08          | 0xC9               |
| GPIOIS0       | GPIO Int Sense<br>Config 0       | 0xC9                     | R/W             | byte        | 0x00          | 0xCA               |
| GPIOIS1       | GPIO Int Sense<br>Config 1       | 0xCA                     | R/W             | byte        | 0x00          | 0xCB               |
| GPIOIS2       | GPIO Int Sense<br>Config 2       | 0xCB                     | R/W             | byte        | 0x00          | 0xCC               |
| GPIOIBE0      | GPIO Int Both<br>Edges Config 0  | 0xCC                     | R/W             | byte        | 0x00          | 0xCD               |
| GPIOIBE1      | GPIO Int Both<br>Edges Config 1  | 0xCD                     | R/W             | byte        | 0x00          | 0xCE               |
| GPIOIBE2      | GPIO Int Both<br>Edges Config 2  | 0xCE                     | R/W             | byte        | 0x00          | 0xCF               |
| GPIOIEV0      | GPIO Int Edge<br>Select 0        | 0xCF                     | R/W             | byte        | 0xFF          | 0xD0               |
| GPIOIEV1      | GPIO Int Edge<br>Select 1        | 0xD0                     | R/W             | byte        | 0xFF          | 0xD1               |
| GPIOIEV2      | GPIO Int Edge<br>Select 2        | 0xD1                     | R/W             | byte        | 0xFF          | 0xD2               |
| GPIOIE0       | GPIO Interrupt<br>Enable 0       | 0xD2                     | R/W             | byte        | 0x00          | 0xD3               |
| GPIOIE1       | GPIO Interrupt<br>Enable 1       | 0xD3                     | R/W             | byte        | 0x00          | 0xD4               |
| GPIOIE2       | GPIO Interrupt<br>Enable 2       | 0xD4                     | R/W             | byte        | 0x00          | 0xD5               |
| GPIORIS0      | GPIO Raw Int<br>Status 0         | 0xD6                     | R               | byte        | 0x00          | 0xD7               |
| GPIORIS1      | GPIO Raw Int<br>Status 1         | 0xD7                     | R               | byte        | 0x00          | 0xD8               |
| GPIORIS2      | GPIO Raw Int<br>Status 2         | 0xD8                     | R               | byte        | 0x00          | 0xD9               |
| GPIOMIS0      | GPIO Masked Int<br>Status 0      | 0xD9                     | R               | byte        | 0x00          | 0xDA               |
| GPIOMIS1      | GPIO Masked Int<br>Status 1      | 0xDA                     | R               | byte        | 0x00          | 0xDB               |

TEXAS INSTRUMENTS

SNLS328A - AUGUST 2011 - REVISED MARCH 2013

www.ti.com

|               | Register Map for GPIO Functionality (continued) |                          |               |             |               |                    |  |  |  |  |  |  |  |
|---------------|-------------------------------------------------|--------------------------|---------------|-------------|---------------|--------------------|--|--|--|--|--|--|--|
| Register Name | Description                                     | Register File<br>Address | Register Type | ACCESS Size | Default value | Next RF<br>Address |  |  |  |  |  |  |  |
| GPIOMIS2      | GPIO Masked Int<br>Status 2                     | 0xDB                     | R             | byte        | 0x00          | 0xDC               |  |  |  |  |  |  |  |
| GPIOIC0       | GPIO Interrupt<br>Clear 0                       | 0xDC                     | W             | byte        |               | 0xDD               |  |  |  |  |  |  |  |
| GPIOIC1       | GPIO Interrupt<br>Clear 1                       | 0xDD                     | W             | byte        |               | 0xDE               |  |  |  |  |  |  |  |
| GPIOIC2       | GPIO Interrupt<br>Clear 2                       | 0xDE                     | W             | byte        |               | 0xDF               |  |  |  |  |  |  |  |
| GPIOOME0      | GPIO Open Drain<br>Mode Enable 0                | 0xE0                     | R/W           | byte        | 0x00          | 0xE1               |  |  |  |  |  |  |  |
| GPIOOMS0      | GPIO Open Drain<br>Mode Select 0                | 0xE1                     | R/W           | byte        | 0x00          | 0xE2               |  |  |  |  |  |  |  |
| GPIOOME1      | GPIO Open Drain<br>Mode Enable 1                | 0xE2                     | R/W           | byte        | 0x00          | 0xE3               |  |  |  |  |  |  |  |
| GPIOOMS1      | GPIO Open Drain<br>Mode Select 1                | 0xE3                     | R/W           | byte        | 0x00          | 0xE4               |  |  |  |  |  |  |  |
| GPIOOME2      | GPIO Open Drain<br>Mode Enable 2                | 0xE4                     | R/W           | byte        | 0x08          | 0xE5               |  |  |  |  |  |  |  |
| GPIOOMS2      | GPIO Open Drain<br>Mode Select 2                | 0xE5                     | R/W           | byte        | 0x00          | 0xE6               |  |  |  |  |  |  |  |
| GPIOWAKE0     | GPIO Wakeup<br>Enable 0                         | 0xE9                     | R/W           | byte        | 0x00          | 0xEA               |  |  |  |  |  |  |  |
| GPIOWAKE1     | GPIO Wakeup<br>Enable 1                         | 0xEA                     | R/W           | byte        | 0x00          | 0xEB               |  |  |  |  |  |  |  |
| GPIOWAKE2     | GPIO Wakeup<br>Enable 2                         | 0xEB                     | R/W           | byte        | 0x00          | 0xEC               |  |  |  |  |  |  |  |

## **Register Map for GPIO Functionality (continued)**

## **REGISTER LAYOUT - Control Bits in LM8328 Registers**

| Register       | Addr. | BIT 7         | BIT 6         | BIT 5         | BIT 4            | BIT 3           | BIT 2         | BIT 1         | BIT 0         |  |  |
|----------------|-------|---------------|---------------|---------------|------------------|-----------------|---------------|---------------|---------------|--|--|
| KBDSETTLE      | 0x01  |               |               |               | Wait             | [7:0]           |               |               |               |  |  |
| KBDBOUNCE      | 0x02  |               |               |               | Wait             | [7:0]           |               |               |               |  |  |
| KBDSIZE        | 0x03  | ROW-<br>SIZE3 | ROW-<br>SIZE2 | ROW-<br>SIZE1 | ROW-<br>SIZE0    | COL-<br>SIZE3   | COL-<br>SIZE2 | COL-<br>SIZE1 | COL-<br>SIZE0 |  |  |
| KBDDEDCFG<br>0 | 0x04  | COL9          | COL8          | COL7          | COL6             | COL5            | COL4          | COL3          | COL2          |  |  |
| KBDDEDCFG<br>1 | 0x05  | ROW7          | ROW6          | ROW5          | ROW4             | ROW3            | ROW2          | COL11         | COL10         |  |  |
| KBDRIS         | 0x06  |               |               |               |                  | RELINT          | REVTINT       | RKLINT        | RSINT         |  |  |
| KBDMIS         | 0x07  |               |               |               |                  | MELINT          | MEVTINT       | MKLINT        | MSINT         |  |  |
| KBDIC          | 0x08  | SFOFF         |               |               |                  |                 |               | EVTIC         | KBDIC         |  |  |
| KBDMSK         | 0x09  |               |               |               |                  | MSKELINT        | MSKEINT       | MSKLINT       | MSKSINT       |  |  |
| KBDCODE0       | 0x0B  | MULTIKEY      | KEYROW2       | KEYROW1       | KEYROW0          | KEYCOL3         | KEYCOL2       | KEYCOL1       | KEYCOL0       |  |  |
| KBDCODE1       | 0x0C  | MULTIKEY      | KEYROW2       | KEYROW1       | KEYROW0          | KEYCOL3         | KEYCOL2       | KEYCOL1       | KEYCOL0       |  |  |
| KBDCODE2       | 0x0D  | MULTIKEY      | KEYROW2       | KEYROW1       | KEYROW0          | KEYCOL3         | KEYCOL2       | KEYCOL1       | KEYCOL0       |  |  |
| KBDCODE3       | 0x0E  | MULTIKEY      | KEYROW2       | KEYROW1       | KEYROW0          | KEYCOL3         | KEYCOL2       | KEYCOL1       | KEYCOL0       |  |  |
| EVTCODE        | 0x10  | RELEASE       | KEYROW2       | KEYROW1       | KEYROW0          | KEYCOL3         | KEYCOL2       | KEYCOL1       | KEYCOL0       |  |  |
| TIMCFG0        | 0x60  |               |               |               | CICIRQ0-<br>MASK |                 |               |               | START         |  |  |
| PWMCFG0        | 0x61  |               |               |               |                  | CDIRQ0-<br>MASK | PGE           | PWMEN         | PWMPOL        |  |  |
| TIMCFG1        | 0x68  |               |               |               | CYIRQ1-<br>MASK  |                 |               |               | START         |  |  |



SNLS328A - AUGUST 2011 - REVISED MARCH 2013

## **REGISTER LAYOUT - Control Bits in LM8328 Registers (continued)**

| Register            | Addr. | BIT 7   | BIT 6    | BIT 5   | BIT 4      | BIT 3           | BIT 2          | BIT 1   | BIT 0   |  |
|---------------------|-------|---------|----------|---------|------------|-----------------|----------------|---------|---------|--|
| PWMCFG1             | 0x69  |         |          |         |            | CDIRQ1-<br>MASK | PGE            | PWMEN   | PWMPOL  |  |
| TIMCFG2             | 0x70  |         |          |         | IRQMASK    |                 |                |         | START   |  |
| PWMCFG2             | 0x71  |         |          |         |            | CDIRQ2-<br>MASK | PGE            | PWMEN   | PWMPOL  |  |
| TIMSWRES            | 0x78  |         |          |         |            |                 | SWRES2         | SWRES1  | SWRES0  |  |
| TIMRIS              | 0x7A  |         |          | CDIRQ2  | CDIRQ1     | CDIRQ0          | CICIRQ2        | CICIRQ1 | CICIRQ0 |  |
| TIMMIS              | 0x7B  |         |          | CDIRQ2  | CDIRQ1     | CDIRQ0          | CICIRQ2        | CICIRQ1 | CICIRQ0 |  |
| TIMIC               | 0x7C  |         |          | CDIRQ2  | CDIRQ1     | CDIRQ0          | CICIRQ2        | CICIRQ1 | CICIRQ0 |  |
| PWMWP               | 0x7D  | 0       |          |         |            | PWMWP[6:0]      |                |         |         |  |
| PWMCFG<br>(Low)     | 0x7E  |         |          |         | CMD        | [7:0]           |                |         |         |  |
| PWMCFG<br>(High)    | 0x7F  |         |          |         | CMD[       | 15:8]           |                |         |         |  |
| I2CSA               | 0x80  |         |          | S       | LAVEADDR[7 | :1]             |                |         | 0       |  |
| MFGCODE             | 0x80  |         |          |         | MFGB       | IT[7:0]         |                |         |         |  |
| SWREV               | 0x81  |         |          |         | SWBI       | T[7:0]          |                |         |         |  |
| SWRESET             | 0x81  |         |          |         | SWBI       | T[7:0]          |                |         |         |  |
| RSTCTRL             | 0x82  |         |          |         | IRQRST     | TIMRST          |                | KBDRST  | GPIRST  |  |
| RSTINTCLR           | 0x84  |         |          |         |            |                 |                |         | IRQCLR  |  |
| CLKMODE             | 0x88  |         |          |         |            |                 |                | MOD-C   | TL[1:0] |  |
| CLKEN               | 0x8A  | CLKOU   | TEN[1:0] |         |            |                 | TIMEN          |         | KBDEN   |  |
| AUTOSLP             | 0x8B  |         |          |         |            |                 |                |         | ENABLE  |  |
| AUTOSLPTI<br>(Low)  | 0x8C  |         |          |         | UP-TIM     | E [7:0]         |                |         |         |  |
| AUTOSLPTI<br>(High) | 0x8D  |         |          |         |            |                 | UP-TIME [10:8] |         | .8]     |  |
| IRQST               | 0x91  | PORIRQ  | KBD1RQ   |         |            | TIM2IRQ         | TIM1IRQ        | TIM01RQ | GPIIRQ  |  |
| IOCFG               | 0xA7  |         |          | a       | IOCFGF     | PM [7:0]        |                | 1       |         |  |
| IOPC0 (Low)         | 0xAA  | KPX3    | PR[1:0]  | KPX2    | PR[1:0]    | KPX1            | PR[1:0]        | KPX0F   | PR[1:0] |  |
| IOPC0 (High)        | 0xAB  | KPX7I   | PR[1:0]  | KPX6    | PR[1:0]    | KPX5            | PR[1:0]        | KPX4F   | PR[1:0] |  |
| IOPC1 (Low)         | 0xAC  | KPY3I   | PR[1:0]  | KPY2F   | PR[1:0]    | KPY1            | PR[1:0]        | KPY0F   | PR[1:0] |  |
| IOPC1 (High)        | 0xAD  | KPY7I   | PR[1:0]  | KPY6    | PR[1:0]    | KPY5            | PR[1:0]        | KPY4F   | PR[1:0] |  |
| IOPC2 (Low)         | 0xAE  | KPY11   | PR[1:0]  | KPY10   | PR[1:0]    | KPY9            | PR[1:0]        | KPY8F   | PR[1:0] |  |
| IOPC2 (High)        | 0xAF  |         |          | ,<br>,  |            | ,<br>,          |                |         |         |  |
| GPIODATA0           | 0xC0  | DATA7   | DATA6    | DATA5   | DATA4      | DATA3           | DATA2          | DATA1   | DATA0   |  |
| GPIOMASK0           | 0xC1  | MASK7   | MASK6    | MASK5   | MASK4      | MASK3           | MASK2          | MASK1   | MASK0   |  |
| GPIODATA1           | 0xC2  | DATA15  | DATA14   | DATA13  | DATA12     | DATA11          | DATA10         | DATA9   | DATA8   |  |
| GPIOMASK1           | 0xC3  | MASK15  | MASK14   | MASK13  | MASK12     | MASK11          | DATA10         | DATA9   | DATA8   |  |
| GPIODATA2           | 0xC4  |         |          |         |            | DATA19          | DATA18         | DATA17  | DATA16  |  |
| GPIOMASK2           | 0xC5  |         |          |         |            | MASK19          | MASK18         | MASK17  | MASK16  |  |
| GPIODIR0            | 0xC6  | KPX7DIR | KPX6DIR  | KPX5DIR | KPX4DIR    | KPX3DIR         | KPX2DIR        | KPX1DIR | KPX0DIR |  |
| GPIODIR1            | 0xC7  | KPY7DIR | KPY6DIR  | KPY5DIR | KPY4DIR    | KPY3DIR         | KPY2DIR        | KPY1DIR | KPY0DIR |  |
| GPIODIR2            | 0xC8  |         |          |         |            | KP11DIR         | KPY10DIR       | KPY9DIR | KPY8DIR |  |
| GPIOIS0             | 0xC9  | KPX7IS  | KPX6IS   | KPX5IS  | KPX4IS     | KPX3IS          | KPX2IS         | KPX1IS  | KPX0IS  |  |
| GPIOIS1             | 0xCA  | KPY7IS  | KPY6IS   | KPY5IS  | KPY4IS     | KPY3IS          | KPY2IS         | KPY1IS  | KPY0IS  |  |
| GPIOIS2             | 0xCB  |         |          |         |            | KPY11IS         | KPY10IS        | KPY9IS  | KPY8IS  |  |
| GPIOIBE0            | 0xCC  | KPX7IBE | KPX6IBE  | KPX5IBE | KPX4IBE    | KPX3IBE         | KPX2IBE        | KPX1IBE | KPX0IBE |  |
| GPIOIBE1            | 0xCD  | KPY7IBE | KPY6IBE  | KPY5IBE | KPY4IBE    | <b>KPY3IBE</b>  | KPY2IBE        | KPY1IBE | KPY0IBE |  |



SNLS328A - AUGUST 2011 - REVISED MARCH 2013

www.ti.com

| RE    | GISTER LA | AYOUT - Co | ontrol Bits | in LM8328 | Registers | (continued | )     |
|-------|-----------|------------|-------------|-----------|-----------|------------|-------|
| Addr. | BIT 7     | BIT 6      | BIT 5       | BIT 4     | BIT 3     | BIT 2      | BIT 1 |

| Register  | Addr. | BIT 7        | BIT 6        | BIT 5        | BIT 4        | BIT 3          | BIT 2         | BIT 1        | BIT 0        |
|-----------|-------|--------------|--------------|--------------|--------------|----------------|---------------|--------------|--------------|
| GPIOIBE2  | 0xCE  |              |              |              |              | KPY11IBE       | KPY10IBE      | KPY9IBE      | KPY8IBE      |
| GPIOIEV0  | 0xCF  | KPX7EV       | KPX6EV       | KPX5EV       | KPX4EV       | KPX3EV         | KPX2EV        | KPX1EV       | KPX0EV       |
| GPIOIEV1  | 0xD0  | KPY7EV       | KPY6EV       | KPY5EV       | KPY4EV       | KPY3EV         | KPY2EV        | KPY1EV       | KPY0EV       |
| GPIOIEV2  | 0xD1  |              |              |              |              | KPY11IEV       | KPY10IEV      | KPY9IEV      | KPY8IEV      |
| GPIOIE0   | 0xD2  | KPX7IE       | KPX6IE       | KPX5IE       | KPX4IE       | KPX3IE         | KPX2IE        | KPX1IE       | KPX0IE       |
| GPIOIE1   | 0xD3  | KPY7IE       | KPY6IE       | KPY5IE       | KPY4IE       | KPY3IE         | KPY2IE        | KPY1IE       | KPY0IE       |
| GPIOIE2   | 0xD4  |              |              |              |              | KPY11IE        | KPY10IE       | KPY9IE       | KPY8IE       |
| GPIORIS0  | 0xD6  | KPX7RIS      | KPX6RIS      | KPX5RIS      | KPX4RIS      | <b>KPX3RIS</b> | KPX2RIS       | KPX1RIS      | KPX0RIS      |
| GPIORIS1  | 0xD7  | KPY7RIS      | KPY6RIS      | KPY5RIS      | KPY4RIS      | KPY3RIS        | KPY2RIS       | KPY1RIS      | KPY0RIS      |
| GPIORIS2  | 0xD8  |              |              |              |              | KPY11RIS       | KPY10RIS      | KPY9RIS      | KPY8RIS      |
| GPIOMIS0  | 0xD9  | KPX7MIS      | KPX6MIS      | KPX5MIS      | KPX4MIS      | KPX3MIS        | KPX2MIS       | KPX1MIS      | KPX0MIS      |
| GPIOMIS1  | 0xDA  | KPY7MIS      | KPY6MIS      | KPY5MIS      | KPY4MIS      | KPY3MIS        | KPY2MIS       | KPY1MIS      | KPY0MIS      |
| GPIOMIS2  | 0xDB  |              |              |              |              | KPY11MIS       | KPY10MIS      | KPY9MIS      | KPY8MIS      |
| GPIOIC0   | 0xDC  | KPX7IC       | KPX6IC       | KPX5IC       | KPX4IC       | KPX3IC         | KPX2IC        | KPX1IC       | KPX0IC       |
| GPIOIC1   | 0xDD  | KPY7IC       | KPY6IC       | KPY5IC       | KPY4IC       | KPY3IC         | KPY2IC        | KPY1IC       | KPY0IC       |
| GPIOIC2   | 0xDE  |              |              |              |              | KPY11IC        | KPY10IC       | KPY9IC       | KPY8IC       |
| GPIOOME0  | 0xE0  | KPX7ODE      | KPX6ODE      | KPX5ODE      | KPX4ODE      | KPX3ODE        | KPX2ODE       | KPX10DE      | KPX00DE      |
| GPIOOMS0  | 0xE1  | KPX7ODM      | KPX6ODM      | KPX5ODM      | KPX4ODM      | KPX3ODM        | KPX2ODM       | KPX10DM      | KPX0ODM      |
| GPIOOME1  | 0xE2  | KPY7ODE      | KPY6ODE      | KPY5ODE      | KPY4ODE      | KPY3ODE        | KPY2ODE       | KPY10DE      | KPY00DE      |
| GPIOOMS1  | 0xE3  | KPY7ODM      | KPY6ODM      | KYY5ODM      | KPY4ODM      | KPY3ODM        | KPY2ODM       | KPY10DM      | KPY00DM      |
| GPIOOME2  | 0xE4  |              |              |              |              | KPY11<br>ODE   | KPY10<br>ODE  | KPY9<br>ODE  | KPY8<br>ODE  |
| GPIOOMS2  | 0xE5  |              |              |              |              | KPY11<br>ODM   | KPY10<br>ODM  | KPY9<br>ODM  | KPY8<br>ODM  |
| GPIOWAKE0 | 0xE9  | KPX7<br>WAKE | KPX6<br>WAKE | KPX5<br>WAKE | KPX4<br>WAKE | KPX3<br>WAKE   | KPX2<br>WAKE  | KPX1<br>WAKE | KPX0<br>WAKE |
| GPIOWAKE1 | 0xEA  | KPY7<br>WAKE | KPY6<br>WAKE | KPY5<br>WAKE | KPY4<br>WAKE | KPY3<br>WAKE   | KPY2<br>WAKE  | KPY1<br>WAKE | KPY0<br>WAKE |
| GPIOWAKE2 | 0xEB  |              |              |              |              | KPY11<br>WAKE  | KPY10<br>WAKE | KPY9<br>WAKE | KPY8<br>WAKE |

SNLS328A - AUGUST 2011 - REVISED MARCH 2013

| Cł | nanges from Original (March 2013) to Revision A    | Page |
|----|----------------------------------------------------|------|
| •  | Changed layout of National Data Sheet to TI format | 48   |



10-Dec-2020

# PACKAGING INFORMATION

| Orderable Device | Status<br>(1) | Package Type | Package<br>Drawing | Pins | Package<br>Qty | Eco Plan<br>(2) | Lead finish/<br>Ball material<br>(6) | MSL Peak Temp<br>(3) | Op Temp (°C) | Device Marking<br>(4/5) | Samples |
|------------------|---------------|--------------|--------------------|------|----------------|-----------------|--------------------------------------|----------------------|--------------|-------------------------|---------|
| LM8328TME/NOPB   | ACTIVE        | DSBGA        | YFQ                | 25   | 250            | RoHS & Green    | SNAGCU                               | Level-1-260C-UNLIM   | -40 to 85    | 2731                    | Samples |
| LM8328TMX/NOPB   | ACTIVE        | DSBGA        | YFQ                | 25   | 3000           | RoHS & Green    | SNAGCU                               | Level-1-260C-UNLIM   | -40 to 85    | 2731                    | Samples |

<sup>(1)</sup> The marketing status values are defined as follows:

ACTIVE: Product device recommended for new designs.

LIFEBUY: TI has announced that the device will be discontinued, and a lifetime-buy period is in effect.

NRND: Not recommended for new designs. Device is in production to support existing customers, but TI does not recommend using this part in a new design.

**PREVIEW:** Device has been announced but is not in production. Samples may or may not be available.

**OBSOLETE:** TI has discontinued the production of the device.

<sup>(2)</sup> RoHS: TI defines "RoHS" to mean semiconductor products that are compliant with the current EU RoHS requirements for all 10 RoHS substances, including the requirement that RoHS substance do not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, "RoHS" products are suitable for use in specified lead-free processes. TI may reference these types of products as "Pb-Free".

**RoHS Exempt:** TI defines "RoHS Exempt" to mean products that contain lead but are compliant with EU RoHS pursuant to a specific EU RoHS exemption.

Green: TI defines "Green" to mean the content of Chlorine (CI) and Bromine (Br) based flame retardants meet JS709B low halogen requirements of <= 1000ppm threshold. Antimony trioxide based flame retardants must also meet the <= 1000ppm threshold requirement.

<sup>(3)</sup> MSL, Peak Temp. - The Moisture Sensitivity Level rating according to the JEDEC industry standard classifications, and peak solder temperature.

<sup>(4)</sup> There may be additional marking, which relates to the logo, the lot trace code information, or the environmental category on the device.

<sup>(5)</sup> Multiple Device Markings will be inside parentheses. Only one Device Marking contained in parentheses and separated by a "~" will appear on a device. If a line is indented then it is a continuation of the previous line and the two combined represent the entire Device Marking for that device.

<sup>(6)</sup> Lead finish/Ball material - Orderable Devices may have multiple material finish options. Finish options are separated by a vertical ruled line. Lead finish/Ball material values may wrap to two lines if the finish value exceeds the maximum column width.

**Important Information and Disclaimer:**The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.

In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis.



# PACKAGE OPTION ADDENDUM

10-Dec-2020

# PACKAGE MATERIALS INFORMATION

Texas Instruments

\*All dimensions are nominal

www.ti.com

## TAPE AND REEL INFORMATION





# QUADRANT ASSIGNMENTS FOR PIN 1 ORIENTATION IN TAPE



| Device         | Package<br>Type | Package<br>Drawing |    | SPQ  | Reel<br>Diameter<br>(mm) | Reel<br>Width<br>W1 (mm) | A0<br>(mm) | B0<br>(mm) | K0<br>(mm) | P1<br>(mm) | W<br>(mm) | Pin1<br>Quadrant |
|----------------|-----------------|--------------------|----|------|--------------------------|--------------------------|------------|------------|------------|------------|-----------|------------------|
| LM8328TME/NOPB | DSBGA           | YFQ                | 25 | 250  | 178.0                    | 8.4                      | 2.08       | 2.08       | 0.76       | 4.0        | 8.0       | Q1               |
| LM8328TMX/NOPB | DSBGA           | YFQ                | 25 | 3000 | 178.0                    | 8.4                      | 2.08       | 2.08       | 0.76       | 4.0        | 8.0       | Q1               |



# PACKAGE MATERIALS INFORMATION

5-Nov-2021



\*All dimensions are nominal

| Device         | Package Type | Package Drawing | Pins | SPQ  | Length (mm) | Width (mm) | Height (mm) |
|----------------|--------------|-----------------|------|------|-------------|------------|-------------|
| LM8328TME/NOPB | DSBGA        | YFQ             | 25   | 250  | 208.0       | 191.0      | 35.0        |
| LM8328TMX/NOPB | DSBGA        | YFQ             | 25   | 3000 | 208.0       | 191.0      | 35.0        |

# YFQ0025



## IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements.

These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to TI's Terms of Sale or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products.

TI objects to and rejects any additional or different terms you may have proposed.

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2021, Texas Instruments Incorporated