# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

## General Description

The DS1856 dual, temperature-controlled, nonvolatile (NV) variable resistors with three monitors consists of two 256-position, linear, variable resistors; three analog monitor inputs (MON1, MON2, MON3); and a direct-todigital temperature sensor. The device provides an ideal method for setting and temperature-compensating bias voltages and currents in control applications using minimal circuitry. The variable resistor settings are stored in EEPROM memory and can be accessed over the 2-wire serial bus.
Relative to other members of the family, the DS1856 is essentially a DS1859 with a DS1852-friendly memory map. In particular, the DS1856 can be configured so the 128 bytes of internal Auxiliary EEPROM memory is mapped into Main Device Table 00h and Table 01h, maintaining compatibility between both the DS1858/DS1859 and the DS1852. The DS1856 also features password protection equivalent to the DS1852, further enhancing compatibility between the two.

## Applications

Optical Transceivers
Optical Transponders
Instrumentation and Industrial Controls
RF Power Amps
Diagnostic Monitoring

## Typical Operating Circuit



Features

- SFF-8472 Compatible
- Five Monitored Channels (Temperature, Vcc, MON1, MON2, MON3)
- Three External Analog Inputs (MON1, MON2, MON3) That Support Internal and External Calibration
- Scalable Dynamic Range for External Analog Inputs
- Internal Direct-to-Digital Temperature Sensor
- Alarm and Warning Flags for All Monitored Channels
- Two Linear, 256-Position, Nonvolatile TemperatureControlled Variable Resistors
- Resistor Settings Changeable Every $2^{\circ} \mathrm{C}$
- Three Levels of Security
- Access to Monitoring and ID Information Configurable with Separate Device Addresses
- 2-Wire Serial Interface
- Two Buffers with TTL/CMOS-Compatible Inputs and Open-Drain Outputs
- Operates from a 3.3V or 5V Supply
$-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ Operating Temperature Range
Ordering Information

| PART | RESO/RES1 <br> RESISTANCE <br> $(\mathbf{k} \boldsymbol{\Omega})$ | PIN-PACKAGE |
| :--- | :---: | :--- |
| DS1856E-050 | $50 / 50$ | 16 TSSOP |
| DS1856E-050/T\&R | $50 / 50$ | 16 TSSOP |
| DS1856B-050 | $50 / 50$ | 16 CSBGA |

Ordering Information continued at end of data sheet.
+Denotes lead-free package.
T\&R denotes tape-and-reel package.
Note: All devices are specified over the $-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ temperature range.

Pin Configurations


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

## ABSOLUTE MAXIMUM RATINGS

Voltage Range on $\mathrm{V}_{\mathrm{CC}}$ Relative to Ground ...........-0.5V to +6.0 V Voltage Range on Inputs Relative
to Ground* .............................................-0.5V to (VCC +0.5 V )
Voltage Range on Resistor Inputs Relative to Ground*
-0.5 V to $\left(\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}\right)$
Current into Resistors .5mA
*Not to exceed 6.0V.

Operating Temperature Range ........................... $-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ Programming Temperature Range ......................... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range ............................. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering Temperature .......................................See IPC/JEDEC J-STD-020A

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

( $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$, unless otherwise noted.)

| PARAMETER | SYMBOL | CONDITIONS | MIN TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\text {CC }}$ | (Note 1) | 2.85 | 5.50 | V |
| Input Logic 1 (SDA, SCL) | $\mathrm{V}_{\mathrm{IH}}$ | (Note 2) | $0.7 \times \mathrm{Vcc}$ | $\mathrm{V}_{\mathrm{Cc}}+0.3$ | V |
| Input Logic 0 (SDA, SCL) | $\mathrm{V}_{\text {IL }}$ | (Note 2) | -0.3 | $+0.3 \times \mathrm{VCC}$ | V |
| Resistor Inputs (L0, L1, H0, H1) |  |  | -0.3 | $V_{C C}+0.3$ | V |
| Resistor Current | IRES |  | -3 | +3 | mA |
| High-Impedance Resistor Current | IROFF |  | 0.001 | 0.1 | $\mu \mathrm{A}$ |
| Input Logic Levels (IN1, IN2) |  | Input logic 1 | 1.6 |  | V |
|  |  | Input logic 0 |  | 0.9 |  |

## DC ELECTRICAL CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=2.85 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$, unless otherwise noted.)

| PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Current | ICC | (Note 3) |  | 1 | 2 | mA |
| Input Leakage | IIL |  | -200 |  | +200 | nA |
| Low-Level Output Voltage (SDA, OUT1, OUT2) | VOL1 | 3mA sink current | 0 |  | 0.4 | V |
|  | VoL2 | 6 mA sink current | 0 |  | 0.6 |  |
| Full-Scale Input (MON1, MON2, MON3) |  | At factory setting (Note 4) | 2.4875 | 2.5 | 2.5125 | V |
| Full-Scale VCC Monitor |  | At factory setting (Note 5) | 6.5208 | 6.5536 | 6.5864 | V |
| I/O Capacitance | Cl/O |  |  |  | 10 | pF |
| Digital Power-On Reset | POD |  | 1.0 |  | 2.2 | V |
| Analog Power-On Reset | POA |  | 2.0 |  | 2.6 | V |

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

## ANALOG RESISTOR CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=2.85 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$, unless otherwise noted.)

| PARAMETER | CONDITIONS | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Position 00h Resistance ( $50 \mathrm{k} \Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 0.65 | 1.0 | 1.35 | $\mathrm{k} \Omega$ |
| Position FFh Resistance (50k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 40 | 50 | 60 | $\mathrm{k} \Omega$ |
| Position 00h Resistance (30k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 0.165 | 0.275 | 0.400 | $\mathrm{k} \Omega$ |
| Position FFh Resistance (30k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 22.5 | 30 | 37.5 | $\mathrm{k} \Omega$ |
| Position 00h Resistance (20k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 0.20 | 0.40 | 0.55 | $\mathrm{k} \Omega$ |
| Position FFh Resistance (20k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 15 | 20 | 25 | $\mathrm{k} \Omega$ |
| Position 00h Resistance (10k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 0.075 | 0.125 | 0.200 | $\mathrm{k} \Omega$ |
| Position FFh Resistance (10k $\Omega$ ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 7.5 | 10 | 12.5 | $\mathrm{k} \Omega$ |
| Position 00h Resistance (2.5k ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 0.1 | 0.175 | 0.250 | k $\Omega$ |
| Position FFh Resistance (2.5k ) | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | 2.0 | 2.50 | 3.0 | $\mathrm{k} \Omega$ |
| Absolute Linearity | (Note 6) | -2 |  | +2 | LSB |
| Relative Linearity | (Note 7) | -1 |  | +1 | LSB |
| Temperature Coefficient | (Note 8) |  | 50 |  | ppm/ ${ }^{\circ} \mathrm{C}$ |

## ANALOG VOLTAGE MONITORING

( $\mathrm{V}_{\mathrm{CC}}=2.85 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$, unless otherwise noted.)

| PARAMETER | SYMBOL | CONDITIONS | MIN TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Resolution | $\triangle \mathrm{VMON}$ |  | 610 |  | $\mu \mathrm{V}$ |
| Supply Resolution | $\Delta \mathrm{V}_{\mathrm{CC}}$ |  | 1.6 |  | mV |
| Input/Supply Accuracy (MON1, MON2, MON3, Vcc) | Acc | At factory setting | 0.25 | 0.5 | $\begin{gathered} \text { \% FS } \\ \text { (full scale) } \end{gathered}$ |
| Update Rate for MON1, MON2, MON3, Temp, or VCc | trame |  | 47 | 60 | ms |
| Input/Supply Offset (MON1, MON2, MON3, VCc) | Vos | (Note 14) | 0 | 5 | LSB |

## DIGITAL THERMOMETER

( $\mathrm{V}_{\mathrm{CC}}=2.85 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$, unless otherwise noted.)

| PARAMETER | SYMBOL | CONDITIONS | MIN TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Thermometer Error | TERR | $-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ |  | $\pm 3.0$ | ${ }^{\circ} \mathrm{C}$ |

## NONVOLATILE MEMORY CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=2.85 \mathrm{~V}$ to 5.5 V )

| PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EEPROM Writes |  | $+70^{\circ} \mathrm{C}$ (Note 14) | 50,000 |  |  | Writes |

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

## AC ELECTRICAL CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=2.85 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$, unless otherwise noted. See Figure 6.)

| PARAMETER | SYMBOL | CONDITIONS | MIN TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SCL Clock Frequency (Note 9) | fSCL | Fast mode | 0 | 400 | kHz |
|  |  | Standard mode | 0 | 100 |  |
| Bus Free Time Between STOP and START Condition (Note 9) | tBUF | Fast mode | 1.3 |  | $\mu \mathrm{s}$ |
|  |  | Standard mode | 4.7 |  |  |
| Hold Time (Repeated) START Condition (Notes 9, 10) | thD:STA | Fast mode | 0.6 |  | $\mu \mathrm{s}$ |
|  |  | Standard mode | 4.0 |  |  |
| LOW Period of SCL Clock (Note 9) | tıow | Fast mode | 1.3 |  | $\mu \mathrm{s}$ |
|  |  | Standard mode | 4.7 |  |  |
| HIGH Period of SCL Clock (Note 9) | thigh | Fast mode | 0.6 |  | $\mu \mathrm{s}$ |
|  |  | Standard mode | 4.0 |  |  |
| Data Hold Time (Notes 9, 11, 12) | thD:DAT | Fast mode | 0 | 0.9 | $\mu \mathrm{s}$ |
|  |  | Standard mode | 0 |  |  |
| Data Setup Time (Note 9) | tSU:DAT | Fast mode | 100 |  | ns |
|  |  | Standard mode | 250 |  |  |
| START Setup Time (Note 9) | tsu:STA | Fast mode | 0.6 |  | $\mu \mathrm{s}$ |
|  |  | Standard mode | 4.7 |  |  |
| Rise Time of Both SDA and SCL Signals (Note 13) | $t_{R}$ | Fast mode | $20+0.1 C_{B}$ | 300 | ns |
|  |  | Standard mode | $20+0.1 C_{B}$ | 1000 |  |
| Fall Time of Both SDA and SCL Signals (Note 13) | $t_{F}$ | Fast mode | $20+0.1 C_{B}$ | 300 | ns |
|  |  | Standard mode | $20+0.1 C_{B}$ | 300 |  |
| Setup Time for STOP Condition | tsu:Sto | Fast mode | 0.6 |  | $\mu \mathrm{s}$ |
|  |  | Standard mode | 4.0 |  |  |
| Capacitive Load for Each Bus Line | CB | (Note 13) |  | 400 | pF |
| EEPROM Write Time | tw |  | 10 | 20 | ms |

Note 1: All voltages are referenced to ground
Note 2: I/O pins of fast-mode devices must not obstruct the SDA and SCL lines if $\mathrm{V}_{\mathrm{Cc}}$ is switched off.
Note 3: SDA and SCL are connected to $\mathrm{V}_{\mathrm{Cc}}$ and all other input signals are connected to well-defined logic levels.
Note 4: Full scale is user programmable. The maximum voltage that the MON inputs read is approximately full scale, even if the voltage on the inputs is greater than full scale.
Note 5: This voltage defines the maximum range of the analog-to-digital converter voltage, not the maximum $V_{C C}$ voltage
Note 6: Absolute linearity is the difference of measured value from expected value at DAC position. The expected value is a straight line from measured minimum position to measured maximum position.
Note 7: Relative linearity is the deviation of an LSB DAC setting change vs. the expected LSB change. The expected LSB change is the slope of the straight line from measured minimum position to measured maximum position.
Note 8: See the Typical Operating Characteristics.
Note 9: A fast-mode device can be used in a standard-mode system, but the requirement tsu:DAT > 250ns must then be met. This is automatically the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line tRMAX + tsu:DAT $=1000 \mathrm{~ns}+250 \mathrm{~ns}=1250 \mathrm{~ns}$ before the SCL line is released.

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

Note 10: After this period, the first clock pulse is generated.
Note 11: The maximum thD:DAT only has to be met if the device does not stretch the LOW period (tLow) of the SCL signal.
Note 12: A device must internally provide a hold time of at least 300ns for the SDA signal (see the $\mathrm{V}_{\mathrm{IH}}$ MIN of the SCL signal) to bridge the undefined region of the falling edge of SCL.
Note 13: $\mathrm{C}_{\mathrm{B}}$-total capacitance of one bus line, timing referenced to $0.9 \times \mathrm{V}_{\mathrm{CC}}$ and $0.1 \times \mathrm{V}_{\mathrm{CC}}$.
Note 14: Guaranteed by design.
$\left(\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}\right.$, for both $50 \mathrm{k} \Omega$ and $20 \mathrm{k} \Omega$ versions, unless otherwise noted.)


## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

Typical Operating Characteristics (continued)
$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}\right.$, for both $50 \mathrm{k} \Omega$ and $20 \mathrm{k} \Omega$ versions, unless otherwise noted.)


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

## Typical Operating Characteristics (continued)

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}\right.$, for both $50 \mathrm{k} \Omega$ and $20 \mathrm{k} \Omega$ versions, unless otherwise noted.)





LSB ERROR vs. FULL-SCALE INPUT


TEMPERATURE COEFFICIENT vs. SETTING


LSB ERROR vs. FULL-SCALE INPUT


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Pin Description

| PIN | BALL | NAME |  |
| :---: | :---: | :---: | :--- |
| 1 | B2 | SDA | 2-Wire Serial Data I/O Pin. Transfers serial data to and from the device. |
| 2 | A2 | SCL | 2-Wire Serial Clock Input. Clocks data into and out of the device. |
| 3 | C3 | OUT1 | Open-Drain Buffer Output |
| 4 | A1 | IN1 | TTL/CMOS-Compatible Input to Buffer |
| 5 | B1 | OUT2 | Open-Drain Buffer Output |
| 6 | C2 | IN2 | TTL/CMOS-Compatible Input to Buffer |
| 7 | C1 | N.C. | No Connection |
| 8 | D1 | GND | Ground |
| 9 | D3 | MON1 | External Analog Input |
| 10 | D4 | MON2 | External Analog Input |
| 11 | C4 | MON3 | External Analog Input |
| 12 | D2 | L0 | Low-End Resistor 0 Terminal. It is not required that the low-end terminals be connected to a potential <br> less than the high-end terminals of the corresponding resistor. Voltage applied to any of the resistor <br> terminals cannot exceed the power-supply voltage, VCC, or go below ground. |
| 13 | B3 | H0 | High-End Resistor 0 Terminal. It is not required that the high-end terminals be connected to a <br> potential greater than the low-end terminals of the corresponding resistor. Voltage applied to any of <br> the resistor terminals cannot exceed the power-supply voltage, VCC, or go below ground. |
| 14 | B4 | L1 | Low-End Resistor 1 Terminal |
| 15 | A4 | H1 | High-End Resistor 1 Terminal |
| 16 | A3 | VCC | Supply Voltage |

## Detailed Description

The user can read the registers that monitor the Vcc, MON1, MON2, MON3, and temperature analog signals. After each signal conversion, a corresponding bit is set that can be monitored to verify that a conversion has occurred. The signals also have alarm and warning flags that notify the user when the signals go above or below the user-defined value. Interrupts can also be set for each signal.

The position values of each resistor can be independently programmed. The user can assign a unique value to each resistor for every $2^{\circ} \mathrm{C}$ increment over the $-40^{\circ} \mathrm{C}$ to $+102^{\circ} \mathrm{C}$ range.
Two buffers are provided to convert logic-level inputs into open-drain outputs. Typically, these buffers are used to implement transmit (Tx) fault and loss-of-signal (LOS) functionality. Additionally, OUT1 can be asserted in the event that one or more of the monitored values go beyond user-defined limits.

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection



Figure 1. Block Diagram

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Table 1. Scales for Monitor Channels at Factory Setting

| SIGNAL | +FS <br> SIGNAL | +FS <br> (hex) | -FS <br> SIGNAL | -FS <br> (hex) |
| :---: | :---: | :---: | :---: | :---: |
| Temperature | $+127.984^{\circ}$ | 7FFC | $-128^{\circ} \mathrm{C}$ | 8000 |
| VCC $^{\circ}$ | 6.5528 V | FFF8 | OV | 0000 |
| MON1 | 2.4997 V | FFF8 | OV | 0000 |
| MON2 | 2.4997 V | FFF8 | OV | 0000 |
| MON3 | 2.4997 V | FFF8 | OV | 0000 |

Table 2. Signal Comparison

| SIGNAL | FORMAT |
| :---: | :---: |
| VCC | Unsigned |
| MON1 | Unsigned |
| MON2 | Unsigned |
| MON3 | Unsigned |
| Temperature | Two's complement |

## Monitored Signals

Each signal (VCC, MON1, MON2, MON3, and temperature) is available as a 16-bit value with 12-bit accuracy (left-justified) over the serial bus. See Table 1 for signal scales and Table 2 for signal format. The four LSBs should be masked when calculating the value. The 3 LSBs are internally masked with Os.
The signals are updated every frame rate (tframe) in a round-robin fashion.
The comparison of all five signals with the high and low user-defined values are done automatically. The corresponding flags are set to 1 within a specified time of the occurrence of an out-of-limit condition.

## Calculating Signal Values

The LSB $=100 \mu \mathrm{~V}$ for VCC , and the $\mathrm{LSB}=38.147 \mu \mathrm{~V}$ for the MON signals when using factory default settings.

## Monitor/Vcc Bit Weights

| MSB | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

Vcc Conversion Examples

| MSB (BIN) | LSB (BIN) | VOLTAGE (V) |
| :---: | :---: | :---: |
| 10000000 | 10000000 | 3.29 |
| 11000000 | 11111000 | 4.94 |

Table 3. Look-Up Table Address for
Corresponding Temperature Values

| TEMPERATURE <br> $\left({ }^{\circ} \mathbf{C}\right)$ | CORRESPONDING LOOK-UP <br> TABLE ADDRESS |
| :---: | :---: |
| $<-40$ | 80 h |
| -40 | 80 h |
| -38 | 81 h |
| -36 | 82 h |
| -34 | 83 h |
| - | - |
| +98 | C5h |
| +100 | C6h |
| +102 | C7h |
| $>+102$ | C7h |

Monitor Conversion Example

| MSB (BIN) | LSB (BIN) | VOLTAGE (V) |
| :---: | :---: | :---: |
| 11000000 | 00000000 | 1.875 |
| 10000000 | 10000000 | 1.255 |

To calculate $\mathrm{V}_{\mathrm{CC}}$, convert the unsigned 16 -bit value to decimal and multiply by $100 \mu \mathrm{~V}$.
To calculate MON1, MON2, or MON3, convert the unsigned 16-bit value to decimal and multiply by $38.147 \mu \mathrm{~V}$.
To calculate the temperature, treat the two's complement value binary number as an unsigned binary number, then convert to decimal and divide by 256. If the result is greater than or equal to 128 , subtract 256 from the result.
Temperature: high byte: $-128^{\circ} \mathrm{C}$ to $+127^{\circ} \mathrm{C}$ signed; low byte: $1 / 256^{\circ} \mathrm{C}$.

## Temperature Bit Weights

| $S$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ |

Temperature Conversion Examples

| MSB (BIN) | LSB (BIN) | TEMPERATURE ( ${ }^{\circ} \mathbf{C}$ ) |
| :---: | :---: | :---: |
| 01000000 | 00000000 | +64 |
| 01000000 | 00001111 | +64.059 |
| 01011111 | 00000000 | +95 |
| 11110110 | 00000000 | -10 |
| 11011000 | 00000000 | -40 |

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Table 4. ADEN Address Configuration

| ADEN <br> (ADDRESS <br> ENABLE) | NO. OF SEPARATE <br> DEVICE <br> ADDRESSES | ADDITIONAL <br> INFORMATION |
| :---: | :---: | :---: |
| 0 | 2 | See Figure 2 |
| 1 | 1 (Main Device Only) | See Figure 3 |

Table 5. ADEN and ADFIX Bits

| ADEN | ADFIX | AUXILIARY <br> ADDRESS | MAIN ADDRESS |
| :---: | :---: | :---: | :---: |
| 0 | 0 | A0h | A2h |
| 0 | 1 | A0h | EEPROM <br> (Table 03, 8Ch) |
| 1 | 0 | - | A2h |
| 1 | 1 | - | EEPROM <br> (Table 03, 8Ch) |



Figure 2. Memory Organization, $A D E N=0$

Variable Resistors The value of each variable resistor is determined by a temperature-addressed look-up table, which can assign a unique value ( 00 h to FFh ) to each resistor for every $2^{\circ} \mathrm{C}$ increment over the $-40^{\circ} \mathrm{C}$ to $+102^{\circ} \mathrm{C}$ range (see Table 3). See the Temperature Conversion section for more information.
The variable resistors can also be used in manual mode. If the TEN bit equals 0 , the resistors are in manual mode and the temperature indexing is disabled.

The user sets the resistors in manual mode by writing to addresses 82h and 83h in Table 03 to control resistors 0 and 1 , respectively.

## Memory Description

The memory of the DS1856 is divided into two areas referred to as the Main Device and the Auxiliary Device. The Main Device comprises all of the DS1856 specific memory while the Auxiliary Device consists of 128 bytes of general-purpose EEPROM and is especially useful in GBIC applications. Main and Auxiliary

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 


Figure 3. Memory Organization, $A D E N=1$
memories can be accessed by two separate 2-wire slave addresses (see Table 4). The Main Device address is A2h (or determined by the value in Table 03, byte 8Ch, when ADFIX $=1$ ) and the Auxiliary Device address is AOh (fixed). A configuration bit, ADEN (Table 03, byte 89h, bit 5), determines whether the DS1856 uses one or two 2-wire slave addresses. This feature can be used to save component count in SFF applications or other applications where both GBIC and monitoring functions are implemented and two device addresses are needed.

The memory organization for $\mathrm{ADEN}=0$ is shown in Figure 2. In this configuration, the 128 bytes of Auxiliary Device EEPROM are located at memory locations 00h to 7Fh and accessed using the Auxiliary Device 2-wire slave address of A0h (fixed). The remainder of the DS1856's memory is accessed using the Main Device address.
The memory organization of the second configuration, ADEN $=1$, is shown in Figure 3. In this configuration, all
of the DS1856's memory including the Auxiliary memory is accessed using only the Main Device address. The Auxiliary Device memory is mapped into Table 00 and Table 01 in the Main Device. Both tables map to the same block of physical memory. This is done to improve the compatibility between previous members of this IC family such as the DS1858/DS1859 and the DS1852. In this configuration, the DS1856 ignores communication using the Auxiliary Device address.
The value of the Main Device address can be changed to a value other than the default value of A2h (see data sheet Table 5). There can be up to 128 devices sharing a common 2 -wire bus, with each device having its own unique address. To change the Main Device address, first write the desired value to the Chip Address byte (Table 03, byte 8Ch). Then, enable the new address by setting ADFIX to a 1 . Subsequent 2 -wire communication must be performed using the new Main Device address. When ADFIX $=0$, the Chip Address byte is ignored, and the Main Device address is set to A2h.

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

The DS1856 2-wire interface uses 8 -bit addressing, which allows up to 256 bytes to be addressed traditionally on a given 2 -wire slave address. However, since the Main Device contains more than 256 bytes, a table scheme is used. The lower 128 bytes of the Main Device, memory locations 00h to 7Fh, function as expected and are independent of the currently selected table. Byte 7Fh is the Table Select byte. This byte determines which memory table will be accessed by the 2-wire interface when address locations 80h to FFh are accessed. Memory locations 80 h to FFh are accessible only through the Main Device address. The Auxiliary Device address has no access to the tables, but the Auxiliary Device memory can be mapped into the Main Device's memory space (by setting ADEN = 1). Valid values for the Table Select byte are shown in the table below.
Table 6. Table Select Byte

| TABLE SELECT <br> BYTE | TABLE NAME |
| :---: | :--- |
| 00 | Auxiliary Device Memory |
| 01 | (When ADEN = 1) |
| 02 | Does Not Exist |
| 03 | Configuration |
| 04 | Resistor 0 Look-up Table |
| 05 | Resistor 1 Look-up Table |

Before attempting to read and write any of the bits or bytes mentioned in this section, it is important to look at the memory map provided in a subsequent section to verify what level of password is required. Password protection is described in the following section.

## Password Protection

The DS1856 uses two 4-byte passwords to achieve three levels of access to various memory locations. The three levels of access are:
User Access: This is the default state after power-up. It allows read access to standard monitoring and status functions.
Level 1 Access: This allows access to customer data table (Tables 00 and 01) in addition to everything granted by User access. This level is granted by entering Password 1 (PW1).
Level 2 Access: This allows access to all memory, settings, and features, in addition to everything granted by Level 1 and User access. This level is granted by entering Password 2 (PW2).
To obtain a particular level of access, the corresponding password must be entered in the Password Entry
(PWE) bytes located in the Main Device at 7Bh to 7Eh. The value entered is compared to both the PW1 and PW2 settings located in Table 03, bytes BOh to B3h and Table 03, bytes B4h to B7h, respectively, to determine if access should be granted. Access is granted until the password is changed or until power is cycled.
Writing PWE can be done with any level of access, although PWE can never be read.
Writing PW1 and PW2 requires PW2 access. However, PW1 and PW2 can never be read, even with PW2 access.
On power-up, PWE is set to all 1s (FFFFh). As long as neither of the passwords are ever changed to FFFFh, then User access is the power-up default. Likewise, password protection can be intentionally disabled by setting the PW2 password to FFFFh.

Memory Map
The following table is the legend used in the memory map to indicate the access level required for read and write access.
Each table in the following memory map begins with a higher level view of a particular portion of the memory showing information such as row ( 8 bytes) and byte names. The tables are then followed, where applicable, by an Expanded Bytes table, which shows bit names and values. Furthermore, both tables use the permission legend to indicate the access required on a row, byte, and bit level.
The memory map is followed by a Register Description section, which describes bytes and bits in further detail.

## Table 7. Password Permission

| PERMISSION | READ | WRITE |
| :---: | :---: | :---: |
| $<0>$ | At least one byte in the row is different than <br> the rest of the row, so look at each byte <br> separately for permissions. |  |
| $<1>$ | all | PW2 |
| $<2>$ | all | NA |
| $<3>$ | all | all (The part also writes to <br> this byte.) |
| $<4>$ | PW2 | PW2 + mode_bit |
| $<5>$ | all | all |
| $<6>$ | NA | all |
| $<7>$ | PW1 | PW1 |
| $<8>$ | PW2 | PW2 |
| $<9>$ | NA | PW2 |
| $<10>$ | PW2 | NA |
| $<11>$ | all | PW1 |

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

Memory Map

| LOWER MEMORY |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Row } \\ & \text { (hex) } \end{aligned}$ | Row Name | Word 0 |  |  |  | Word 1 |  |  |  | Word 2 |  |  |  | Word 3 |  |  |  |
|  |  | Byte 0/8 |  | Byte 1/9 |  | Byte 2/A |  | Byte 3/B |  | Byte 4/C |  | Byte 5/D |  | Byte 6/E |  | Byte 7/F |  |
| 00 | ${ }^{\text {<1> }}$ Thresholdo | Temp Alarm Hi |  |  |  | Temp Alarm Lo |  |  |  | Temp Warn Hi |  |  |  | Temp Warn Lo |  |  |  |
| 08 | ${ }^{\text {<1> }}$ Threshold ${ }_{1}$ | Vcc Alarm Hi |  |  |  | Vcc Alarm Lo |  |  |  | VCC Warn Hi |  |  |  | V CC Warn Lo |  |  |  |
| 10 | ${ }^{\text {<1> }{ }^{\text {T }} \text { Threshold } 2}$ | Mon1 Alarm Hi |  |  |  | Mon1 Alarm Lo |  |  |  | Mon1 Warn Hi |  |  |  | Mon1 Warn Lo |  |  |  |
| 18 | ${ }^{\text {<1> }}$ Threshold3 | Mon2 Alarm Hi |  |  |  | Mon2 Alarm Lo |  |  |  | Mon2 Warn Hi |  |  |  | Mon2 Warn Lo |  |  |  |
| 20 | ${ }^{\text {<1] }}$ Threshold 4 | Mon3 Alarm Hi |  |  |  | Mon3 Alarm Lo |  |  |  | Mon3 Warn Hi |  |  |  | Mon3 Warn Lo |  |  |  |
| 28 | ${ }^{\text {<1] }}$ user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 30 | ${ }^{\text {<1] }}$ user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 38 | <1>user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 40 | ${ }^{\text {<1] }}$ user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 48 | <1] user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 50 | ${ }^{\text {<1] }}$ user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 58 | ${ }^{\text {<1] }}$ user ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 60 | ${ }^{\text {<2> }}$ Valueso | Temp Value |  |  |  | Vcc Value |  |  |  | Mon1 Value |  |  |  | Mon2 Value |  |  |  |
| 68 | ${ }^{\text {< } 0>}$ Values 1 | ${ }^{22}$ Mon3 Value |  |  |  | ${ }^{\text {<2> }}$ Reserved |  |  |  | ${ }^{\text {<2> }}$ Reserved |  |  |  | ${ }^{\text {<0> Status }}$ |  | ${ }^{\text {<3> Update }}$ |  |
| 70 | ${ }^{\text {<22 }}$ Alrm Wrn | Alarm 1 |  | Alarmo |  | Reserved |  | Reserved |  | Warn 1 |  | Warno |  | Reserved |  | Reserved |  |
| 78 | ${ }^{\text {<0) Table Select }}$ | ${ }^{\text {<6> }}$ Reserved |  | ${ }^{\text {<6> }}$ Reserved |  | ${ }^{\text {<6> }}$ Reserved |  | ${ }^{\text {<6> PWE msb }}$ |  |  |  | ${ }^{\text {<6] PWE Isb }}$ |  |  |  | ${ }^{\text {<5> }}$ Tbl Sel |  |
| EXPANDED BYTES |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Byte (hex) | Byte Name | Bit7 |  | Bit6 |  | Bit5 |  | Bit4 |  | Bit3 |  | Bit2 |  | Bit1 |  | Bit0 |  |
|  |  | bit15 | bit 14 | bit13 | bit12 | bit ${ }_{11}$ | bit 10 | bit9 | bit8 | bit7 | bit6 | bit5 | bit $_{4}$ | bit3 | bit2 | bit1 | bito |
|  | User EE | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
|  | Temp Alarm | S | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2{ }^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ |
|  | Temp Warn | S | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{6}$ | $2^{-7}$ | $2^{-8}$ |
|  | Volt Alarm | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
|  | Volt Warn | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2{ }^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| 28 | User ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 30 | User ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 38 | User ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 40 | User ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 48 | User ROM | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  | EE |  |
| 50 | User ROM | EE |  | EE |  | EE |  | E |  | E |  | E |  | E |  | E |  |
| 58 | User ROM | EE |  | EE |  | EE |  | E |  | E |  | E |  | E |  | E |  |

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

Memory Map (continued)

| 60 | Temp Value | S | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 62 | VCc Value | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| 64 | Mon1 Value | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| 66 | Mon2 Value | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| 68 | Mon3 Value | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{\circ}$ |
| 6E | Status |  |  | <11>S | thiz | ${ }^{\text {<2> }}$ Re | rved | ${ }^{\text {<2> }}$ Re | rved | ${ }^{<2>}$ | rved |  |  |  |  |  |  |
| 6F | Update | Tem |  |  | Rdy | Mon | Rdy | Mon | Rdy | Mon | Rdy | Res | ved | Res | ved |  | rved |
| 70 | Alarm $_{1}$ |  |  |  | Lo |  |  |  |  |  |  |  |  |  |  |  | 2 Lo |
| 71 | Alarmo |  |  |  | Lo | Res | ved | Res | ved | Res | ved | Res | ved | Res | ved |  |  |
| 74 | Warn $_{1}$ |  |  |  | Lo |  |  |  |  |  |  |  |  |  |  |  | Lo |
| 75 | Warno |  |  |  | Lo | Res | ved | Res | ved | Res | ved |  | ved | Res | ved |  | rved |
| 7B | PWE msb | $2^{31}$ | $2^{30}$ | $2^{29}$ | $2^{28}$ | $2^{27}$ | $2^{26}$ | $2^{25}$ | $2^{24}$ | $2^{23}$ | $2^{22}$ | $2^{21}$ | $2^{20}$ | $2^{19}$ | $2^{18}$ | $2^{17}$ | $2^{16}$ |
| 7D | PWE Isb | $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| 7F | Tbl Sel | $2^{7}$ |  | $2^{6}$ |  | $2^{5}$ |  | $2^{4}$ |  | $2^{3}$ |  | $2^{2}$ |  | $2^{1}$ |  | $2^{0}$ |  |


| AUXILIARY (VALID WHEN ADEN = 0) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Row } \\ & \text { (hex) } \end{aligned}$ | Row Name | Word 0 |  | Word 1 |  | Word 2 |  | Word 3 |  |
|  |  | Byte 0/8 | Byte 1/9 | Byte 2/A | Byte 3/B | Byte 4/C | Byte 5/D | Byte 6/E | Byte 7/F |
| 00-7F | <1>EE | EE | EE | EE | EE | EE | EE | EE | EE |
| TABLE 00/01 (VALID WHEN ADEN = 1) |  |  |  |  |  |  |  |  |  |
| Row <br> (hex) | Row <br> Name | Word 0 |  | Word 1 |  | Word 2 |  | Word 3 |  |
|  |  | Byte 0/8 | Byte 1/9 | Byte 2/A | Byte 3/B | Byte 4/C | Byte 5/D | Byte 6/E | Byte 7/F |
| 80-FF | ${ }^{<7>} E E$ | EE | EE | EE | EE | EE | EE | EE | EE |

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Memory Map (continued)

*The final result must be XOR'ed with BB40h.

## Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection

| TABLE 04 (LOOKUP TABLE FOR RESISTOR 0) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Row <br> (hex) | Row <br> Name | Word 0 |  | Word 1 |  | Word 2 |  | Word 3 |  |
|  |  | Byte 0/8 | Byte 1/9 | Byte 2/A | Byte 3/B | Byte 4/C | Byte 5/D | Byte 6/E | Byte 7/F |
| 80 | ${ }^{\text {<8> }}$ LUT |  |  |  |  |  |  |  |  |
| 88 | ${ }^{<88}$ LUT |  |  |  |  |  |  |  |  |
| 90 | ${ }^{<88}$ LUT |  |  |  |  |  |  |  |  |
| 98 | ${ }^{\text {<88 }}$ LUT |  |  |  |  |  |  |  |  |
| A0 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| A8 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| B0 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| B8 | ${ }^{<88}$ LUT |  |  |  |  |  |  |  |  |
| C0 | ${ }^{\text {888 }}$ LUT |  |  |  |  |  |  |  |  |
| C8 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| D0 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| D8 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| E0 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| E8 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| F0 |  | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved |
| F8 | ${ }^{<10>}$ Res0 data | Resistor 0 Calibration Constants (see data sheet Table 8) |  |  |  |  |  |  |  |
| EXPANDED BYTES |  |  |  |  |  |  |  |  |  |
| Byte <br> (hex) | Byte Name | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
| 80-C7 | Res0 | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| F8-FF | ResO data | Resistor 0 Calibration Constants (see data sheet Table 8 for weighting) |  |  |  |  |  |  |  |

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Memory Map (continued)

| TABLE 05 (LOOKUP TABLE FOR RESISTOR 1) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Row (hex) | Row Name | Word 0 |  | Word 1 |  | Word 2 |  | Word 3 |  |
|  |  | Byte 0/8 | Byte 1/9 | Byte 2/A | Byte 3/B | Byte 4/C | Byte 5/D | Byte 6/E | Byte 7/F |
| 80 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| 88 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| 90 | ${ }^{\text {<8> }}$ LUT |  |  |  |  |  |  |  |  |
| 98 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| A0 | ${ }^{<88}$ LUT |  |  |  |  |  |  |  |  |
| A8 | ${ }^{\text {<8> }}$ LUT |  |  |  |  |  |  |  |  |
| B0 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| B8 | ${ }^{\text {888 }}$ LUT |  |  |  |  |  |  |  |  |
| C0 | ${ }^{<8>}$ LUT |  |  |  |  |  |  |  |  |
| C8 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| D0 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| D8 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| E0 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| E8 |  | Empty | Empty | Empty | Empty | Empty | Empty | Empty | Empty |
| F0 |  | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved |
| F8 | ${ }^{\text {<10> }}$ Res1 data | Resistor 1 Calibration Constants (see data sheet Table 8) |  |  |  |  |  |  |  |
| EXPANDED BYTES |  |  |  |  |  |  |  |  |  |
| Byte (hex) | Byte Name | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
| 80-C7 | Res1 | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| F8-FF | Res1 data | Resistor 1 Calibration Constants (see data sheet Table 8 for weighting) |  |  |  |  |  |  |  |

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Threshold ${ }_{0}$

- Temp High Alarm ..... $<\mathrm{R}$-all/W-pw2><NV><7FFFh> Temperature measurements above this two's complement threshold set its corresponding alarm bit. Measurements below this threshold clear the alarm bit.
- Temp Low Alarm....... <R-all/W-pw2><NV><8000h $>$ Temperature measurements below this two's complement threshold set its corresponding alarm bit. Measurements above this threshold clear the alarm bit.
- Temp High Warning. $<\mathrm{R}$-all/W-pw2><NV><7FFFh $>$ Temperature measurements above this two's complement threshold set its corresponding warning bit. Measurements below this threshold clear the warning bit.
- Temp Low Warning .. $<\mathrm{R}$-all/W-pw2><NV><8000h $>$ Temperature measurements below this two's complement threshold set its corresponding warning bit. Measurements above this threshold clear the warning bit.


## Threshold ${ }_{1}$

- VCC High Alarm........ <R-all/W-pw2><NV><FFFFh> Voltage measurements of the $\mathrm{V}_{\mathrm{CC}}$ input above this unsigned threshold set its corresponding alarm bit. Measurements below this threshold clear the alarm bit.
- VCC Low Alarm......... $<\mathrm{R}$-all/W-pw2><<NV><0000h> Voltage measurements of the $\mathrm{V}_{\mathrm{CC}}$ input below this unsigned threshold set its corresponding alarm bit. Measurements above this threshold clear the alarm bit.
- VCC High Warning... <R-all/W-pw2><NV><FFFFh> Voltage measurements of the $\mathrm{V}_{\mathrm{CC}}$ input above this unsigned threshold set its corresponding warning bit. Measurements below this threshold clear the warning bit.
- VCC Low Warning..... $<\mathrm{R}$-all/W-pw2 $>\ll \mathrm{NV}><0000 \mathrm{~h}>$ Voltage measurements of the $\mathrm{V}_{\mathrm{CC}}$ input below this unsigned threshold set its corresponding warning bit. Measurements above this threshold clear the warning bit.


## Threshold 2

- Mon1 High Alarm..... <R-all/W-pw2><NV><FFFFh> Voltage measurements of the Mon1 input above this unsigned threshold set its corresponding alarm bit. Measurements below this threshold clear the alarm bit.
- Mon1 Low Alarm ...... <R-all/W-pw2><NV><0000h> Voltage measurements of the Mon1 input below this unsigned threshold set its corresponding alarm bit. Measurements above this threshold clear the alarm bit.
- Mon1 High Warning. $<\mathrm{R}-\mathrm{all} / \mathrm{W}-\mathrm{pw} 2><\mathrm{NV}><\mathrm{FFFFh}>$ Voltage measurements of the Mon1 input above this unsigned threshold set its corresponding warning bit. Measurements below this threshold clear the warning bit.
- Mon1 Low Warning.. $<\mathrm{R}$-all/W-pw2><NV><0000h $>$ Voltage measurements of the Mon1 input below this unsigned threshold set its corresponding warning bit. Measurements above this threshold clear the warning bit.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Threshold 3

- Mon2 High Alarm ..... <R-all/W-pw2><NV><FFFFh> Voltage measurements of the Mon2 input above this unsigned threshold set its corresponding alarm bit. Measurements below this threshold clear the alarm bit.
- Mon2 Low Alarm ...... $<\mathrm{R}-\mathrm{all} / \mathrm{W}-\mathrm{pw} 2><\mathrm{NV}><0000 \mathrm{~h}>$ Voltage measurements of the Mon2 input below this unsigned threshold set its corresponding alarm bit. Measurements above this threshold clear the alarm bit.
- Mon2 High Warning. <R-all/W-pw2><NV><FFFFh> Voltage measurements of the Mon2 input above this unsigned threshold set its corresponding warning bit. Measurements below this threshold clear the warning bit.
- Mon2 Low Warning.. $<\mathrm{R}-\mathrm{all} / \mathrm{W}-\mathrm{pw} 2><\mathrm{NV}><0000 \mathrm{~h}>$ Voltage measurements of the Mon2 input below this unsigned threshold set its corresponding warning bit. Measurements above this threshold clear the warning bit.


## Threshold 4

- Mon3 High Alarm ..... <R-all/W-pw2><NV><FFFFh $>$ Voltage measurements of the Mon3 input above this unsigned threshold set its corresponding alarm bit. Measurements below this threshold clear the alarm bit.
- Mon3 Low Alarm ...... <R-all/W-pw2><NV><0000h> Voltage measurements of the Mon3 input below this unsigned threshold set its corresponding alarm bit. Measurements above this threshold clear the alarm bit.
- Mon3 High Warning. <R-all/W-pw2><NV><FFFFh $>$ Voltage measurements of the Mon3 input above this unsigned threshold set its corresponding warning bit. Measurements below this threshold clear the warning bit.
- Mon3 Low Warning.. <R-all/W-pw2><NV><0000h> Voltage measurements of the Mon3 input below this unsigned threshold set its corresponding warning bit. Measurements above this threshold clear the warning bit.


## User ROM

- User ROM ................. <R-all/W-pw2><NV><00h> Nonvolatile EEPROM memory.


## A2D Value ${ }_{0}$

- Temp Meas ................ $<\mathrm{R}$-all $><\mathrm{W}-\mathrm{NA}><0000 \mathrm{~h}>$ The signed two's complement Direct-toTemperature measurement.
- VCC Meas. $\qquad$ $<$ R-all $><$ W-NA $><0000 \mathrm{~h}>$ Unsigned voltage measurement.
- Mon1 Meas $\qquad$ $<$ R-all $><$ W-NA $><0000 \mathrm{~h}>$ Unsigned voltage measurement.
- Mon2 Meas $\qquad$ $<$ R-all $><$ W-NA $><0000 \mathrm{~h}>$ Unsigned voltage measurement.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

## Register Descriptions (continued)

A2D Value ${ }_{1}$

- Mon3 Meas. $\qquad$ $<\mathrm{R}$-all $><\mathrm{W}-\mathrm{NA}><0000 \mathrm{~h}>$ Unsigned voltage measurement.
- Reserved. $<$ R-all $><$ W-NA $><0000$ h $>$
- Status $<$ R-all><W-see bits><conditional>
a) Rhiz $<\mathrm{R}$-all $><\mathrm{W}-\mathrm{NA}><1 \mathrm{~b}>$ High when resistor outputs are high impedance.
b) Soft Hiz. $<\mathrm{R}$-all $><\mathrm{W}$-all $><0 \mathrm{~b}>$ Setting this bit will make resistor outputs high impedance.
c) Reserved ........... $<$ R-all $><$ W-NA $><0$ b $>$
d) TxF $<$ R-all $>$ <W-NA><conditional> Reflects the logic level to be output on pin Out1.
e) $R x L$ $<\mathrm{R}$-all $><\mathrm{W}-\mathrm{NA}><$ conditional $>$ Reflects the logic level to be output on pin Out2.
f) Rdyb $\qquad$ $<\mathrm{R}$-all $><\mathrm{W}-\mathrm{NA}><\mathrm{V}_{\text {CC }}$ dependant $>$ Ready Bar. When the supply is above the Power-On-Analog (POA) trip point, this bit is active LOW. Thus, this bit reads a logic One if the supply is below POA or too low to communicate over the 2 -wire bus.
- Update $\qquad$ $<\mathrm{R}$-all/W-all $><00 \mathrm{~h}>$ Status of completed conversions. At Power-On, these bits are cleared and will be set as each conversion is completed. These bits can be cleared so that a completion of a new conversion may be verified.
a) Temp Rdy .......... Temperature conversion is ready.
b) VCC Rdy............ V $\mathrm{V}_{\mathrm{CC}}$ conversion is ready.
c) Mon1 Rdy.......... Mon1 conversion is ready.
d) Mon2 Rdy.......... Mon2 conversion is ready.
e) Mon3 Rdy.......... Mon3 conversion is ready.
- Alarm $_{0}$ $\qquad$ $<$ R-all $><\mathrm{W}-\mathrm{NA}><10 \mathrm{~h}>$ High Alarm Status bits.
a) Temp Hi............. High Alarm Status for Temperature measurement.
b) Temp Lo ............ Low Alarm Status for Temperature measurement.
c) VCC Hi .............. High Alarm Status for VCC measurement.
d) VCC Lo .............. Low Alarm Status for VCC measurement. This bit is set when theV ${ }_{C C}$ supply is below the POA trip point value. It clears itself when a VCC measurement is completed and the value is above the low threshold.
e) MON1 Hi........... High Alarm Status for MON1 measurement.
f) MON1 Lo .......... Low Alarm Status for MON1 measurement.
g) MON2 Hi........... High Alarm Status for MON2 measurement.
h) MON2 Lo ........... Low Alarm Status for MON2 measurement.
- Alarm ${ }_{1}$...................... <R-all><W-NA><00h $>$ Low Alarm Status bits.
a) MON3 HI........... High Alarm Status for MON3 measurement.
b) MON3 Lo .......... Low Alarm Status for MON3 measurement.
c) Mint .................. Maskable Interrupt. If an alarm is present and the alarm is enabled then this bit is high. Otherwise this bit is a zero.
- Reserved.
$<$ R-all $><$ W-NA $><00 \mathrm{~h}>$.
- Warning $<$ R-all $><$ W-NA $><00 h>$ High Warning Status bits.
a) Temp Hi............. High Warning Status for Temperature measurement.
b) Temp Lo ............ Low Warning Status for Temperature measurement.
c) $\mathrm{VCCH}^{\mathrm{Hi}}$............. High Warning Status for $\mathrm{V}_{\mathrm{CC}}$ measurement.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

# Register Descriptions (continued) 

d) $\mathrm{V}_{\mathrm{CC}} \mathrm{Lo}$ $\qquad$ Low Warning Status for $\mathrm{V}_{\mathrm{CC}}$ measurement. This bit is set when the $\mathrm{V}_{\mathrm{CC}}$ supply is below the POA trip point value. It clears itself when a VCC measurement is completed and the value is above the low threshold.
e) MON1 Hi........... High Warning Status for MON1 measurement.
f) MON1 Lo .......... Low Warning Status for MON1 measurement.
g) MON2 Hi........... High Warning Status for MON2 measurement.
h) MON2 Lo .......... Low Warning Status for MON2 measurement.

- Warning ${ }_{1}$.................. $<\mathrm{R}$-all $><\mathrm{W}-\mathrm{NA}><00 \mathrm{~h}>$ Low warning Status bits.
a) MON3 HI........... High Warning Status for MON3 measurement.
b) MON3 Lo........... Low Warning Status for MON3 measurement.

Table Select

- Reserved .................. $<$ R-NA $><$ W-all $><00 \mathrm{~h}>$
- PWE.
$<$ R-NA $><$ W-all $><$ FFFFFFFFh $>$ Password Entry. There are two passwords for the DS1856. The lower level password (PW1) has all the access of a normal user plus those made available with PW1. The higher level password (PW2) has all of the access of PW1 plus those made available with PW2. The value of the password reside in EE inside of PW2 memory.
- TBL Sel.
$<\mathrm{R}$-all/W-all $><00 \mathrm{~h}>$ Table Select. The upper memory tables of the DS1856 are accessible by writing the correct table value in this register. If the device is configured to have a Table 01 h then writing a 00 h ora 01 h in this byte will access that table.


## Config ${ }_{0}$

$\qquad$ <R-pw2/W-pw2><NV><03h>
a) TEN.

At Power-On this bit is HIGH, which enables autocontrol of the LUT. If this bit is written to a ZERO then the resistor values are writeable by the user and the LUT recalls are disabled. This allows the user to interactively test their modules by manually writing resistor values. The resistors will update with the new value at the end of the write cycle. Thus both registers (Res0 and Res1) should be written in the same write cycle. The 2 -wire Stop condition is the end of the write cycle.
b) AEN At Power-On this bit is HIGH, which enables autocontrol of the LUT. If this bit is cleared to a ZERO then the temperature calculated index value ( T index ) is writeable by the user and the updates of calculated indexes are disabled. This allows the user to interactively test their modules by controlling the indexing for the look-up tables. The recalled values from the LUTs will appear in the resistor registers after the next completion of a temperature conversion (just like it would happen in auto mode). Both pots will update at the same time (just like it would happen in auto mode).

- TIndex...................... $<\mathrm{R}$-pw2><W-pw2+AENb><00h> Holds the calculated index based on the Temperature Measurement. This index is used for the address during Look-up of Tables 4 and 5.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

## Register Descriptions (continued)

- Res0 $\qquad$ $<$ R-pw2 $><$ W-pw2+TENb $><$ FFh $>$ The base value used for Resistor 0 and recalled from Table 4 at the memory address found in T Index. This register is updated at the end of the Temperature conversion.
- Res1 $\qquad$ $<$ R-pw $2><$ W-pw2+TENb $><$ FFh $>$ The base value used for Resistor 1 and recalled from Table 5 at the memory address found in T Index. This register is updated at the end of the Temperature conversion.
- Reserved. $<$ R-pw2 $><$ W-pw2 $><00 h>$ SRAM.
- Int Enable $\qquad$ $<$ R-pw2/W-pw2 $><$ NV $><$ F8h $>$ Configures the maskable interrupt for the Out1 pin.
a) Temp Enable...... Temperature measurements, outside of the threshold limits, are enabled to create an active interrupt on the Out1 pin.
b) VCC Enable......... VCC measurements, outside of the threshold limits, are enabled to create an active interrupt on the Outl pin.
c) MON1 Enable.... MON1 measurements, outside of the threshold limits, are enabled to create an active interrupt on the Outl pin.
d) MON2 Enable.... MON2 measurements, outside of the threshold limits, are enabled to create an active interrupt on the Outl pin.
e) MON3 Enable.... MON3 measurements, outside of the threshold limits, are enabled to create an active interrupt on the Out1 pin.
f) Reserved EE.
- Config $\qquad$ $<$ R-pw2/W-pw2 $><$ NV $><00 \mathrm{~h}>$ Configure the memory location and the polarity of the digital outputs.
a) Reserved EE.
b) ADEN $\qquad$ Auxiliary Device ENable. 128 bytes of EE are addressable depending on the value of this bit. When set to a 1 , the memory is located in or as Table 01 h . When set to a 0 , the memory is addressed by using a Device address of A0h and the locations in memory are 00 h to 7 Fh .
c) ADFIX ............... Device Fixable Address. When this bit is set to a 1, the main memory of the DS1856 is a Device Address equal to the value found in byte chip_address. When this bit is set to a 0 the main memory of the DS1856 is a Device Address of A2h.
d) Inv1 .................... Enable the inversion of the relationship between IN1 and OUT1.
e) Inv2 Enable the inversion of the relationship between IN2 and OUT2.
- Chip Address ............. This value becomes the Device address for the main memory when $A D F I X$ bit is set.
- Right Shift ${ }_{1}$ $\qquad$ Allows for right-shifting the final answer of some voltage measurements. This allows for scaling the measurements to the smallest full-scale voltage and then right-shifting the final result so the reading is weighted to the correct lsb.
- Right Shift $t_{0} \ldots . . . . . . . . . . .$. Allows for right-shifting the final answer of some voltage measurements. This allows for scaling the measurements to the smallest full-scale voltage and then right-shifting the final result so the reading is weighted to the correct lsb.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Scale $_{0}$

- VCC Scale. $\qquad$ $<\mathrm{R}-\mathrm{pw} 2 / \mathrm{W}-\mathrm{pw} 2><\mathrm{NV}><6.5535 \mathrm{~V}>$ Controls the Scaling or Gain of the $\mathrm{V}_{C C}$ measurements.
- MONI Scale. $\qquad$ $<\mathrm{R}-\mathrm{pw} 2 / \mathrm{W}-\mathrm{pw} 2><\mathrm{NV}><2.500 \mathrm{~V}>$ Controls the Scaling or Gain of the MON1 measurements.
- MON2 Scale $<\mathrm{R}$-pw2/W-pw2><2.500V> Controls the Scaling or Gain of the MON2 measurements.

Scale $_{1}$

- MON3 Scale............... <R-pw2/W-pw2><NV><2.500V> Controls the Scaling or Gain of the MON3 measurements.

Offset $_{0}$

- VCC Offset $\qquad$ $<\mathrm{R}-\mathrm{pw} 2 / \mathrm{W}-\mathrm{pw} 2><\mathrm{NV}><0000 \mathrm{~h}>$ Allows for offset control of $\mathrm{V}_{C C}$ measurement if desired.
- MONI Offset. $\qquad$ $<\mathrm{R}$-pw2/W-pw2><NV><0000h> Allows for offset control of MON1 measurement if desired.
- MON2 Offset $\qquad$ $<$ R-pw2/W-pw2><NV><0000h> Allows for offset control of MON2 measurement if desired.

Offset ${ }_{1}$

- MON3 Offset .............. <R-pw2/W-pw2><NV><0000h> Allows for offset control of MON3 measurement if desired.
- Temp Offset $\qquad$ $<$ R-pw2/W-pw2><NV><0000h> Allows for offset control of Temp measurement if desired.

PWD Value

- Password 1................ <R-NA/W-pw2><NV><FFFFFFFFh> The PWE value is compared against the value written to this location to enable PW1 access. At power-on, the PWE value is set to all ones. Thus writing these bytes to all ones grants PW1 access on power-up without writing the password entry.
- Password 2. $<$ R-NA/W-pw2 $><$ NV $><$ FFFFFFFFh $>$ The PWE value is compared against the value written to this location to enable PW2 access. At power-on, the PWE value is set to all ones. Thus writing these bytes to all ones grants PW2 access on power-up without writing the password entry.

LUT

- Res0 $\qquad$ The unsigned value for Resistor 0 .
- Res1 $\qquad$ The unsigned value for Resistor 1.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 


#### Abstract

Programming the Look-up Table (LUT) The following equation can be used to determine which resistor position setting, 00h to FFh, should be written in the LUT to achieve a given resistance at a specific temperature.


$$
\operatorname{pos}(\alpha, R, C)=\frac{R-u \times\left[1+v \times(C-25)+w \times(C-25)^{2}\right]}{(\times) \times\left[1+y \times(C-25)+z \times(C-25)^{2}\right]}-\alpha
$$

$R=$ the resistance desired at the output terminal
$\mathrm{C}=$ temperature in degrees Celsius
$u, v, w, x_{1}, x 0, y, z$, and $\alpha$ are calculated values found in the corresponding look-up tables. The variable $\times$ from the equation above is separated into $x_{1}$ (the MSB of $x$ ) and $x_{0}$ (the LSB of $x$ ). Their addresses and LSB values are given below. The variable $y$ is assigned a value. All other variables are unsigned. Resistor 0 variables are found in Table 04, and Resistor 1 variables are found in Table 05.
When shipped from the factory, all other memory locations in the LUTs are programmed to FFh.

## Table 8. Calibration Constants

| ADDRESS | VARIABLE | LSB |
| :---: | :---: | :---: |
| F8h | $u$ | $2^{0}$ |
| F9h | $v$ | $20 \mathrm{E}-6$ |
| FAh | $w$ | $100 \mathrm{E}-9$ |
| FBh | $x_{1}$ | $2^{1}$ |
| FCh | $x_{0}$ | $2^{-7}$ |
| FDh |  | $y$ |
|  |  | $2 \mathrm{E}-6$ (signed) |
|  |  | $8 \mathrm{E}-6$ (signed) for -025 version |
| FEh | $z$ | $4 \mathrm{E}-6$ (signed) for -030 version |
| FFh | $\alpha$ | $10 \mathrm{E}-9$ |

## Internal Calibration

The DS1856 has two methods for scaling an analog input to a digital result. The two methods are gain and offset. Each of the inputs (VCC, MON1, MON2, and MON3) has a unique register for the gain and the offset found in Table 03h, 92h to 99h, and A2h to A9h.

To scale the gain and offset of the converter for a specific input, you must first know the relationship between the analog input and the expected digital result. The input that would produce a digital result of all zeros is the null value (normally this input is GND). The input that would produce a digital result of all ones is the fullscale (FS) value. The FS value is also found by multiplying an all-ones digital answer by the weighted LSB (e.g., since the digital reading is a 16-bit register, let us assume that the LSB of the lowest weighted bit is $50 \mu \mathrm{~V}$, then the FS value is $65,535 \times 50 \mu \mathrm{~V}=3.27675 \mathrm{~V}$ ).
A binary search is used to scale the gain of the converter. This requires forcing two known voltages to the input pin. It is preferred that one of the forced voltages is the null input and the other is $90 \%$ of FS . Since the LSB of the least significant bit in the digital reading register is known, the expected digital results are also known for both inputs (null/LSB = CNT1 and $90 \%$ FS/ LSB = CNT2).
The user might not directly force a voltage on the input. Instead they have a circuit that transforms light, frequency, power, or current to a voltage that is the input to the DS1856. In this situation, the user does not need to know the relationship of voltage to expected digital result but instead knows the relationship of light, frequency, power, or current to the expected digital result.
An explanation of the binary search used to scale the gain is best served with the following example pseudocode:
/* Assume that the null input is 0.5 V . */
$/ *$ In addition, the requirement for LSB is $50 \mu \mathrm{~V}$. */
FS $=65535 \times 50 \mathrm{E}-6 ; \quad \quad / * 3.27675$ */
CNT1 $=0.5 / 50 \mathrm{E}-6 ; \quad \quad$ * 10000 */
CNT2 $=0.90 \times$ FS $/ 50 \mathrm{E}-6 ; \quad / * 58981.5 * /$
/* Thus the null input 0.5 V and the $90 \%$ of FS input is 2.949075V. */

Set the trim-offset-register to zero;
Set Right-Shift register to zero (typically zero.
See the Right-Shifting section);
gain_result = Oh;
Clamp $=$ FFF8h/2^(Right_Shift_Register);
For $n=15$ down to 0
begin

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

gain_result = gain_result $+2^{\wedge} n$;<br>Force the $90 \%$ FS input (2.949075V);<br>Meas2 = read the digital result from the part;<br>If Meas2 >= Clamp then<br>gain_result = gain_result $-2^{\wedge} n$;<br>Else<br>Force the null input ( 0.5 V );<br>Meas1 = read the digital result from the part;<br>if (Meas2 - Meas1) > (CNT2 CNT1) then<br>gain_result = gain_result $-2^{\wedge} n$;

end;
Set the gain register to gain_result;
The gain register is now set and the resolution of the conversion will best match the expected LSB. The next step is to calibrate the offset of the DS1856. With the correct gain value written to the gain register, again force the null input to the pin. Read the digital result from the part (Meas1). The offset value is equal to the negative value of Meas1.

$$
\text { Offset_Register=[ Meas1 } \left.\frac{4}{}\right]
$$

The calculated offset is now written to the DS1856 and the gain and offset scaling is now complete.

Right-Shifting A/D Conversion Result (Scalable Dynamic Ranging) The right-shifting method is used to regain some of the lost ADC range of a calibrated system. If a system is calibrated so the maximum expected input results in a digital output value of less than 7FFFh (1/2 FS), then it is a candidate for using the right-shifting method.
If the maximum desired digital output is less than 7FFFh, then the calibrated system is using less than $1 / 2$ of the ADC's range. Similarly, if the maximum desired digital output is less than 1FFFh, then the calibrated system is only using $1 / 8$ of the ADC's range. For example, if using a zero for the right-shift during internal calibration and the maximum expected input results in a maximum digital output less than 1FFCh, only $1 / 8$ of the ADC's range is used. If left like this, the three MS bits of the ADC will never be used. In this example, a value of 3 for the rightshifting maximizes the ADC range. No resolution is lost since this is a 12-bit converter that is left justified. The
value can be right-shifted four times without losing resolution. Table 9 shows when the right-shifting method can be used.

## Temperature Conversion

The direct-to-digital temperature sensor measures temperature through the use of an on-chip temperature measurement technique with a $-40^{\circ} \mathrm{C}$ to $+102^{\circ} \mathrm{C}$ operating range. Temperature conversions are initiated upon power-up, and the most recent conversion is stored in memory locations 60h and 61h of the Main Device, which are updated every tframe. Temperature conversions do not occur during an active read or write to memory.
The value of each resistor is determined by the tempera-ture-addressed look-up table. The look-up table assigns a unique value to each resistor for every $2^{\circ} \mathrm{C}$ increment with a $1^{\circ} \mathrm{C}$ hysteresis at a temperature transition over the operating temperature range (see Figure 4).

## Table 9. Right Shifting

| OUTPUT RANGE USED <br> WITH ZERO RIGHT-SHIFTS | NUMBER OF <br> RIGHT-SHIFTS NEEDED |
| :---: | :---: |
| Oh....FFFFh | 0 |
| Oh...7FFFh | 1 |
| Oh...3FFFh | 2 |
| Oh....1FFFh | 3 |
| Oh....0FFFh | 4 |



Figure 4. Look-Up Table Hysteresis

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 


#### Abstract

Power-Up and Low-Voltage Operation During power-up, the device is inactive until VCC exceeds the digital power-on-reset voltage (POD). At this voltage, the digital circuitry, which includes the 2-wire interface, becomes functional. However, EEPROMbacked registers/settings cannot be internally read (recalled into shadow SRAM) until VCC exceeds the analog power-on-reset voltage (POA), at which time the remainder of the device becomes fully functional. Once VCC exceeds POA, the RDYB bit in byte 6Eh of the Main Device memory is timed to go from a 1 to a 0 and indicates when analog-to-digital conversions begin. If VCC ever dips below POA, the RDYB bit reads as a 1 again. Once a device exceeds POA and the EEPROM is recalled, the values remain active (recalled) until VCC falls below POD.

For 2-wire device addresses sourced from EEPROM (ADFIX = 1), the device address defaults to A2h until VcC exceeds POA and the EEPROM values are recalled. The Auxiliary Device (AOh) is always available within this voltage window (between POD and the EEPROM recall) regardless of the programmed state of ADEN. Furthermore, as the device powers up, the Vcclo alarm flag (bit 4 of 70h in Main Device) defaults to a 1 until the first VCC analog-to-digital conversion occurs and sets or clears the flag accordingly.


## 2-Wire Operation

Clock and Data Transitions: The SDA pin is normally pulled high with an external resistor or device. Data on the SDA pin may only change during SCL-low time periods. Data changes during SCL-high periods will indicate a START or STOP condition depending on the conditions discussed below. See the timing diagrams in Figures 5 and 6 for further details.
START Condition: A high-to-low transition of SDA with SCL high is a START condition that must precede any other command. See the timing diagrams in Figures 5 and 6 for further details.
STOP Condition: A low-to-high transition of SDA with SCL high is a STOP condition. After a read or write sequence, the stop command places the DS1856 into a low-power mode. See the timing diagrams in Figures 5 and 6 for further details.
Acknowledge: All address and data bytes are transmitted through a serial protocol. The DS1856 pulls the SDA line low during the ninth clock pulse to acknowledge that it has received each word.

Standby Mode: The DS1856 features a low-power mode that is automatically enabled after power-on, after a STOP command, and after the completion of all internal operations.
Device Addressing: The DS1856 must receive an 8-bit device address, the slave address byte, following a START condition to enable a specific device for a read or write operation. The address is clocked into this part MSB to LSB. The address byte consists of either A2h or the value in Table 03, 8Ch for the Main Device or AOh for the Auxiliary Device, then the R/W bit. This byte must match the address programmed into Table 03, 8Ch or A0h (for the Auxiliary Device). If a device address match occurs, this part will output a zero for one clock cycle as an acknowledge and the corresponding block of memory is enabled (see the Memory Organization section). If the R/W bit is high, a read operation is initiated. If the $R / \bar{W}$ is low, a write operation is initiated (see the Memory Organization section). If the address does not match, this part returns to a lowpower mode.

## Write Operations

After receiving a matching address byte with the R/W bit set low, if there is no write protect, the device goes into the write mode of operation (see the Memory Organization section). The master must transmit an 8bit EEPROM memory address to the device to define the address where the data is to be written. After the byte has been received, the DS1856 transmits a zero for one clock cycle to acknowledge the address has been received. The master must then transmit an 8-bit data word to be written into this address. The DS1856 again transmits a zero for one clock cycle to acknowledge the receipt of the data. At this point, the master must terminate the write operation with a STOP condition. The DS1856 then enters an internally timed write process $t_{w}$ to the EEPROM memory. All inputs are dis-
abled during this byte write cycle.

The DS1856 is capable of an 8-byte page write. A page is any 8 -byte block of memory starting with an address evenly divisible by eight and ending with the starting address plus seven. For example, addresses 00h through 07h constitute one page. Other pages would be addresses 08h through OFh, 10h through 17h, 18h through 1Fh, etc. abled during this byte write cycle.

## Page Write

 through 1Fh, etc.
# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

A page write is initiated the same way as a byte write, but the master does not send a STOP condition after the first byte. Instead, after the slave acknowledges the data byte has been received, the master can send up to seven more bytes using the same nine-clock sequence. The master must terminate the write cycle with a STOP condition or the data clocked into the DS1856 will not be latched into permanent memory.
The address counter rolls on a page during a write. The counter does not count through the entire address space as during a read. For example, if the starting address is 06 h and 4 bytes are written, the first byte goes into address 06 h . The second goes into address 07h. The third goes into address 00h (not 08h). The fourth goes into address 01h. If 9 bytes or more are written before a STOP condition is sent, the first bytes sent are overwritten. Only the last 8 bytes of data are written to the page.
Acknowledge Polling: Once the internally timed write has started and the DS1856 inputs are disabled, acknowledge polling can be initiated. The process involves transmitting a START condition followed by the device address. The R/W bit signifies the type of operation that is desired. The read or write sequence will only be allowed to proceed if the internal write cycle has completed and the DS1856 responds with a zero.

## Read Operations

After receiving a matching address byte with the R/W bit set high, the device goes into the read mode of operation. There are three read operations: current address read, random read, and sequential address read.

## Current Address Read

The DS1856 has an internal address register that maintains the address used during the last read or write operation, incremented by one. This data is maintained as long as $V_{C C}$ is valid. If the most recent address was the last byte in memory, then the register resets to the first address.
Once the device address is clocked in and acknowledged by the DS1856 with the R/W bit set to high, the current address data word is clocked out. The master does not respond with a zero, but does generate a STOP condition afterwards.

## Single Read

A random read requires a dummy byte write sequence to load in the data byte address. Once the device and data address bytes are clocked in by the master and acknowledged by the DS1856, the master must generate another START condition. The master now initiates a current
address read by sending the device address with the R/W bit set high. The DS1856 acknowledges the device address and serially clocks out the data byte.

## Sequential Address Read

Sequential reads are initiated by either a current address read or a random address read. After the master receives the first data byte, the master responds with an acknowledge. As long as the DS1856 receives this acknowledge after a byte is read, the master can clock out additional data words from the DS1856. After reaching address FFh, it resets to address $00 h$.
The sequential read operation is terminated when the master initiates a STOP condition. The master does not respond with a zero.
The following section provides a detailed description of the 2-wire theory of operation.

## 2-Wire Serial-Port Operation

The 2-wire serial-port interface supports a bidirectional data transmission protocol with device addressing. A device that sends data on the bus is defined as a transmitter, and a device that receives data as a receiver. The device that controls the message is called a master. The devices that are controlled by the master are slaves. The bus must be controlled by a master device that generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions. The DS1856 operates as a slave on the 2-wire bus. Connections to the bus are made through the open-drain I/O lines SDA and SCL. The following I/O terminals control the 2 -wire serial port: SDA, SCL. Timing diagrams for the 2 -wire serial port can be found in Figures 5 and 6. Timing information for the 2-wire serial port is provided in the AC Electrical Characteristics table for 2-wire serial communications.
The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is high. Changes in the data line while the clock line is high will be interpreted as control signals.
Accordingly, the following bus conditions have been defined:
Bus not busy: Both data and clock lines remain high.
Start data transfer: A change in the state of the data line from high to low while the clock is high defines a START condition.


# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Stop data transfer: A change in the state of the data line from low to high while the clock line is high defines the STOP condition.
Data valid: The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the high period of the clock signal. The data on the line can be changed during the low period of the clock signal. There is one clock pulse per bit of data. Figures 5 and 6 detail how data transfer is accom-
plished on the 2-wire bus. Depending on the state of the $\mathrm{R} / \overline{\mathrm{W}}$ bit, two types of data transfer are possible.
Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of data bytes transferred between START and STOP conditions is not limited and is determined by the master device. The information is transferred byte-wise and each receiver acknowledges with a ninth bit.


Figure 5. 2-Wire Data Transfer Protocol


Figure 6. 2-Wire AC Characteristics

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Within the bus specifications, a standard mode ( 100 kHz clock rate) and a fast mode ( 400 kHz clock rate) are defined. The DS1856 works in both modes.
Acknowledge: Each receiving device, when addressed, is obliged to generate an acknowledge after the byte has been received. The master device must generate an extra clock pulse, which is associated with this acknowledge bit.
A device that acknowledges must pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is a stable low during the high period of the acknowledge-related clock pulse. Setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line high to enable the master to generate the STOP condition.

1) Data transfer from a master transmitter to a slave receiver. The first byte transmitted by the master is the command/control byte. Next follows a number of data bytes. The slave returns an acknowledge bit after each received byte.
2) Data transfer from a slave transmitter to a master receiver. The master transmits the first byte (the command/control byte) to the slave. The slave then returns an acknowledge bit. Next follows a number of data bytes transmitted by the slave to the master. The master returns an acknowledge bit after all received bytes other than the last byte. At the end of the last received byte, a not acknowledge can be returned.

The master device generates all serial clock pulses and the START and STOP conditions. A transfer is ended with a STOP condition or with a repeated START condition. Since a repeated START condition is also the beginning of the next serial transfer, the bus is not released.
The DS1856 can operate in the following two modes:

1) Slave Receiver Mode: Serial data and clock are received through SDA and SCL, respectively. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are recognized as the beginning and end of a serial transfer. Address recognition is performed by hardware after the slave (device) address and direction bit have been received.
2) Slave Transmitter Mode: The first byte is received and handled as in the slave receiver mode. However, in this mode the direction bit indicates that the transfer direction is reversed. Serial data is transmitted on SDA by the DS1856, while the serial clock is input on SCL. START and STOP conditions are recognized as the beginning and end of a serial transfer.

# Dual, Temperature-Controlled Resistors with Internally Calibrated Monitors and Password Protection 

Ordering Information (continued)

| PART | RESO/RES1 <br> RESISTANCE <br> $\mathbf{( k} \boldsymbol{\Omega})$ | PIN-PACKAGE |
| :--- | :--- | :--- |
| DS1856B-050 | $50 / 50$ | 16 CSBGA |
| DS1856B-050/T\&R | $50 / 50$ | 16 CSBGA |
| DS1856B-050+ | $50 / 50$ | 16 CSBGA |
| DS1856B-050+T\&R | $50 / 50$ | 16 CSBGA |
| DS1856E-050 | $50 / 50$ | 16 TSSOP |
| DS1856E-050/T\&R | $50 / 50$ | 16 TSSOP |
| DS1856E-020 | $20 / 20$ | 16 TSSOP |
| DS1856E-020/T\&R | $20 / 20$ | 16 TSSOP |
| DS1856B-020 | $20 / 20$ | 16 CSBGA |
| DS1856B-020/T\&R | $20 / 20$ | 16 CSBGA |
| DS1856B-020+ | $20 / 20$ | 16 CSBGA |


| PART | RESO/RES1 <br> RESISTANCE <br> $(\mathbf{k} \Omega \boldsymbol{)}$ | PIN-PACKAGE |
| :--- | :--- | :--- |
| DS1856B-020+T\&R | $20 / 20$ | 16 CSBGA |
| DS1856B-030 | $30 / 10$ | 16 CSBGA |
| DS1856E-030+ | $30 / 10$ | 16 TSSOP |
| DS1856E-030+T\&R | $30 / 10$ | 16 TSSOP |
| DS1856B-030+ | $30 / 10$ | 16 CSBGA |
| DS1856B-030+T\&R | $30 / 10$ | 16 CSBGA |
| DS1856E-002 | $10 / 2.5$ | 16 TSSOP |
| DS1856E-002/T\&R | $10 / 2.5$ | 16 TSSOP |
| DS1856B-002 | $10 / 2.5$ | 16 CSBGA |
| DS1856B-002/T\&R | $10 / 2.5$ | 16 CSBGA |
| DS1856B-025 | $2.5 / 2.5$ | 16 CSBGA |

+Denotes lead-free package.
T\&R denotes tape-and-reel package.
Note: All devices are specified over the $-40^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ temperature range.

## Chip Information

TRANSISTOR COUNT: 51,061
SUBSTRATE CONNECTED TO GROUND

## Package Information

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

[^0][^1]
# OCEAN CHIPS <br> Океан Электроники <br> Поставка электронных компонентов 

Компания «Океан Электроники» предлагает заключение долгосрочных отношений при поставках импортных электронных компонентов на взаимовыгодных условиях!

Наши преимущества:

- Поставка оригинальных импортных электронных компонентов напрямую с производств Америки, Европы и Азии, а так же с крупнейших складов мира;
- Широкая линейка поставок активных и пассивных импортных электронных компонентов (более 30 млн. наименований);
- Поставка сложных, дефицитных, либо снятых с производства позиций;
- Оперативные сроки поставки под заказ (от 5 рабочих дней);
- Экспресс доставка в любую точку России;
- Помощь Конструкторского Отдела и консультации квалифицированных инженеров;
- Техническая поддержка проекта, помощь в подборе аналогов, поставка прототипов;
- Поставка электронных компонентов под контролем ВП;
- Система менеджмента качества сертифицирована по Международному стандарту ISO 9001;
- При необходимости вся продукция военного и аэрокосмического назначения проходит испытания и сертификацию в лаборатории (по согласованию с заказчиком);
- Поставка специализированных компонентов военного и аэрокосмического уровня качества (Xilinx, Altera, Analog Devices, Intersil, Interpoint, Microsemi, Actel, Aeroflex, Peregrine, VPT, Syfer, Eurofarad, Texas Instruments, MS Kennedy, Miteq, Cobham, E2V, MA-COM, Hittite, Mini-Circuits, General Dynamics и др.);

Компания «Океан Электроники» является официальным дистрибьютором и эксклюзивным представителем в России одного из крупнейших производителей разъемов военного и аэрокосмического назначения «JONHON», а так же официальным дистрибьютором и эксклюзивным представителем в России производителя высокотехнологичных и надежных решений для передачи СВЧ сигналов «FORSTAR». JONHON
«JONHON» (основан в 1970 г.)
Разъемы специального, военного и аэрокосмического назначения:
(Применяются в военной, авиационной, аэрокосмической, морской, железнодорожной, горно- и нефтедобывающей отраслях промышленности)
«FORSTAR» (основан в 1998 г.)
ВЧ соединители, коаксиальные кабели, кабельные сборки и микроволновые компоненты:
(Применяются в телекоммуникациях гражданского и специального назначения, в средствах связи, РЛС, а так же военной, авиационной и аэрокосмической отраслях промышленности).


Телефон: 8 (812) 309-75-97 (многоканальный)
Факс: 8 (812) 320-03-32
Электронная почта: ocean@oceanchips.ru
Web: http://oceanchips.ru/
Адрес: 198099, г. Санкт-Петербург, ул. Калинина, д. 2, корп. 4, лит. А


[^0]:    Maxim cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim product. No circuit patent licenses are implied. Maxim reserves the right to change the circuitry and specifications without notice at any time.

[^1]:    © 2006 Maxim Integrated Products
    Printed USA
    MIXXINI is a registered trademark of Maxim Integrated Products, Inc.
    DEALLAS is a registered trademark of Dallas Semiconductor Corporation.

