# **General Description**

The DS1841 is a 7-bit, logarithmic, nonvolatile (NV) digital resistor that features an on-chip temperature sensor and associated analog-to-digital converter (ADC). The integrated temperature sensor indexes a 72-byte NV lookup table (LUT) encompassing a temperature range from -40°C to +100°C. The LUT output can drive the resistor directly or be added to an NV initial-value register (IVR) to drive the resistor. This flexible LUT-based architecture allows the DS1841 to provide a temperature-compensated resistor output with arbitrary slope. Programming is accomplished by an I2C-compatible interface, which can operate at speeds of up to 400kHz.

## **Applications**

Optical Transceivers Linear and Nonlinear Compensation Instrumentation and Industrial Controls Mechanical Potentiometer Replacement

Registers and Modes are capitalized for clarity.<br>EP = Exposed pad.



# **Typical Operating Circuit**

# **MAXIM**

**\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ Maxim Integrated Products 1**

**Features**

- ♦ **22k**Ω **to 3.7k**Ω **Adjustable Logarithmic Resistor with a 3.6k**Ω **Fixed Resistor**
- ♦ **128 Wiper Tap Points**
- ♦ **On-Chip Temperature Sensor and ADC**
- ♦ **72-Byte Lookup Table (LUT)**
- ♦ **I2C-Compatible Serial Interface**
- ♦ **Address Pins Allow Up to Four DS1841s to Share the Same I2C Bus**
- ♦ **Digital Supply of 2.7V to 5.5V**
- ♦ **-40°C to +100°C Operating Range**
- ♦ **3mm x 3mm, 10-Pin TDFN Package**

## **Ordering Information**



+Denotes a lead-free package.

T&R = Tape and reel.

# **Pin Configuration**



**For pricing, delivery, and ordering information, please contact Maxim Direct at 1-888-629-4642, or visit Maxim's website at www.maxim-ic.com.**

# **ABSOLUTE MAXIMUM RATINGS**





Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## **RECOMMENDED OPERATING CONDITIONS**

 $(T_A = -40\degree C \text{ to } +100\degree C)$ 



## **DC ELECTRICAL CHARACTERISTICS**

(V<sub>CC</sub> =  $+2.7V$  to  $+5.5V$ , T<sub>A</sub> = -40°C to  $+100$ °C, unless otherwise noted.)



# **TEMPERATURE SENSOR CHARACTERISTICS**

( $V_{\text{CC}}$  = +2.7V to +5.5V,  $T_A$  = -40°C to +100°C, unless otherwise noted.)



# **ANALOG VOLTAGE MONITORING CHARACTERISTICS**

(V<sub>CC</sub> =  $+2.7V$  to  $+5.5V$ , T<sub>A</sub> = -40°C to  $+100$ °C, unless otherwise noted.)



# **I2C AC ELECTRICAL CHARACTERISTICS (See Figure 3)**

 $(V_{CC} = +2.7V$  to +5.5V,  $T_A = -40^{\circ}C$  to +100°C, timing referenced to  $V_{IL(MAX)}$  and  $V_{HH(MIN)}$ .



# **I2C AC ELECTRICAL CHARACTERISTICS (See Figure 3) (continued)**

(V<sub>CC</sub> = +2.7V to +5.5V, T<sub>A</sub> = -40°C to +100°C, timing referenced to V<sub>IL(MAX)</sub> and V<sub>IH(MIN)</sub>.)



# **NONVOLATILE MEMORY CHARACTERISTICS**

 $(V_{CC} = +2.7V$  to  $+5.5V)$ 



**Note 1:** All voltages are referenced to ground. Currents entering the IC are specified positive and currents exiting the IC are negative.

**Note 2:**  $|_{CC}$  is specified with the following conditions: SCL and SDA =  $V_{CC}$ , RW and RH floating with Update Mode bit = 1.

**Note 3:** This is the minimum V<sub>CC</sub> voltage that causes NV memory to be recalled.

**Note 4**: This is the time from  $V_{CC}$  >  $V_{POR}$  until initial memory recall is complete.

**Note 5:** Guaranteed by design.

Note 6: I<sup>2</sup>C interface timing shown is for Fast-Mode (400kHz) operation. This device is also backward-compatible with I<sup>2</sup>C-Standard Mode timing.

**Note 7:** C<sub>B</sub>—total capacitance of one bus line in picofarads.

**Note 8:** EEPROM write time begins after a STOP condition occurs.

**Note 9:** Guaranteed by characterization.

**Typical Operating Characteristics**



( $V_{CC}$  = +2.7V to +5.5V,  $T_A$  = +25°C, unless otherwise noted.)

SUPPLY VOLTAGE (V)

**DS1841**

**DS1841** 

DS1841 toc03

DS1841 toc06



## **Detailed Description**

The DS1841 operates in one of two modes: LUT Mode and LUT Adder Mode. In LUT Mode and LUT Adder Mode, the resistor's wiper position is controlled as a function of the temperature measured by the DS1841's internal temperature sensor. The difference between the two LUT modes is the way the resistor's wiper position is calculated. Detailed descriptions of these two modes, as well as additional features of the DS1841, are discussed in subsequent sections.

#### **Digital Resistor Description**

The DS1841's resistor consists of 128 resistive steps between RW and RGND with a series resistor, RS, between RH and RW. The wiper position and the output seen on RW are decoded based on the value in the wiper register (WR). The step size of each position is optimized to produce a linear response when used in the feedback network of a DC-DC converter.

#### **Mode Selection**

**Pin Description**

The DS1841 mode of operation is determined by the Update Mode bit (Control Register 1, address 03h, bit 0) and the Adder Mode bit (Control Register 1, address 03h, bit 1). Table 1 illustrates how the two control bits are used to select the operating mode. When shipped from the factory, the DS1841 is programmed with the Update Mode and Adder Mode bits set to 1, hence configuring the DS1841 in LUT Adder Mode. See Appendix A for a detailed table of the control logic bit functions.

#### **Table 1. Operating Modes**



#### **LUT Adder Mode (Default)**

LUT Adder Mode is selected by setting the Update Mode bit to 1 and the Adder Mode bit to 1. This mode operates similar to LUT Mode with one major difference (see the LUT Mode and LUT Adder Mode Block Diagram). The WR is loaded with the sum of the values of LUTVAL (the value pointed to by the address stored in LUTAR) and IVR. Furthermore, in this mode, the values programmed into the LUT are signed two's complement. This allows convenient positive or negative offsetting of the nominal IVR value. WR resistance values clamp at 00h and 7Fh (the MSB is ignored).

#### **LUT Mode**

LUT Mode is selected by setting the Update Mode bit (Control Register 1, address 03h, bit 0) to a 1 and the Adder Mode bit (Control Register 1, address 03h, bit 1) to a 0. An overview of the DS1841 in this mode is illustrated in the LUT Mode and LUT Adder Mode Block Diagram. The memory map for the LUT Mode and the LUT Adder Mode is shown in Table 2. The major difference between the two LUT modes is whether the value

in the IVR is added to the values stored in the LUT. The dashed line/arrow shown in the LUT Drive Mode Block Diagram is not active in LUT Mode. When in LUT Mode, on power-up the IVR value is recalled into the WR. This value remains there until completion of the first temperature conversion following power-up. The temperature is measured every tFRAME. The temperature value is used to calculate an index that points to the corresponding value in the LUT. This index is referred to as the LUT Address Register (LUTAR) and is located at address 08h. The value stored in the LUT at the location pointed to by LUTAR is called LUTVAL, and this value is stored as the WR value (WR) at address 09h when Update Mode bit  $= 1$ . The process then repeats itself, continuously updating the wiper setting in a closed-loop fashion. In this mode the 72-byte LUT is populated with wiper settings for each two-degree temperature window. Valid wiper settings are 00h to 7Fh (the MSB is ignored). Table 3 shows the memory addresses of the LUT as well as the corresponding temperature range for each byte in the LUT.

**Table 2. LUT Mode and LUT Adder Mode Memory Map**

| <b>REGISTER</b> | <b>NAME</b>                     | <b>ADDRESS</b><br>(HEX) | <b>VOLATILE/NV</b>   | <b>FACTORY/POWER-UP</b><br><b>DEFAULT</b> |
|-----------------|---------------------------------|-------------------------|----------------------|-------------------------------------------|
| IV <sub>R</sub> | Initial Value Register          | 00h                     | NV (Shadowed)        | 00h                                       |
| C <sub>RO</sub> | Control Register 0              | 02h                     | Volatile             | 00h                                       |
| CR <sub>1</sub> | Control Register 1              | 03h                     | NV (Shadowed)        | 03h                                       |
| LUTAR           | <b>LUT Address Register</b>     | 08h                     | Volatile             | 00h                                       |
| <b>WR</b>       | <b>LUT Value Register</b>       | $09h*$                  | Volatile             | 00h                                       |
| C <sub>R2</sub> | Control Register 2              | 0Ah                     | Volatile             | 00h                                       |
| <b>TEMP</b>     | Temperature Result              | 0Ch                     | Volatile (Read Only) | N/A                                       |
| <b>VOLTAGE</b>  | Supply Voltage Result           | 0Eh                     | Volatile             | N/A                                       |
| LUT             | Temperature Lookup<br>Registers | $80h - C7h$             | <b>NV</b>            | 00h                                       |

\*In LUT Mode and LUT Adder Mode, WR is accessed through memory address 09h, while IVR remains at memory address 00h.

 $V_{\text{CC}}$ INITIAL VALUE REGISTER (IVR) GND CONTROL LOGIC/ SCL CONTROL **REGISTERS** 1 OF 128 MULTIPLEXERS IVAN AND POWER-UP ONLY WHEN IN LUTVAL **CONLY POWER-**<br>
1 OF ADDER MODER MODER MODER MODER CONLY WHEN IN LUTVAL **CONLY WHEN** IN LUTVAL **CONLY CON** SD<sub>A</sub> RGND I 2C **INTERFACE** A0 POS 7FH  $\blacktriangleright$  DATA A1 LUT 72-BYTE WIPER ADDRESS LOOKUP REGISTER REGISTER TABLE <sup>∑</sup> LUTVAL **TFMF TFMF** SENSOR (WR) 0Ch LUTVAL  $\ddot{\cdot}$  $(111TAR)$  $(111T)$ ADC OR 09h\*  $V_{\Gamma}$  $V_{CC}$  (V) LUTVAL+IVR08h 80h–C7h POS 00h VOLTAGE 0Eh RW  $\mathsf{Rs}_{\Lambda}$ RH \*NOTE THAT WHEN IN LUT OR LUT ADDER MODE, WR IS ACCESSED THROUGH 09h WHILE IVR REMAINS AT 00h.

## **LUT Mode and LUT Adder Mode Block Diagram (Update Mode Bit = 1)**

#### **Temperature Conversion and Supply Voltage Monitoring**

#### **Temperature Conversion**

The DS1841 features an internal 8-bit temperature sensor that can drive the LUT and provide a measurement of the ambient temperature over I2C by reading the value stored in address 0Ch. The sensor is functional over the entire operating temperature range and is stored in signed two's complement format with a resolution of 1°C/bit. See Table 2, Register 0Ch description for the temperature sensor's bit weights. To calculate the temperature, treat the two's complement binary value as an unsigned binary number, then convert it to decimal. If the result is greater than or equal to 128, subtract 256 from the result.

**LUT** The DS1841 monitors the internal temperature by repeatedly polling the sensor's result with update rate tFRAME. During each cycle, the DS1841 reads the internal temperature, and, based on that temperature, points to the corresponding LUT address. Every two degrees of temperature will convert into one temperature address slot. See Table 3 for a list of temperatures and their corresponding LUT addresses.

The LUT features one-degree hysteresis to prevent chattering if the measured temperature falls on the boundary between two windows (see Figure 1).



## **Table 3. LUT Registers and Temperature Ranges**

*IVI A* XI*IV*I

**DS1841**

**DS1841** 



Figure 1. LUT Hysteresis



Figure 2. Slave Address Byte

#### **Supply Voltage Monitoring**

The DS1841 also features an internal 8-bit supply voltage ( $V_{CC}$ ) monitor. A value of the supply voltage measurement can be read over I<sup>2</sup>C at the address 0Eh.

To calculate the supply voltage, simply convert the hexadecimal result into decimal and then multiply it by the LSB as shown in the Analog Voltage Monitoring Characteristics electrical table.

#### **Supply Current (ICC)**

The DS1841 has two supply current levels of power supply consumption. First, active current during I2C communications while in the LUT-Driven Mode is the "worst case" supply current, I<sub>CC</sub>. All functionality including I<sup>2</sup>C communication is operating simultaneously. Second, active current without I2C while in the LUT-Driven Mode is quantified by the supply current, I<sub>CC2</sub>. SDA and SCL are held statically in the high logic level.

#### **Slave Address Byte and Address Pins**

The slave address byte consists of a 7-bit slave address plus a R $\overline{W}$  bit (see Figure 2). The DS1841's slave address is determined by the state of the A0 and A1 address pins. These pins allow up to four devices to reside on the same I2C bus. Address pins tied to GND result in a 0 in the corresponding bit position in the slave address. Conversely, address pins tied to V<sub>CC</sub> result in a 1 in the corresponding bit positions. For example, the DS1841's slave address byte is 50h when A0 and A1 pins are grounded. I<sup>2</sup>C communication is described in detail in the I<sup>2</sup>C Serial Interface Description section.

## **Memory Description**

The DS1841's internal memory consists of both volatile and NV registers that are organized into eight byte rows. Three control registers as well as specialized data registers are used to control the wiper and drive the LUT.

#### **Register Descriptions**

## **Register 00h: Initial Value Register (IVR)**

FACTORY DEFAULT (IVR) 00h MEMORY TYPE NV MEMORY TYPE Volatile



If  $\overline{\text{SEE}}$  bit = 0, an I<sup>2</sup>C READ retrieves the IVR value and an I<sup>2</sup>C WRITE sets the wiper position in volatile memory and updates IVR in NV memory with this new value. If  $\overline{\text{SEE}}$  bit = 1, an I<sup>2</sup>C READ retrieves the WR value and an I<sup>2</sup>C WRITE sets the wiper position (volatile) and the IVR value is not modified. During power-up, IVR's value is used to set the wiper position.

## **Register 02h: Control Register 0 (CR0)**





Control Register 0 determines how the wiper position values (volatile and NV versions) are set, as well as how writes to Control Register 1 are stored.

The IVR is located at memory address 00h and is implemented as EEPROM shadowed SRAM. This register can be visualized as an SRAM byte (the WR portion) in parallel with an EEPROM byte (the IVR portion). The operation of the register is controlled by the Shadow EEPROM (SEE) bit in Control Register 0, address 02h, bit 7. When the SEE bit = 0 (default), data written to memory address 00h by I<sup>2</sup>C actually gets stored in both SRAM (WR) and EEPROM (IVR). When  $\overline{\text{SEE}}$  = 1, only the SRAM (WR) is written to the new value. The EEPROM byte (IVR) continues to store the last value written to it when SEE was 0. Reading memory address 00h reads the value stored in WR. The SEE bit is volatile and its power-up default state is 0.

**10 \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_**

## **Register 03h: Control Register 1 (CR1)**

FACTORY DEFAULT 03h MEMORY TYPE Shadowed NV





Control Register 1 controls how the wiper position is determined. The **SEE** bit controls whether the values of this register are stored in EEPROM or in Shadowed SRAM. On power-up, the EEPROM value is recalled to this register, regardless of the state of SEE.

While the registers other than 00h through 0Ah can be read, they are not updated by the ADC as the ADC is disabled with the Update Mode bit  $= 0$ .

## **Register 08h: LUT Address Register (LUTAR)**





The LUTAR register serves as the index pointer to choose the corresponding temperature slot in the LUT based on the internal temperature sensor result. The LUTAR can be directly read by acessing address 08h; however, to write an new value to LUTAR (to control WR manually), the LUTAR Mode bit must be set to a 1.

## **Register 09h: LUT Value Register (WR\*)**

FACTORY DEFAULT 00h MEMORY TYPE Volatile

09h WR\* Bit 7 Bit 0

WR serves as an intermediate location, which is populated automatically with the results of the temperature-indexed lookup. The WR can be directly read by acessing address 09h; however to write an new value to WR (to control it manually), the wiper access control bit must be set to a 1. WR is an unsigned 7-bit value.

\*WR is updated every tFRAME if Update Mode bit = 1. If Update Mode bit = 0, WR holds the value stored in register 00h.



# **Register 0Ah: Control Register 2 (CR2)**

FACTORY DEFAULT 00h MEMORY TYPE Volatile





Control Register 2 controls how the wiper position is determined.

## **Register 0Ch: Temperature Result (TEMP)**



Bit 7 Bit 0

This register holds the current temperature result. It is updated every conversion time, tFRAME. To calculate the temperature, treat the two's complement binary value as an unsigned binary number, then convert it to decimal. If the result is greater than or equal to 128, subtract 256 from the result. This register is only updated when the Update Mode  $bit = 1$ . When the Update Mode bit = 0, no ADC updates are made to this register.

# **Register 0Eh: Supply Voltage Result (VOLTAGE)**

FACTORY DEFAULT None MEMORY TYPE Volatile



This register holds the current supply voltage result. It is updated every conversion time, tFRAME. See the Supply Voltage Monitoring section. This register is only updated when the Update Mode bit  $= 1$ . When the Update Mode bit  $= 0$ , no ADC updates are made to this register.

#### **Registers 80h to C7h: Temperature Lookup Register (LUT)**



These registers at location 80h to C7h are NV and serve to temperature compensate RW over the operating temperature range of the DS1841.

The LUT entries are unsigned 8-bit values if the Adder Mode bit  $= 0$ . If the Adder Mode bit  $= 1$ , LUT entries are two's complement, signed 7-bit values.

## **I<sup>2</sup>C Serial Interface Description**

#### **I2C Definitions**

The following terminology is commonly used to describe I2C data transfers. (See Figure 3 and I2C AC Electrical Table for additional information.)

**Master device:** The master device controls the slave devices on the bus. The master device generates SCL clock pulses and START and STOP conditions.

**Slave devices:** Slave devices send and receive data at the master's request.

**Bus idle or not busy:** Time between STOP and START conditions when both SDA and SCL are inactive and in their logic-high states.

**START condition:** A START condition is generated by the master to initiate a new data transfer with a slave. Transitioning SDA from high to low while SCL remains high generates a START condition.

**STOP condition:** A STOP condition is generated by the master to end a data transfer with a slave. Transitioning SDA from low to high while SCL remains high generates a STOP condition.

**Repeated START condition:** The master can use a repeated START condition at the end of one data transfer to indicate that it will immediately initiate a new data transfer following the current one. Repeated starts are commonly used during read operations to identify a specific memory address to begin a data transfer. A repeated START condition is issued identically to a normal START condition.

**Bit write:** Transitions of SDA must occur during the low state of SCL. The data on SDA must remain valid and unchanged during the entire high pulse of SCL plus the setup and hold time requirements. Data is shifted into the device during the rising edge of the SCL.

**Bit read:** At the end of a write operation, the master must release the SDA bus line for the proper amount of setup time before the next rising edge of SCL during a bit read. The device shifts out each bit of data on SDA at the falling edge of the previous SCL pulse and the data bit is valid at the rising edge of the current SCL pulse. Remember that the master generates all SCL clock pulses, including when it is reading bits from the slave.

**Acknowledge (ACK and NACK):** An Acknowledge (ACK) or Not Acknowledge (NACK) is always the 9th bit transmitted during a byte transfer. The device receiving data (the master during a read or the slave during a write operation) performs an ACK by transmitting a 0 during the 9th bit. A device performs a NACK by transmitting a 1 during the 9th bit. Timing for the ACK and NACK is identical to all other bit writes. An ACK is the acknowledgment that the device is properly receiving data. A NACK is used to terminate a read sequence or indicates that the device is not receiving data.

**Byte write:** A byte write consists of 8 bits of information transferred from the master to the slave (most significant bit first) plus a 1-bit acknowledgment from the slave to the master. The 8 bits transmitted by the master are done according to the bit write definition and the acknowledgment is read using the bit read definition.

**DS1841 DS184** 





Figure 3. I2C Timing Diagram

**Byte read:** A byte read is an 8-bit information transfer from the slave to the master plus a 1-bit ACK or NACK from the master to the slave. The 8 bits of information that are transferred (most significant bit first) from the slave to the master are read by the master using the bit read definition, and the master transmits an ACK using the bit write definition to receive additional data bytes. The master must NACK the last byte read to terminate communication so the slave returns control of SDA to the master.

**Slave address byte:** Each slave on the I<sup>2</sup>C bus responds to a slave address byte sent immediately following a START condition. The slave address byte contains the slave address in the most significant 7 bits and the  $R/\overline{W}$  bit in the least significant bit.

The DS1841's slave address is determined by the state of the A0 and A1 address pins as shown in Figure 2. Address pins tied to GND result in a 0 in the corresponding bit position in the slave address. Conversely, address pins tied to  $V_{CC}$  result in a 1 in the corresponding bit positions.

When the R $\overline{W}$  bit is 0 (such as in 50h), the master is indicating that it will write data to the slave. If  $R/\overline{W} = 1$ (51h in this case), the master is indicating that it wants to read from the slave.

If an incorrect slave address is written, the DS1841 assumes the master is communicating with another I2C device and ignores the communication until the next START condition is sent.

**Memory address:** During an I<sup>2</sup>C write operation, the master must transmit a memory address to identify the memory location where the slave is to store the data. The memory address is always the second byte transmitted during a write operation following the slave address byte.

#### **I2C Communication**

**Writing a single byte to a slave:** The master must generate a START condition, write the slave address byte  $(R/\overline{W} = 0)$ , write the memory address, write the byte of data, and generate a STOP condition. Remember the master must read the slave's acknowledgment during all byte write operations.

When writing to the DS1841, the potentiometer adjusts to the new setting once it has acknowledged the new data that is being written, and the EEPROM is written following the STOP condition at the end of the write command. To change the setting without changing the EEPROM, terminate the write with a repeated START condition before the next STOP condition occurs. Using a repeated START condition prevents the tw delay required for the EEPROM write cycle to finish.

# **DS1841 DS1841**

**Temperature-Controlled, NV, I<sup>2</sup>C, Logarithmic Resistor**

**Writing multiple bytes to a slave:** I<sup>2</sup>C write operations of multiple bytes can also be performed. During a single write sequence, up to 8 bytes in one page can be written at one time. If more than eight bytes are transmitted in the sequence, then only the last eight transmitted bytes are stored. After the last physical memory location in a particular page (8-byte page write), the address counter automatically wraps back to the first location in the same page for subsequent byte write operations.

**Acknowledge polling:** Any time a EEPROM byte is written, the DS1841 requires the EEPROM write time (tW) after the STOP condition to write the contents of the byte to EEPROM. During the EEPROM write time, the device does not acknowledge its slave address because it is busy. It is possible to take advantage of this phenomenon by repeatedly addressing the DS1841, which allows communication to continue as soon as the DS1841 is ready. The alternative to acknowledge polling is to wait for a maximum period of tw to elapse before attempting to access the device.

**Reading a single byte from a slave:** Unlike the write operation that uses the specified memory address byte to define where the data is to be written, the read operation occurs at the present value of the memory address counter. To read a single byte from the slave, the master generates a START condition, writes the slave address byte with  $R/\overline{W}$  = 1, reads the data byte with a NACK to indicate the end of the transfer, and generates a STOP condition. However, since requiring the master to keep track of the memory address counter is impractical, the following method should be used to perform reads from a specified memory location.

**Reading multiple bytes from a slave:** The read operation can be used to read multiple bytes with a single transfer. When reading bytes from the slave, the master simply ACKs the data byte if it desires to read another byte before terminating the transaction. After the master reads the last byte it must NACK to indicate the end of the transfer and generates a STOP condition. During a single read sequence of multiple bytes, after the last address counter position of FFh is accessed, the address counter automatically wraps back to the first location, 00h. Read operations can continue indefinitely.

**Manipulating the address counter for reads:** A dummy write cycle can be used to force the address counter to a particular value. To do this the master generates a START condition, writes the slave address byte ( $R/\overline{W}$  = 0), writes the memory address where it desires to read, generates a repeated START condi-



Figure 4. <sup>2</sup>C Communication Examples

tion, writes the slave address byte  $(R/\overline{W} = 1)$ , reads data with ACK or NACK as applicable, and generates a STOP condition. See Figure 4 for I<sup>2</sup>C Communication Examples.

# **Applications Information**

#### **Power-Supply Decoupling**

To achieve the best results when using the DS1841, decouple both the power-supply pin and the wiper-bias voltage pin with a 0.01µF or 0.1µF capacitor. Use a high-quality ceramic surface-mount capacitor if possible. Surface-mount components minimize lead inductance, which improves performance, and ceramic capacitors tend to have adequate high-frequency response for decoupling applications.

#### **SDA and SCL Pullup Resistors**

SDA is an I/O with an open-collector output that requires a pullup resistor to realize high-logic levels. A master using either an open-collector output with a pullup resistor or a push-pull output driver can be used for SCL. Pullup resistor values should be chosen to ensure that the rise and fall times listed in the AC electrical characteristics are within specification. A typical value for the pullup resistors is 4.7k $Ω$ .



## **Appendix A: Control Bits Logic Table**

# **Package Information**

For the latest package outline information, go to **www.maxim-ic.com/packages**.

