# **Data Sheet**



# Description

The Avago Technologies ADNS-4000 is a low power, small form factor optical mouse sensor that is licensed for blue LED mouse application. Using patented technologies, this mouse sensor tracks on virtually any surface.

The ADNS-4000 low-power architecture and automatic power management modes make it ideal for powersensitive applications such as cordless input devices. The ADNS-4000 is capable of high-speed motion detection – up to 30ips and 8G. In addition, it has an on-chip oscillator and LED driver to minimize external components.

The ADNS-4000 along with the ADNS-5110-001 lens, ADNS-5200 clip, and HLMP-CB34 LED form a complete and compact mouse tracking system. There are no moving parts and this translates to high reliability and less maintenance for the end user. In addition, precision optical alignment is not required, facilitating high volume assembly.

The sensor is programmed via registers through a fourwire serial port. It is housed in an 8-pin staggered dual in-line package (DIP).

#### **Features**

- Low Power Architecture
- Small Form Factor
- Programmable Periods / Response Times and Downshift Times from one mode to another for the Power-saving Modes
- 'Smart' LED Current Switching depending on surface brightness
- High Speed Motion Detection up to 30ips and 8G
- External Interrupt Output for Motion Detection
- Internal Oscillator no clock input needed
- Selectable Resolution up to 1750cpi
- Operating Voltage: as low as 2.8V
- Four wire Serial Port Interface
- Minimal number of passive components

#### **Applications**

- Optical mice and optical trackballs
- Integrated input devices
- Battery-powered input devices



# **Theory of Operation**

The ADNS-4000 is based on Optical Navigation Technology, which measures changes in position by optically acquiring sequential surface images (frames) and mathematically determining the direction and magnitude of movement.

The ADNS-4000 contains an Image Acquisition System (IAS), a Digital Signal Processor (DSP), and a four wire serial port.

The IAS acquires microscopic surface images via the lens and illumination system. These images are processed by the DSP to determine the direction and distance of motion. The DSP calculates the Dx and Dy relative displacement values.

An external microcontroller reads and translates the Dx and Dy information from the sensor serial port into PS2, USB, or RF signals before sending them to the host PC.

#### Pinout of ADNS-4000 Optical Mouse Sensor

| Pin | Name   | Input/<br>Output | Description                                     |
|-----|--------|------------------|-------------------------------------------------|
| 1   | MISO   | 0                | Serial Data Output<br>(Master In/ Slave Out)    |
| 2   | LED    | 0                | LED Illumination                                |
| 3   | MOTION | 0                | Motion Interrupt Output<br>(Default active low) |
| 4   | NCS    | I                | Chip Select<br>(Active low input)               |
| 5   | SCLK   | I                | Serial Clock                                    |
| 6   | GND    | Gnd              | Ground                                          |
| 7   | VDD    | Power            | Supply Voltage                                  |
| 8   | MOSI   | Ι                | Serial Data Input<br>(Master Out/ Slave In)     |



Figure 1. Package outline drawing (top view)



CAUTION: It is advised that normal static precautions be taken in handling and assembling of this component to prevent damage and/or degradation which may be induced by ESD.

#### **Overview of Optical Mouse Sensor Assembly**

Avago Technologies provides an IGES file drawing describing the base plate molding features for lens and PCB alignment. The ADNS-4000 sensor is designed for mounting on a through-hole PCB. There is an aperture stop and features on the package that align to the lens. The ADNS-5110-001 lens provides optics for the imaging of the surface as well as illumination of the surface at the optimum angle. Features on the lens align it to the sensor, base plate, and clip with the LED. The ADNS-5200 clip holds the LED in relation to the lens. The LED must be inserted into the clip and the LED's leads formed prior to loading on the PCB.

The HLMP-CB34 LED is recommended for illumination.



Figure 3. Recommended PCB Mechanical Cutouts and Spacing (Top View)



Important Note: Pin 1 of sensor should be located nearest to the LED





Note:

A – Distance from object surface to lens reference plane B – Distance from object surface to sensor reference plane

# Figure 5. Distance from lens reference plane to tracking surface (Z)





#### **PCB Assembly Considerations**

- 1. Insert the sensor and all other electrical components into PCB.
- 2. Insert the LED into the assembly clip and bend the leads 90 degrees.
- 3. Insert the LED clip assembly into PCB.
- 4. This sensor package is only qualified for wave-solder process.
- 5. Wave solder the entire assembly in a no-wash solder process utilizing solder fixture. The solder fixture is needed to protect the sensor during the solder process. It also sets the correct sensor-to-PCB distance as the lead shoulders do not normally rest on the PCB surface. The fixture should be designed to expose the sensor leads to solder while shielding the optical aperture from direct solder contact.
- 6. Place the lens onto the base plate.
- Remove the protective kapton tape from optical aperture of the sensor. Care must be taken to keep contaminants from entering the aperture. Recommend not to place the PCB facing up during the entire mouse assembly process. Recommend to hold the PCB first vertically for the kapton removal process.
- 8. Insert PCB assembly over the lens onto the base plate aligning post to retain PCB assembly. The sensor aperture ring should self-align to the lens.

- 9. The optical position reference for the PCB is set by the base plate and lens. Note that the PCB motion due to button presses must be minimized to maintain optical alignment.
- 10. Install mouse top case. There MUST be a feature in the top case to press down onto the PCB assembly to ensure all components are interlocked to the correct vertical height.



Figure 7. Block diagram of ADNS-4000 optical mouse

Recommended Typical Application (Receiver Side)

Recommended Typical Application (Transmitter Side)



Figure 8. Schematic diagram for interface between ADNS-4000 and microcontroller with HLMP-CB34 LED (cordless application)

Note:

The ADNS-4000 Low Power Optical Mouse Sensor is available for use with Blue LEDs.

#### **Design Considerations for Improved ESD Performance**

For improved electrostatic discharge performance, typical creepage and clearance distance are shown in the table below. Assumption: base plate construction is as per the Avago Technologies supplied IGES file and ADNS-5110-001 lens. Note that the lens material is polycarbonate or polystyrene HH30. Therefore, cyanoacrylate based adhesives or other adhesives that may damage the lens should NOT be used.

|           | Typical Distance (mm)<br>ADNS-5110-001 |  |
|-----------|----------------------------------------|--|
| Creepage  | 15.43                                  |  |
| Clearance | 7.77                                   |  |

#### **Regulatory Requirements**

- Passes FCC B and worldwide analogous emission limits when assembled into a mouse with shielded cable and following Avago Technologies recommendations.
- Passes IEC-1000-4-3 radiated susceptibility level when assembled into a mouse with shielded cable and following Avago Technologies recommendations.
- UL flammability level UL94 HB.

# **Table 1. Absolute Maximum Ratings**

| Parameter               | Symbol          | Minimum | Maximum               | Units | Notes                                     |
|-------------------------|-----------------|---------|-----------------------|-------|-------------------------------------------|
| Storage Temperature     | Ts              | -40     | 85                    | °C    |                                           |
| Operating Temperature   | T <sub>A</sub>  | -15     | 55                    | °C    |                                           |
| Lead Solder Temperature |                 |         | 260                   | °C    | For 7 seconds, 1.6mm below seating plane. |
| Supply Voltage          | V <sub>DD</sub> | -0.5    | 3.7                   | V     |                                           |
| ESD (Human Body Model)  |                 |         | 2                     | kV    | All pins                                  |
| Input Voltage           | VIN             | -0.5    | V <sub>DD</sub> + 0.5 | V     | All I/O pins                              |
| Output Current          | lout            |         | 7                     | mA    | MISO pin                                  |

#### Table 2. Recommended Operating Condition

| Parameter                                                          | Symbol            | Min   | Тур. | Мах | Units | Notes                 |
|--------------------------------------------------------------------|-------------------|-------|------|-----|-------|-----------------------|
| Operating Temperature                                              | T <sub>A</sub>    | 0     |      | 40  | °C    |                       |
| Power Supply Voltage                                               | V <sub>DD</sub>   | 2.8   |      | 3.0 | V     |                       |
| Power Supply Rise Time                                             | T <sub>RT</sub>   | 0.005 |      | 100 | ms    | 0 to VDD min          |
| Supply Noise (Sinusoidal)                                          | V <sub>NA</sub>   |       |      | 100 | mVp-p | 10kHz –50MHz          |
| Serial Port Clock<br>Frequency                                     | f <sub>SCLK</sub> |       |      | 1   | MHz   | 50% duty cycle        |
| Distance from Lens Refer-<br>ence Plane to Tracking<br>Surface (Z) | Z                 | 2.3   | 2.4  | 2.5 | mm    |                       |
| Speed                                                              | S                 | 0     |      | 30  | ips   | At default frame rate |
| Acceleration                                                       | а                 |       |      | 8   | G     | At run mode           |
| Load Capacitance                                                   | Cout              |       |      | 100 | pF    | MISO                  |

# Table 3. AC Electrical Specifications

| Electrical characteristics over | recommended operating | conditions. Typical | values at 25 °C | C, VDD = 2.8 V. |
|---------------------------------|-----------------------|---------------------|-----------------|-----------------|
|                                 |                       |                     |                 |                 |

| Parameter                                           | Symbol                               | Min. | Тур. | Max.                | Units | Notes                                                                                                                    |
|-----------------------------------------------------|--------------------------------------|------|------|---------------------|-------|--------------------------------------------------------------------------------------------------------------------------|
| Motion Delay after<br>Reset                         | t <sub>MOT-RST</sub>                 |      |      | 50                  | ms    | From RESET register write to valid motion                                                                                |
| Forced Rest Enable                                  | t <sub>REST-EN</sub>                 |      |      | 1                   | S     | From Rest Mode(RM) bits set to target rest mode                                                                          |
| Wake from Forced<br>Rest                            | t <sub>REST-DIS</sub>                |      |      | 1                   | S     | From Rest Mode(RM) bits cleared to valid motion                                                                          |
| Power Down                                          | t <sub>PD</sub>                      |      |      | 50                  | ms    | From PD active (when bit 1 of register 0x0d is set) to low current                                                       |
| Wake from Power<br>Down                             | t <sub>WAKEUP</sub>                  | 50   |      | 55                  | ms    | From PD inactive (when write 0x5a to regis-<br>ter 0x3a) to valid motion                                                 |
| MISO Rise Time                                      | t <sub>r-MISO</sub>                  |      | 40   | 200                 | ns    | C <sub>L</sub> = 100 pF                                                                                                  |
| MISO Fall Time                                      | t <sub>f-MISO</sub>                  |      | 40   | 200                 | ns    | C <sub>L</sub> = 100 pF                                                                                                  |
| MISO Delay after<br>SCLK                            | t <sub>DLY-MISO</sub>                |      |      | 120                 | ns    | From SCLK falling edge to MISO data valid, no load conditions                                                            |
| MISO Hold Time                                      | t <sub>hold-MISO</sub>               | 500  |      | 1/f <sub>SCLK</sub> | ns    | Data held until next falling SCLK edge                                                                                   |
| MOSI Hold Time                                      | t <sub>hold-MOSI</sub>               | 200  |      |                     | ns    | Amount of time data is valid after SCLK rising edge                                                                      |
| MOSI Setup Time                                     | t <sub>setup-MOSI</sub>              | 120  |      |                     | ns    | From data valid to SCLK rising edge                                                                                      |
| SPI Time between<br>Write Commands                  | t <sub>SWW</sub>                     | 30   |      |                     | μs    | From rising SCLK for last bit of the first data<br>byte, Commands to rising SCLK for last bit of<br>the second data byte |
| SPI Time between<br>Write and Read Com-<br>mands    | t <sub>SWR</sub>                     | 20   |      |                     | μs    | From rising SCLK f or last bit of the first data byte, to rising SCLK for last bit of the second address byte            |
| SPI Time between<br>Read and Subsequent<br>Commands | t <sub>SRW</sub><br>t <sub>SRR</sub> | 250  |      |                     | ns    | From rising SCLK for last bit of the first data byte, to falling SCLK for the first bit of the next address              |
| SPI Read Address-Data<br>Delay                      | t <sub>SRAD</sub>                    | 4    |      |                     | μs    | From rising SCLK for last bit of the address byte, to falling SCLK for first bit of data being read                      |
| NCS Inactive after Mo-<br>tion Burst                | t <sub>BEXIT</sub>                   | 250  |      |                     | ns    | Minimum NCS inactive time after motion burst before next SPI usage                                                       |
| NCS to SCLK Active                                  | t <sub>NCS-SCLK</sub>                | 120  |      |                     | ns    | From NCS falling edge to first SCLK falling edge                                                                         |
| SCLK to NCS Inactive<br>(for Read Operation)        | t <sub>SCLK-NCS</sub>                | 120  |      |                     | ns    | From last SCLK rising edge to NCS rising edge, for valid MISO data transfer                                              |
| SCLK to NCS Inactive (for Write Operation)          | t <sub>SCLK-NCS</sub>                | 20   |      |                     | μs    | From last SCLK rising edge to NCS rising edge, for valid MOSI data transfer                                              |
| NCS to MISO high-Z                                  | t <sub>NCS-MISO</sub>                |      |      | 250                 | ns    | From NCS rising edge to MISO high-Z state                                                                                |
| Transient Supply<br>Current                         | I <sub>DDT</sub>                     |      |      | 60                  | mA    | Max supply current during a VDD ramp from<br>0 to VDD                                                                    |

# Table 4. DC Electrical Specifications

| Parameter             | Symbol                | Min     | Тур.  | Max   | Units | Notes                                       |
|-----------------------|-----------------------|---------|-------|-------|-------|---------------------------------------------|
| DC Supply Current in  | I <sub>DD_AVG</sub>   |         | 8.23  | 20.41 | mA    | Average run current, including LED current, |
| Various Mode          | IDD_REST1             |         | 0.79  | 1.65  | mA    | at max frame rate. No load on MISO          |
|                       | I <sub>DD_REST2</sub> |         | 0.08  | 0.18  | mA    |                                             |
|                       | I <sub>DD_REST3</sub> |         | 0.026 | 0.054 | mA    |                                             |
| Power Down Current    |                       |         | 10    |       | μΑ    |                                             |
| Input Low Voltage     | V <sub>IL</sub>       |         |       | 0.5   | V     | SCLK, MOSI, NCS                             |
| Input High Voltage    | VIH                   | Vdd-0.5 |       |       | V     | SCLK, MOSI, NCS                             |
| Input Hysteresis      | V <sub>I_HYS</sub>    |         | 200   |       | mV    | SCLK, MOSI, NCS                             |
| Input leakage current | l <sub>leak</sub>     |         | ±1    | ±10   | μΑ    | Vin=VDD-0.6V, SCLK, MOSI, NCS               |
| Output Low Voltage    | V <sub>OL</sub>       |         |       | 0.7   | V     | lout=1mA, MISO, MOTION                      |
| Output High Voltage   | V <sub>OH</sub>       | Vdd-0.7 |       |       | V     | lout=-1mA, MISO, MOTION                     |
| Input Capacitance     | Cin                   |         | 50    |       | pF    | MOSI, NCS, SCLK                             |

Electrical characteristics over recommended operating conditions. Typical values at 25 °C, VDD = 2.8 V.

# **Typical Performance Characteristics**



Figure 9. Typical path deviation.



Figure 10. Mean resolution vs. distance from lens reference plane to surface.



Figure 11. Relative wavelength responsivity.

# **Synchronous Serial Port**

The synchronous serial port is used to set and read parameters in the ADNS-4000, and to read out the motion information. The port is a four wire serial port. The host micro-controller always initiates communication; the ADNS-4000 never initiates data transfers. SCLK, MOSI, and NCS may be driven directly by a micro-controller. The port pins may be shared with other SPI slave devices. When the NCS pin is high, the inputs are ignored and the output is at tri-state.

The lines that comprise the SPI port:

SCLK: Clock input. It is always generated by the master (the micro-controller).

MOSI: Input data. (Master Out/Slave In)

MISO: Output data. (Master In/Slave Out)

NCS: Chip select input (active low). NCS needs to be low to activate the serial port; otherwise, MISO will be high Z, and MOSI & SCLK will be ignored. NCS can also be used to reset the serial port in case of an error.

# **Chip Select Operation**

The serial port is activated after NCS goes low. If NCS is raised during a transaction, the entire transaction is aborted and the serial port will be reset. This is true for all transactions. After a transaction is aborted, the normal address-to-data or transaction-to-transaction delay is still required before beginning the next transaction. To improve communication reliability, all serial transactions should be framed by NCS. In other words, the port should not remain enabled during periods of non-use because ESD and EFT/B events could be interpreted as serial communication and put the chip into an unknown state. In addition, NCS must be raised after each burst-mode transaction is complete to terminate burst-mode. The port is not available for further use until burst-mode is terminated.

# 'Smart' LED Current Switching

ADNS-4000 is designed with 'smart' LED feature, an auto or self-adjusting LED current switching between the low and high current settings depending on the brightness of the tracking surface. If the surface is sufficiently bright to the sensor, lower LED current will be selected. When tracking on a darker surface, the higher current setting will be used. This feature is one of the power saving features in this sensor controlled by AUTO\_LED\_CTRL register (0x43).

# **Power Management Modes**

The ADNS-4000 has three power-saving modes. Each mode has a different motion detection period with its respective response time to mouse motion. Response Time is the time taken for the sensor to 'wake up' from rest mode when motion is detected. When left idle, the sensor automatically changes or downshift from Run mode to Rest1, to Rest2 and finally to Rest3 which consumes the least current. Do note that current consumption is the lowest at Rest3 and highest at Rest1, however time required for sensor to respond to motion from Rest1 is the shortest and longest from Rest3. Downshift Time is the elapsed time (under no motion condition) from current mode to the next mode for example, it takes 10s for the sensor that is in Rest1 to change to Rest2. The typical response time and downshift time for each mode is shown in the following table. However, user can change the default time setting for each mode via register 0x0e through 0x13.

| Mode   | Response Time<br>(Typical) | Downshift Time<br>(Typical) |
|--------|----------------------------|-----------------------------|
| Rest 1 | 10ms                       | <1s                         |
| Rest 2 | 100 ms                     | 9s                          |
| Rest 3 | 500 ms                     | 430s                        |
|        |                            |                             |

Another feature in ADNS-4000 that can be used to optimize the power consumption of the optical mouse system is the Motion Interrupt Output or MOTION pin (pin 3). It allows the host controller to be in sleep mode (or lowest operating current mode) when there is no motion detected after some time instead of consistently be in active mode and polling motion data from the sensor. When motion is detected, the sensor will send the motion interrupt signal through pin 3 to the controller to wake it up from sleep mode to resume its motion detection routine for navigation position and direction update.

# **MOTION Detection Routine**

Typically in the motion detection routine, MCU will poll the sensor for valid motion data by checking on the MO-TION\_ST bit in MOTION\_ST register. If MOTION\_ST bit is set, motion data in DELTA\_X and DELTA\_Y is valid and ready to be read by the MCU.

# **MOTION Function**

MOTION output signal (pin 3) can be used as interrupt input to the microcontroller of the mouse to trigger the controller to read the motion data from the sensor whenever there is motion detected by the sensor. The MOTION signal can be configured to be level or edge triggered, active high or low by setting the bits in MOTION\_CTRL register.

For active high level-triggered configuration, the MOTION pin level will be driven high as long the MOTION bit in register 0x02 is set and there is motion data in DELTA\_X and DELTA\_Y registers ready to be read by the microcontroller. Once all the motion data has been read, DELTA\_X and DELTA\_Y values become zero, MOTION bit is reset and the MOTION pin level is driven low.

For active high edge-triggered configuration, a pulse of 230us will be sent through the MOTION pin when there is motion detected by the sensor during rest modes. The pulse can be used as interrupt input to activate the microcontroller from its sleep mode to enter into run mode to start polling the sensor for motion data by monitoring MOTION\_ST bit (set whenever there is valid motion data) in MOTION register (0x02) and reading DELTA\_X and DELTA\_Y registers until MOTION\_ST bit is reset.

# Write Operation

Write operation, defined as data going from the micro-controller to the ADNS-4000, is always initiated by the micro-controller and consists of two bytes. The first byte contains the address (seven bits) and has a "1" as its MSB to indicate write sequence. The second byte contains the data. The ADNS-4000 reads MOSI on rising edges of SCLK.



MOSI DRIVEN BY MICRO-CONTROLLER

Figure 12. Write Operation

# MOSI setup and hold time during write operation



Figure 13. MOSI setup

# **Read Operation**

A read operation, defined as data going from the ADNS-4000 to the micro-controller, is always initiated by the micro-controller and consists of two bytes. The first byte contains the address, is sent by the micro-controller over MOSI, and has a "0" as its MSB to indicate data direction. The second byte contains the data and is driven by the ADNS-4000 over MISO. The sensor outputs MISO bits on falling edges of SCLK and samples MOSI bits on every rising edge of SCLK.



Figure 14. Read Operation

#### MOSI delay and hold time during read operation



Figure 15. MISO delay

NOTE: The 500 ns minimum high state of SCLK is also the minimum MISO data hold time of the ADNS-4000. Since the falling edge of SCLK is actually the start of the next read or write command, the ADNS-4000 will hold the state of data on MISO until the falling edge of SCLK.

#### **Required Timing between Read and Write Commands**

There are minimum timing requirements between read and write commands on the serial port.

# **Timing between Two Write Commands**

If the rising edge of the SCLK for the last data bit of the second write command occurs before the required delay (t<sub>sww</sub>), then the first write command may not complete correctly.



Figure 16. Timing between Two Write Commands

# **Timing between Write and Read Commands**

If the rising edge of SCLK for the last address bit of the read command occurs before the required delay (t<sub>SWR</sub>), the write command may not complete correctly.



Figure 17. Timing between Write and Read Commands

# **Timing between Read and Subsequent Write or Read Commands**

During a read operation SCLK should be delayed at least t<sub>SRAD</sub> after the last address data bit to ensure that the ADNS-4000 has time to prepare the requested data. The falling edge of SCLK for the first address bit of either the read or write command must be at least t<sub>SRR</sub> or t<sub>SRW</sub> after the last SCLK rising edge of the last data bit of the previous read operation.



Figure 18. Timing between Read and Subsequent Write or Read Commands







#### **Burst Mode Operation**

Burst mode is a special serial port operation mode that may be used to reduce the serial transaction time for a motion read. The speed improvement is achieved by continuous data clocking to or from multiple registers without the need to specify the register address, and by not requiring the normal delay period between data bytes.

Burst mode is initiated by reading the MOTION\_BURST register (0x63). The ADNS-4000 will respond with the contents of the DELTA\_X, DELTA\_Y, SQUAL, SHUT\_HI, SHUT\_LO, and PIX\_MAX and PIX\_ACCUM registers in that order. The burst transaction can be terminated anywhere in the sequence after the DELTA\_Y value by bringing the NCS pin high. The default "Read First Byte" is DELTA\_X content and is specified in register 0x42 (BURST\_READ\_FIRST). The address that specifies the "Read First Byte" can be changed to address 0x00 – 0x02 (PROD\_ID – MOTION\_ST) or 0x05 – 0x08 (SQUAL – PIX\_MAX) by writing to register 0x42.

After reading the MOTION\_BURST address (0x63), the microcontroller must wait  $t_{SRAD}$  before starting to read the continuous data bytes. All data bits can be read with no delay between bytes by driving SCLK at the normal rate. The data are latched into the output buffer after the last address bit is received. After the burst transmission is complete, the micro-controller must raise the NCS line for at least  $t_{BEXIT}$  to terminate burst mode. The serial port is not available for use until it is reset with NCS, even for a second burst transmission.

Prior to reading MOTION\_BURST register (0x63), MOTION\_ ST bit in MOTION\_ST register (0x02) should be read. Alternatively, read MOTION\_BURST register (0x63) only after MOTION pin is triggered.

Avago Technologies highly recommends the usage of burst mode operation in optical mouse sensor design applications.

# **Power Up Reset**

Although ADNS-4000 does have an internal power up self reset circuitry, it is still highly recommended to follow the power up sequence below:

- i. Apply power
- ii. Drive NCS high, then low to reset the SPI port.
- iii. Write 0x5a to register 0x3a.

#### Reset

ADNS-4000 can be reset by writing 0x5a to register 0x3a. A full reset will thus be executed and any register settings must be reloaded. The table below shows the state of the various pins during reset.

State of Signal Pins after VDD is Valid

| Paring heset | AIter Reset                                  |
|--------------|----------------------------------------------|
| Ignored      | Functional                                   |
| Low          | Depends on NCS                               |
| Ignored      | Depends on NCS                               |
| Ignored      | Depends on NCS                               |
| High         | Functional                                   |
|              | Ignored<br>Low<br>Ignored<br>Ignored<br>High |

#### **Power Down**

The ADNS-4000 can be set to Power Down mode by writing 0x02 to register 0x0d to disable the sensor. In addition, the SPI port should not be accessed during power down. Other ICs on the same SPI bus can be accessed, as long as the sensor's NCS pin is not asserted. The table below shows the state of various pins during power down. To exit Power Down, write 0x5a to register 0x3a to reset the sensor in order to wake it up. A full reset will thus be executed. Wait t<sub>WAKEUP</sub> before accessing the SPI port. Any register settings must then be reloaded.

| Dim    | During Dower Down |
|--------|-------------------|
| PIN    | During Power Down |
| MOTION | Undefined         |
| NCS    | Functional*       |
| MISO   | Undefined         |
| SCLK   | Functional*       |
| MOSI   | Functional*       |
| XY_LED | Low current       |
|        |                   |

Notes:

\* NCS pin must be held to 1 (HIGH) if SPI bus is shared with other devices. It can be in either state if the sensor is the only device in connected to the host micro-controller.

Reading of registers should only be performed after exiting from the power down mode. Any read operation during power down will not reflect the actual data of the registers.

# Lift Detection Cutoff Algorithm

When the mouse is raised from the tracking surface which is also known as lifted condition, there is a specific z-height whereby the tracking of the sensor will cease. However the tracking cutoff height of the ADNS-4000 sensor varies with the different tracking surfaces. In general to have a lower tracking cutoff height than the default settings, below is the recommended algorithm illustrated in the form of a pseudo code.

If (MOTION)

{

```
Delta_X = Read_Register(REG_DELTA_X);
Delta_Y = Read_Register(REG_DELTA_Y);
Squal = Read_Register(REG_SQUAL);
Pixel_Accum = Read_Register(REG_PIX_ACCUM);
If ( (Pixel_Accum < 105) && (Squal < 20) )
{ Delta_X = 0;
Delta_Y = 0;
}
USB_Send_Report();
```

# Registers

The ADNS-4000 registers are accessible via the serial port. The registers are used to read motion data and status as well as to set the device configuration.

| Address | Register Name    | Register Description            | Read/Write | Default Value |
|---------|------------------|---------------------------------|------------|---------------|
| 0x00    | PROD_ID          | Product ID                      | R          | 0x29          |
| 0x01    | REV_ID           | Revision ID                     | R          | 0x01          |
| 0x02    | MOTION_ST        | Motion Status                   | R          | 0x00          |
| 0x03    | DELTA_X          | Delta_X                         | R          | 0x00          |
| 0x04    | DELTA_Y          | Delta_Y                         | R          | 0x00          |
| 0x05    | SQUAL            | Squal Quality                   | R          | 0x00          |
| 0x06    | SHUT_HI          | Shutter Open Time (Upper 8-bit) | R          | 0x01          |
| 0x07    | SHUT_LO          | Shutter Open Time (Lower 8-bit) | R          | 0x00          |
| 0x08    | PIX_MAX          | Maximum Pixel Value             | R          | 0x00          |
| 0x09    | PIX_ACCUM        | Average Pixel Value             | R          | 0x00          |
| 0x0a    | PIX_MIN          | Minimum Pixel Value             | R          | 0x00          |
| 0x0b    | PIX_GRAB         | Pixel Grabber                   | R/W        | 0x00          |
| 0x0d    | MOUSE_CTRL       | Mouse Control                   | R/W        | 0x01          |
| 0x0e    | RUN_DOWNSHIFT    | Run to Rest1 Time               | R/W        | 0x46          |
| 0x0f    | REST1_PERIOD     | Rest1 Period                    | R/W        | 0x00          |
| 0x10    | REST1_DOWNSHIFT  | Rest1 to Rest2 Time             | R/W        | 0x4f          |
| 0x11    | REST2_PERIOD     | Rest2 Period                    | R/W        | 0x09          |
| 0x12    | REST2_DOWNSHIFT  | Rest2 to Rest3 Time             | R/W        | 0x2f          |
| 0x13    | REST3_PERIOD     | Rest3 Period                    | R/W        | 0x31          |
| 0x21    | MOUSE_CTRL_EN    | Mouse Control Enable Register   | W          | 0x00          |
| 0x35    | FRAME_IDLE       | Frame Idle Setting              | R/W        | 0xf0          |
| 0x3a    | RESET            | Reset                           | W          | 0x00          |
| 0x3f    | NOT_REV_ID       | Inverted Revision ID            | R          | 0xfe          |
| 0x40    | LED_CTRL         | LED Control                     | R/W        | 0x00          |
| 0x41    | MOTION_CTRL      | Motion Control                  | R/W        | 0x40          |
| 0x42    | BURST_READ_FIRST | Burst Read Starting Register    | R/W        | 0x03          |
| 0x43    | AUTO_LED_CTRL    | AUTO LED Control                | R/W        | 0x08          |
| 0x45    | REST_MODE_CONFIG | Rest Mode Configuration         | R/W        | 0x00          |
| 0x63    | MOTION_BURST     | Burst Read                      | R          | 0x00          |

| PROD_ID           |     | Addre              | ss: 0x00      |                      |               |              |              |              |               |
|-------------------|-----|--------------------|---------------|----------------------|---------------|--------------|--------------|--------------|---------------|
| Product ID Regist | ter |                    |               |                      |               |              |              |              |               |
| Access: Read      |     | Reset              | Value: 0x29   |                      |               |              |              |              |               |
|                   | Bit | 7                  | 6             | 5                    | 4             | 3            | 2            | 1            | 0             |
| Fi                | eld | PID7               | PID6          | PID5                 | PID4          | PID3         | PID2         | PID1         | PID0          |
| USAGE:            |     | 8-Bit u<br>This re | egister conta | eger<br>ains a uniqu | ie identifica | tion assigne | ed to the AI | ONS-4000. TI | he value in t |

| REV_ID                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      | Addres              | s: 0x01          |              |              |            |           |          |                                                                      |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------|------------------|--------------|--------------|------------|-----------|----------|----------------------------------------------------------------------|--|--|
| Revision ID Registe                                                                                                                                                                                                                                                                                                                                                                                                                                         | r    |                     |                  |              |              |            |           |          |                                                                      |  |  |
| Access: Read                                                                                                                                                                                                                                                                                                                                                                                                                                                |      | Reset Value: 0x01   |                  |              |              |            |           |          |                                                                      |  |  |
| Bi                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7    |                     | 6                | 5            | 4            | 3          | 2         | 1        | 0                                                                    |  |  |
| Field                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RIE  | 07                  | RID6             | RID5         | RID4         | RID3       | RID2      | RID1     | RIDO                                                                 |  |  |
| Data Type:                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      | 8-Bit ur            | nsigned int      | eger         |              |            |           |          |                                                                      |  |  |
| USAGE:                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      | This ree<br>release | gister con<br>d. | tains the IC | revision. It | is subject | to change | when new | IC versions a                                                        |  |  |
| MOTION_ST                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      | Addres              | s: 0x02          |              |              |            |           |          |                                                                      |  |  |
| Motion Status Regi                                                                                                                                                                                                                                                                                                                                                                                                                                          | ster |                     |                  |              |              |            |           |          |                                                                      |  |  |
| Access: Read/Write                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | Reset V             | alue: 0x00       |              |              |            |           |          |                                                                      |  |  |
| Bi                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7    |                     | 6                | 5            | 4            | 3          | 2         | 1        | 0                                                                    |  |  |
| Field                                                                                                                                                                                                                                                                                                                                                                                                                                                       | M    | DTION_ST            | RSVD             | RSVD         | RSVD         | RSVD       | RSVD      | RSVD     | RSVD                                                                 |  |  |
| Data Type: Bit field.                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                     |                  |              |              |            |           |          |                                                                      |  |  |
| USAGE: Register 0x02 allows the user to determine if motion has occurred since the last time it<br>read. If the MOTION_ST bit is set, then the user should read registers 0x03 (DELTA_X) and<br>(DELTA_Y) to get the accumulated motion data. Read this register before reading the DELT<br>and DELTA_Y registers. Writing any data into this register clears MOTION_ST bit, DELTA_X<br>DELTA_Y registers. However the written data byte will not be saved. |      |                     |                  |              |              |            |           |          | last time it wa<br>_TA_X) and 0x(<br>ng the DELTA_<br>it, DELTA_X ar |  |  |

| Bit | Field Name | Description                                                            |
|-----|------------|------------------------------------------------------------------------|
| 7   | MOTION_ST  | Motion detected since last report                                      |
|     |            | 0 = No motion (default)                                                |
|     |            | 1 = Motion occurred, data in DELTA_X and DELTA_Y registers ready to be |
|     |            | read                                                                   |
| 6-0 | RSVD       | Reserved                                                               |

|                                                                                                                                    | Ad                                                             | dress: 0x03                                                                                    |                                              |                         |               |                   |                   |                     |          |        |  |
|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------|-------------------------|---------------|-------------------|-------------------|---------------------|----------|--------|--|
| X Displacement Reg                                                                                                                 | ister                                                          |                                                                                                |                                              |                         |               |                   |                   |                     |          |        |  |
| Access: Read                                                                                                                       | Res                                                            | Reset Value: 0x00                                                                              |                                              |                         |               |                   |                   |                     |          |        |  |
| Bit                                                                                                                                | 7                                                              | 6                                                                                              | 5                                            | 4                       | 3             |                   | 2                 | 1                   | 0        |        |  |
| Field                                                                                                                              | X7                                                             | X6                                                                                             | X5                                           | X4                      | Х3            |                   | X2                | X1                  | X        | )      |  |
| Data Type:                                                                                                                         | Eig                                                            | ht bit 2's coi                                                                                 | mplement nu                                  | ımber.                  |               |                   |                   |                     |          |        |  |
| USAGE:                                                                                                                             | X-a<br>Rea                                                     | axis moveme<br>ading this re                                                                   | ent in count<br>gister clears                | s since la<br>the conte | ent of this   | . Abso<br>registe | lute value<br>er. | is deter            | mined by | resolu |  |
| MOTION                                                                                                                             | -128                                                           | -127                                                                                           | -2                                           | -1                      | 0             | +1                | +2                |                     | +126     | +127   |  |
|                                                                                                                                    |                                                                |                                                                                                |                                              |                         |               |                   |                   | (                   |          |        |  |
|                                                                                                                                    |                                                                |                                                                                                | )                                            |                         |               |                   |                   | ))                  |          |        |  |
|                                                                                                                                    |                                                                |                                                                                                |                                              |                         |               |                   |                   |                     |          |        |  |
| DELTA_X                                                                                                                            | 80                                                             | 81                                                                                             | FE                                           | FF                      | 00            | 01                | 02                |                     | 7E       | 7F     |  |
| DELTA_X NOTE: Registers 0x0: DELTA_Y                                                                                               | <b>80</b><br>3 and 0x0<br>Ad                                   | <b>81</b><br>04 MUST be<br>dress: 0x04                                                         | FE<br>read consecu                           | FF<br>Itively.          | 00            | 01                | 02                |                     | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x0.<br>                                                                                                | 80<br>3 and 0x0<br>Ad                                          | <b>81</b><br>04 MUST be<br>dress: 0x04                                                         | FE<br>read consecu                           | FF<br>Itively.          | 00            | 01                | 02                |                     | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x0<br>DELTA_Y<br>Y Displacement Reg<br>Access: Read                                                    | 80<br>3 and 0x0<br>Adrister<br>Res                             | 81<br>04 MUST be<br>dress: 0x04<br>set Value: 0x                                               | FE<br>read consecu<br>00                     | FF<br>Itively.          | 00            | 01                | 02                |                     | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x0:<br>DELTA_Y<br>Y Displacement Reg<br>Access: Read<br>Bit                                            | 80<br>3 and 0x0<br>ister<br>Res                                | 81<br>04 MUST be<br>dress: 0x04<br>set Value: 0x                                               | FE<br>read consecu<br>00                     | FF<br>Itively.          | 00            | 01                | 02                | 1                   | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x0:<br>DELTA_Y<br>Y Displacement Reg<br>Access: Read<br>Bit<br>Field                                   | 80<br>3 and 0x0<br>ister<br>Res<br>7<br>Y7                     | 81<br>04 MUST be<br>dress: 0x04<br>set Value: 0x<br>6<br>Y6                                    | FE<br>read consecu<br>00<br>5<br>Y5          | FF<br>Itively.          | 00<br>3<br>Y3 | 01                | 02<br>2<br>Y2     | 1<br>Y1             | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x0:<br>DELTA_Y<br>Y Displacement Reg<br>Access: Read<br>Bit<br>Field                                   | 80<br>3 and 0x0<br>ister<br>Res<br>7<br>Y7                     | 81           04 MUST be           dress: 0x04           set Value: 0x           6           Y6 | FE<br>read consecu<br>00<br>5<br>Y5          | FF<br>Itively.          | 00<br>3<br>Y3 | 01                | 02<br>2<br>Y2     | 1<br>Y1             | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x01<br>DELTA_Y<br>Y Displacement Reg<br>Access: Read<br>Bit<br>Field<br>Data Type: Eight bit           | 80<br>3 and 0x0<br>ister<br>Res<br>7<br>Y7<br>2's compl        | 81<br>04 MUST be<br>dress: 0x04<br>set Value: 0x<br>6<br>Y6                                    | FE<br>read consecu<br>00<br>5<br>Y5<br>Iber. | FF<br>Itively.          | 00<br>3<br>Y3 | 01                | 02<br>2<br>Y2     | 1<br>Y1             | 7E       | 7F     |  |
| DELTA_X<br>NOTE: Registers 0x0.<br>DELTA_Y<br>Y Displacement Reg<br>Access: Read<br>Bit<br>Field<br>Data Type: Eight bit<br>USAGE: | 80<br>3 and 0x0<br>ister<br>Res<br>7<br>Y7<br>2's compl<br>Y-a | 81<br>04 MUST be<br>dress: 0x04<br>set Value: 0x<br>6<br>Y6<br>lement num<br>xis moveme        | FE<br>read consecu<br>00<br>5<br>Y5<br>ber.  | FF<br>Itively.          | 00<br>3<br>Y3 | 01                | 02                | 1<br>Y1<br>is deter | 7E       | 7F     |  |



NOTE: Avago RECOMMENDS that registers 0x03 and 0x04 be read consecutively.

# SQUAL

Address: 0x05

**Squal Quality Register** 

Access: Read

Reset Value: 0x00

| Bit   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|
| Field | SQ7 | SQ6 | SQ5 | SQ4 | SQ3 | SQ2 | SQ1 | SQ0 |

Data Type:

USAGE:

Upper 8 bits of a 9-bit unsigned integer.

SQUAL (Surface Quality) is a measure of the number of valid features visible by the sensor in the current frame.

The maximum SQUAL register value is 128. Since small changes in the current frame can result in changes in SQUAL, variations in SQUAL when looking at a surface are expected. The graph below shows 800 sequentially acquired SQUAL values, while a sensor was moved slowly over white paper. SQUAL is nearly equal to zero, if there is no surface below the sensor. SQUAL is typically maximized when the navigation surface is at the optimum distance from the imaging lens (the nominal Z-height).



Figure 20. Squal values (white paper)



Figure 21. Mean squal vs. Z (White Paper)

# SHUT\_HI Address: 0x06

| Shutter Open | Time (l | Jpper | 8-bits) | Register |
|--------------|---------|-------|---------|----------|
|              | •       |       | ,       | 5        |

Access: Read

#### Reset Value: 0x01

| Bit   | 7   | 6   | 5   | 4   | 3   | 2   | 1  | 0  |
|-------|-----|-----|-----|-----|-----|-----|----|----|
| Field | S15 | S14 | S13 | S12 | S11 | S10 | S9 | S8 |

# SHUT\_LO

#### Shutter Open Time (Lower 8-bits) Register

Access: Read

Reset Value: 0x00

Address: 0x07

| Bit   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|----|----|
| Field | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 |

Data Type:

USAGE:

#### Sixteen bit unsigned integer.

Units are in clock cycles. Read SHUT\_HI first, then SHUT\_LO. They should be read consecutively. The shutter is adjusted to keep the average and maximum pixel values within normal operating ranges. The shutter value is automatically adjusted.







Figure 23. Mean shutter vs. Z (white paper).

| PIX_MAX              |          | Ado                | dress: 0x08                            |                               |                              |                             |                              |                            |                               |
|----------------------|----------|--------------------|----------------------------------------|-------------------------------|------------------------------|-----------------------------|------------------------------|----------------------------|-------------------------------|
| Maximum Pix          | el Valu  | e Registei         |                                        |                               |                              |                             |                              |                            |                               |
| Access: Read         |          | Res                | et Value: 0x(                          | 00                            |                              |                             |                              |                            |                               |
|                      | Bit      | 7                  | 6                                      | 5                             | 4                            | 3                           | 2                            | 1                          | 0                             |
|                      | Field    | MP7                | MP6                                    | MP5                           | MP4                          | MP3                         | MP2                          | MP1                        | MP0                           |
| Data Type:           |          | Eigl               | nt-bit numb                            | er.                           |                              |                             |                              |                            |                               |
| USAGE:               |          | Sto<br>hig         | re the highe<br>hest pixel va          | st pixel valu<br>Ilue may var | e in current<br>y with diffe | frame. Minir<br>rent frame. | num value =                  | = 0, maximu                | m value = 255                 |
| PIX_ACCUM            |          | Ado                | dress: 0x09                            |                               |                              |                             |                              |                            |                               |
| Average Pixel        | Value I  | Register           |                                        |                               |                              |                             |                              |                            |                               |
| Access: Read         |          | Res                | et Value: 0x(                          | 00                            |                              |                             |                              |                            |                               |
|                      | Bit      | 7                  | 6                                      | 5                             | 4                            | 3                           | 2                            | 1                          | 0                             |
|                      | Field    | AP7                | AP6                                    | AP5                           | AP4                          | AP3                         | AP2                          | AP1                        | AP0                           |
| Data Type:<br>USAGE: |          | Hig<br>This        | h 8-bits of a<br>s register sto        | n unsigned<br>pres the acc    | 16-bit integ<br>umulated p   | er.<br>ixel value of        | the last ima                 | age taken. Ti              | his register ca               |
|                      |          | use                | d to find the                          | e average pi                  | xel value, wl                | here Average                | e Pixel = (reg               | gister value /             | AP[7:0]) * 0.71               |
|                      |          | The<br>max<br>diff | maximum<br>kimum regi:<br>erent frame. | accumulate<br>ster value is   | d value is 4<br>5 179. The r | 15847 but o<br>ninimum is   | nly bits [15:<br>0. The PIX_ | 8] are repor<br>_ACCUM val | ted, therefore<br>ue may vary |
| PIX_MIN              |          | Ado                | dress: 0x0a                            |                               |                              |                             |                              |                            |                               |
| Minimum Pixe         | el Value | e Register         |                                        |                               |                              |                             |                              |                            |                               |
| Access: Read         |          | Res                | et Value: 0x0                          | 00                            |                              |                             |                              |                            |                               |
|                      | Bit      | 7                  | 6                                      | 5                             | 4                            | 3                           | 2                            | 1                          | 0                             |
|                      | Field    | MP7                | MP6                                    | MP5                           | MP4                          | MP3                         | MP2                          | MP1                        | MP0                           |
| Data Type:           |          | Eigl               | nt-bit numb                            | er.                           |                              |                             |                              |                            |                               |

USAGE:

Store the lowest pixel value in current frame. Minimum value = 0, maximum value = 127. The minimum pixel value may vary with different frame.

| PIX_GRAB  | 3            |                                                                                                                                                                                                                                                         | Addre     | ss: 0x0b    |       |     |     |     |     |
|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|-------|-----|-----|-----|-----|
| Pixel Gra | bber Registe | er                                                                                                                                                                                                                                                      |           |             |       |     |     |     |     |
| Access: R | Read/Write   |                                                                                                                                                                                                                                                         | Reset     | Value: 0x00 |       |     |     |     |     |
|           | Bit          | 7                                                                                                                                                                                                                                                       | 6         | 5           | 4     | 3   | 2   | 1   | 0   |
|           | Field        | PG_VALID                                                                                                                                                                                                                                                | PG6       | PG5         | PG4   | PG3 | PG2 | PG1 | PG0 |
| Data Typ  | e:           | Eight                                                                                                                                                                                                                                                   | bit word. |             |       |     |     |     |     |
| USAGE:    |              | The pixel grabber captures 1 pixel per frame. Bit-7 (MSB) of this register will be set to that the 7-bit pixel data (PG[6:0]) is valid for grabbing. In a 19x19 pixel array, it will read operations to grab all the pixels to form the complete image. |           |             |       |     |     |     |     |
| -         | Bit(s)       | Field Nar                                                                                                                                                                                                                                               | ne        | Descri      | ption |     |     |     |     |

| Bit(s) | Field Name | Description         |  |
|--------|------------|---------------------|--|
| 7      | PG_VALID   | Pixel Grabber Valid |  |
| 6:0    | PG[6:0]    | Pixel Data          |  |

NOTE: Any write operation into this register will reset the grabber to origin (pixel 0 position). The sensor should not be moved before the 361 read operations are completed to ensure original data is grabbed to produce good (uncorrupted) image.

#### 19x19 Pixel Array Address Map – (View from top of sensor)

| 342 | 323 | 304 | 285 | 266 | 247 | 228 | 209 | 190 | 171 | 152 | 133 | 114 | 95  | 76 | 57 | 38 | 19 | 0  | Fi |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|
| 343 | 324 | 305 | 286 | 267 | 248 | 229 | 210 | 191 | 172 | 153 | 134 | 115 | 96  | 77 | 58 | 39 | 20 | 1  |    |
| 344 | 325 | 306 | 287 | 268 | 249 | 230 | 211 | 192 | 173 | 154 | 135 | 116 | 97  | 78 | 59 | 40 | 21 | 2  |    |
| 345 | 326 | 307 | 288 | 269 | 250 | 231 | 212 | 193 | 174 | 155 | 136 | 117 | 98  | 79 | 60 | 41 | 22 | 3  |    |
| 346 | 327 | 308 | 289 | 270 | 251 | 232 | 213 | 194 | 175 | 156 | 137 | 118 | 99  | 80 | 61 | 42 | 23 | 4  |    |
| 347 | 328 | 309 | 290 | 271 | 252 | 233 | 214 | 195 | 176 | 157 | 138 | 119 | 100 | 81 | 62 | 43 | 24 | 5  |    |
| 348 | 329 | 310 | 291 | 272 | 253 | 234 | 215 | 196 | 177 | 158 | 139 | 120 | 101 | 82 | 63 | 44 | 25 | 6  |    |
| 349 | 330 | 311 | 292 | 273 | 254 | 235 | 216 | 197 | 178 | 159 | 140 | 121 | 102 | 83 | 64 | 45 | 26 | 7  |    |
| 350 | 331 | 312 | 293 | 274 | 255 | 236 | 217 | 198 | 179 | 160 | 141 | 122 | 103 | 84 | 65 | 46 | 27 | 8  |    |
| 351 | 332 | 313 | 294 | 275 | 256 | 237 | 218 | 199 | 180 | 161 | 142 | 123 | 104 | 85 | 66 | 47 | 28 | 9  |    |
| 352 | 333 | 314 | 295 | 276 | 257 | 238 | 219 | 200 | 181 | 162 | 143 | 124 | 105 | 86 | 67 | 48 | 29 | 10 |    |
| 353 | 334 | 315 | 296 | 277 | 258 | 239 | 220 | 201 | 182 | 163 | 144 | 125 | 106 | 87 | 68 | 49 | 30 | 11 |    |
| 354 | 335 | 316 | 297 | 278 | 259 | 240 | 221 | 202 | 183 | 164 | 145 | 126 | 107 | 88 | 69 | 50 | 31 | 12 |    |
| 355 | 336 | 317 | 298 | 279 | 260 | 241 | 222 | 203 | 184 | 165 | 146 | 127 | 108 | 89 | 70 | 51 | 32 | 13 |    |
| 356 | 337 | 318 | 299 | 280 | 261 | 242 | 223 | 204 | 185 | 166 | 147 | 128 | 109 | 90 | 71 | 52 | 33 | 14 |    |
| 357 | 338 | 319 | 300 | 281 | 262 | 243 | 224 | 205 | 186 | 167 | 148 | 129 | 110 | 91 | 72 | 53 | 34 | 15 |    |
| 358 | 339 | 320 | 301 | 282 | 263 | 244 | 225 | 206 | 187 | 168 | 149 | 130 | 111 | 92 | 73 | 54 | 35 | 16 |    |
| 359 | 340 | 321 | 302 | 283 | 264 | 245 | 226 | 207 | 188 | 169 | 150 | 131 | 112 | 93 | 74 | 55 | 36 | 17 |    |
| 360 | 341 | 322 | 303 | 284 | 265 | 246 | 227 | 208 | 189 | 170 | 151 | 132 | 113 | 94 | 75 | 56 | 37 | 18 |    |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    |    |    |    |    |



# MOUSE\_CTRL

Address: 0x0d

Mouse Control Register

Access: Read/Write

Reset Value: 0x01

| Bit   | 7    | 6    | 5      | 4    | 3    | 2    | 1  | 0     |
|-------|------|------|--------|------|------|------|----|-------|
| Field | RSVD | RSVD | RES_EN | RES2 | RES1 | RES0 | PD | RES_D |

### Data Type: Bit field

USAGE: Resolution and chip reset information can be accessed or to be edited by this register.

| Bit(s) | Field Name | Description                                                                                                                     |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------|
| 7:6    | RSVD       | Reserved                                                                                                                        |
| 5      | RES_EN     | Enable resolution settings set on<br>MOUSE_CTRL [4:2]                                                                           |
| 4:2    | RES [2:0]  | Resolution<br><b>000: 1000 dpi (default)</b><br>001: 250 dpi<br>010: 500 dpi<br>011: 1250 dpi<br>100: 1500 dpi<br>101: 1750 dpi |
| 1      | PD         | Power Down                                                                                                                      |
| 0      | RES_D      | 0: 500 dpi<br><b>1: 1000 dpi (default)</b>                                                                                      |

#### NOTE:

1. Setting MOUSE\_CTRL [5] bit to '1' will supersede and ignore MOUSE\_CTRL [0] setting.

2. Each read/write operation of this register should be followed by a write operation: write register 0x21 with 0x10.

| RUN_DOWNSHIFT        | Addre                                | ss: 0x0e |      |      |      |      |      |      |  |
|----------------------|--------------------------------------|----------|------|------|------|------|------|------|--|
| Run to Rest1 Time Re | Run to Rest1 Time Register           |          |      |      |      |      |      |      |  |
| Access: Read/Write   | Access: Read/Write Reset Value: 0x46 |          |      |      |      |      |      |      |  |
| Bit                  | 7                                    | 6        | 5    | 4    | 3    | 2    | 1    | 0    |  |
| Field                | RUD7                                 | RUD6     | RUD5 | RUD4 | RUD3 | RUD2 | RUD1 | RUD0 |  |

Data Type: Eight bit number

USAGE:

This register sets the Run to Rest1 mode downshift time. The time is the value of this register multiply by 16 frames. Min value for this register must be 1.

For example at typical frame rate of 2250fps, each frame period is about 444us. Therefore the run downshift time would be Register value (0x46) \* 16 \* frame period = 70 \* 16 \* 444us = 497.3ms

| REST1_PERIOD                                           |                         | Addre                     | ess: 0x0f                                     |                                                 |                                            |                                               |                                          |                                       |                           |
|--------------------------------------------------------|-------------------------|---------------------------|-----------------------------------------------|-------------------------------------------------|--------------------------------------------|-----------------------------------------------|------------------------------------------|---------------------------------------|---------------------------|
| Rest1 Period F                                         | Registe                 | r                         |                                               |                                                 |                                            |                                               |                                          |                                       |                           |
| Access: Read/                                          | Write                   | Reset                     | Value: 0x00                                   |                                                 |                                            |                                               |                                          |                                       |                           |
|                                                        | Bit                     | 7                         | 6                                             | 5                                               | 4                                          | 3                                             | 2                                        | 1                                     | 0                         |
|                                                        | Field                   | R1P7                      | R1P6                                          | R1P5                                            | R1P4                                       | R1P3                                          | R1P2                                     | R1P1                                  | R1P0                      |
| Data Type:                                             |                         | Eight                     | bit number                                    |                                                 |                                            |                                               |                                          |                                       |                           |
| USAGE:                                                 |                         | This re<br>clock          | egister sets<br>period). Mir                  | the Rest1 pe<br>value for th                    | eriod. Perio<br>is register i              | d = (register<br>s 0. Max val                 | r value R1F<br>ue is 0xFD.               | 9 [7:0] +1) x                         | 7ms (typical              |
| NOTE:                                                  |                         | Writin<br>unexp<br>be inc | ig into this i<br>bected beha<br>corporated p | register whe<br>vior of the s<br>prior and afte | en the sens<br>ensor. To a<br>er the write | or itself is op<br>void this fro<br>command i | perating in<br>m happeni<br>nto this reg | this rest m<br>ng, below c<br>gister. | ode may res<br>ommands sh |
|                                                        |                         | w 22 8                    | 30 -> write (                                 | 0x80H into r                                    | egister 0x2                                | 2H prior to v                                 | vriting into                             | this registe                          | r                         |
|                                                        |                         | w Of X                    | X -> writing                                  | g into this re                                  | gister                                     |                                               |                                          |                                       |                           |
|                                                        |                         | w 22 (                    | 00 -> write (                                 | 0x00H into r                                    | egister 0x2                                | 2H after writ                                 | ing into th                              | is register                           |                           |
|                                                        |                         |                           |                                               |                                                 |                                            |                                               |                                          |                                       |                           |
| REST1_DOWNS                                            | HIFT                    | Addre                     | ess: 0x10                                     |                                                 |                                            |                                               |                                          |                                       |                           |
| Rest1 to Rest2                                         | 2 Down                  | shift Time F              | Register                                      |                                                 |                                            |                                               |                                          |                                       |                           |
| Access: Read/                                          | Write                   | Reset                     | Value: 0x4f                                   |                                                 |                                            |                                               |                                          |                                       |                           |
|                                                        | Bit                     | 7                         | 6                                             | 5                                               | 4                                          | 3                                             | 2                                        | 1                                     | 0                         |
|                                                        | Field                   | R1D7                      | R1D6                                          | R1D5                                            | R1D4                                       | R1D3                                          | R1D2                                     | R1D1                                  | R1D0                      |
|                                                        |                         |                           |                                               |                                                 |                                            |                                               | 1                                        | 1                                     |                           |
| Data Type:                                             |                         | Eight                     | bit number                                    |                                                 |                                            |                                               |                                          |                                       |                           |
| USAGE:                                                 |                         | This re<br>(Rest1         | egister sets<br>period) x 1                   | the Rest1 to<br>6. Min value                    | Rest2 mod<br>for this reg                  | e downshift<br>ister is 0.                    | time. Time                               | e = (register                         | value R1D [7              |
|                                                        |                         |                           |                                               |                                                 |                                            |                                               |                                          |                                       |                           |
| REST2 PERIOD                                           |                         | Addre                     | ess: 0x11                                     |                                                 |                                            |                                               |                                          |                                       |                           |
| REST2_PERIOD                                           | Reaiste                 | Addre<br>r                | ess: 0x11                                     |                                                 |                                            |                                               |                                          |                                       |                           |
| <b>REST2_PERIOD</b><br>Rest2 Period F<br>Access: Read/ | Registe<br>Write        | Addre<br>r<br>Reset       | ess: 0x11<br>Value: 0x09                      |                                                 |                                            |                                               |                                          |                                       |                           |
| REST2_PERIOD<br>Rest2 Period F<br>Access: Read/        | Registe<br>Write<br>Bit | Addre<br>r<br>Reset       | value: 0x09                                   | 5                                               | 4                                          | 3                                             | 2                                        | 1                                     | 0                         |

| Data Type: | Eight bit number                                                                                                                                                                                                                                            |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| USAGE:     | This register sets the Rest2 period. Period = (register value R2P [7:0] +1) x 7ms (typical slow clock period). Min value for this register is 0. Max value is 0xFD.                                                                                         |
| NOTE:      | Writing into this register when the sensor itself is operating in this rest mode may result in unexpected behavior of the sensor. To avoid this from happening, below commands should be incorporated prior and after the write command into this register. |
|            | w 22 80 -> write 0x80H into register 0x22H prior to writing into this register                                                                                                                                                                              |
|            | w 11 XX -> writing into this register                                                                                                                                                                                                                       |
|            | w 22 00 -> write 0x00H into register 0x22H after writing into this register                                                                                                                                                                                 |
|            |                                                                                                                                                                                                                                                             |

| REST2 | DOWNSHIFT | Address: 0x12 |
|-------|-----------|---------------|
|       |           |               |

| Rest2 to Rest3 Down  | shift Time I              | Register                                    |                                           |                                               |                                             |                                            |                                          |                               |
|----------------------|---------------------------|---------------------------------------------|-------------------------------------------|-----------------------------------------------|---------------------------------------------|--------------------------------------------|------------------------------------------|-------------------------------|
| Access: Read/Write   | Reset                     | Value: 0x2f                                 |                                           |                                               |                                             |                                            |                                          |                               |
| Bit                  | 7                         | 6                                           | 5                                         | 4                                             | 3                                           | 2                                          | 1                                        | 0                             |
| Field                | R2D7                      | R2D6                                        | R2D5                                      | R2D4                                          | R2D3                                        | R2D2                                       | R2D1                                     | R2D0                          |
| Data Type:<br>USAGE: | Eight<br>This r<br>(Rest2 | bit numbei<br>egister sets<br>2 period) x ´ | the Rest1<br>28. Min va                   | to Rest2 mo<br>llue for this r                | de downshi<br>egister is 0.                 | ft time. Time                              | e = (register                            | value R2D [7:0]               |
| REST3_PERIOD         | Addre                     | ess: 0x13                                   |                                           |                                               |                                             |                                            |                                          |                               |
| Rest3 Period Registe | r                         |                                             |                                           |                                               |                                             |                                            |                                          |                               |
| Access: Read/Write   | Reset                     | Value: 0x31                                 |                                           |                                               |                                             |                                            |                                          |                               |
| Bit                  | 7                         | 6                                           | 5                                         | 4                                             | 3                                           | 2                                          | 1                                        | 0                             |
| Field                | R3P7                      | R3P6                                        | R3P5                                      | R3P4                                          | R3P3                                        | R3P2                                       | R3P1                                     | R3P0                          |
| Data Type<br>USAGE:  | Eight<br>This r<br>clock  | bit number<br>register sets<br>period). Mi  | the Rest3<br>n value for                  | period. Peri<br>this register                 | od = (regist<br>is 0. Max va                | er value R3I<br>lue is 0xFD.               | P [7:0] +1) x                            | 7ms (typical sl               |
| NOTE:                | Writir<br>unex<br>be inc  | ng into this<br>pected beh<br>corporated    | register w<br>avior of the<br>prior and a | hen the sen<br>e sensor. To<br>ifter the writ | sor itself is<br>avoid this fr<br>e command | operating ir<br>om happen<br>into this reg | i this rest m<br>ing, below c<br>gister. | ode may resul<br>commands sho |
|                      | w 22                      | 80 -> write                                 | 0x80H into                                | o register 0x                                 | 22H prior to                                | writing into                               | this registe                             | r                             |
|                      | w 13                      | XX -> writii                                | ng into this                              | register                                      |                                             |                                            |                                          |                               |
|                      | w 22                      | 00 -> write                                 | 0x00H into                                | o register 0x                                 | 22H after wr                                | iting into th                              | is register                              |                               |
| MOUSE_CTRL_EN        | Addre                     | ess: 0x21                                   |                                           |                                               |                                             |                                            |                                          |                               |

# Mouse Control Enable Register

| Access: Write |  |
|---------------|--|
| Access: Write |  |

Reset Value: 0x00

| Bit   | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|------|------|------|------|------|------|------|------|
| Field | MCE7 | MCE6 | MCE5 | MCE4 | MCE3 | MCE2 | MCE1 | MCE0 |

Data Type: USAGE: Eight bit unsigned integer.

Write 0x10 to this register after accessing register 0x0d to complete read/write operations.

| FRAME_IDLE                                                                                                                                    | Addr                                                                   | ess: 0x35                                                                                             |                                              |                                |                               |                             |                   |               |
|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------|--------------------------------|-------------------------------|-----------------------------|-------------------|---------------|
| Frame Idle Setting F                                                                                                                          | legister                                                               |                                                                                                       |                                              |                                |                               |                             |                   |               |
| Access: Read/Write                                                                                                                            | Rese                                                                   | t Value: 0xf0                                                                                         | )                                            |                                |                               |                             |                   |               |
| Bit                                                                                                                                           | 7                                                                      | 6                                                                                                     | 5                                            | 4                              | 3                             | 2                           | 1                 | 0             |
| Field                                                                                                                                         | 1                                                                      | 1                                                                                                     | FR5                                          | FR4                            | FR3                           | FR2                         | FR1               | FR0           |
| Data Type                                                                                                                                     | Eight                                                                  | : bit unsign                                                                                          | ed integer.                                  |                                |                               |                             |                   |               |
| USAGE:                                                                                                                                        | This<br>idling                                                         | register is u<br>g time, whic                                                                         | sed to cont<br>h effective                   | trol the fram<br>ly reduces th | e rate. The v<br>e frame rate | value in this<br>2.         | register is u     | ised to add f |
|                                                                                                                                               | fram                                                                   | e_idle_time                                                                                           | e (in clock co                               | ounts) = (reg                  | jister value)                 | * 32                        |                   |               |
|                                                                                                                                               | Fram<br>fram                                                           | e period (i<br>e_idle_time                                                                            | n clock cou                                  | unts) = shut                   | ter_time (re                  | g 0x06 and                  | l reg 0x07) -     | + (3400 cloc  |
|                                                                                                                                               | Whe                                                                    | n this regist                                                                                         | er is set to (                               | 0xf0, the typ                  | ical frame ra                 | ite is about 2              | 2250 fps @20      | 6MHz          |
|                                                                                                                                               |                                                                        |                                                                                                       |                                              |                                |                               |                             |                   |               |
| RESET                                                                                                                                         | Addr                                                                   | ess: 0x3a                                                                                             |                                              |                                |                               |                             |                   |               |
| <b>RESET</b><br>Reset Register                                                                                                                | Addr                                                                   | ess: 0x3a                                                                                             |                                              |                                |                               |                             |                   |               |
| <b>RESET</b><br>Reset Register<br>Access: Write                                                                                               | Addr<br>Rese                                                           | ess: 0x3a<br>t Value: 0x0                                                                             | 0                                            |                                |                               |                             |                   |               |
| <b>RESET</b><br>Reset Register<br>Access: Write<br>Bit                                                                                        | Addr<br>Rese                                                           | ess: 0x3a<br>t Value: 0x0                                                                             | 0 5                                          | 4                              | 3                             | 2                           | 1                 | 0             |
| <b>RESET</b><br>Reset Register<br>Access: Write<br>Bit<br>Field                                                                               | Addr<br>Rese<br>7<br>RST7                                              | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6                                                                | 0<br>5<br>RST5                               | 4<br>RST4                      | 3<br>RST3                     | 2<br>RST2                   | 1<br>RST1         | 0<br>RST0     |
| <b>RESET</b><br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:                                                                 | Addr<br>Rese<br>7<br>RST7<br>Eight                                     | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6                                                                | 0<br>5<br>RST5<br>ed integer.                | 4<br>RST4                      | 3<br>RST3                     | 2<br>RST2                   | 1<br>RST1         | 0<br>RST0     |
| <b>RESET</b><br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:<br>USAGE:                                                       | Addr<br>Rese<br>7<br>RST7<br>Eight<br>This                             | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6<br>: bit unsign<br>register is u                               | 0<br>5<br>RST5<br>ed integer.<br>sed as chip | 4<br>RST4<br>reset by wri      | 3<br>RST3                     | 2<br>RST2                   | 1<br>RST1         | 0<br>RSTO     |
| <b>RESET</b><br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:<br>USAGE:                                                       | Addr<br>Rese<br>7<br>RST7<br>Eight<br>This                             | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6<br>: bit unsign<br>register is u                               | 0<br>5<br>RST5<br>ed integer.<br>sed as chip | 4<br>RST4<br>reset by wri      | 3<br>RST3<br>ting 0x5a inf    | 2<br>RST2<br>to this regist | 1<br>RST1         | 0<br>RST0     |
| RESET<br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:<br>USAGE:<br>NOT_REV_ID                                                | Addr<br>Rese<br>7<br>RST7<br>Eight<br>This<br>Addr                     | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6<br>bit unsign<br>register is u<br>ess: 0x3f                    | 0<br>5<br>RST5<br>ed integer.<br>sed as chip | 4<br>RST4<br>reset by wri      | 3<br>RST3<br>ting 0x5a inf    | 2<br>RST2<br>to this regist | 1<br>RST1         | 0<br>RST0     |
| RESET<br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:<br>USAGE:<br>NOT_REV_ID<br>Inverted Revision ID                        | Addr<br>Rese<br>7<br>RST7<br>Eight<br>This<br>Addr<br>9 Register       | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6<br>: bit unsign<br>register is u<br>ess: 0x3f                  | 0<br>5<br>RST5<br>ed integer.<br>sed as chip | 4<br>RST4<br>reset by wri      | 3<br>RST3<br>ting 0x5a int    | 2<br>RST2<br>to this regist | 1<br>RST1<br>ter. | 0<br>RST0     |
| RESET<br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:<br>USAGE:<br>NOT_REV_ID<br>Inverted Revision ID<br>Access: Read        | Addr<br>Rese<br>7<br>RST7<br>Eight<br>This<br>Addr<br>Register<br>Rese | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6<br>: bit unsign<br>register is u<br>ess: 0x3f<br>t Value: 0xfe | 0<br>5<br>RST5<br>ed integer.<br>sed as chip | 4<br>RST4<br>reset by wri      | 3<br>RST3<br>ting 0x5a inf    | 2<br>RST2<br>to this regist | 1<br>RST1         | 0<br>RSTO     |
| RESET<br>Reset Register<br>Access: Write<br>Bit<br>Field<br>Data Type:<br>USAGE:<br>NOT_REV_ID<br>Inverted Revision ID<br>Access: Read<br>Bit | Addr<br>Rese<br>7<br>RST7<br>Eight<br>This<br>PRegister<br>Rese<br>7   | ess: 0x3a<br>t Value: 0x0<br>6<br>RST6<br>bit unsign<br>register is u<br>ess: 0x3f<br>t Value: 0xfe   | 0<br>5<br>RST5<br>ed integer.<br>sed as chip | 4<br>RST4<br>reset by wri      | 3<br>RST3<br>ting 0x5a inf    | 2<br>RST2<br>to this regist | 1<br>RST1<br>ter. | 0<br>RST0     |

USAGE:

This register contains the inverse of the revision ID which is located at register 0x01.

| LED_CTR   | L             | Addre                                                                                                                       | ess: 0x40                                                                                                                                                                                              |                                                                                                                                                                          |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LED Con   | trol Register | r                                                                                                                           |                                                                                                                                                                                                        |                                                                                                                                                                          |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
| Access: F | Read/Write    | Reset                                                                                                                       | Value: 0x00                                                                                                                                                                                            |                                                                                                                                                                          |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | Bit           | 7                                                                                                                           | 6                                                                                                                                                                                                      | 5                                                                                                                                                                        | 4                                                                                                                                                                             | 3                                                                                                                                                                        | 2                                                                                                                                                                                 | 1                                                                                                                                                                                  | 0                                                                                                                                                                                       |
|           | Field         | RSVD                                                                                                                        | RSVD                                                                                                                                                                                                   | RSVD                                                                                                                                                                     | RSVD                                                                                                                                                                          | LCOF                                                                                                                                                                     | RSVD                                                                                                                                                                              | LSEL1                                                                                                                                                                              | LSELO                                                                                                                                                                                   |
| Data Tvr  | )e·           | Fight                                                                                                                       | hit unsigne                                                                                                                                                                                            | d integer                                                                                                                                                                | 1                                                                                                                                                                             |                                                                                                                                                                          |                                                                                                                                                                                   | 1                                                                                                                                                                                  | I                                                                                                                                                                                       |
| USAGE.    |               | This re                                                                                                                     | eaister is us                                                                                                                                                                                          | ed to contr                                                                                                                                                              | ol the I FD o                                                                                                                                                                 | perating m                                                                                                                                                               | ode and curi                                                                                                                                                                      | rent to optin                                                                                                                                                                      | nize/minimiz                                                                                                                                                                            |
|           |               | powe                                                                                                                        | r consumpt                                                                                                                                                                                             | ion.                                                                                                                                                                     |                                                                                                                                                                               | percentgrin                                                                                                                                                              |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | Bit           | Field Name                                                                                                                  | Des                                                                                                                                                                                                    | cription                                                                                                                                                                 |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 7:4           | RSVD                                                                                                                        | Res                                                                                                                                                                                                    | erved                                                                                                                                                                    |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 3             | LCOF                                                                                                                        | <b>0:N</b><br>1:L                                                                                                                                                                                      | <b>ormal opera</b><br>ED Continu                                                                                                                                         | <b>tion (default)</b><br>ous Off                                                                                                                                              |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 2             | RSVD                                                                                                                        | Res                                                                                                                                                                                                    | erved                                                                                                                                                                    |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 1:0           | LSEL[1:0]                                                                                                                   | <b>0x0</b><br>0x1<br>0x2<br>0x3                                                                                                                                                                        | LED Current<br>LED Currer<br>LED Currer<br>LED Currer                                                                                                                    | set to 20mA (continued and set to 15mA)<br>at set to 36mA<br>at set to 30mA                                                                                                   | lefault)                                                                                                                                                                 |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
| NOTE:     |               | If LED<br>0x43<br>currer<br>is dete                                                                                         | ) is operatin<br>is cleared, L<br>nt switching<br>ermined by                                                                                                                                           | ng in AUT(<br>ED current<br>is disabled<br>LED_CONT                                                                                                                      | D current sv<br>t setting (LE<br>d through se<br>TROL [1:0]                                                                                                                   | vitching mc<br>D_CONTRO<br>etting AUTO                                                                                                                                   | ode (AUTO_I<br>L [1:0]) will<br>_LED_CONT                                                                                                                                         | LED_CONTR<br>be ignored.<br>ROL [0], the                                                                                                                                           | OL [0] at add<br>Only when A<br>LED drive cu                                                                                                                                            |
| MOTION    | CTRL          | Addre                                                                                                                       | ess: 0x41                                                                                                                                                                                              |                                                                                                                                                                          |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
| Motion (  | Control Regi  | ster                                                                                                                        |                                                                                                                                                                                                        |                                                                                                                                                                          |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
| Access: F | Read/Write    | Reset                                                                                                                       | Value: 0x40                                                                                                                                                                                            |                                                                                                                                                                          |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | Bit           | 7                                                                                                                           | 6                                                                                                                                                                                                      | 5                                                                                                                                                                        | 4                                                                                                                                                                             | 3                                                                                                                                                                        | 2                                                                                                                                                                                 | 1                                                                                                                                                                                  | 0                                                                                                                                                                                       |
|           | Field         | MOT_A                                                                                                                       | MOT_S                                                                                                                                                                                                  | RSVD                                                                                                                                                                     | RSVD                                                                                                                                                                          | RSVD                                                                                                                                                                     | RSVD                                                                                                                                                                              | RSVD                                                                                                                                                                               | RSVD                                                                                                                                                                                    |
| Data Tvr  | <u>م</u> .    | Fight                                                                                                                       | hit unsigne                                                                                                                                                                                            | d integer                                                                                                                                                                |                                                                                                                                                                               |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
| USAGE:    |               | This re<br>MOTIO<br>the M<br>data i<br>regist<br>has b<br>high k<br>If MO<br>rising<br>be sen<br>its sle<br>regist<br>for m | egister is us<br>ON pin is lev<br>OTION pin 's<br>in DELTA_X<br>er, DELTA_X<br>een read, D<br>by the senso<br>T_S is set, th<br>edge triggent<br>out throu<br>ep mode to<br>er, DELTA_X<br>pre informa | ed to set t<br>el-sensitive<br>will be driv<br>and DELT,<br>register, a<br>ELTA_X an<br>or.<br>Me MOTION<br>ered. When<br>red. When<br>read motio<br>register, a<br>tion | he feature of<br>e. With active<br>ren low whe<br>A_Y register<br>and then DE<br>d DELTA_Y<br>I pin is edge<br>rever there is<br>n. This pulse<br>on data from<br>nd then DEl | of MOTION i<br>e low (MOT_<br>n there is m<br>s. The mou<br>LTA_Y regist<br>registers wil<br>sensitive. If<br>s motion de<br>can be used<br>n the sensor.<br>TA_Y regist | nterrupt out<br>A bit is clear<br>otion detect<br>se microcor<br>ter sequenti<br>Il be zero, th<br>MOT_A is al<br>tected by th<br>I to trigger c<br>. The control<br>er sequentia | tput. If MOT<br>level-sensit<br>ted indicatir<br>ntroller can<br>ally. After al<br>ne MOTION<br>so set, it me<br>e sensor, a p<br>or wake the c<br>ler can then<br>ally. (Refer to | _S bit is clear<br>ive configura<br>ig there is mo<br>read MOTIOI<br>I the motion<br>pin will be dr<br>ans active hig<br>oulse (~230us<br>controller up<br>read MOTIOI<br>o Motion Fund |
|           | Rit           | Field N:                                                                                                                    |                                                                                                                                                                                                        | δος                                                                                                                                                                      | crintion                                                                                                                                                                      |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 7             | MOT_A                                                                                                                       |                                                                                                                                                                                                        | MO                                                                                                                                                                       | TION Active                                                                                                                                                                   |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           |               |                                                                                                                             |                                                                                                                                                                                                        | <b>0:L</b><br>1:H                                                                                                                                                        | <b>OW (default)</b><br>HIGH                                                                                                                                                   |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 6             | MOT_S                                                                                                                       |                                                                                                                                                                                                        | MO<br>0 : L                                                                                                                                                              | TION Sensitiv<br>evel sensitive                                                                                                                                               | ity                                                                                                                                                                      |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           |               |                                                                                                                             |                                                                                                                                                                                                        | 1:E                                                                                                                                                                      | dge sensitive (                                                                                                                                                               | default)                                                                                                                                                                 |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |
|           | 2:0           | RSVD                                                                                                                        |                                                                                                                                                                                                        | Kes                                                                                                                                                                      | erveu                                                                                                                                                                         |                                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                    |                                                                                                                                                                                         |

# BURST\_READ\_FIRST Address: 0x42

| Burst Read Starting  | Address Reg                                                | gister                                                                                                      |                                                                                                       |                                                                                            |                                                                                               |                                                                                |                                                                           |                                                                           |
|----------------------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| Access: Read/Write   | Reset                                                      | Value: 0x03                                                                                                 |                                                                                                       |                                                                                            |                                                                                               |                                                                                |                                                                           |                                                                           |
| Bit                  | 7                                                          | 6                                                                                                           | 5                                                                                                     | 4                                                                                          | 3                                                                                             | 2                                                                              | 1                                                                         | 0                                                                         |
| Field                | BM7                                                        | BM6                                                                                                         | BM5                                                                                                   | BM4                                                                                        | BM3                                                                                           | BM2                                                                            | BM1                                                                       | BMO                                                                       |
| Data Type:<br>USAGE: | Eight<br>This r<br>more<br>Note:<br>low, s<br>0x63<br>each | bit unsigned<br>egister provi<br>information<br>To change t<br>et the BURS<br>for burst read<br>time when p | d integer<br>ides the stat<br>, refer to Bu<br>he burst mo<br>T_READ_FI<br>ds, and tern<br>performing | rting registe<br>Irst Mode C<br>ode starting<br>RST registe<br>ninate the b<br>burst reads | er address the<br>peration.<br>address fror<br>r with the bu<br>urst reads by<br>with address | e sensor will<br>n default (Df<br>irst mode sta<br>pulling NCS<br>s other than | read during<br>ELTA_X or 0x0<br>arting addres<br>high. This m<br>default. | Burst Mode. Fo<br>03) pull the NCS<br>ss, read registe<br>ust be repeated |

| AUTO_LED_CTRL | Address: 0x43 |  |
|---------------|---------------|--|
|---------------|---------------|--|

AUTO LED Control Access: Read/Write

Reset Value: 0x08

| Bit   | 7    | 6    | 5    | 4    | 3          | 2          | 1      | 0         |
|-------|------|------|------|------|------------|------------|--------|-----------|
| Field | RSVD | RSVD | RSVD | RSVD | LED_HI [1] | LED_HI [0] | LED_LO | A_LED_DIS |

Data Type:

USAGE:

### Eight bit unsigned integer

This register enables AUTO LED current switching. This is a 'smart' LED feature whereby the LED current is self adjusting between the low and high current settings (bit 3:1) according to the brightness of the tracking surface if this feature is enabled (via clearing bit 0). The brighter the surface, the lower the LED current will be. If A\_LED\_DIS (bit 0) is set, this means AUTO LED mode is disabled, then the LED current is determined by LSEL[1:0] setting in LED\_CTRL register (0x40).

| Bit | Field Name   | Description                                                                                                                                                                                    |
|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | RSVD         | Reserved                                                                                                                                                                                       |
| 3:2 | LED_HI [1:0] | AUTO LED High Current<br>0x0: Auto LED high current is 15mA<br>0x1: Auto LED high current is 20mA<br><b>0x2: Auto LED high current is 30mA (default)</b><br>0x3: Auto LED high current is 36mA |
| 1   | LED_LO       | AUTO LED Low Current<br><b>0: Auto LED low current is 15mA (default)</b><br>1: Auto LED low current is 20mA                                                                                    |
| 0   | A_LED_DIS    | AUTO LED Disable<br><b>0: AUTO LED enabled (default)</b><br>1: AUTO LED disabled                                                                                                               |

Note: When AUTO LED is enabled, the AUTO LED current will be switched between low and high current setting determined by LED\_LO and LED\_HI [1:0]. If LED\_LO current setting is higher than the LED\_HI, the current will be based on the higher setting. For example if LED\_LO is 20mA and LED\_HI is 15mA, the AUTO LED current will be fixed at 20mA.

| REST_MODE_CONFIG     | Addr                          | ess: 0x45                     |              |              |            |      |      |      |
|----------------------|-------------------------------|-------------------------------|--------------|--------------|------------|------|------|------|
| Rest Mode Configura  | ation Regis                   | ter                           |              |              |            |      |      |      |
| Access: Read/Write   | Reset                         | t Value: 0x(                  | 00           |              |            |      |      |      |
| Bit                  | 7                             | 6                             | 5            | 4            | 3          | 2    | 1    | 0    |
| Field                | RM1                           | RM0                           | RSVD         | RSVD         | RSVD       | RSVD | RSVD | RSVD |
| Data Type:<br>USAGE: | : bit unsigr<br>register is u | ned integer<br>used to set th | ne operating | ) mode of th | e ADNS-400 | 00.  |      |      |

| Bit | Field Name | Description            |
|-----|------------|------------------------|
| 7:6 | RM[1:0]    | Sensor Operating Mode  |
|     |            | 0x00: Normal (default) |
|     |            | 0x01: Rest 1           |
|     |            | 0x02: Rest 2           |
|     |            | 0x03: Rest 3           |
| 5:0 | RSVD       | Reserved               |

Read operation to REST\_MODE\_CONFIG indicates which mode the sensor is in. Write operation into this register will force the sensor into rest modes (Rest 1, 2 or 3). Write the value 0x40 into 0x45 register to force sensor into Rest 1, 0x80 to Rest 2 or 0xC0 to Rest 3. To get out of any forced rest mode, write 0x00 into this register to set back to normal mode.

Note: Write 0x00 to register 0x22 during start up sensor initialization to enable configuration to this register.

| MOTION_BURST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | •      | Add               | lress: 0x63 |     |     |     |     |     |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|-------------|-----|-----|-----|-----|-----|-----|
| Burst Read Reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | gister |                   |             |     |     |     |     |     |     |
| Access: Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        | Reset Value: 0x00 |             |     |     |     |     |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit    | 7                 | 6           | 5   | 4   | 3   | 2   | 1   | 0   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Field  | MB7               | MB6         | MB5 | MB4 | MB3 | MB2 | MB1 | MBO |
| Data Type:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | Vari              | ous.        |     |     |     |     |     |     |
| JSAGE: This register is used to enable burst mode. Burst is initiated by a read of this register, whic<br>will then return continuous data starting from the address stored in BURST_READ FIRS<br>register through register 0x09. If burst operation is not terminated at this point, the intern-<br>address counter stops incrementing and register 0x09 value will be returned repeatedly. Burst<br>operation is terminated when NCS is asserted high. For more information, refer to Burst Moc |        |                   |             |     |     |     |     |     |     |

For product information and a complete list of distributors, please go to our web site: www.avagotech.com

Operation.

