## **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<br>or any other conditions beyond those in

## **Electrical Characteristics**

(V<sub>DD</sub> = 2.5V to 4.5V, T<sub>A</sub>= -20°C to +70°C, unless otherwise noted. Typical values are at T<sub>A</sub> = +25°C.) (Note 1)



## **Electrical Characteristics (I**2**C INTERFACE)**

 $(2.5V < V<sub>DD</sub> < 4.5V, T<sub>A</sub> = -20°C$  to +70°C, unless otherwise noted.) (Note 1)



**Note 1:** Specifications are 100% tested at  $T_A = +25^\circ$ C. Limits over the operating range are guaranteed by design and characterization.

**Note 2:** All voltages are referenced to GND.

**Note 3:** Test is performed on unmounted/unsoldered parts.

**Note 4:** The voltage is trimmed and verified with 16x averaging.

**Note 5:** This current is always present.

**Note 6:** The IC enters shutdown mode after  $SCL < V_{II}$  and  $SDA < V_{II}$  for longer than 2.5s.

**Note 7:** Timing must be fast enough to prevent the IC from entering sleep mode due to bus low for period  $> t_{\text{SI FFD}}$ .

**Note 8:** f<sub>SCL</sub> must meet the minimum clock low time plus the rise/fall times.

Note 9: The maximum t<sub>HD:DAT</sub> has to be met only if the device does not stretch the low period (t<sub>LOW</sub>) of the SCL signal.

**Note 10:** This device internally provides a hold time of at least 100ns for the SDA signal (referred to the V<sub>IH,MIN</sub> of the SCL signal) to bridge the undefined region of the falling edge of SCL.

**Note 11:** Filters on SDA and SCL suppress noise spikes at the input buffers and delay the sampling instance.

**Note 12:** C<sub>B</sub> is total capacitance of one bus line in pF.



*Figure 1. I2C Bus Timing Diagram*

## **Typical Operating Characteristics**

 $(T_A = +25^{\circ}C$ , battery is Sanyo UF504553F, unless otherwise noted.)

TIME (Hr)



TIME (min)

## **Typical Operating Characteristics (continued)**

 $(T_A = +25^{\circ}C$ , battery is Sanyo UF504553F, unless otherwise noted.)











 $M$ **BATTERY-INSERTION DEBOUNCE/ OCV ACQUISITION**



## **Pin/Bump Configurations**



# **Pin/Bump Descriptions**



### **Detailed Description**

### **ModelGauge Theory of Operation**

The MAX17048/MAX17049 ICs simulate the internal, nonlinear dynamics of a Li+ battery to determine its SOC. The sophisticated battery model considers impedance and the slow rate of chemical reactions in the battery [\(Figure 2](#page-5-0)).

ModelGauge performs best with a custom model, obtained by characterizing the battery at multiple discharge currents and temperatures to precisely model it. At power-on reset (POR), the ICs have a preloaded ROM model that performs well for some batteries. Contact Maxim if you need a custom model.

### **Fuel-Gauge Performance**

In coulomb counter-based fuel gauges, SOC drifts because offset error in the current-sense ADC measurement accumulates over time. Instantaneous error can be very small, but never precisely zero. Error accumulates over time in such systems (typically 0.5%–2% per day) and requires periodic corrections. Some algorithms correct drift using occasional events, and until such an event occurs the algorithm's error is boundless:

- Reaching predefined SOC levels near full or empty
- Measuring the relaxed battery voltage after a long period of inactivity
- Completing a full charge/discharge cycle

<span id="page-5-0"></span>

ModelGauge requires no correction events because it uses only voltage, which is stable over time. As TOCs 8, 9, and 10 show, ModelGauge remains accurate despite the absence of any of the above events; it neither drifts nor accumulates error over time.

To correctly measure performance of a fuel gauge as experienced by end-users, exercise the battery dynamically. Accuracy cannot be fully determined from only simple cycles.

### **Battery Voltage and State-Of-Charge**

Open-circuit voltage (OCV) of a Li+ battery uniquely determines its SOC; one SOC can have only one value of OCV. In contrast, a given  $V_{\text{CELL}}$  can occur at many different values of OCV because  $V_{\text{CFI}}$  is a function of time, OCV, load, temperature, age, and impedance, etc.; one value of OCV can have many values of  $V_{\text{CELL}}$ . Therefore, one SOC can have many values of V<sub>CELL</sub>, so V<sub>CELL</sub> cannot uniquely determine SOC.

[Figure 3](#page-5-1) shows that  $V_{\text{CELL}} = 3.81V$  occurs at 2%, 50%, and 72% SOC.

Even the use of sophisticated tables to consider both voltage and load results in significant error due to the load transients typically experienced in a system. During charging or discharging, and for approximately 30min after,  $V_{\text{CELL}}$  and OCV differ substantially, and  $V_{\text{CELL}}$  has been affected by the preceding hours of battery activity. ModelGauge uses voltage comprehensively.

<span id="page-5-1"></span>

*Figure 2. Block Diagram Figure 3. Instantaneous Voltage Does Not Translate Directly to SOC*

### **Temperature Compensation**

For best performance, the host microcontroller must measure battery temperature periodically, and compensate the RCOMP ModelGauge parameter accordingly, at least once per minute. Each custom model defines constants RCOMP0 (default is 0x97), TempCoUp (default is -0.5), and TempCoDown (default is -5.0). To calculate the new value of CONFIG.RCOMP:

// T is battery temperature (degrees Celsius)

if  $(T > 20)$  {

RCOMP = RCOMP0 + (T - 20) x TempCoUp;

}

else {

RCOMP = RCOMP0 + (T - 20) x TempCoDown;



<span id="page-6-0"></span>

<span id="page-6-1"></span>*Figure 4. Increasing Empty Voltage Reduces Battery Capacity*

### **Impact of Empty-Voltage Selection**

Most applications have a minimum operating voltage below which the system immediately powers off (empty voltage). When characterizing the battery to create a custom model, choose empty voltage carefully. As shown in [Figure 4,](#page-6-0) capacity unavailable to the system increases at an accelerating rate as empty voltage increases.

To ensure a controlled shutdown, consider including operating margin into the fuel gauge based on some low threshold of SOC, for example shutting down at 3% or 5%. This utilizes the battery more effectively than adding error margin to empty voltage.

### **Battery Insertion**

When the battery is first inserted into the system, the fuel-gauge IC has no previous knowledge about the battery's SOC. Assuming that the battery is relaxed, the IC translates its first  $V_{\text{CELL}}$  measurement into the best initial estimate of SOC. Initial error caused by the battery not being in a relaxed state diminishes over time, regardless of loading following this initial conversion. While SOC estimated by a coulomb counter diverges, ModelGauge SOC converges, correcting error automatically as illustrated in [Figure 5;](#page-6-1) initial error has no long-lasting impact.

### <span id="page-6-2"></span>**Battery Insertion Debounce**

Any time the IC powers on or resets (see the *[VRESET/](#page-11-0) [ID Register \(0x18\)](#page-11-0)* section), it estimates that OCV is the maximum of 16  $V_{\text{CELL}}$  samples (1ms each, full 12-bit resolution). OCV is ready 17ms after battery insertion, and SOC is ready 175ms after that.



### **Battery Swap Detection**

If  $V_{\text{CELL}}$  falls below  $V_{\text{RST}}$ , the IC quick-starts when V<sub>CELL</sub> returns above V<sub>RST</sub>. This handles battery swap; the SOC of the previous battery does not affect that of the new one. See the *[Quick-Start](#page-7-0) and [VRESET/ID Register](#page-11-0) [\(0x18\)](#page-11-0)* sections.

### <span id="page-7-0"></span>**Quick-Start**

If the IC generates an erroneous initial SOC, the battery insertion and system powerup voltage waveforms must be examined to determine if a quick-start is necessary, as well as the best time to execute the command. The IC samples the maximum  $V_{\text{CELL}}$  during the first 17ms. See the *[Battery Insertion Debounce](#page-6-2)* section. Unless V<sub>CELL</sub> is fully relaxed, even the best sampled voltage can appear greater or less than OCV. Therefore, quick-start must be used cautiously.

Most systems should not use quick-start because the ICs handle most startup problems transparently, such as intermittent battery-terminal connection during insertion. If battery voltage stabilizes faster than 17ms, as illustrated in [Figure 6](#page-7-1), then do not use quick-start.

The quick-start command restarts fuel-gauge calculations in the same manner as initial power-up of the IC. If the system power-up sequence is so noisy that the initial estimate of SOC has unacceptable error, the system microcontroller might be able to reduce the error by using

<span id="page-7-1"></span>

*Figure 6. Insertion Waveform Not Requiring Quick-Start Command*

quick-start. A quick-start is initiated by a rising edge on the QSTRT pin, or by writing 1 to the quick-start bit in the MODE register.

### <span id="page-7-2"></span>**Power-On Reset (POR)**

POR includes a quick-start, so only use it when the battery is fully relaxed. See the *[Quick-Start](#page-7-0)* section. This command restores all registers to their default values. After this command, reload the custom model. See the *[CMD Register \(0xFE\)](#page-12-0)* section.

### **Hibernate Mode**

The ICs have a low-power hibernate mode that can accurately fuel gauge the battery when the charge/discharge rate is low. By default, the device automatically enters and exits the hibernate mode according to the charge/ discharge rate, which minimizes quiescent current (below 5µA) without compromising fuel-gauge accuracy. The ICs can be forced into hibernate or active modes. Force the IC into hibernate mode to reduce power consumption in applications with less than C/4-rate maximum loading. For applications with higher loading, Maxim recommends the default configuration of automatic control of hibernate mode.

In hibernate mode, the device reduces its ADC conversion period and SOC update to once per 45s. See the *[HIBRT Register \(0x0A\)](#page-10-0)* section for details on how the IC automatically enters and exits hibernate mode.



*Figure 7. Insertion Waveform Requiring Quick-Start Command*

### **Alert Interrupt**

The ICs can interrupt a system microcontroller with five configurable alerts (see [Table 1](#page-8-0)). All alerts can be disabled or enabled with software. When the interrupt occurs, the system microcontroller can determine the cause from the STATUS register.

When an alert is triggered, the IC drives the ALRT pin logic-low and sets CONFIG.ALRT = 1. The ALRT pin remains logic-low until the system software writes CONFIG.ALRT = 0 to clear the alert. The alert function is enabled by default, so any alert can occur immediately upon power-up. Entering sleep mode clears no alerts.

### <span id="page-8-2"></span>**Sleep Mode**

In sleep mode, the IC halts all operations, reducing current consumption to below 1µA. After exiting sleep mode, the IC continues normal operation. In sleep mode, the IC does not detect self-discharge. If the battery changes state while the IC sleeps, the IC cannot detect it, causing SOC error. Wake up the IC before charging or discharging. To enter sleep mode, write MODE.EnSleep = 1 and either:

- Hold SDA and SCL logic-low for a period for t<sub>SLEEP</sub>. A rising edge on SDA or SCL wakes up the IC.
- Write CONFIG.SLEEP = 1. To wake up the IC, write CONFIG.SLEEP = 0. Other communication does not wake up the IC. POR does wake up the IC.

Applications which can tolerate 4µA should use hibernate rather than sleep mode.

### **Register Summary**

All registers must be written and read as 16-bit words; 8-bit writes cause no effect. Any bits marked X (don't care) or read only must be written with the rest of the register, but the value written is ignored by the IC. The values read from don't care bits are undefined. Calculate the register's value by multiplying the 16-bit word by the register's LSb value, as shown in [Table 2.](#page-8-1)

### **VCELL Register (0x02)**

The MAX17048 measures VCELL between the  $V<sub>DD</sub>$  and GND pins. The MAX17049 measures VCELL between the CELL and GND pins. VCELL is the average of four ADC conversions. The value updates every 250ms in active mode and every 45s in hibernate mode.

### **SOC Register (0x04)**

The ICs calculate SOC using the ModelGauge algorithm. This register automatically adapts to variation in battery size since ModelGauge naturally recognizes relative SOC.

The upper byte least-significant bit has units of 1%. The lower byte provides additional resolution.

The first update is available approximately 1s after POR of the IC. Subsequent updates occur at variable intervals depending on application conditions.

### <span id="page-8-0"></span>**Table 1. Alert Interrupt Summary**



### <span id="page-8-1"></span>**Table 2. Register Summary**





### **Table 2. Register Summary (continued)**

<span id="page-9-0"></span>

*Figure 8. MODE Register Format*

### **MODE Register (0x06)**

The MODE register allows the system processor to send special commands to the IC (see [Figure 8\)](#page-9-0).

- **Quick-Start** generates a first estimate of OCV and SOC based on the immediate cell voltage. Use with caution; see the *[Quick-Start](#page-7-0)* section.
- **EnSleep** enables sleep mode. See the *[Sleep Mode](#page-8-2)*  section.
- **HibStat** indicates when the IC is in hibernate mode (read only).

### **VERSION Register (0x08)**

The value of this read-only register indicates the production version of the IC.

### <span id="page-10-0"></span>**HIBRT Register (0x0A)**

To disable hibernate mode, set HIBRT = 0x0000. To always use hibernate mode, set HIBRT = 0xFFFF (see [Figure 9](#page-10-1)).

- **ActThr** (active threshold): If at any ADC sample |OCV-CELL| is greater than ActThr, the IC exits hibernate mode. 1 LSb = 1.25mV.
- **HibThr** (hibernate threshold). If the absolute value of CRATE is less than HibThr for longer than 6min, the IC enters hibernate mode. 1 LSb = 0.208%/hr.

### **CONFIG Register (0x0C)**

- **RCOMP** is an 8-bit value that can be adjusted to optimize IC performance for different lithium chemistries or different operating temperatures. Contact Maxim for instructions for optimization. The POR value of RCOMP is 0x97.
- **SLEEP** forces the IC in or out of sleep mode if Mode. EnSleep is set. Writing 1 forces the IC to enter sleep mode, and 0 forces the IC to exit. The POR value of SLEEP is 0.
- **ALSC** (SOC change alert) enables alerting when SOC changes by at least 1%. Each alert remains until STATUS.SC is cleared, after which the alert automatically clears until SOC again changes by 1%. Do not use this alert to accumulate changes in SOC.
- **ALRT** (alert status bit) is set by the IC when an alert occurs. When this bit is set, the ALRT pin asserts low. Clear this bit to service and deassert the ALRT pin. The power-up default value for ALRT is 0. The STATUS register specifies why the ALRT pin was asserted.
- **ATHD** (empty alert threshold) sets the SOC threshold, where an interrupt is generated on the ALRT pin and can be programmed from 1% up to 32%. The value is (32 - ATHD)% (e.g., 00000b **→** 32%, 00001b **→** 31%, 00010b **→** 30%, 11111b **→** 1%). The POR value of ATHD is 0x1C, or 4%. The alert only occurs on a falling edge past this threshold.

<span id="page-10-1"></span>



*Figure 10. CONFIG Register Format*

### **VALRT Register (0x14)**

This register is divided into two thresholds: Voltage alert maximum (VALRT.MAX) and minimum (VALRT. MIN). Both registers have 1 LSb = 20mV. The IC alerts while VCELL > VALRT.MAX or VCELL < VALRT.MIN (see [Figure 11\)](#page-11-1).

### **CRATE Register (0x16)**

The IC calculates an approximate value for the average SOC rate of change. 1 LSb = 0.208% per hour (not for conversion to ampere).

### <span id="page-11-0"></span>**VRESET/ID Register (0x18)**

### See [Figure 12](#page-11-2).

• **ID** is an 8-bit read-only value that is one-time programmable at the factory, which can be used as an identifier to distinguish multiple cell types in production. Writes to these bits are ignored.

- **VRESET[7:1]** adjusts a fast analog comparator and a slower digital ADC threshold to detect battery removal and reinsertion. For captive batteries, set to 2.5V. For removable batteries, set to at least 300mV below the application's empty voltage, according to the desired reset threshold for your application. If the comparator is enabled, the IC resets 1ms after VCELL rises above the threshold. Otherwise, the IC resets 250ms after the VCELL register rises above the threshold.
- **Dis.** Set Dis = 1 to disable the analog comparator in hibernate mode to save approximately 0.5µA.

<span id="page-11-1"></span>

*Figure 11. VALRT Register Format*

<span id="page-11-2"></span>

*Figure 12. VRESET/ID Register Format*

### **STATUS Register (0x1A)**

An alert can indicate many different conditions. The STATUS register identifies which alert condition was met. Clear the corresponding bit after servicing the alert (see [Figure 13](#page-12-1)).

### **Reset Indicator:**

• **RI** (reset indicator) is set when the device powers up. Any time this bit is set, the IC is not configured, so the model should be loaded and the bit should be cleared.

### **Alert Descriptors:**

These bits are set only when they cause an alert (e.g., if CONFIG.ALSC = 0, then SC is never set).

- **VH** (voltage high) is set when VCELL has been above ALRT.VALRTMAX.
- **VL** (voltage low) is set when VCELL has been below ALRT.VALRTMIN.
- **VR** (voltage reset) is set after the device has been reset if EnVr is set.
- **HD** (SOC low) is set when SOC crosses the value in CONFIG.ATHD.
- **SC** (1% SOC change) is set when SOC changes by at least 1% if CONFIG.ALSC is set.

### **Enable or Disable VRESET Alert:**

**EnVr** (enable voltage reset alert) when set to 1 asserts the ALRT pin when a voltage-reset event occurs under the conditions described by the VRESET/ ID register.

### **TABLE Registers (0x40 to 0x7F)**

Contact Maxim for details on how to configure these registers. The default value is appropriate for some Li+ batteries.

To unlock the TABLE registers, write 0x57 to address 0x3F, and 0x4A to address 0x3E. While TABLE is unlocked, no ModelGauge registers are updated, so relock as soon as possible by writing 0x00 to address 0x3F, and 0x00 to address 0x3E.

### <span id="page-12-0"></span>**CMD Register (0xFE)**

Writing a value of 0x5400 to this register causes the device to completely reset as if power had been removed (see the *[Power-On Reset \(POR\)](#page-7-2)* section). The reset occurs when the last bit has been clocked in. The IC does not respond with an I2C ACK after this command sequence.

### **Application Examples**

The ICs have a variety of configurations, depending on the application. [Table 3](#page-13-0) shows the most common system configurations and the proper pin connections for each.

In all cases, the system must provide pullup circuits for ALRT (if used), SDA, and SDL.

[Figure 14](#page-13-1) shows an example application for a 1S cell pack. In this example, the ALRT pin is connected to the microcontroller's interrupt input to allow the MAX17048 to signal when the battery is low. The QSTRT pin is unused in this application and is connected to GND.

[Figure 15](#page-13-2) shows a MAX17049 example application using a 2S cell pack. The MAX17049 is mounted on the system side and powered from a 3.3V supply generated by the system. The CELL pin is still connected directly to PACK+.

<span id="page-12-1"></span>

### *Figure 13. STATUS Register Format*

<span id="page-13-2"></span><span id="page-13-1"></span>



## <span id="page-13-0"></span>**Table 3. Possible Application Configurations**



## **I**2**C Bus System**

The I2C bus system supports operation as a slave-only device in a single or multislave, and single or multimaster system. Slave devices can share the bus by uniquely setting the 7-bit slave address. The I2C interface consists of a serial-data line (SDA) and serial-clock line (SCL). SDA and SCL provide bidirectional communication between the IC's slave device and a master device at speeds up to 400kHz. The IC's SDA pin operates bidirectionally; that is, when the IC receives data, SDA operates as an input, and when the IC returns data, SDA operates as an open-drain output, with the host system providing a resistive pullup. The IC always operates as a slave device, receiving and transmitting data under the control of a master device. The master initiates all transactions on the bus and generates the SCL signal, as well as the START and STOP bits, which begin and end each transaction.

### **Bit Transfer**

One data bit is transferred during each SCL clock cycle, with the cycle defined by SCL transitioning low-to-high and then high-to-low. The SDA logic level must remain stable during the high period of the SCL clock pulse. Any change in SDA when SCL is high is interpreted as a START or STOP control signal.

### **Bus Idle**

The bus is defined to be idle, or not busy, when no master device has control. Both SDA and SCL remain high when the bus is idle. The STOP condition is the proper method to return the bus to the idle state.

### **START and STOP Conditions**

The master initiates transactions with a START condition (S) by forcing a high-to-low transition on SDA while SCL is high. The master terminates a transaction with a STOP condition (P), a low-to-high transition on SDA while SCL is high. A Repeated START condition (Sr) can be used in place of a STOP then START sequence to terminate one transaction and begin another without returning the bus to the idle state. In multimaster systems, a Repeated START allows the master to retain control of the bus. The START and STOP conditions are the only bus activities in which the SDA transitions when SCL is high.

### **Acknowledge Bits**

Each byte of a data transfer is acknowledged with an acknowledge bit (A) or a no-acknowledge bit (N). Both the master and the MAX17048 slave generate acknowledge bits. To generate an acknowledge, the receiving device must pull SDA low before the rising edge of the acknowledge-related clock pulse (ninth pulse) and keep it low until SCL returns low. To generate a no- acknowledge (also called NAK), the receiver releases SDA before the rising edge of the acknowledge-related clock pulse and leaves SDA high until SCL returns low. Monitoring the acknowledge bits allows for detection of unsuccessful data transfers. An unsuccessful data transfer can occur if a receiving device is busy or if a system fault has occurred. In the event of an unsuccessful data transfer, the bus master should reattempt communication.

### **Data Order**

A byte of data consists of 8 bits ordered most significant bit (MSb) first. The least significant bit (LSb) of each byte is followed by the acknowledge bit. The IC registers composed of multibyte values are ordered MSB first. The MSB of multibyte registers is stored on even datamemory addresses.

### **Slave Address**

A bus master initiates communication with a slave device by issuing a START condition followed by a slave address (SAddr) and the read/write (R/W) bit. When the bus is idle, the ICs continuously monitor for a START condition followed by its slave address. When the ICs receive a slave address that matches the value in the slave address register, they respond with an acknowledge bit during the clock period following the R/W bit. The 7-bit slave address is fixed to 0x6C (write)/0x6D (read):



### **Read/Write Bit**

The R/W bit following the slave address determines the data direction of subsequent bytes in the transfer. R/W = 0 selects a write transaction with the following bytes being written by the master to the slave. R/W = 1 selects a read transaction with the following bytes being read from the slave by the master [\(Table 4\)](#page-15-0).



### <span id="page-15-0"></span>**Table 4. I2C Protocol Key**

### **Bus Timing**

The ICs are compatible with any bus timing up to 400kHz. No special configuration is required to operate at any speed.

### **I2C Command Protocols**

The command protocols involve several transaction formats. The simplest format consists of the master writing the START bit, slave address, R/W bit, and then monitoring the acknowledge bit for presence of the ICs. More complex formats, such as the Write Data and Read Data, read data and execute device-specific operations. All bytes in each command format require the slave or host to return an acknowledge bit before continuing with the next byte. [Table 4](#page-15-0) shows the key that applies to the transaction formats.

### **Basic Transaction Formats**

A write transaction transfers 2 or more data bytes to the ICs. The data transfer begins at the memory address supplied in the MAddr byte. Control of the SDA signal is retained by the master throughout the transaction, except for the acknowledge cycles:

A read transaction transfers 2 or more bytes from the ICs. Read transactions are composed of two parts, a write portion followed by a read portion, and are therefore inherently longer than a write transaction. The write portion communicates the starting point for the read operation. The read portion follows immediately, beginning with a Repeated START, slave address with R/W set to a 1. Control of SDA is assumed by the ICs, beginning with the slave address acknowledge cycle. Control of the SDA signal is retained by the ICs throughout the transaction, except for the acknowledge cycles. The master indicates

the end of a read transaction by responding to the last byte it requires with a no acknowledge. This signals the ICs that control of SDA is to remain with the master following the acknowledge clock.

Write: S. SAddr W. A. MAddr. A. Data0. A. Data1. A. P

Read: S. SAddr W. A. MAddr. A. Sr. SAddr R. A. Data0. A. Data1. N. P

Write Portion **Read Portion** 

### **Write Data Protocol**

The write data protocol is used to write to register to the ICs starting at memory address MAddr. Data0 represents the data written to MAddr, Data1 represents the data written to MAddr + 1, and DataN represents the last data byte, written to MAddr + N. The master indicates the end of a write transaction by sending a STOP or Repeated START after receiving the last acknowledge bit:

S. SAddr W. A. MAddr. A. Data0. A. Data1. A... DataN. A. P

The MSb of the data to be stored at address MAddr can be written immediately after the MAddr byte is acknowledged. Because the address is automatically incremented after the LSb of each byte is received by the ICs, the MSb of the data at address MAddr + 1 can be written immediately after the acknowledgment of the data at address MAddr. If the bus master continues an autoincremented write transaction beyond address 4Fh, the ICs ignore the data. A valid write must include both register bytes. Data is also ignored on writes to read-only addresses. Incomplete bytes and bytes that are not acknowledged by the ICs are not written to memory.

### **Read Data Protocol**

The read data protocol is used to read to register from the ICs starting at the memory address specified by MAddr. Both register bytes must be read in the same transaction for the register data to be valid. Data0 represents the data byte in memory location MAddr, Data1 represents the data from MAddr + 1, and DataN represents the last byte read by the master:

> S. SAddr W. A. MAddr. A. Sr. SAddr R. A. Data0. A. Data1. A... DataN. N. P

Data is returned beginning with the MSb of the data in MAddr. Because the address is automatically incremented after the LSb of each byte is returned, the MSb of the data at address MAddr + 1 is available to the host immediately after the acknowledgment of the data at address MAddr. If the bus master continues to read beyond address FFh, the ICs output data values of FFh. Addresses labeled Reserved in the memory map return undefined data. The bus master terminates the read transaction at any byte boundary by issuing a no acknowledge followed by a STOP or Repeated START.

### **Ordering Information**



*+Denotes a lead(Pb)-free/RoHS-compliant package.*

*\*EP = Exposed pad.*

*T = Tape and reel.*

### **Package Information**

For the latest package outline information and land patterns (footprints), go to **[www.maximintegrated.com/packages](http://www.maximintegrated.com/packages)**. Note that a "+", "#", or "-" in the package code indicates RoHS status only. Package drawings may show a different suffix character, but the drawing pertains to the package regardless of RoHS status.



## **Revision History**



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

*Maxim Integrated cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim Integrated product. No circuit patent licenses*  are implied. Maxim Integrated reserves the right to change the circuitry and specifications without notice at any time. The parametric values (min and max limits) *shown in the Electrical Characteristics table are guaranteed. Other parametric values quoted in this data sheet are provided for guidance.*

# **Mouser Electronics**

Authorized Distributor

Click to View Pricing, Inventory, Delivery & Lifecycle Information:

[Maxim Integrated](https://www.mouser.com/maxim-integrated):

 [MAX17048G+](https://www.mouser.com/access/?pn=MAX17048G+) [MAX17048G+T10](https://www.mouser.com/access/?pn=MAX17048G+T10) [MAX17049G+](https://www.mouser.com/access/?pn=MAX17049G+) [MAX17049G+T10](https://www.mouser.com/access/?pn=MAX17049G+T10) [MAX17048X+](https://www.mouser.com/access/?pn=MAX17048X+) [MAX17048X+T10](https://www.mouser.com/access/?pn=MAX17048X+T10) [MAX17049X+](https://www.mouser.com/access/?pn=MAX17049X+) [MAX17049X+T10](https://www.mouser.com/access/?pn=MAX17049X+T10) [MAX17048XEVKIT#](https://www.mouser.com/access/?pn=MAX17048XEVKIT#) [MAX17049XEVKIT#](https://www.mouser.com/access/?pn=MAX17049XEVKIT#)