

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

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

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



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China







#### **ADNS-2051**

# **Optical Mouse Sensor**



# **Data Sheet**





#### **Description**

The ADNS-2051 is a low cost optical sensor used to implement a non-mechanical tracking engine for computer mice.

It 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 sensor is housed in a 16-pin staggered dual inline package (DIP) that is designed for use with the HDNS-2100 Lens and HDNS-2200 Clip and HLMP-ED80-XX000 (639 nm LED illuminator source). There are no moving parts, and precision optical alignment is not required, facilitating high volume assembly.

The output format is two channel quadrature (X and Y direction) which emulates encoder photo-transistors. The current X and Y information are also available in registers accessed via a serial port.

Default resolution is specified as 400 counts per inch (cpi), with rates of motion up to 14 inches per second (ips).

Resolution can also be programmed to 800 cpi.

The part is programmed via a two wire serial port, through registers.

#### **Theory of Operation**

The ADNS-2051 is based on Optical Navigation Technology. It contains an Image Acquisition System (IAS), a Digital Signal Processor (DSP), a two-channel quadrature output, and a two wire serial port.

The IAS acquires microscopic surface images via the lens and illumination system provided by the HDNS-2100, 2200, and HLMP-ED80-XX000 LED. These images are processed by the DSP to determine the direction and distance of motion. The DSP generates the  $\Delta x$  and  $\Delta y$  relative displacement values that are converted into two channel quadrature signals.

#### **Features**

- Precise optical navigation technology
- No mechanical moving parts
- Complete 2D motion sensor
- Serial interface and/or quadrature interface
- Smooth surface navigation
- Programmable frame speed up to 2300 frames per sec (fps)
- Accurate motion up to 14 ips
- 800 cpi resolution
- High reliability
- High speed motion detector
- No precision optical alignment
- Wave solderable
- Single 5.0 volt power supply
- Shutdown pin for USB suspend mode operation
- Power conservation mode during times of no movement
- On chip LED drive with regulated current
- Serial port registers
  - Programming
  - Data transfer
- 16-pin staggered dual inline package (DIP)

#### **Applications**

- Mice for desktop PCs, workstations, and portable PCs
- Trackballs
- Integrated input devices

# Outline Drawing of ADNS-2051 Optical Mouse Sensor

#### Pinout

| Pin | Pin      | Description                    |
|-----|----------|--------------------------------|
| 1   | SCLK     | Serial port clock (input)      |
| 2   | XA       | XA quadrature output           |
| 3   | XB       | XB quadrature output           |
| 4   | YB       | YB quadrature output           |
| 5   | YA       | YA quadrature output           |
| 6   | XY_LED   | LED control                    |
| 7   | REFA     | Internal reference             |
| 8   | REFB     | Internal reference             |
| 9   | OSC_IN   | Oscillator input               |
| 10  | GND      | System ground                  |
| 11  | OSC_OUT  | Oscillator output              |
| 12  | GND      | System ground                  |
| 13  | $V_{DD}$ | 5.0 volt power supply          |
| 14  | R_BIN    | LED current bin resistor       |
| 15  | PD       | Power down pin, active high    |
| 16  | SDIO     | Serial data (input and output) |



Figure 1. Top view



#### Notes:

- 1. Dimensions in millimeters / inches.
- 2 Dimensional tolerance: ±0.1 mm.
- 3. Coplanarity of leads: 0.1 mm.
- 4. Lead pitch tolerance ± 0.15 mm.
- 5. Non-cummulative pitch tolerance: ± 0.15 mm.
- 6 Angular tolerance: ± 3.0°.
- 7. Maximum flash + 0.2 mm.
- 8. Chamfer (25°  $\times$  2) on the taper side of the lead.
- 9 () Bracket dimensions are for references only and should not be used to mechanically reference the sensor.

Figure 2. Package outline drawing

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

2D Assembly Drawing of ADNS-2051

Figures 3 and 4, shown with HDNS-2100, HDNS-2200, and HLMP-ED80-XX000.

Avago Technologies provides an IGES file drawing describing the base plate molding features for lens and PCB alignment.

The components interlock as they are mounted onto defined features on the base plate.

The ADNS-2051 sensor is designed for mounting on a through hole PCB, looking down. There is an aperture stop and features on the package that align to the lens (see Figure 3).

The HDNS-2100 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 lens also has a large round flange to provide a long creepage path for any ESD events that occur at the opening of the base plate (see Figure 4).

The HDNS-2200 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 clip interlocks the sensor to the lens, and through the lens to the alignment features on the base plate.

The HLMP-ED80-XX000 LED is recommended for illumination. If used with the bin table, sufficient illumination can be guaranteed.



**DIMENSIONS IN MILLIMETERS (INCHES)** 

Figure 3. Recommended PCB mechanical cutouts and spacing (top view)





DIMENSIONS IN MILLIMETERS (INCHES).

Figure 4. 2D assembly drawing of ADNS-2051 (top and side view)



Figure 5. Exploded view drawing

#### **PCB Assembly Considerations**

- Insert the sensor and all other electrical components into PCB.
- Bend the LED leads 90° and then insert the LED into the assembly clip until the snap feature locks the LED base.
- 3. Insert the LED/clip assembly into PCB.
- 4. 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. The fixture should be designed to expose the sensor leads to solder while shielding the optical aperture from direct solder contact. The solder fixture is also used to set the reference height of the sensor to the PCB top during wave soldering (Note: DO NOT remove the kapton tape during wave soldering).
- 5. Place the lens onto the base plate.

- 6. Remove the protective kapton tape from optical aperture of the sensor. Care must be taken to keep contaminants from entering the aperture. It is recommended not to place the PCB facing up during the entire mouse assembly process. The PCB should be held vertically during the kapton removal process.
- 7. 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.
- 8. 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.
- Install mouse top case. There MUST be a feature in the top case to press down onto the clip to ensure all components are interlocked to the correct vertical height.



Figure 6. Block diagram of ADNS-2051 optical mouse sensor

#### **Design Considerations for Improving ESD Performance**

The flange on the lens has been designed to increase the creepage and clearance distance for electrostatic discharge. The table on the right shows typical values assuming base plate construction per the Avago supplied IGES file and HDNS-2100 lens flange.

For improved ESD performance, the lens flange can be sealed (i.e. glued) to the base plate. Note that the lens material is polycarbonate and therefore, cyanoacrylate-based adhesives or other adhesives that may damage the lens should NOT be used.

The trimmed lens, HDNS-2100#001, is not recommended for corded applications due to the ESD spec requirement.

| Typical Distance | Millimeters |
|------------------|-------------|
| Creepage         | 16.0        |
| Clearance        | 2.1         |



Figure 7. PCB assembly

#### **Recommended Typical Application Using SDIO Pins**



Figure 8. Application using SDIO pins

#### **Notes on Bypass Capacitors:**

- Caps for pins 7, 8 and 12, 13 MUST have trace lengths LESS than 5 mm.
- The 0.1 μF caps must be ceramic.
- Caps should have less than 5 nH of self inductance
- Caps should have less than 0.2 Ω ESR

Surface mount parts are recommended.

SDIO and SCLK pins should be grounded if not used.

#### **Regulatory Requirements**

- Passes FCC B and worldwide analogous emission limits when assembled into a mouse with unshielded cable and following Avago recommendations.
- Passes EN61000-4-4/IEC801-4 EFT tests when assembled into a mouse with unshielded cable and following Avago recommendations.
- UL flammability level UL94 V-0.
- Provides sufficient ESD creepage/clearance distance to avoid discharge up to 15 kV when assembled into a mouse according to usage instructions above.
- For eye safety consideration, please refer to the technical report available on the web site,

http://www.Avago.com

• The 15.0  $k\Omega$  resistor is determined by the absolute maximum rating of 50 mA for the HLMP-ED80-XX000. The other resistor values for brighter bins will guarantee good signals with reduced power.

## **Alternative Application using Quadrature Output Pins**



Figure 9. Application using quadrature output pins

#### **Absolute Maximum Ratings**

| Parameter               | Symbol          | Min. | Max.                  | Units | Notes                                   |  |
|-------------------------|-----------------|------|-----------------------|-------|-----------------------------------------|--|
| Storage Temperature     | T <sub>S</sub>  | -40  | 85                    | °C    |                                         |  |
| Operating Temperature   | T <sub>A</sub>  | -15  | 55                    | °C    |                                         |  |
| Lead Solder Temperature |                 |      | 260                   | °C    | For 10 seconds, 1.6 mm below seating    |  |
|                         |                 |      |                       |       | plane.                                  |  |
| Supply Voltage          | $V_{DD}$        | -0.5 | 5.5                   | V     |                                         |  |
| ESD                     |                 |      | 2                     | kV    | All pins, human body model MIL 883      |  |
|                         |                 |      |                       |       | Method 3015                             |  |
| Input Voltage           | V <sub>IN</sub> | -0.5 | V <sub>DD</sub> + 0.5 | V     | PD, SDIO, SCLK, XA, XB, YA, YB, XY_LED, |  |
|                         |                 |      |                       | R_BIN |                                         |  |
| Input Voltage           | V <sub>IN</sub> | -0.5 | 3.6                   | V     | OSC_IN, OSC_OUT, REF_A                  |  |

# **Recommended Operating Conditions**

| Parameter                                        | Symbol               | Min.      | Typ. | Max.                | Units             | Notes                                                                                                                                                                                                                                     |
|--------------------------------------------------|----------------------|-----------|------|---------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operating Temperature                            | T <sub>A</sub>       | 0         |      | 40                  | °C                |                                                                                                                                                                                                                                           |
| Power Supply Voltage                             | $V_{DD}$             | 4.25      | 5.0  | 5.5                 | volts             | Register values retained for voltage transients below 4.25 V but greater than 4 V.                                                                                                                                                        |
| Power Supply Rise Time                           | V <sub>RT</sub>      |           |      | 100                 | ms                |                                                                                                                                                                                                                                           |
| Supply Noise                                     | V <sub>N</sub>       |           |      | 100                 | mV                | Peak to peak within<br>0-100 MHz.                                                                                                                                                                                                         |
| Clock Frequency                                  | f <sub>CLK</sub>     | 17.4      | 18.0 | 18.7                | MHz               | Set by ceramic resonator.                                                                                                                                                                                                                 |
| Serial Port Clock Frequency                      | SCLK                 |           |      | f <sub>CLK</sub> /4 | MHz               |                                                                                                                                                                                                                                           |
| Resonator Impendance                             | X <sub>RES</sub>     |           |      | 55                  | Ω                 |                                                                                                                                                                                                                                           |
| Distance from Lens Reference<br>Plane to Surface | Z                    | 2.3       | 2.4  | 2.5                 | mm                | Results in $\pm 0.2$ mm DOF.<br>(See Figure 10.)                                                                                                                                                                                          |
| Speed                                            | S                    | 0         |      | 14                  | in/sec            | @ frame rate = 1500/second.                                                                                                                                                                                                               |
| Acceleration                                     | Α                    |           |      | 0.15                | g                 | @ frame rate = 1500/second.                                                                                                                                                                                                               |
| Light Level onto IC                              | IRR <sub>INC</sub>   | 80<br>100 |      | 25,000<br>30,000    | mW/m <sup>2</sup> | $\lambda = 639 \text{ nm}$<br>$\lambda = 875 \text{ nm}$                                                                                                                                                                                  |
| SDIO Read Hold Time                              | t <sub>HOLD</sub>    | 100       |      |                     | μs                | Hold time for valid data.<br>(Refer to Figure 28.)                                                                                                                                                                                        |
| SDIO Serial Write-Write Time                     | t <sub>SWW</sub>     | 100       |      |                     | μs                | Time between two write commands. (Refer to Figure 31.)                                                                                                                                                                                    |
| SDIO Serial Write-Read Time                      | t <sub>SWR</sub>     | 100       |      |                     | μs                | Time between write and read operation. (Refer to Figure 32.)                                                                                                                                                                              |
| SDIO Serial Read-Write Time                      | t <sub>SRW</sub>     | 120       |      |                     | ns                | Time between read and write operation. (Refer to Figure 33.)                                                                                                                                                                              |
| SDIO Serial Read-Read Time                       | t <sub>SRR</sub>     | 120       |      |                     | ns                | Time between two read commands. (Refer to Figure 33.)                                                                                                                                                                                     |
| Data Delay after PD ↓                            | <sup>†</sup> СОМРИТЕ | 3.2       |      |                     | ms                | After t <sub>COMPUTE</sub> , all registers contain data from first image after PD↓. Note that an additional 75 frames for AGC (shutter) stabilization may be required if mouse movement occurred while PD was high. (Refer to Figure 12.) |
| SDIO Write Setup Time                            | t <sub>SETUP</sub>   | 60        |      |                     | ns                | Data valid time before the rising of SCLK. (Refer to Figure 26.)                                                                                                                                                                          |
| PD Pulse Width<br>(to power down the chip)       | t <sub>PDW</sub>     | 700       |      |                     | μs                | Pulse width to initiate the power<br>down cycle @ 1500 fps. (Refer<br>to Figure 12 and Figure 14.)                                                                                                                                        |
| PD Pulse Width<br>(to reset the serial port)     | t <sub>PDR</sub>     | 100       |      |                     | μs                | Pulse width to reset the serial port @ 1500 fps (but may also initiate a power down cycle.  Normal PD recovery sequence to be followed. (Refer to Figure 15.)                                                                             |
| Frame Rate                                       | FR                   |           | 1500 |                     | frames/s          | See Frame_Period register section.                                                                                                                                                                                                        |
| Bin Resistor                                     | R1                   | 15 K      | 15 K | 37 K                | Ω                 | Refer to Figure 8.                                                                                                                                                                                                                        |
|                                                  |                      |           | •    |                     |                   |                                                                                                                                                                                                                                           |



Figure 10. Distance from lens reference plane to surface

# **AC Electrical Specifications**

Electrical Characteristics over recommended operating conditions. Typical values at  $25^{\circ}$ C,  $V_{DD} = 5.0$  V, 1500 fps, 18 MHz.

| Parameter                                       |  | Symbol            | Min. | Тур. | Max. | Units | Notes                                                                                                                                               |
|-------------------------------------------------|--|-------------------|------|------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Power Down                                      |  | t <sub>PD</sub>   |      | 700  |      | μs    | From PD ↑<br>Time uncertainty due to firm-<br>ware delay. (Refer to Figure 12.)                                                                     |
| Power Up from PD ↓                              |  | t <sub>PUPD</sub> |      |      | 50   | ms    | From PD↓to valid quad signals<br>705 µsec + 75 frames. (Refer to<br>Figure 12.)                                                                     |
| Power Up from V <sub>DD</sub> ↑                 |  | t <sub>PU</sub>   |      |      | 30   | ms    | From V <sub>DD</sub> ↑to valid quad<br>signals<br>705 µsec + 40 frames                                                                              |
| Rise and Fall Times: SDIO  XA, XB, YA, YB  ILED |  | t <sub>r</sub>    |      | 30   |      | ns    | C <sub>L</sub> = 30 pF (the rise time is between 10% and 90%)                                                                                       |
|                                                 |  | t <sub>f</sub>    |      | 16   |      | ns    | $C_L = 30 \text{ pF}$ (the fall time is between 10% and 90%)                                                                                        |
|                                                 |  | t <sub>r</sub>    |      | 50   |      | ns    | C <sub>L</sub> = 30 pF (the rise time is between 10% and 90%)                                                                                       |
|                                                 |  | t <sub>f</sub>    |      | 20   |      | ns    | $C_L = 30 \text{ pF}$ (the fall time is between 10% and 90%)                                                                                        |
|                                                 |  | t <sub>r</sub>    |      | 40   |      | ns    | With HLMP-ED80-XX000 LED (the rise time is between 10% and 90%)                                                                                     |
|                                                 |  | t <sub>f</sub>    |      | 200  |      | ns    | With HLMP-ED80-XX000 LED (the fall time is between 10% and 90%)                                                                                     |
| Serial Port Transaction Timer                   |  | t <sub>SPTT</sub> | 0.7  | 0.9  | 1.0  | S     | Serial port will reset if current transaction is not complete within t <sub>SPTT</sub> . (Refer to Figure 36.)                                      |
| Transient Supply Current                        |  | I <sub>DDT</sub>  |      | 20   | 37   | mA    | Max. supply current during a V <sub>DD</sub> ramp from 0 to 5.0 V with > 500 µs rise time. Does not include charging current for bypass capacitors. |

**DC Electrical Specifications** Electrical Characteristics over recommended operating conditions. Typical values at  $25\,^{\circ}$ C,  $V_{DD} = 5.0\,\text{V}$ ,  $18\,\text{MHz}$ .

| Parameter                                                   | Symbol               | Min.                                                          | Тур.   | Max.      | Units | Notes                                                                  |
|-------------------------------------------------------------|----------------------|---------------------------------------------------------------|--------|-----------|-------|------------------------------------------------------------------------|
| DC Supply Current<br>(mouse moving)                         | I <sub>DD</sub> avg  |                                                               | 15     | 25        | mA    | No load on XA, XB, YA, YB,<br>SCLK, SDIO. Excluding LED<br>current.    |
| Peak Supply Current<br>(mouse moving)                       | I <sub>DD</sub> PEAK |                                                               | 20     |           | mA    | No load on XA, XB, YA, YB, SCLK, SDIO. Excluding LED current.          |
| C Supply Current I <sub>DD</sub> 12 25 mA nouse not moving) |                      | No load on XA, XB, YA, YB, SCLK, SDIO. Excluding LED current. |        |           |       |                                                                        |
| DC Supply Current<br>(power down)                           | I <sub>DDPD</sub>    |                                                               | 170    | 240       | μА    | PD = high; SCLK, SDIO = GND or $V_{DD}$ ; $V_{DD}$ = 4.25 V to 5.25 V. |
| SCLK, SDIO, PD                                              |                      |                                                               |        |           |       |                                                                        |
| Input Low Voltage                                           | V <sub>IL</sub>      |                                                               |        | 0.8       | V     |                                                                        |
| Input High Voltage                                          | V <sub>IH</sub>      | 0.5 * V <sub>DD</sub>                                         |        |           | V     |                                                                        |
| Output Low Voltage                                          | V <sub>OL</sub>      |                                                               |        | 0.7       | V     | @ I <sub>OL</sub> = 2 mA (SDIO only)                                   |
| Output High Voltage                                         | V <sub>OH</sub>      | 0.6 * V <sub>DD</sub>                                         |        |           | V     | @ I <sub>OH</sub> = 2 mA (SDIO only)                                   |
| Output Low Voltage<br>(XA, XB, YA, YB)                      | V <sub>OL</sub>      |                                                               |        | 0.4       | V     | @ I <sub>OL</sub> = 0.5 mA.                                            |
| Output High Voltage<br>(XA, XB, YA, YB)                     | $V_{OH}$             | 0.6 * V <sub>DD</sub>                                         |        |           | V     | $@ I_{OH} = 0.5 \text{ mA}.$                                           |
| Output Low Voltage<br>(XY_LED)                              | V <sub>OL</sub>      |                                                               |        | 1.1       | V     | Refer to Figure 11.                                                    |
| XY LED Current                                              | I <sub>LED</sub>     | Typ-15%                                                       | 630/R1 | Typ + 15% | A     | Refer to Figure 11, see table below.                                   |
| XY LED Current<br>(fault mode)                              | I <sub>LED</sub>     |                                                               |        | 500       | μΑ    | R1 < 200 Ω.                                                            |
| REF_A (normal mode)                                         | V <sub>REFA</sub>    |                                                               | 3.3    |           | V     | 1.5 K $\Omega$ to 3.0 V or GND, PD = low.                              |
| REF_A (power down mode)                                     | V <sub>REFA</sub>    |                                                               | 3.3    |           | V     | 1.5 K $\Omega$ to 3.0 V or GND, PD = high.                             |



Figure 11. Typical I-V characteristic of ADNS-2051 XY\_LED pin

# **Typical LED Current Table**

| R1 Value              | kΩ | 15 | 18 | 22 | 27 | 33 | 37 |
|-----------------------|----|----|----|----|----|----|----|
| LED current (typical) | mA | 42 | 35 | 29 | 23 | 19 | 17 |

#### **PD Pin Timing**



Figure 12. PD timing normal mode



PD

t<sub>PDW</sub>

700 μs

(POWER DOWN)

Figure 13. PD timing sleep mode

Figure 14. PD minimum pulse width



Figure 15. Detail of PD falling edge timing

#### **Quadrature Mode Timing**

The output waveforms emulate the output from encoders. With the resolution set to 400 cpi, from one to five quadrature states can exist within one frame time. The minimum state time is 133  $\mu$ s. If the resolution is 800 cpi, then up to ten quadrature states can exist within a frame time. If the motion within a frame is greater than these values, the extra motion will be reported in the

next frame. The following diagrams (see Figures 16, 17, and 18) show the timing for positive X motion, to the right or positive Y motion, up. If a power down via the PD pin occurs during a transfer, the transfer will resume after PD is de-asserted. The timing for that quadrature state will be increased by the length of the PD time.



Figure 16. Quadrature states per frame (400 cpi mode)



Figure 17. Quadrature states per frame (800 cp imode)



Figure 18. Quadrature states per frame (800 cpi mode)

#### **Quadrature State Machine**

The following state machine shows the states of the quadrature pins. The two things to note are that while the PD pin is asserted, the state machine is halted. Once PD is de-asserted, the state machine picks up from where it left off. State 0 is entered after a power up reset.



Figure 19. Quadrature state machine

### **Quadrature Output Waveform**

The two channel quadrature outputs are 5.0 volt CMOS outputs. The  $\Delta x$  count is used to generate the XA and XB signals, and  $\Delta y$  count is used for the YA and YB signals.



Figure 20. Quadrature output waveform

#### **Typical Performance Characteristics**

Performance characteristics over recommended operating conditions. Typical values at 25°C, V<sub>DD</sub> = 5.0 V, 18 MHz.

| Parameter              | Symbol             | Min. | Тур. | Max. | Units | Notes                                        |
|------------------------|--------------------|------|------|------|-------|----------------------------------------------|
| Path Error (Deviation) | P <sub>ERROR</sub> |      | 0.5  |      | %     | Path Error (Deviation) is the error from the |
|                        |                    |      |      |      |       | ideal cursor path. It is expressed as a      |
|                        |                    |      |      |      |       | percentage of total travel and is measured   |
|                        |                    |      |      |      |       | over standard surfaces.                      |

The following graphs (Figures 21, 22, 23, and 24) are the typical performance of the ADNS-2051 sensor, assembled as shown in the 2D assembly drawing with the HDNS-2100 Lens/Prism, the HDNS-2200 clip, and the HLMP-ED80-XX000 LED (page 3, Figure 4).



Figure 21. Typical resolution vs. Z (comparative surfaces)  $^{\left[2,3\right]}$ 



Figure 23. Typical resolution vs. z (manila folder and LED variation)<sup>[2,3]</sup>



Figure 22. Wavelength responsitivity<sup>[1]</sup>



Figure 24. Typical resolution vs. z (black copy and LED variation)<sup>[2,3]</sup>

#### Nota:

- 1. The ADNS-2051 is designed for optimal performance when used with the HLMP-ED80-XX000 (red LED 639 nm). For use with other LED colors (i.e., blue, green), please consult factory. When using alternate LEDs, there may also be performance degradation and additional eye safety considerations.
- 2. Z = Distance from Lens Reference plane to Surface.
- 3. DOF = Depth of Field.

#### **Synchronous Serial Port**

The synchronous serial port is used to set and read parameters in the ADNS-2051, and can be used to read out the motion information instead of the quadrature data pins.

The port is a two wire, half duplex port. The host microcontroller always initiates communication; the ADNS-2051 never initiates data transfers.

SCLK: The serial port clock. It is always generated by the master (the micro-controller).

SDIO: The data line.

PD: A third line is sometimes involved. PD (Power Down) is usually used to place the ADNS-2051 in a low power mode to meet USB suspend specification. PD can also be used to force resynchronization between the micro-controller and the ADNS-2051 in case of an error.

#### **Write Operation**

Write operations, where data is going from the micro-controller to the ADNS-2051, 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 data direction. The second byte contains the data. The transfer is synchronized by SCLK. The micro-controller changes SDIO on falling edges of SCLK. The ADNS-2051 reads SDIO on rising edges of SCLK.



Figure 25. Write operation



Figure 26. SDIO setup and hold times SCLK pulse width

#### **Read Operation**

A read operation, which means that data is going from the ADNS-2051 to the micro-controller, is always initiated by the micro-controller and consists of two bytes. The first byte contains the address, is written by the micro-controller, and has a "0" as its MSB to indicate data direction. The second byte contains the data and is driven by the ADNS-2051. The transfer is synchronized by SCLK. SDIO is changed on falling edges of SCLK and read on every rising

edge of SCLK. The micro-controller must go to a high Z state after the last address data bit. The ADNS-2051 will go to the high Z state after the last data bit (see detail "B" in Figure 28). One other thing to note during a read operation is that SCLK will need to be delayed after the last address data bit to ensure that the ADNS-2051 has at least  $100 \mu s$  to prepare the requested data. This is shown in the timing diagrams below.



Figure 27. Read operation



Figure 28. Microcontroller to ADNS-2051 SDIO handoff



Figure 29. ADNS-2051 to microcontroller SDIO handoff

#### Note:

The 120 ns high state of SCLK is the minimum data hold time of the ADNS-2051. Since the falling edge of SCLK is actually the start of the next read or write command, the ADNS-2051 will hold the state of  $D_0$  on the SDIO line until the falling edge of SCLK. In both write and read operations, SCLK is driven by the micro-controller.

Serial port communications is not allowed while PD (power down) is high. See "Error Detection and Recovery" regarding resynchronizing via PD.

#### Forcing the SDIO Line to the Hi-Z State

There are times when the SDIO line from the ADNS-2051 should be in the Hi-Z state. If the microprocessor has completed a write to the ADNS-2051, the SDIO line is Hi-Z, since the SDIO pin is still configured as an input. However, if the last operation from the microprocessor was a read, the ADNS-2051 will hold the D0 state on SDIO until a falling edge of SCLK.

To place the SDIO pin into the Hi-Z state, raise the PD pin for 100  $\mu$ s (min). The PD pin can stay high, with the ADNS-2051 in the shutdown state, or the PD pin can be lowered, returning the ADNS-2051 to normal operation. The SDIO line will now be in the Hi-Z state.



Figure 30. SDIO Hi-Z state and timing

# Required Timing between Read and Write Commands (tsxx)

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

If the rising edge of the SCLK for the last data bit of the second write command occurs before the 100 microsecond required delay, then the first write command may not complete correctly.



Figure 31. Timing between two write commands

If the rising edge of SCLK for the last address bit of the read command occurs before the 100 microsecond required delay, then the write command may not complete correctly.



Figure 32. Timing between write and read commands

The falling edge of SCLK for the first address bit of either the read or write command must be at least 120 ns after the last SCLK rising edge of the last data bit of the previous read operation.



Figure 33. Timing between read and either write or subsequent read commands



Figure 34. Timing between SCLK and PD rising edge

#### **Error Detection and Recovery**

- 1. The ADNS-2051 and the micro-controller might get out of synchronization due to ESD events, power supply droops or micro-controller firmware flaws. In such a case, the micro-controller should raise PD for 100  $\mu$ s. The ADNS-2051 will reset the serial port but will not reset the registers and be prepared for the beginning of a new transmission.
- The ADNS-2051 has a transaction timer for the serial port. If the sixteenth SCLK rising edge is spaced more than approximately 0.9 seconds from the first SCLK edge of the current transaction, the serial port will reset.

#### Invalid addresses:

Writing to an invalid address will have no effect.
 Reading from an invalid address will return all zeros.

#### Collision detection on SDIO

The only time that the ADNS-2051 drives the SDIO line is during a READ operation. To avoid data collisions, the micro-controller should relinquish SDIO before the falling edge of SCLK after the last address bit. The ADNS-2051 begins to drive SDIO after the next rising edge of SCLK. The ADNS-2051 relinquishes SDIO within 120 ns of the falling SCLK edge after the last data bit. The micro-controller can begin driving SDIO any time afterthat. In order to maintain low power consumption in nor mal operation or when the PD pin is pulled high, the micro-controller should not leave SDIO floating un til the next transmission (although that will not cause any communication difficulties).

- In case of synchronization failure, both the ADNS-2051 and the micro-controller may drive SDIO. The ADNS-2051 can withstand 30 mA of short circuit current and will withstand infinite duration short circuit conditions.
- 6. Termination of a transmission by the micro-controller may sometimes be required (for example, due to a USB suspend interrupt during a read operation). To accomplish this the micro-controller should raise PD. The ADNS-2051 will not write to any register and will reset the serial port (but nothing else) and be prepared for the beginning of future transmissions after PD goes low.
- 7. The micro-controller can verify success of write operations by issuing a read command to the same address and comparing written data to read data.
- 8. The micro-controller can verify the synchronization of the serial port by periodically reading the product ID register.



Figure 35. Power up serial port watchdog timer sequence

#### Notes on Power up and the Serial Port

The sequence in which  $V_{DD}$ , PD, SCLK, and SDIO are set during powerup can affect the operation of the serial port. The diagram below shows what can happen shortly after powerup when the microprocessor tries to read data from the serial port.

This diagram shows the  $V_{DD}$  rising to valid levels, at some point the microcontroller starts its program, sets the SCLK and SDIO lines to be outputs, and sets them high. It then waits to ensure that the ADNS-2051 has powered up and is ready to communicate. The microprocessor then tries to read from location 0x00, Product\_ID, and is expecting a value of 0x02. If it receives this value, it then knows that the communication to the ADNS-2051 is operational.

The problem occurs if the ADNS-2051 powers up before the microprocessor sets the SCLK and SDIO lines to be outputs and high. The ADNS-2051 sees the raising of the SCLK as a valid rising edge, and clocks in the state of the SDIO as the first bit of the address (sets either a read or a write depending upon the state).

In the case of SDIO low, then a read operation has started. When the microprocessor begins to actually send the address, the ADNS-2051 already has the first bit of an address. When the seventh bit is sent by the micro, the ADNS-2051 has a valid address, and drives the SDIO line high within 120 ns (see detail "A" in Figure 27 and Figure 28). This results in a bus fight for SDIO. Since the address is wrong, the data sent back will be incorrect.

In the case of SDIO high, a write operation is started. The address and data are out of synchronization, and the wrong data will be written to the wrong address.



Figure 36. Power up serial port watchdog timer sequence



Figure 37. Power up serial port PD sync sequence

#### **Two Solutions**

There are two different ways to solve the problem, waiting for the serial port watchdog timer to time out, or using the PD line to reset the serial port.

#### 1. Serial Port Watchdog Timer Timeout

If the microprocessor waits at least  $t_{SPTT}$  from  $V_{DD}$  valid, it will ensure that the ADNS-2051 has powered up and the watchdog timer has timed out. This assumes that the microprocessor and the ADNS-2051 share the same power supply. If not, then the microprocessor must wait  $t_{SPTT}$  from ADNS-2051  $V_{DD}$  valid. Then when the SCLK toggles for the address, the ADNS-2051 will be in sync with the microprocessor.

#### 2. PD Sync

The PD line can be used to resync the serial port. If the microprocessor waits for 4 ms from  $V_{DD}$  valid, and then outputs a valid PD pulse (see Figure 15), then the serial port will be ready for data.

#### **Resync Note**

If the microprocessor and the ADNS-2051 get out of sync, then the data either written or read from the registers will be incorrect. An easy way to solve this is to output a PD pulse to resync the parts after an incorrect read.

#### SPI communication code for the Cypress CY7C63000 or CY7C63001

(Please consult factory for the CY7C63722 or CY7C63723 codes.)

**Note:** This programming sequence is not covered in Avago's product warranty. It is only a recommended example when using the mentioned Cypress microcontrollers. For the latest updates on Cypress microcontrollers, please contact Cypress at email: usbapps@cypress.com or call (858) 613-7929 (US).

The following code can be used to implement the SPI data communications. See the schematic in Figure 9.

```
Notes:
   CY7C63001 20pin package
   ADNS-2051
   SDIO line connected to pin5 (P1.0)
  PD connected to pin 16 (P1.1)
   SCLK line connected to pin15 (P1.3)
   I/O port
Port1_Data:
                             01h
                                                      GPIO data port 1
                      equ
Port1 Interrupt:
                                                      Interrupt enable for port 1
                      equ
                             05h
Port1_Pullup:
                                                      Pullup resistor control for port 1
                      equ
                            09h
   Port bit definitions
SDIO:
                            01h
                                                   ; bit 0
PD:
                            02h
                                                      bit 1
                      equ
SCLK:
                             08h
                                                      bit 3
                      equ
Pt1 Current:
                      equ
                             00h
                                                   ; port1 current setting
   GPIO Isink registers
Port1_Isink:
                             38h
                      equ
Port1 Isink0:
                             38h
                      equ
Port1 Isink1:
                             39h
                      equ
Port1_Isink3:
                      equ
                             3Bh
   data memory variables
                             40h
                                                      address of spi writes
spi addr:
                      equ
spi_data:
                             41h
                                                      data of spi writes
                      equ
bit counter:
                      equ
                             44h
                                                      SPI bit counter
                                                      what we wrote last
port1 wrote:
                      equ 45h
   initialize Port 1
                             mov A, Pt1_Current ; select DAC setting
                                                  ; isink current Port 1 bit[0]
                      iowr Port1_Isink0
                      iowr Port1_Isink1
                                                      isink current Port 1 bit[1]
                      iowr Port1_Isink3
                                                      isink current Port 1 bit[3]
                      mov A, 0h
                                                      enable Port 1 bit [7:0] pullups
                      iowr Port1_Pullup
                      mov A, ~(PD|SDIO)
                                                    ; turn on the ADNS-2051
                      mov [port1_wrote], A
                      mov A, [port1_wrote]
                      iowr Port1 Data
                                                    ; PD low, SCLK, SDIO
                       mov A, 0
                      iowr Port1_Interrupt
                                                   ; disable port 1 interrupts
   There are possible problems with the SPI port if the microcontroller starts executing
   instructionsbefore the ADNS-2051 sensor has powered up. See page 18 for details.
   It is assumed that power to the microcontroller is OK if the next instructions can be executed.
   These instructions will reset the SPI port of the sensor.
```

Resync sensor: mov A,~(SCLK|SDIO|PD) ; set the SCLK, SDIO and PD lines low and [port1\_wrote], A mov A, [port1\_wrote] iowr Port1 Data ; If the power to the sensor needs more time ; to stabilize, insert a delay here ; wait about 4 milliseconds for the sensor call delay700us call delay700us ; oscillator to stabilize call delay700us call delay700us call delay700us call delay700us mov A, (SCLK|SDIO|PD ; set the SCLK, SDIO and PD lines high or [port1 wrote], A ; this shuts down the oscillator and mov A, [port1\_wrote] ; resets the SPI port iowr Port1 Data call delay700us ; wait for the PD to reset the part mov A, ~PD set the PD line low to put the sensor and [port1\_wrote], A ; back into normal operation mov A, [port1\_wrote] iowr Port1\_Data call delay700us wait about 4 milliseconds for the sensor call delay700us oscillator to stabilize call delay700us call delay700us call delay700us call delay700us ; sensor SPI port now in sync ReadSPI routine Includes delays for long traces or cables between the uP and ADNS-2051 Has correct timing of SCLK and SDIO On entry: spi\_addr = Address of SPI register in the ADNS-2051 spi data = undefined spi\_addr = undefined On exit spi data = register contents from ADNS-2051 ReadSPI: mov A. 64 ; wait 200us (optional) mov [bit\_counter], A (about 3us per loop) Waitrspi: nop nop nop nop nop nop dec [bit\_counter] jnz Waitrspi read address mov A,~80h and [spi\_addr], A lower MSB of address (read) call writeaddr wait 200us (about 3us per loop)(100us minimum required) mov A,64 wait for data to be ready mov [bit\_counter], A Waitrspi2: nop nop nop nop nop nop dec [bit\_counter] jnz Waitrspi2 mov A, 0h ; clear the data