# A Semtech Company USAR®

## Zero-Power Keyboard Encoder & Power Management IC for Intel StrongARM-based H/PCs

USAR H/PC ICs family product specifications

#### **Description**

The USAR SPICoder™ UR5HCSPI-SA, a member of USAR's H/PC ICs family, is a keyboard encoder and power management IC designed specifically for Handheld PCs (H/PCs), Web Phones and other systems that run Microsoft® Windows CE® and utilize the Intel StrongARM™ processor.

The UR5HCSPI-SA offers several features necessary to H/PCs, including low power consumption, real estate-saving size, and special keyboard modes.

The IC operates at Zero-Power™ (less than 2µA @ 3V), providing the the host system both power management and I/O flexibility, with minimal battery drainage.

Special keyboard modes and built-in power management features allow the USAR SPICoder™ SA to operate in harmony with the power management modes of Windows CE®, resulting in greater user flexibility, and longer battery life.

The IC will scan, debounce and encode an 8 x 14 keyboard matrix. It communicates with the Host over the SPI channel, implementing a high-reliability two-way protocol. The UR5HCSPI-SA also offers programmable features for wake-up keys and general purpose I/O pins. The UR5HCSPI-SA is utilized in several Intel reference designs.

#### **Features**

- SPI-compatible keyboard encoder and power management IC with other interfaces available
- Ideal for use with the Intel StrongARM™ processor
- Operates at patented Zero-Power™
   — typically consuming less than 2µA, between 3-5V
- Offers overall system power management capabilities
- Implements high-reliability two-way protocol

- Fully compatible to the Windows CE® keyboard specification
- Works in harmony with the power management modes of Win CE®
- Provides special modes of operation for H/PCs, including programmable "wake-up" keys
- Scans an 8 x 14 matrix and controls discrete switches and LED indicators
- Compatible with "system-on silicon" CPUs for H/PCs
- Available in small 10mm by 10mm, 44-pin QFP package

#### **Applications**

- StrongARM™ Handheld PCs
- Windows CE® Platforms
- Web Phones

- Personal Digital Assistants (PDAs)
- Wearable Computers
- Internet Appliance

#### **Pin Assignments**





Copyright 1999-2000 USAR Systems, Inc. All rights reserved.

| Ordering Code        |              |                     |
|----------------------|--------------|---------------------|
| Package options      | Pich In mm's | TA = -40°C to +85°C |
| 44-pin, Plastic PLCC | 1.27 mm      | UR5CSPI-SA-FN       |
| 44-pin, Plastic QFP  | 0.8 mm       | UR5CSPI-SA-FB       |

#### **Block Diagram**



#### **Functional Description**

The UR5HCSPI-SA consists functionally of five major sections (see the Functional Diagram on page 2). These are the Keyboard Scanner and State control, the Programmable I/O, the SPI Communication Channel, the System Monitor and the Power Management unit. All sections communicate with each other and operate concurrently.

#### **Pin Definitions**

| Mnemonic | PLCC  | QFP   | Туре     | Name and Function                        |
|----------|-------|-------|----------|------------------------------------------|
| VCC      | 44    | 38    | T I      | Power Supply: 3-5V                       |
| VSS      | 22    | 17    |          | Ground                                   |
| VX       | 4     | 43    |          | Tie to VCC                               |
| OSCI     | 43    | 37    |          | Oscillator input                         |
| OSCO     | 42    | 36    | 0        | Oscillator output                        |
| _RESET   |       | 41    |          | Reset: apply 0V to provide orderly       |
|          |       |       |          | start-up                                 |
| MISO     | 34    | 29    | 0        | SPI Interface Signals                    |
| MOSI     | 35    | 30    | 1        | _                                        |
| SCK      | 36    | 31    | 1        |                                          |
| _SS      | 37    | 32    | 1        | Slave Select: If not used tie to VSS     |
| _IOTEST  | 24    | 18    |          | Wake-Up Control Signals                  |
| _WKU     | 2     | 42    | 1        |                                          |
| R0-R4    | 13-17 | 8-12  |          | Row Data Inputs                          |
| R5-R7    | 19-21 | 13-15 | 1        | Port provides internal pull-up resistors |
| C0-C5    | 12-7  | 7-2   |          | Column Select Outputs:                   |
| C6-C7    | 6-5   | 1,44  | 0        |                                          |
| C8-C9    | 31-30 | 26-25 | 0        |                                          |
| C12      | 27    | 21    | 0        |                                          |
| C13      | 26    | 20    | O        |                                          |
|          |       |       |          | Multi-function pins                      |
| C10/WUKO | 29    | 24    | I/O      | C10 & "Wake-Up Keys Only" imput          |
| C11/_LID | 28_   | 23    | I/O      | C11 & Lid latch detect input             |
|          |       |       |          | Miscellaneous functions                  |
| GI00     | 25    | 19    | I/O      | General programmable I/O                 |
| XSW      | 33    | 28    | 1        | External discrete switch                 |
| SWO      | 32    | 27    | <u> </u> | Discrete switch                          |
|          |       |       |          | Power Management Pins                    |
| _ATN     | 38    | 33    | 0        | CPU Attention Output                     |
| _PWR_OK  | 39_   | 34    |          | Power OK Input                           |
| NC       | 3,18  | 39-40 |          | No Connects: these pins are unused       |
|          | 23,40 | 16,22 |          |                                          |
| NC0      | 41    | 35    |          | NC0 should be tied to VSS or GND         |

Note: An underscore before a pin mnemonic denotes an active low signal.

#### **Pin Descriptions**

#### VCC and VSS

VCC and VSS are the power supply and ground pins. The UR5HCSPI-SA will operate from a 3-5 Volt power supply. To prevent noise problems, provide bypass capacitors placed as close as possible to the IC with the power supply. VX, where available, should be tied to Vcc.

#### **OSCI and OSCO**

OSCI and OSCO provide the input and output connections for the onchip oscillator. The oscillator can be driven by any of the following circuits:

- Crystal
- Ceramic Resonator
- External Clock Signal The frequency of the on-chip oscillator is 2 MHz

#### RESET

A logic zero on the \_RESET pin will force the UR5HCSPI-SA into a known start-up state. The reset signal can be supplied by any of the following circuits:

- RC
- Voltage monitor
- Master system reset

#### MOSI, MISO, SCK, \_SS, \_ATN

These five signals implement the SPI interface. The device acts as a slave on the SPI bus. The \_SS (Slave Select) pin must go high between successive characters in an SPI message or it will cause a write collision error. The \_ATN pin is asserted low each time the UR5HCSPI-SA has a packet ready for delivery. For a more detailed description, refer to the SPI Communication Channel section on page 11 of this document.

#### \_IOTEST and \_WKU

The\_IOTEST and \_WKU pins ("Input Output Test" and "Wake Up") pins control the stop mode exit of the device. The designer can connect any number of active low signals to these two pins through a 15K resistor, in order to force the device to exit the stop mode. A sample circuit is shown on page 17 of this document. All the signals are "wire-anded." When any one of these signals is not active, it should be floating (i.e., these signals should be driven from "open-collector" or "opendrain" outputs). Other configurations are possible; contact the factory.

#### **R0-R7**

The R0-R7 pins are connected to the rows of the scanned matrix. Each pin provides an internal pullup resistor, eliminating the need for external components.

#### C0 to C9

Pins C0 to C9 are bi-directional pins and are connected to the columns of the scanned matrix. When a column is selected, the pin outputs an active low signal. When the column is de-selected, the pin turns into high-impedance.

#### C10/WUKO

The C10/WUKO pin acts alternatively as column scan output and as an input. As an input, the pin detects the "Wake-Up Keys Only" signal, typically provided by the host CPU to indicate that the user has turned the unit off. When the device detects an active high state on this pin, it feeds this information into the "Keyboard State Control" unit, in order to disable the keyboard and enable the programmed wake-up keys.

#### C11/\_LID

The C11/\_LID pin acts in a similar manner to the C10/WUKO. Typically this pin is connected to the LID latch through a 150K resistor, in order to detect physical closing of the device cover. When the pin detects an active low state in this input, it feeds this information into the "Keyboard State Control" unit, in order to disable keys inside the case and enable only switches located physically on the outer body of the H/PC unit.

#### Pin Descriptions, Cont.

#### C12 and C13

C12 and C13 are used as additional column pins in order to accommodate larger-size keyboards, such as the Fujitsu FKB1406 palmtop keyboard. GIO0 is a programmable input/output switch or LED pin; it can also be used as a wake-up signal. Its programming is explained on page 9 of this document.

#### **XSW**

The XSW pin is dedicated to an external switch. This pin is handled differently than the rest of the switch matrix and is intended to be connected to a switch physically located on the outside of the unit.

#### **SW**0

The SWO pin is a dedicated input pin for a switch.

#### PWR\_OK

The PWR\_OK is an active low pin that monitors the battery status of the unit. When the UR5HCSPI-SA detects a transition from high to low on this pin, it will immediately enter the STOP mode, turn the LED off and remain in this state until the batteries of the unit are replaced and the signal is deasserted.

#### The Windows CE® Keyboard

The following illustration shows a typical implementation of a Windows CE® keyboard.



Windows CE® does not support the following keyboard keys typically found on desktop and laptop keyboards:

- INSERT
- SCROLL LOCK
- PAUSE
- NUM LOCK
- Function Keys (F1-F12)
- PRINT SCREEN

If the keyboard implements the Windows key, the following key combinations are supported in the Windows CE® environment:

| XC |
|----|
| )  |
|    |
|    |

#### "Ghost" Keys

In any scanned contact switch matrix, whenever three keys defining a rectangle on the switch matrix are pressed at the same time, a fourth key positioned on the fourth corner of the rectangle is sensed as being pressed. This is known as the "ghost" or "phantom" key problem.



Figure 1: "Ghost" or "Phantom" Key Problem

Although the problem cannot be totally eliminated without using external hardware, there are methods to neutralize its negative effects for most practical applications. Keys that are intended to be used in combinations should be placed in the same row or column of the matrix, whenever possible. Shift Keys (Shift, Alt, Ctrl, Window) should not reside in the same row (or column) as any other keys. The UR5HCSPI-SA has built-in mechanisms to detect the presence of "ghost" keys.

#### **Keyboard Scanner**

The encoder scans a keyboard organized as an 8 row by 14 column matrix for a maximum of 112 keys. Smaller size matrixes can also be accommodated by simply leaving unused pins open. The UR5HCSPI-SA provides internal pull-ups for the Row input pins. When active, the encoder selects one of the column lines (C0-C13) every 512 µS and then reads the row data lines (R0-R7). A key closure is detected as a zero in the corresponding position of the matrix.

A complete scan cycle for the entire keyboard takes approximately 9.2 mS. Each key found pressed is debounced for a period of 20 mS. Once the key is verified, the corresponding key code(s) are loaded into the transmit buffer of the SPI communication channel.

#### **Keyboard Scanning**

N-Key Rollover

In this mode, the code(s) corresponding to each key press are transmitted to the host system as soon as that key is debounced, independent of the release of other keys.

When a key is released, the corresponding break code is transmitted to the host system. There is no limitation to the number of keys that can be held pressed at the same time. However, two or more key closures, occurring within a time interval of less than 5mS, will set an error flag and will not be processed. This feature is to protect against the effects of accidental key presses.

#### **Keyboard States**

These states of operation refer only to the keyboard functionality and, although they are related to power states, they are also independent of them.

#### "Send All Keys"

Entry Conditions: Power on reset, soft reset, PWR\_OK =1, {(LID=1) AND (WUKO=0)}

Exit Conditions: PWR\_OK = 0 -> "Send No Keys" (WUKO=1) AND (Key Press) -> "Send Wake-Up Keys Only" (LID = 0) AND (WUKO=0) AND (Key Press) -> "Send XSW Key Only"

Description: This is the UR5HCSPI-SA's normal state of operation, accepting and transmitting every key press to the system. This state is entered after the user powers on the unit and it is sustained while the unit is being used.

#### "Send Wake-Up Keys Only"

Entry Conditions: (WUKO=1) AND (Key or Switch press)

Exit Conditions: Soft Reset -> "Send All Keys"PWR\_OK = 0 -> "Send No Keys"

Description: This state is entered when the user turns the unit off. A signal line driven by the host will notify the UR5HCSPI-SA about this state transition. While in this state, the UR5HCSPI-SA will transmit only keys programmed to be wake-up keys to the system. It is not necessary for the UR5HCSPI-SA to detect this transition in real time, since it does not affect any operation besides buffering keystrokes.



Figure 2: The UR5HCSPI-SA implements four modes of keyboard and switch operation.

#### "Send No Keys"

Entry Conditions PWR\_OK transition from high to low

Exit Conditions: (PWR\_OK = 1) AND (Matrix key pressed OR Switch OR \_WKUP)

Description: This state is entered when a PWR\_OK signal is asserted (transition high to low), indicating a critically low level of battery voltage. The PWR\_OK signal will cause an interrupt to the UR5HCSPI-SA, which guarantees that the transition is performed in real time. While in this state, the UR5HCSPI-SA will perform as follows:

- 1. The LED will be turned off. Nevertheless, its state is saved and will be restored after exiting the disabled state (change of batteries).
- 2. The UR5HCSPI-SA will enter the STOP mode for maximum energy conservation.

- 3 Stop mode time-out entry will be shortened to further conserve energy.
- 4. While in this state all interrupts are disabled. The UR5HCSPI-SA will exit this state on the next interrupt event that detects the PWR\_OK line has been deasserted.

#### "Send XSW Key Only"

Entry Condition: (LID=0) AND (WUKO=0) AND (Key Press)

Exit Condition: (LID=1) AND (WUKO=0) AND (Key Press) -> "Send All Keys"PWR\_OK = 0 -> "Send No Keys" (WUKO = 1) AND (Key Press) -> "Send Wake Up Keys Only"

Description: This state is entered upon closing the lid of the device. While in this state, the encoder will transmit only the XSW key, which is located outside the unit. This feature is designed to accommodate buttons on the outside of the box, such as a microphone button, that need to be used while the lid is closed.

| 0<br>LAIt | 1 . | 2    | 3     | 4  | 5     | 6  | 7          | 8     | 9          | 10         | 11         | 12     | 13         |
|-----------|-----|------|-------|----|-------|----|------------|-------|------------|------------|------------|--------|------------|
| LAIt      | *   |      |       |    |       |    |            |       |            | 10         | 11         | 12     | 10         |
|           |     |      | LCtrl | FN | Esc   | 1  | 2          | 9     | 0          | -          | +          |        | BkSp       |
|           |     |      |       |    |       | F1 | F2         | F9    | F10        | NmLk       | Bk         |        | ·          |
|           | \   | LSft |       |    | Del   |    | T          | Υ     | U<br>Pad 4 | I<br>Pad 5 | Enter      | RShift | <b>+</b>   |
|           |     |      |       |    |       |    |            |       |            |            |            |        | PgDn       |
|           | TAB |      |       |    | Q     | W  | Е          | R     | O<br>Pad 6 | P          | [<br>Pause |        | ]<br>ScrLk |
|           |     |      |       |    |       |    |            |       | rau o      | Ins        | rause      |        | JCILK A    |
|           | Z   |      |       |    | CapLk |    |            | K     | L          | ,          | 6          |        | <b>†</b>   |
|           |     |      |       |    |       |    |            | Pad 2 | Pad 3      | PrtScr     | SysReq     |        | PgUp       |
|           | А   |      |       |    | S     | D  | F          | G     | Н          | J          | /          |        | •          |
|           |     |      |       |    |       |    |            |       |            | Pad 1      | /          |        | Home       |
|           | Χ   |      |       |    | С     | V  | B<br>Pad 0 | Ν     | М          | ,          |            |        | Spc        |

#### **Keyboard Layout for Fujitsu FKB1406**



#### **Key Codes**

Key codes range from 01H to 73H and are arranged as follows:

Make code = column\_number \* 8 + row\_number + 1

Break code = Make code OR 80H

Discrete Switches transmit the following codes:

XSW = 71H

SW0 = 72H

GIO0 = 73H

#### GIO0 Pin

The UR5HCSPI-SA provides a general purpose pin, GIO0, that can be programmed as Input, Output, Debounced Switch Input or LED Output. The programmable I/O pin can be configured to the desired mode through a command from the system. After the I/O pin is configured, the host system can read or write data to it. If the pin is configured as a Debounced Switch, it will return scan codes.

For Pin GIO0:

I/O Number = 0 LED Number = 0

#### **Input Mode**

While in the Input Mode, the GIO0 pin will detect input signals and report the input status to system as required.

#### **Output Mode**

In the Output Mode, the UR5HCSPI-SA will control the output signal level according to the system command. When the pin is set at Output Mode, the default output is low.

#### **Switch Input Mode**

In Switch Input Mode, the UR5HCSPI-SA will generate an individual make key code when the switch closes (pin goes low), and a break key code when the switch returns to open (pin goes to high). The switches generate key codes outside of those generated by the key matrix, from 71H - 73H. When the switch closes, the USAR SPICoder™ will not fall asleep.

#### **Pin Configurations**

When prototyping, caution should be taken to ensure that programming of the GIO0 pin does not conflict with the circuit implemented. A series protection resistor is recommended for protection from improper programming of the pin.

After a power-on or soft reset, GIO0 defaults to the Input state.

The following drawing illustrates the suggested interface to the general purpose input/output pin.



**Figure 3:** Suggested interface of general purpose input/output pin

#### LED Modes



Figure 4: Timing chart: the behavior of an LED using the settings, 1: LED on; 0: LED off.

There are three LED modes: off, on, and blinking. The LED can be individually set to one of these modes. In the Blinking Mode, both the oninterval and the off-interval can be individually set. Additionally, a meta blink count and meta blink interval may be specified. This describes an interval of a different length which may be inserted after each specified number of blinks. All the intervals are based on a 1/16th of a second duration. When the LED is on or blinking, the USAR SPICoder™ will not enter the STOP Mode unless the PWR\_OK signal is asserted low. In this case, the device will save the status of the LED and turn it off. The default LED mode is off.

The above timing chart describes the behavior of an LED using these settings,1: LED on; 0: LED off.

#### **SPI Communication Channel**

SPI data transfers can be performed at a maximum clock rate of 500 KHz. When the UR5HCSPI-SA asserts the \_ATN signal to the host Master, the data will have already been loaded into the data register waiting for the clocks from the master. One \_ATN signal is used per each byte transfer. If the host fails to provide clock signals for successive bytes in the data packet within 120 mS, the transmission will be aborted and a new session will be initiated by asserting a new \_ATN signal. In such a case, the whole packet will be re-transmitted.

If the SPI transmission fails 20 times consecutively, the synchronization between the master and slave may be lost. In this case, the UR5HCSPI-SA will enter the reset state.

When CPHA = 0, the shift clock is the OR of \_SS with SCK; therefore, \_SS must go high between successive characters in an SPI message. The master can assert \_SS low only when it is getting ready to transmit or receive. After the last bit is shifted out, \_SS must go high within  $60 \, \mu$ S.

The UR5HCSPI-SA implements the SPI communication protocol according to the following diagram:

CPOL = 0 ------ SCK line idles in low state

CPHA = 0 ----- SS line is an output enable control



Figure 5: SPI Communication Protocol

When the host sends commands to the keyboard, the UR5HCSPI-SA requires that the minimum and maximum intervals between two successive bytes be 200 µS and 5 mS respectively.



Figure 6: Transmitting Data Waveforms:



Figure 7: Receiving Data Waveforms

#### **Data/Command Buffer**

The UR5HCSPI-SA implements a data buffer that contains the key code/command bytes waiting to be transmitted to the host. If the data buffer is full, the whole buffer will be cleared and an "Initialize" command will be sent to the host. At the same time, the keyboard will be disabled until the "Initialize" or "Initialize Complete" command from the host is received.

#### **SPI Communication Table**

The following table describes the specific timing referenced in diagrams on page 11.

| Signal Name | Description                         | Min | Max | Units |
|-------------|-------------------------------------|-----|-----|-------|
| tATN:SA _   | ATN to first clock pulse            | -   | 120 | mS    |
| TSCK        | Clock period                        | 2   | -   | μS    |
| tSS:HD      | Last clock pulse to _SS de-asertion | -   | 60  | μS    |
| tWKUP       | _WKUP pulse width                   | 125 | -   | nS    |
| tSCK:SA     | _WKUP to first clock pulse          | 5   | 150 | mS    |
| tIB         | Inter-byte period                   | 0.2 | 5   | mS    |

#### **Power Management Unit**

The UR5HCSPI-SA supports two modes of operation. The following table lists the typical and maximum supply current (no DC loads) for each mode at 3.3 Volts (+/- 10%).

| Current | Typical | Max | Unit | Description                                                     |
|---------|---------|-----|------|-----------------------------------------------------------------|
| RUN     | 1.5 1   | 3.0 | mA   | Entered only while data/commands are in process and if the LEDs |
|         |         |     |      | are blinking                                                    |
| STOP    | 2.0     | 20  | μΑ   | Entered after 125 mS of inactivity if LEDs islow                |

Power consumption of the keyboard sub-system will be determined primarily by the use of the LEDs. While the UR5HCSPI-SA is in the STOP mode, an active low Wake-Up Output from the Master must be connected to the edge-sensitive \_WKU pin of the UR5HCSPI-SA. This signal will be used to wake up the UR5HCSPI-SA in order to receive data from the Master host. The Master host will have to wait a minimum of 5 mS prior to providing clocks to the UR5HCSPI-SA. The UR5HCSPI-SA will enter the STOP mode after a 125 mS period of keypad and/or host communications inactivity, or anytime the PWR\_OK line is asserted low by the host. Note that while one or more keys are held pressed, the UR5HCSPI-SA will not enter the STOP mode until every key is released.



Figure 8: The power states of the UR5HCSPI-SA.

#### **Communication Protocol**

There are eight commands that may be sent from the UR5HCSPI-SA to the host, and ten commands that may be sent from the host to the UR5HCSPI-SA.

Each command from UR5HCSPI-SA to the host is composed of a sequence of codes. All commands start with <CONTROL> code (80H) and end with LRC code (see the description of the LRC calculation on page 14). Command details are listed below.

**Commands to the Host - Summary** 

| Code | Description                                                           |
|------|-----------------------------------------------------------------------|
| AOH  | Sent to the host when the data buffer is full                         |
| A1H  | Issued upon completion of the "Initialize" command issued by the host |
| A2H  | Response to "Heartbeat Request" issued by the host                    |
| F2H  | Response to "Identification Request" issued by the host               |
| АЗН  | Response to "LED Status Request"                                      |
| A5H  | Issued upon error during the reception of a packet                    |
| A7H  | Reports the status of GIO0 pin                                        |
| A8H  | Response to "I/O Data Request" command from the host                  |
|      | AOH<br>A1H<br>A2H<br>F2H<br>A3H<br>A5H<br>A7H                         |

#### **LRC Calculation**

The LRC is calculated for the whole packet, including the Command Code and the Command Prefix. The LRC is calculated by first taking the bitwise exclusive OR of all bytes from the message. If the most significant bit (MSB) of the LRC is set, the LRC is modified by clearing the MSB and changing the state of the next most significant bit. Thus, the Packet Check Byte will never consist of a valid LRC with the most significant bit set.

#### **Commands to the Host Analytically**

#### **Initialize Request:**

<CONTROL> 80H <INIT> A0H <LRC> 20H

The UR5HCSPI-SA will send the Initialize Request Command to the host when its data buffer is full.

#### **Initialization Complete**

<CONTROL> 80H <INIT COMPLETE> A1H <LRC> 21H

The UR5HCSPI-SA will send the Initialize Complete Report to the host when it finishes the initialization caused by Initialize Command from the host.

#### **Heartbeat Response:**

<CONTROL> 80H <ONLINE> A2H <LRC> 22H

The UR5HCSPI-SA will send the Heartbeat Response to the host when it receives the Heartbeat Request Command from the host.

#### **Identification Response:**

 <CONTROL>
 80H

 <ID>
 F2H

 <Vendor>
 02H
 --- USAR

 <Revision>
 08H
 --- Rev 0.8A

 <Switch>
 00H
 .

 <LRC>
 7EH

The UR5HCSPI-SA will send the Identification Response to the host when it receives the Identification Request Command from the host.

#### LRC Calculation, Cont.

The following C language function is an example of an LRC calculation program. It accepts two arguments: a pointer to a buffer and a buffer length. Its return value is the LRC value for the specified buffer.

char Calculate LRC (char buffer, size buffer) char LRC; size\_t index;

\* Init the LRC using the first two message bytes.

/\*

LRC = buffer [0] ^ buffer [1];

\* Update the LRC using the remainder of the buffer.

for (index = 2; index < buffer; index

 $LRC \land = buffer[index];$ 

\* If the MSB is set then clear the MSB and change the next most significant bit

if (LRC & 0x80)

LRC  $\wedge = 0xC0$ :

/\* \* Return the LRC value for the buffer.\*/}

#### Commands to the Host from the UR5HCSPI-SA, Cont.

#### **LED Status Report**

<CONTROL> H08 <LED> АЗН <Status 0> ххН LED0 status:( 0=OFF; 1=ON; 2=BLINKING; 3=NO LED MODE) <Status 1> LED1 status:( 0=OFF; 1=ON; ххH 2=BLINKING; 3=NO LED MODE) <Status 2> LED2 status:( 0=OFF; 1=ON; ххН 2=BLINKING; 3=NO LED MODE) <LRC> ххH

The UR5HCSPI-SA will send the LED Status Report to the host when it receives the LED Status Request Command from the host.

#### **Resend Request**

<CONTROL> H08 <RESEND> A5H <LRC> 25H

The UR5HCSPI-SA will send this Resend Request Command to the host when its command buffer is full, or if it detects either a parity error or an unknown command during a system command transmission.

#### **Input/Output Mode Status Report**

<CONTROL> 80H <MODIO> A7H <IO NUMBER> ххН IO number. 0 <IO MODE> ххН IO mode: (0=input; 1=output; 2=switch: 3=LED) <LRC> ххH

The UR5HCSPI-SA will send the I/O Mode Status Report to the host when it receives the I/O Mode Status Request Command from the host, in order to report the status of the GIO0 pin.

#### **Input/Output Data Report**

<CONTROL> H08 <MODIO> A8H

<IO NUMBER> ххН IO number, 0

<IO DATA> ххН IO data: (0=low, 1=high)

<LRC> ххH

The UR5HCSPI-SA will send the I/O Data Report to the host when it receives the I/O Data Request Command from the host.

#### Commands from the Host to the UR5HCSPI-SA

Each command to UR5HCSPI-SA is composed of a sequence of codes. All commands start with <ESC> code (1BH) and end with the LRC code (bitwise exclusive OR of all bytes).

Commands from the Host - Summary

| <b>Command Name</b>      | Code | Description                                                      |
|--------------------------|------|------------------------------------------------------------------|
| Initialize               | AOH  | Causes the UR5HCSPI-SA to enter the power-on state               |
| Initialization Complete  | A1H  | Issued as a response to the "Initialize Request"                 |
| Heartbeat Request        | A2H  | The UR5HCSPI-SA will respond with "Heartbeat Response"           |
| Identification Request   | F2H  | The UR5HCSPI-SA will respond with "Identification Response"      |
| LED Status Request       | АЗН  | The UR5HCSPI-SA will respond with "LED Status Response"          |
| LED Modify               | A6H  | The UR5HCSPI-SA will change the LED accordingly                  |
| Resend Request           | A5H  | Issued upon error during the reception of a packet               |
| Input/Output Mode Modify | A7H  | The UR5HCSPI-SA will modify or report the status of the GIO0 pin |
| Output Data to I/O pin   | A8H  | The UR5HCSPI-SA will output a signal to the GIO0 pin             |
| Set Wake-Up Keys         | A9H  | Defines which keys are "wake-up" keys                            |

#### **Commands from the Host to the UR5HCSPI-SA Analytically**

#### Initialize

<ESC> 1BH <INIT> A0H <LRC> 7BH

When the UR5HCSPI-SA receives this command, it will clear all buffers and return to the power-on state.

#### **Initialization Complete**

<ESC> 1BH <INIT COMPLETE> A1H <I BC> 7AH

When the UR5HCSPI-SA receives this command, it will enable transmission of keyboard data. Keyboard data transmission is disabled if the TX output buffer is full (32 bytes). Note that if the transmit data buffer gets full the encoder will issue an "Initialize Request" to the host.

#### **Heartbeat Request**

<ESC> 1BH <ONLINE> A2H <LRC> 79H

When the UR5HCSPI-SA receives this command, it will reply with the Heartbeat Response Report.

#### **Identification Request**

<ESC> 1BH <ID> F2H <LRC> 29H

the UR5HCSPI-SA will reply to this command with the Identification Response Report.

#### **LED Status Request**

<ESC> 1BH <LED> A3H <LRC> 78H

When UR5HCSPI-SA receives this command, it will reply with the LED Status Report.

#### Commands from the Host to the UR5HCSPI-SA, Cont.

| Set Wake-Up Keys               | S           | LED   |
|--------------------------------|-------------|-------|
| <esc></esc>                    |             |       |
| <setmatrix></setmatrix>        | A9H         |       |
| <col0></col0>                  | xxH         |       |
| (R7 R6 R5 R4 R3 R2 I           | R1 R0       |       |
| Bitmap: 0-enabled 1-           | -disabled)  |       |
| <col1></col1>                  | xxH         |       |
| <col2></col2>                  | xxH         |       |
| <col3></col3>                  | xxH         |       |
| <col4></col4>                  | xxH         |       |
| <col5></col5>                  | xxH         |       |
| <col6></col6>                  | xxH         |       |
| <col7></col7>                  | xxH         |       |
| <col8></col8>                  | xxH         |       |
| <col9></col9>                  | xxH         |       |
| <col10></col10>                | xxH         |       |
| <col11></col11>                | xxH         | Wher  |
| <col12>*</col12>               | xxH         | mode  |
| <col13>*</col13>               | xxH         |       |
| <switches></switches>          |             | I/O I |
| (where SWITCHES bit            | assignments |       |
| are $= x \times x \times GIO0$ | SW0 XSW)    |       |
| <lrc></lrc>                    | xxH         |       |

The "Set Wake-Up Keys" command is used to disable specific keys from waking up the host. Using this command, the host can set only a group of keys to act as "power-on" switches. The host can change the keyboard behavior dynamically according to the system power management requirements. The default after power on is "All Keys Enabled."

| LED | <b>Modify</b> |
|-----|---------------|
|-----|---------------|

|       | - 1110 GIII <b>,</b>       |         |                                                                             |
|-------|----------------------------|---------|-----------------------------------------------------------------------------|
|       | <esc></esc>                | 1BH     |                                                                             |
|       | <modled></modled>          | A6H     |                                                                             |
|       | <led number=""></led>      | xxH     | LED number (0)                                                              |
|       | <led state=""></led>       | xxH     | (0=LED OFF; 1=LED ON; 2=LED BLINKING)                                       |
|       | <on interval=""></on>      | xxH     | Time in 1/16ths of a second for LED to be on                                |
|       | <off interval=""></off>    | xxH     | Time in 1/16ths of a second for LFD to be off                               |
|       | <meta count=""/>           | xxH     | Number of blinks after which to apply meta blink interval                   |
|       | <meta interval=""/>        | xxH     | Time in 1/16ths of a second for LED to be off after <meta count=""/> blinks |
|       | <lrc></lrc>                | xxH     |                                                                             |
| \//hc | on the LIDSHCODI CA receiv | oc thic | command it will change the LED                                              |

When the UR5HCSPI-SA receives this command, it will change the LED mode accordingly.

#### **I/O Mode Modify**

| o mode modily       |     |                                 |
|---------------------|-----|---------------------------------|
| <esc></esc>         | 1BH |                                 |
| <modio></modio>     | A7H |                                 |
| <io number=""></io> | xxH | IO number: 0                    |
| <io mode=""></io>   | xxH | IO mode: (0=input, 1=output,    |
|                     |     | 2=switch, 3=LED, 4=current mode |
|                     |     | state request)                  |
| <lrc></lrc>         | xxH |                                 |

When UR5HCSPI-SA receives this command, it will change the I/O pins' mode accordingly. If the <IO MODE> =4, the UR5HCSPI-SA will send the I/O Mode Status Report to the host.

#### **Output Data to I/O Pin**

| <esc></esc>                 | 1BH |                          |
|-----------------------------|-----|--------------------------|
| <modio></modio>             | A8H |                          |
| <io number=""></io>         | xxH | IO number: 0             |
| <io data=""></io>           | xxH | IO data: (0=low, 1=high, |
| 2=current I/O data request) |     |                          |
| <lrc></lrc>                 | xxH |                          |

When UR5HCSPI-SA receives this command, it will change the value of the output pin accordingly. If the addressed pin is not configured as an output pin, the command will be ignored. If <IO DATA> =2, the UR5HCSPI-SA will respond by issuing the I/O Data Status Report to the host.

#### **Sample Configuration**



#### Implementation Notes for the UR5HCSPI-SA

The following notes pertain to the suggested schematic found on the previous page.

The Built-in Oscillator on the UR5HCSPI-06 requires the attachment of the 2.00 MHz Ceramic Resonators with built-in Load Capacitors.. You can use either an AVX, part number PBRC-2.00 BR; or a Murata part number CSTCC2.00MG ceramic resonator.

It may also be possible to operate with the 2.00 MHz Crystal, albeit with reduced performance. Due to their high Q, the Crystal oscillator circuits start-up slowly. Since the USAR SPICoder™ SA constantly switches the clock on and off, it is important that the Ceramic Resonator is used (it starts up much quicker than the Crystal). Resonators are also less expensive than Crystals.

Also, if Crystal is attached, two Load Capacitors (33pF to 47pF) should be added, a Capacitor between each side of the Crystal and ground.

In both cases, using Ceramic Resonator with built-in Load Capacitors, or Crystal with external Load Capacitors, a feedback Resistor of 1 Meg should be connected between OSCIN and OSCOUT.

Troubleshoot the circuit by looking at the Output pin of the Oscillator. If the voltage is half-way between Supply and Ground (while the Oscillator should be running) --- the problem is with the Load Caps / Crystal. If the voltage is all the way at Supply or Ground (while the Oscillator should be running) --- there are shorts on the PCB.

Note: When the Oscillator is intentionally turned OFF, the voltage on the Output pin of the Oscillator is High (at the Supply rail).

#### **Electrical Specifications**

| <b>Absolute Maximum Ra</b> | atings |
|----------------------------|--------|
|----------------------------|--------|

| Ratings                    | Symbol | Value                | Unit |
|----------------------------|--------|----------------------|------|
| Supply Voltage             | Vdd    | -0.3 to +7.0         | V    |
| Input Voltage              | Vin    | Vss -0.3 to Vdd +0.3 | V    |
| Current Drain per Pin      | T      | 25                   | mA   |
| (not including Vss or Vdd) |        |                      |      |
| Operating Temperature      | Ta Ta  | T low to T high      | ° C  |
| UR5HCSPI-SA                |        | -40 to +85           |      |
| Storage Temperature Range  | Tstg - | 65 to +150           | ° C  |

#### **Thermal Characteristics**

| Characteristic     | Symbol | Value | Unit     |
|--------------------|--------|-------|----------|
| Thermal Resistance | Tja    |       | °C per W |
| ■ Plastic          |        | 60    |          |
| ■ PLCC             |        | 70    |          |

DC Electrical Characteristics (Vdd=3.3 Vdc +/-10%, Vss=0 Vdc, Temperature range=T low to T high unless otherwise noted)

| Characteristic                     | Symbol | Min     | Тур   | Max     | Unit |
|------------------------------------|--------|---------|-------|---------|------|
| Output Voltage (I load<10µA)       | Vol    |         |       | 0.1     | V    |
|                                    | Voh    | Vdd-0.1 |       |         |      |
| Output High Voltage (I load=0.8mA) | Voh    | Vdd-0.8 | · ·   |         | V    |
| Output Low Voltage (I load=1.6mA)  | Vol:   |         |       | 0.4     | V    |
| Input High Voltage                 | Vih    | 0.7xVdd |       | Vdd     | V    |
| Input Low Voltage                  | Vil    | Vss     |       | 0.2xVdd | V    |
| User Mode Current                  | Ірр    |         | 5     | 10      | mA   |
| Data Retention Mode (0 to 70°C)    | Vrm    | 2.0     |       |         | V    |
| Supply Current (Run)               | ldd    |         | 1.53  | 3.0     | mA   |
| (Wait)                             |        |         | 0.711 | 1.0     | mA   |
| (Stop)                             |        |         | 2.0   | 20      | μΑ   |
| I/O Ports Hi-Z Leakage Current     | lil    |         |       | +/-10   | μΑ   |
| Input Current                      | lin    |         |       | +/- 1   | μΑ   |
| I/O Port Capacitance               | Cio    |         | 8     | 12      | pF   |

Control Timing (Vdd=3.3 Vdc +/-10%, Vss=0 Vdc, Temperature range=T low to T high unless otherwise noted)

| Characteristic                  | Symbol   | Min  | Max | Unit |
|---------------------------------|----------|------|-----|------|
| Frequency of Operation          | fosc     |      |     | MHz  |
| ■ Crystal Option                |          |      | 2.0 |      |
| ■ External Clock Option         |          | dc   | 2.0 |      |
| Cycle Time                      | tcyc     | 1000 |     | ns   |
| Crystal Oscillator Startup Time | toxov    |      | 100 | ms   |
| Stop Recovery Startup Time      | tilch    |      | 100 | ms   |
| RESET Pulse Width               | trl      | 8    |     | tcyc |
| Interrupt Pulse Width Low       | tlih     | 250  |     | ns   |
| Interrupt Pulse Period          | tilil    | *    |     | tcyc |
| OSC1 Pulse Width                | toh, tol | 200  |     | ns   |

<sup>\*</sup>The minimum period tlil should not be less than the number of cycle times it takes to execute the interrupt service routine plus 21 tcyc.

#### Bill of Materials for UR5HCSPI-SA-FB

| Quantity | Manufacture | Part#            | Description                                             |
|----------|-------------|------------------|---------------------------------------------------------|
| 3        | Generic     | 15K              | 15K Resistor                                            |
| 1        | Generic     | 150K             | 150K Resistor                                           |
| 1        | Generic     | 11M              | 1M Resistor                                             |
| 2        | Generic     | 1.5K             | 1.5 Resistors                                           |
| 1        | TELCOM      | TC54VC4302ECB713 | IC Volt Detector CMOS 4.3V SOT23, for 5V Operation      |
|          |             | TC54VC4302ECB713 | IC Volt Detector CMOS 2.7V SOT23, for 3.3V Operation    |
| 1        | AVX         | PBRC-2.00BR      | 2.00MHZ Ceramic Resonator with Built in Capacitors, SMT |

**Revised 7/14/99** 

This Page Intentionally Left Blank



### For sales information and product literature, contact:

USAR – A Semtech Company 568 Broadway New York, NY 10012 info@usar.com http://www.usar.com 212 226 2042 Telephone 212 226 3215 Telefax

In Japan: Semtech Japan Tel: 81-45-948-5925 Fax: 81-45-948-5930

In Taiwan: Semtech Asia/Pacific Sales Tel: 011-886-2-2748-3380 Fax: 011-886-2-2748-3390

Koryo Electronics Co., Ltd. Telephone +886-2-2698-1143 E-mail alex.chen@koryo.com.tw

In Korea: Semtech Korea Tel: 011-82-2-527-4377 Fax: 011-82-2-527-4376

In Europe Semtech Limited Tel: +44-1592-630350 Fax: +44-1592-774781

Copyright 1999-2000 USAR – A Semtech Company. All rights reserved. SPICoder and Zero-Power are trademarks of USAR Systems, Inc. USAR and the USAR logo are registered trademarks of USAR – A Semtech Company. All other trademarks belong to their respective companies.

INTELLECTUAL PROPERTY DISCLAIMER

This specification is provided "as is" with no warranties whatsoever including any warranty of merchantability, fitness for any particular purpose, or any warranty otherwise arising out of any proposal, specification or sample.

A license is hereby granted to reproduce and distribute this specification for internal use only. No other license, expressed or implied to any other intellectual property rights is granted or intended hereby. Authors of this specification disclaim any liability, including liability for infringement of proprietary rights, relating to the implementation of information in this specification. Authors of this specification also do not warrant or represent that such implementation(s) will not infringe such rights.