4Kb EEPROM with Single-Wire HDQ Interface and Temperature Sensor

Check for Samples: bq2028

FEATURES
- Serial Non-Volatile Memory (NVM)
  - 512 Byte (4Kb) EEPROM
  - Provides Battery Pack NVM storage for bq27505-E1 Fuel Gauge:
    - Manufacturing Data
    - Operational History
    - Resistance Tables
    - State of Health Information
- Single Wire HDQ Communications Port
- Integrated 2.5V LDO Linear Regulator
  - Ultra-low power “shutdown” mode (1µA Typical) via auto-timeout and/or host command
  - Wake up from shutdown via HDQ break
- Internal Die-Temperature Sensor
  - ±5°C Range = –40°C to 85°C
  - Raw AD to Temperature Conversion Performed by Host Firmware
- Package
  - 12-pin, 1490 × 2350 µm WCSP (YZG), 0.625mm Max Thickness, 0.5mm Pitch

DESCRIPTION
The Texas Instruments bq2028 serial 4Kb nonvolatile memory (EEPROM) with integrated temperature sensor and LDO linear regulator provides pack-side memory storage and temperature monitoring for a single-cell system-side battery fuel gauge solution such as the bq27505-E1.

The bq2028 communicates with the bq27505-E1 gauge over a single-wire HDQ interface with a minimal overhead protocol yet ensures error free data transfer.
These devices have limited built-in ESD protection. The leads should be shorted together or the device placed in conductive foam during storage or handling to prevent electrostatic damage to the MOS gates.

**DEVICE INFORMATION**

**AVAILABLE OPTIONS**

<table>
<thead>
<tr>
<th>PRODUCTION PART #</th>
<th>PACKAGE</th>
<th>TAPE and REEL QUANTITY</th>
</tr>
</thead>
<tbody>
<tr>
<td>bq2028YZGR</td>
<td>12-pin WCSP</td>
<td>3000</td>
</tr>
<tr>
<td>bq2028YZGT</td>
<td></td>
<td>250</td>
</tr>
</tbody>
</table>

**PIN ASSIGNMENT**

![CSP-12 Pin Assignment (Bottom View)](image)

**PIN DESCRIPTIONS**

<table>
<thead>
<tr>
<th>PIN NAME</th>
<th>CSP-12 PIN</th>
<th>I/O</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>TEST3</td>
<td>C3</td>
<td>I/O</td>
<td>Reserved for factory test. Connect to VSS in application circuit.</td>
</tr>
<tr>
<td>REGIN</td>
<td>D3</td>
<td>P</td>
<td>Regulator input. Typically connected to battery CELL+.</td>
</tr>
<tr>
<td>VDD</td>
<td>D2</td>
<td>P</td>
<td>Regulator 2.5V output. Decouple with a 0.47μF cap to VSS.</td>
</tr>
<tr>
<td>VSS</td>
<td>A1, B1, D1, B2, C2</td>
<td>P</td>
<td>Ground pin.</td>
</tr>
<tr>
<td>HDQ</td>
<td>A2</td>
<td>I/O</td>
<td>HDQ Data pin. Open-drain I/O. Requires external pull-up for proper operation.</td>
</tr>
<tr>
<td>TEST1</td>
<td>C1</td>
<td>I/O</td>
<td>Reserved for factory test. Connect to VSS in application circuit.</td>
</tr>
<tr>
<td>TEST0</td>
<td>B3</td>
<td>I/O</td>
<td>Reserved for factory test. Connect to VSS in application circuit.</td>
</tr>
<tr>
<td>TEST2</td>
<td>A3</td>
<td>I/O</td>
<td>Reserved for factory test. Connect to VSS in application circuit.</td>
</tr>
</tbody>
</table>
ELECTRICAL SPECIFICATIONS

ABSOLUTE MAXIMUM RATINGS

over operating free-air temperature range (unless otherwise noted)\(^{(1)}\)

<table>
<thead>
<tr>
<th>VALUE</th>
<th>UNIT</th>
<th>MIN</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>(V_{\text{REGIN}}) Supply voltage range</td>
<td></td>
<td>–0.3</td>
<td>5.5</td>
</tr>
<tr>
<td>HDQ Open-drain I/O pin</td>
<td></td>
<td>–0.3</td>
<td>5.5</td>
</tr>
<tr>
<td>(V_{i}) Input voltage range to all other pins (TEST0-3)</td>
<td></td>
<td>–0.3 (V_{\text{REGIN}} + 0.3)</td>
<td>V</td>
</tr>
<tr>
<td>ESD HBM for pins other than TEST1, TEST2, TEST3</td>
<td></td>
<td>2</td>
<td>kV</td>
</tr>
<tr>
<td>(T_{A}) Operating free-air temperature range</td>
<td></td>
<td>–40</td>
<td>85 °C</td>
</tr>
<tr>
<td>(T_{F}) Functional temperature</td>
<td></td>
<td>–40</td>
<td>100 °C</td>
</tr>
<tr>
<td>(T_{\text{stg}}) Storage temperature range</td>
<td></td>
<td>–65</td>
<td>150 °C</td>
</tr>
</tbody>
</table>

\(^{(1)}\) 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 under recommended operating condition “is not implied. Exposure to absolute–maximum–rated conditions for extended periods may affect device reliability.

RECOMMENDED OPERATING CONDITIONS

\(T_{A} = 25^\circ C, \ C_{\text{LDO25}} = 0.47 \ \mu F, \ V_{\text{REGIN}} = 3.6V\) (unless otherwise noted)

<table>
<thead>
<tr>
<th>VALUE</th>
<th>UNIT</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>(V_{\text{REGIN}}) Supply Voltage</td>
<td></td>
<td>2.45</td>
<td>4.5</td>
<td>V</td>
</tr>
<tr>
<td>(R_{\text{PUEXT}}) HDQ external pull-up</td>
<td></td>
<td>10</td>
<td>22</td>
<td>kΩ</td>
</tr>
<tr>
<td>(C_{\text{HDQ}}) HDQ capacitive loading</td>
<td></td>
<td>50</td>
<td>250</td>
<td>pF</td>
</tr>
<tr>
<td>(C_{\text{REGIN}}) External input capacitor for internal LDO between (\text{REGIN}) and (\text{VSS})</td>
<td></td>
<td>Nominal capacitor values specified. Recommend a 5% ceramic X5R type capacitor located close to the device.</td>
<td>0.1</td>
<td>μF</td>
</tr>
<tr>
<td>(C_{\text{LDO25}}) External output capacitor for internal LDO between (\text{VDD}) and (\text{VSS})</td>
<td></td>
<td></td>
<td>0.47</td>
<td>μF</td>
</tr>
</tbody>
</table>
DC ELECTRICAL CHARACTERISTICS

\( T_A = -40^\circ \text{C} \) to \( 85^\circ \text{C}, C_{\text{LDO25}} = 0.47 \mu \text{F}, V_{\text{REGIN}} = 3.6 \text{ V} \) (unless otherwise noted)

<table>
<thead>
<tr>
<th>PARAMETER</th>
<th>TEST CONDITION</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>( I_{\text{CC}} )</td>
<td>Supply Current (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SHUTDOWN Mode (LDO = off)</td>
<td>1</td>
<td>2</td>
<td></td>
<td>\mu \text{A}</td>
</tr>
<tr>
<td></td>
<td>SLEEP Mode (LFO = on; HFO = off)</td>
<td>20</td>
<td>50</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>IDLE Mode (LFO, HFO = on; CONV= 0)</td>
<td>55</td>
<td>110</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>TEMP Read (LFO, HFO = on; CONV = 1)</td>
<td>110</td>
<td>200</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>EEPROM Read (LFO, HFO = on)</td>
<td>300</td>
<td>600</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>EEPROM Write (LFO, HFO = on)</td>
<td>2300</td>
<td>5000</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

2.5V LDO REGULATOR

| \( V_{\text{REG25}} \) | Regulator output voltage | 2.7 V \( \leq V_{\text{REGIN}} \leq 4.5 \text{ V}, I_{\text{OUT}} \leq 10 \text{ mA} \) | 2.4 | 2.5 | 2.6 | V |
| | 2.45 V \( \leq V_{\text{REGIN}} \) < 2.7 V (low battery), \( I_{\text{OUT}} \leq 3 \text{ mA} \) | 2.4 | | | |

**OTHER ANALOG: POWER ON RESET, TEMPERATURE SENSOR, INTERNAL VOLTAGE REFERENCE**

| \( V_{\text{POR+}} \) | POR Threshold | Positive-going input at VDD, \( T_A = 25^\circ \text{C} \) | 2.05 | 2.20 | 2.31 | V |
| \( V_{\text{HWPOR}} \) | POR Hysteresis | \( TA = 25^\circ \text{C} \) | 45 | 115 | 185 | mV |
| \( V_{\text{WU+}} \) | HDQ Wakeup threshold | Positive-going input at HDQ, \( T_A = 25^\circ \text{C} \) | 1.2 | 1.4 | | V |
| \( V_{\text{HYSWU}} \) | HDQ Wakeup hysteresis | \( T_A = 25^\circ \text{C} \) | 505 | | | mV |
| \( V_{\text{ASD}} \) | Auto shutdown threshold | | 2.05 | 2.20 | 2.31 | V |
| \( V_{\text{HYSAASD}} \) | Auto shutdown hysteresis | | 45 | 115 | 185 | V |
| \( V_{(\text{TEMP})} \) | Temperature sensor | | | | | –1.986 mV/°C |

**HDQ INTERFACE**

| \( V_{\text{IH}} \) | Input voltage high | 1.8 | | | V |
| \( V_{\text{IL}} \) | Input voltage low | | 0.6 | | V |
| \( V_{\text{OH}} \) | Output voltage high | Open drain, external pull up to VDD | \( V_{\text{OH}}-0.5 \) | | V |
| \( V_{\text{OL}} \) | Output voltage low | Open-drain IOL = 1mA | 0.4 | | V |
| \( C_{t} \) | Input capacitance | | 10 | | pF |
| \( I_{\text{IH}} \) | HDQ input total current | Includes leakage plus internal pull-down | 2 | | \mu \text{A} |
| \( I_{\text{OL}} \) | Output low sink current | VOL = 0.4V | 1 | | mA |
| \( R_{\text{PDINT}} \) | HDQ internal pull-down | For auto-shutdown | 1.25 | 2.5 | 5 | M\Omega |

(1) An EEPROM write operation is required for proper device initialization following exit from SHUTDOWN, SLEEP, or POWER-ON RESET.
AC ELECTRICAL CHARACTERISTICS

\( T_A = -40^\circ C \) to 85\(^\circ C \), \( C_{LDO25} = 0.47 \mu F \), \( V_{REGIN} = 3.6V \) (unless otherwise noted)

<table>
<thead>
<tr>
<th>PARAMETER</th>
<th>TEST CONDITION</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
<th>UNIT</th>
</tr>
</thead>
<tbody>
<tr>
<td>EEPROM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Array Size</td>
<td>128 words x 32 bits = 4Kbits</td>
<td>512</td>
<td>Bytes</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Write Cycle Endurance</td>
<td></td>
<td>1000</td>
<td>K cycles</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HDQ Data Access</td>
<td>Via 32 bit BUFFER</td>
<td>8</td>
<td>Bits</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Program time</td>
<td>Per word (internal timing only)</td>
<td>6</td>
<td>20</td>
<td>mS</td>
<td></td>
</tr>
<tr>
<td>Read time</td>
<td>Per word (internal timing only)</td>
<td>300</td>
<td>2000</td>
<td>nS</td>
<td></td>
</tr>
<tr>
<td>HDQ INTERFACE AND MISCELLANEOUS (Refer to Figure 6 and Figure 7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_B ) Break time</td>
<td></td>
<td>190</td>
<td>( \mu s )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{BR} ) Break recovery time</td>
<td></td>
<td>40</td>
<td>( \mu s )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SLWU} ) SLEEP wakeup</td>
<td>Host drives HDQ Break. Timed from rising edge of first wakeup break pulse to falling edge of next break pulse with first data.</td>
<td>200</td>
<td>( \mu s )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SHWU} ) SHUTDOWN wakeup</td>
<td>Time delay after ( V_{ASS} ) threshold is met before SHUTDOWN mode is entered.</td>
<td>2</td>
<td>10</td>
<td>S</td>
<td></td>
</tr>
<tr>
<td>( t_{SHUTDN} ) SHUTDOWN time</td>
<td>Time delay after ( V_{ASS} ) threshold is met or 2 second timeout is met before Host can drive HDQ break for wakeup.</td>
<td>2</td>
<td>10</td>
<td>S</td>
<td></td>
</tr>
<tr>
<td>( t_{ASHWU} ) AUTO SHUTDOWN wakeup</td>
<td>Power on reset wakeup time before device is ready to receive first HDQ message</td>
<td>200</td>
<td>( \mu s )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{PORWU} ) POR wakeup</td>
<td>REGIN valid to 1(^{st}) rising edge of HDQ to POR device. (Figure 3)</td>
<td>15</td>
<td>ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{REGINTOHDQ} ) REGIN to HDQ</td>
<td>VDD ramp to POR release. (Figure 3)</td>
<td>200</td>
<td>ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SHUTDN} ) POR reset</td>
<td>POR release to GRST release. (Figure 3)</td>
<td>3</td>
<td>11</td>
<td>ms</td>
<td></td>
</tr>
<tr>
<td>( t_{GRST} ) Global reset</td>
<td></td>
<td>4</td>
<td>ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{W1} ) Host Write 1 time</td>
<td>Host drives HDQ</td>
<td>5</td>
<td>50</td>
<td>( \mu s )</td>
<td></td>
</tr>
<tr>
<td>( t_{W0} ) Host Write 0 time</td>
<td>Host drives HDQ</td>
<td>86</td>
<td>145</td>
<td>( \mu s )</td>
<td></td>
</tr>
<tr>
<td>( t_{CYC} ) Host cycle time</td>
<td>Host drives HDQ</td>
<td>190</td>
<td>( \mu s )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{D1} ) Device Write 1 time</td>
<td>bq2028 drives HDQ</td>
<td>39</td>
<td>41</td>
<td>43 ( \mu s )</td>
<td></td>
</tr>
<tr>
<td>( t_{D0} ) Device Write 0 time</td>
<td>bq2028 drives HDQ</td>
<td>106</td>
<td>111</td>
<td>116 ( \mu s )</td>
<td></td>
</tr>
<tr>
<td>( t_{CD} ) Device cycle time</td>
<td>bq2028 drives HDQ</td>
<td>197</td>
<td>207</td>
<td>217 ( \mu s )</td>
<td></td>
</tr>
<tr>
<td>( t_{RPS} ) Device response time</td>
<td>bq2028 drives HDQ</td>
<td>211</td>
<td>222</td>
<td>233 ( \mu s )</td>
<td></td>
</tr>
<tr>
<td>( t_{HDQSTDET} ) HDQ Start detect</td>
<td>bq2028 filters out very short HDQ pulses</td>
<td>0</td>
<td>1.98</td>
<td>( \mu s )</td>
<td></td>
</tr>
<tr>
<td>A/D CONVERTER</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SAMPLE} ) Sampling frequency</td>
<td>Delta Sigma modulator frequency</td>
<td>65.5</td>
<td>kHz</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{CONV} ) Conversion time</td>
<td>SPEED[1:0] = 00</td>
<td>125</td>
<td>ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SPEED[1:0] = 01</td>
<td>62.50</td>
<td>ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SPEED[1:0] = 10</td>
<td>31.25</td>
<td>ms</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SPEED[1:0] = 11</td>
<td>7.8125</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( V_{ADC-IN} ) Input voltage range</td>
<td>Internal Vref, ( T_A = 25^\circ C ), VTEMP internal channel only</td>
<td>–0.2</td>
<td>1 V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>HIGH FREQUENCY OSCILLATOR (HFO)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( HF_{OSC} ) Operating frequency</td>
<td></td>
<td>8.389</td>
<td>MHz</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( HF_{ERR} ) Frequency error</td>
<td>( T_A = -40^\circ C ) to 85(^\circ C )</td>
<td>–8.0%</td>
<td>8.0%</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( HF_{START} ) Start-up time</td>
<td></td>
<td>14</td>
<td>200</td>
<td>( \mu s )</td>
<td></td>
</tr>
<tr>
<td>LOW FREQUENCY OSCILLATOR (LFO)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( LF_{OSC} ) Operating frequency</td>
<td></td>
<td>32.768</td>
<td>kHz</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( LF_{ERR} ) Frequency error</td>
<td>( T_A = -40^\circ C ) to 85(^\circ C )</td>
<td>–8.0%</td>
<td>8.0%</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( LF_{START} ) Start-up time</td>
<td></td>
<td>100</td>
<td>500</td>
<td>( \mu s )</td>
<td></td>
</tr>
</tbody>
</table>
**Power Modes**

The bq2028 has multiple operational modes for reduced power consumption. Defines which circuits are enabled in each of these operational modes.

<table>
<thead>
<tr>
<th>CIRCUIT</th>
<th>SHUT-DOWN</th>
<th>SLEEP</th>
<th>IDLE</th>
<th>HDQ READ/WRITE</th>
<th>TEMP READ</th>
<th>EEPROM READ</th>
<th>EEPROM WRITE</th>
</tr>
</thead>
<tbody>
<tr>
<td>Wakeup/ POR</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
</tr>
<tr>
<td>LDO Regulator</td>
<td>–</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
</tr>
<tr>
<td>32kHz LFO</td>
<td>–</td>
<td>–</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
</tr>
<tr>
<td>8MHz HFO</td>
<td>–</td>
<td>–</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
</tr>
<tr>
<td>HDQ Interface</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>√</td>
<td>√</td>
<td>√</td>
<td>√</td>
</tr>
<tr>
<td>ADC</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td></td>
</tr>
<tr>
<td>EEPROM Read</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>√</td>
<td>–</td>
</tr>
<tr>
<td>EEPROM Write</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>√</td>
</tr>
</tbody>
</table>

(1) √: Active  –: Not in use
HDQ Interface

The bq2028 supports a single-wire, open-drain communication interface that supports the HDQ protocol as shown in Figure 5. The HDQ protocol is based on the Texas Instruments HDQ standard as discussed in the TI application report (SLUA408A) (http://focus.ti.com.cn/cn/lit/an/slua408a/slua408a.pdf).

The communication protocol is asynchronous return-to-one referenced to Vss. A passive pullup resistance is required to pull the HDQ line to a high state when neither the host nor the slave is pulling the line low during two-way communication over the single wire interface. The interface uses a command-based protocol, where the host sends a command byte to the HDQ slave device. The command directs the slave to either receive or transmit the next byte of data. The last transmitted bit of the command byte determines the direction of the data (read or write) as shown in Figure 7.

Figure 5. HDQ Interface Connections (single wire configuration)
Device Control

Using a register address access method, the HDQ command byte limits addressing to 7 bits so a mapping scheme is necessary to differentiate device control and status registers from EEPROM data. This register and paged EEPROM access scheme is shown in Figure 8.
Access to device control and data registers use the “Un-Mapped” address space with the “M” (Map bit) set to ‘0’. Access to the EEPROM space uses a Memory Mapped scheme with the “M” bit set to ‘1’. Refer to Figure 9 for details.

### Memory Mapped Registers

<table>
<thead>
<tr>
<th>W/R</th>
<th>R3</th>
<th>R2</th>
<th>R1</th>
<th>R0</th>
<th>C1</th>
<th>C0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- Bit 7 = W/R: Read/Write command (1 = Write, 0 = Read)
- Bit 6 = Map Bit, M = 1
- Bits 5:2 = Row index: R[3:0]
- Bits 1:0 = Column/Buffer index: C[1:0]

### Unmapped Registers

<table>
<thead>
<tr>
<th>W/R</th>
<th>A5</th>
<th>A4</th>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- Bit 7 = W/R: Read/Write command (1 = Write, 0 = Read)
- Bits 6:5 = Map Bit, M = 0
- Bits 4:0 = HDQ register: A[5:0] Range = 0x00 to 0x3F

**Figure 9. HDQ Command Byte Decode**
7 HDQ Access Method

Figure 10. HDQ Access Flow Chart
EEPROM Access

The bq2028 provides 512 bytes of EEPROM non-volatile memory storage organized as 128 words x 32 bits. Due to the address limitations of the HDQ interface protocol, the EEPROM is accessed in 8 pages, with 16 rows of 4 bytes each. For IC manufacturing and analog trim data, 16 bytes or 4 words are reserved in last page of data.

The access model terminology is listed below:

- **EEPROM** = 128x32-bit (512 bytes) non-volatile memory with paged access
- **BUFFER** = 32-bit long word in 4x8b volatile Buffer
- **C** = 2-bit byte Column index for Buffer: C[1:0]
- **Buffer[C]** = 8-bit access to BUFFER at index C. MSB is at byte indexed by $C='11'$.  
- **P** = 3-bit Page index for EEPROM: P[2:0] (8 pages/EEPROM)
- **PAGE[P]** = 16x32-bit rows (64 bytes) from EEPROM indexed by [P]
- **R** = 4-bit Row index for EEPROM: R[3:0] (16 rows/page)
- **ROW[P,R]** = 32-bit long word from EEPROM indexed by [P,R]
- **Pre-Fetch** = Automatic copy of an ROW[P,R] to BUFFER before read/write operation
- **M** = Mapping operations to access BUFFER and EEPROM: M[1:0]

Figure 11. Memory Map
HDQ Registers

A summary of the Un-Mapped HDQ Registers is provided by Table 2.

Table 2. HDQ Un-Mapped Register Summary

<table>
<thead>
<tr>
<th>Address</th>
<th>R/W</th>
<th>Register</th>
<th>B</th>
<th>Address</th>
<th>R/W</th>
<th>Register</th>
<th>B</th>
<th>Address</th>
<th>R/W</th>
<th>Register</th>
<th>B</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>R/W</td>
<td>Buffer0</td>
<td></td>
<td>0x10</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x20</td>
<td>R</td>
<td>CRCR</td>
<td></td>
</tr>
<tr>
<td>0x01</td>
<td>R/W</td>
<td>Buffer1</td>
<td></td>
<td>0x11</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x21</td>
<td>R/W</td>
<td>CRCT</td>
<td></td>
</tr>
<tr>
<td>0x02</td>
<td>R/W</td>
<td>Buffer2</td>
<td></td>
<td>0x12</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x22</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
<tr>
<td>0x03</td>
<td>R/W</td>
<td>Buffer3</td>
<td></td>
<td>0x13</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x23</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
<tr>
<td>0x04</td>
<td>R</td>
<td>Status</td>
<td></td>
<td>0x14</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x24</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x05</td>
<td>R/W</td>
<td>Control</td>
<td></td>
<td>0x15</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x25</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x06</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x16</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x26</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x07</td>
<td>R/W</td>
<td>Page</td>
<td></td>
<td>0x17</td>
<td></td>
<td>(Reserved)</td>
<td></td>
<td>0x27</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x08</td>
<td>R/W</td>
<td>ADCTL1</td>
<td></td>
<td>0x18</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x28</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x09</td>
<td>R/W</td>
<td>ADCTL2</td>
<td></td>
<td>0x19</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x29</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
<tr>
<td>0x0A</td>
<td>R</td>
<td>ADHI</td>
<td></td>
<td>0x1A</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x2A</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
<tr>
<td>0x0B</td>
<td>R</td>
<td>ADLOW</td>
<td></td>
<td>0x1B</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x2B</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
<tr>
<td>0x0C</td>
<td>R</td>
<td>CRCH</td>
<td></td>
<td>0x1C</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x2C</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x0D</td>
<td>R</td>
<td>Row</td>
<td></td>
<td>0x1D</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x2D</td>
<td></td>
<td>(Reserved)</td>
<td></td>
</tr>
<tr>
<td>0x0E</td>
<td>R</td>
<td>DeviceRev</td>
<td></td>
<td>0x1E</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x2E</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
<tr>
<td>0x0F</td>
<td>R</td>
<td>DeviceID</td>
<td></td>
<td>0x1F</td>
<td></td>
<td>(spare)</td>
<td></td>
<td>0x2F</td>
<td></td>
<td>(spare)</td>
<td></td>
</tr>
</tbody>
</table>

(1) B = Defaults "Backed Up" in EEPROM Page[0] and auto-loaded at Power On Reset
(2) Page[0] EEPROM Addresses 0x38 to 0x3F contain the TI Die ID but these are not mapped to HDQ registers.

32-bit BUFFER Access (addresses 0x00 through 0x03)

Access to the 32-bit words in the EEPROM is provided by a 32-bit BUFFER that is available as 8-bit HDQ registers: Buffer0 [LSB], Buffer1, Buffer2, Buffer[MSB].

<table>
<thead>
<tr>
<th>32-BIT BUFFER</th>
</tr>
</thead>
<tbody>
<tr>
<td>MS-Byte</td>
</tr>
<tr>
<td>Buffer3</td>
</tr>
<tr>
<td>Buffer1</td>
</tr>
</tbody>
</table>

Status Register (address 0x04):

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>Buffer0[7:0] (address 0x00) – Least Significant Byte</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Name</td>
<td>Buffer1[7:0] (address 0x01)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Name</td>
<td>Buffer2[7:0] (address 0x02)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Name</td>
<td>Buffer3[7:0] (address 0x03) – Most Significant Byte</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Access</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>Undefined</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

BUSY (bit 7): Busy flag. This bit is normally ‘0’ and is set to ‘1’ when the device is performing an extended duration function such as device initialization, an ADC measurement or EEPROM write. Upon completion of the function, the BUSY bit will automatically clear to ‘0’.

ADC_DRDY (bit 6): ADC Data ready flag. This bit indicates that conversion data is ready in the ADC Data Registers (ADHI and ADLOW). This bit is cleared by setting the CONV bit in the Control register.
1 – ADC data is ready
0 – ADC data is not ready.

**PGEN_ERR (bit 5):** Page Enable Error flag. This indicates that an EEPROM write was attempted to a page that was not enabled for write-access.

**MEM_WR (bit 4):** Memory Write flag. This bit is set during the EEPROM memory access scheme when the Map bit is set with an HDQ write command. This bit is cleared if the Map bit is set with an HDQ read command or upon completion of an EEPROM program cycle. Refer to Figure 10.

**RSTBIT (bit 2):** This bit is set to ‘1’ when the device has reset due to a Power On Reset (POR) event or a soft reset initiated by the Control:Reset bit. The RSTBIT will remain set to ‘1’ until the Control:RSTCLR bit is set to ‘0’.

**MEM_ERR (bit 1):** This bit is set to ‘1’ when the device detects an EEPROM memory error. Refer to Figure 10. This bit, along with CRCB_ERR, is cleared using the Control:ERRCLR bit.

**CRCB_ERR (bit 0):** This bit is set to ‘1’ when the device detects a BUFFER memory error after computing a CRC check. Refer to Figure 10. This bit, along with MEM_ERR, is cleared using the Control:ERRCLR bit.

### Control Register (address 0x05):

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>CONV</td>
<td>RSVD</td>
<td>RSVD</td>
<td>ERRCLR</td>
<td>SLEEP</td>
<td>RSTCLR</td>
<td>RESET</td>
</tr>
<tr>
<td>Access</td>
<td>R/W</td>
<td>R</td>
<td>R</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CONV (bit 7):** Convert command bit. This bit is used to start an ADC conversion when set to ‘1’ and is automatically cleared at the end of data conversion cycle in order to minimize HDQ traffic. At the start of data conversion, the device sets the Status:BUSY flag and automatically clears the Status:ADC_DRDY flag to indicate data conversion is in progress. When data conversion is complete, both the CONV bit and BUSY flag are cleared and the ADC_DRDY flag is set. To abort an ADC conversion in process, the host can clear the CONV bit to ‘0’.

**ERRCLR (bit 4):** A ‘1’ written to this bit will clear both the Status:MEM_ERR and CRCB_ERR bits. This bit auto-clears itself so a readback always reads ‘0’.

**SLEEP (bit 3):** A ‘1’ written to this bit enables a lower-power mode with the HFO disabled. This bit is automatically cleared upon detection of HDQ communication activity. Therefore a readback of this bit over HDQ will always be ‘0’.

Note: If SLEEP mode is commanded, the host should wake up the bq2028 by issuing an HDQ break pulse with no associated data, followed by a wait period of at least 200 us (tSLWU), then send a second HDQ break pulse with the first command.

**RSTCLR (bit 2):** A ‘1’ written to this bit will clear the Status:RSTBIT flag and auto-clear itself so a readback always reads ‘0’.

**RESET (bit 1):** A ‘1’ written to this bit will initiate a full device initialization. The device will auto-clear the RESET bit and set the Status:RSTBIT and Status:BUSY flags at the start of initialization. After initialization is complete the device will clear the BUSY flag.

**SHUTDOWN (bit 0):** A ‘1’ written to this bit will initiate a full device Shutdown. This bit is automatically cleared upon a POR and must be cleared for correct HDQ activity. Therefore a readback of this bit over HDQ will always be ‘0’.

Note: If SHUTDOWN mode is commanded, the host should wake up the bq2028 by issuing an HDQ break pulse with no associated data, followed by a wait period of at least 15ms (tSHWU), then send a second HDQ break pulse with the first command.
Page Register (address 0x07): EEPROM Page Register

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>Page[2:0]</td>
<td></td>
</tr>
<tr>
<td>Access</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Page[2:0]: This contains the current 3-bit Page pointer for EEPROM access.

ADCTL1 (address 0x08): ADC Control Register 1

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

RSVD (bit 7) Do not use.

VRVDD (bit 6): Voltage reference selection bit. This bit selects which voltage reference (either V_{DD} or internal V_{REF}) is used by the ADC.

- 1 – Selects VDD as the ADC reference voltage for ratio metric conversions
- 0 – Selects the internal V_{REF} as the ADC reference voltage

SPEED[1:0] (bits 5-4):
Conversion speed selection bits.

<table>
<thead>
<tr>
<th>SPEED[1:0]</th>
<th>FILTER LENGTH</th>
<th>CONVERSION TIME</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>8192</td>
<td>125ms</td>
</tr>
<tr>
<td>01</td>
<td>4096</td>
<td>62.5ms</td>
</tr>
<tr>
<td>10</td>
<td>2048</td>
<td>31.25ms</td>
</tr>
<tr>
<td>11</td>
<td>512</td>
<td>7.8125ms</td>
</tr>
</tbody>
</table>

RSVD (bit 3) Do not use.

CHAN[2:0] (bits 2–0): ADC Channel selection bits. Set to VTEMP (‘101’) to measure the internal die temperature sensor or set to VSS (‘111’) for measuring ADC offset.

<table>
<thead>
<tr>
<th>CHAN[2:0]</th>
<th>ADC INPUT CHANNEL (Product Datasheet)</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>RSVD</td>
</tr>
<tr>
<td>001</td>
<td>RSVD</td>
</tr>
<tr>
<td>010</td>
<td>RSVD</td>
</tr>
<tr>
<td>011</td>
<td>RSVD</td>
</tr>
<tr>
<td>100</td>
<td>RSVD</td>
</tr>
<tr>
<td>101</td>
<td>VTEMP</td>
</tr>
<tr>
<td>110</td>
<td>RSVD</td>
</tr>
<tr>
<td>111</td>
<td>VSS</td>
</tr>
</tbody>
</table>
ADCTL2 (address 0x09): ADC Control Register 2

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Final Product</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
</tr>
<tr>
<td>Access</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

RSVD (bits 7:0): Do not use.

ADHI (address 0x0A): ADC High Byte Data Register
This register provides the high byte ADC conversion data in 2’s complement format. A full scale (max value) for this register is 7FFFh. A zero scale (min value) for this register is 8000h.

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>ADC[15:8]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Access</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

ADC[15:8] (bits 7:0): ADC high byte conversion data.

ADLOW (address 0x0B): ADC Low Byte Data Register

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>ADC[7:0]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Access</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

ADC[7:0] (bits 7:0): ADC low byte conversion data.

CRCH Register (address 0x0C): HDQ CRC Register
The register contains the CRC-8 result of the previous HDQ command + data sequence and is useful for data integrity checks for single HDQ packet transfers.

<table>
<thead>
<tr>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>CHRH[7:0]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Access</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

CHRH[7:0]: CRC-8 data from the previous HDQ packet. Data is computed using the full 16-bit HDQ package sequence included W/R bit, 7-bit command and 8-bit data.
Row Register (address 0x0D): EEPROM Row Register

<table>
<thead>
<tr>
<th>Name</th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>Row[3:0]</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**Row[3:0]:** This contains the current 4-bit Row pointer for a particular page. The value is automatically updated by Mapped access to the EEPROM.

DeviceRev Register (address 0x0E): Device Revision Register

<table>
<thead>
<tr>
<th>Name</th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access</td>
<td>DeviceRev[7:0]</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>DeviceRev[7:0]</td>
<td>Undefined</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**DeviceRev[7:0]:** The read-only register returns the hardware device revision value. The initial revision is 0x01 and increments by 1 for each design revision.

DeviceID Register (address 0x0F): Device ID Register

<table>
<thead>
<tr>
<th>Name</th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access</td>
<td>DeviceID[7:0]</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>DeviceID[7:0] = 0x28</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**DeviceID[7:0]:** This read-only register returns the unique device identification value which provides a method for the host to distinguish the bq2028 from other HDQ devices. The DeviceID for the bq2028 = 0x28.

CRCR Register (address 0x20): BUFFER CRC Result Register

<table>
<thead>
<tr>
<th>Name</th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access</td>
<td>CRCR[7:0]</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
<td>R</td>
</tr>
<tr>
<td>Reset</td>
<td>Undefined</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**CRCR[7:0]:** This register contains the last BUFFER CRC computation result.

CRCT Register (address 0x21): BUFFER CRC Target Register

<table>
<thead>
<tr>
<th>Name</th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Access</td>
<td>CRCT[7:0]</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**CRCT[7:0]:** This register contains the CRC computation target for verifying the BUFFER contents prior to writing the data to EEPROM. This method is used to prevent EEPROM data corruption due to interrupted HDQ transfers or communication errors. An HDQ write to this register triggers the comparison of the CRC previously calculated as BUFFER data is loaded from the HDQ interface. If the MEM_WR flag is set and the CRCT target register matches the CRCR result register, the device will write the BUFFER to the EEPROM using the current ROW and PAGE register values. Then a read-back of the EEPROM will be rechecked to confirm the integrity of the memory write. Refer to flow chart in Figure 10 for CRC initialization and computations. An HDQ read of this register returns the previously written target value.
CONTROL2 (address 0x25): CONTROL2 Register

<table>
<thead>
<tr>
<th></th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>RSVD</td>
<td>MANWREN</td>
</tr>
<tr>
<td>Access</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

RSVD (bits 7:1): Do not use.

MANWREN (Bit 0): A ‘1’ enables write access to the Page 0 Manufacturer’s area registers and associated EEPROM locations 0x30 through 0x3F. Users of the bq2028 may only change the PageEn register (0x031) without adversely changing manufacturing trim data.

PageEn Register (address 0x31): Page Enable Register

<table>
<thead>
<tr>
<th></th>
<th>7(MSB)</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Name</td>
<td>PageEn[7:0]</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Access</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
<td>R/W</td>
</tr>
<tr>
<td>Reset</td>
<td>EEPROM Page[0], Address 0x31</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

PageEn[X]: Each bit maps to the associated EEPROM page and enables write access. An attempt to write to Page[X] with PageEn[X]=0 will cause the PGEN_ERR bit to be set in the Status Register. This register has a hardware write protection feature. To write to this register, the MANWREN bit must be set in the Control 2 Register. This register is automatically loaded at reset with data stored in the EEPROM memory (page 0, byte address 0x31)

1 – Page[X] is writable
0 – Page[X] is read-only

CRC FUNCTIONS FOR DATA INTEGRITY

For data integrity checks, the bq2028 provides a CRC-8 computation block with the polynomial function of \((X^8 + X^5 + X^4 + 1)\). The following Python code indicates the parallel computation method where the 8-bit variable ‘c’ is the new data for calculating the CRC and the 8-bit variable ‘prev’ is the previous result if calculating the CRC on multiple data items. To start a new sequence, the ‘prev’ variable is initialized with the value 0xFF. Note: The initialization value of 0xFF is new in spec version 1.5. Previous versions used an initialization value of 0x00.

```python
    c ^= prev
    for I in range(8):
        if (c & 0x80):
            c = ((c << 1 & 0xff)) ^ 0x31
        else:
            c = (c << 1) & 0xff
    return c
```

Refer to the table below for example data sequences and the expected CRC:

<table>
<thead>
<tr>
<th>EXAMPLE DATA SEQUENCE (Byte order left to right)</th>
<th>CRC</th>
</tr>
</thead>
<tbody>
<tr>
<td>0x00</td>
<td>0xAC</td>
</tr>
<tr>
<td>0xAA</td>
<td>0x8B</td>
</tr>
<tr>
<td>0xFF</td>
<td>0x00</td>
</tr>
<tr>
<td>0x00 0xAA</td>
<td>0xA6</td>
</tr>
<tr>
<td>0xAA 0x55</td>
<td>0x1B</td>
</tr>
<tr>
<td>0xFF 0x01 0x55</td>
<td>0x7F</td>
</tr>
<tr>
<td>0x00 0x01 0x55 0xAA</td>
<td>0xF1</td>
</tr>
</tbody>
</table>
The CRC-8 function is typically used for verification of EEPROM data integrity via the BUFFER. To prevent EEPROM memory corruption, BUFFER data will not be written to EEPROM without passing a CRC verification check. Refer to the Figure 10 flow-char for the HDQ Access Method related to CRC computation and verification. The additional complexity of this CRC-8 computation method is provided to minimize HDQ overhead traffic when performing data integrity checks on variable length data elements.

The CRC-8 function is initiated on every HDQ data transfer with the result of the previous CRC-8 stored in the CRCH register. The CRCH register is typically used for single HDQ data packet integrity checks. Since the HDQ protocol shifts data with the LSB arriving first, the CRC is computed in this order:

A0:A6, R/W, D0-D7.

Note: This is the opposite bit ordering from the BUFFER CRC-8 computations.

Memory Access HDQ host pseudo-code examples

8-bit EEPROM Write (Example is <Byte1>):

```plaintext
Crc8 = FnCRC8(Byte1)  // Pre-Compute CRC-8 for 8-bit data
WRITE '1RRRR01', Byte1 // Pre-fetch EEPROM ROW 'RRRR', Poke Buffer[1], Set MEM_WR
WRITE '0100001', Crc8  // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR
```

8-bit EEPROM Read (Example is <Byte2>):

```plaintext
READ '1RRRR10', Byte2 // Fetch ROW 'RRRR' to BUFFER, Peek Buffer[2], Clear MEM_WR
Crc8 = FnCRC8(Byte2)  // Compute CRC-8 on 1 byte read
WRITE '0100001', Crc8  // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR
```

16-bit EEPROM Write (Lower 2-Bytes)

```plaintext
Crc8 = FnCRC8(Byte0, Byte1) // Pre-Compute CRC-8 for 16-bit data
WRITE '1RRRR00', Byte0 // Pre-fetch EEPROM ROW 'RRRR', Poke Buffer[0], Set MEM_WR
WRITE '0100001', Crc8  // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR
```

16-bit EEPROM Read (Lower 2-Bytes)

```plaintext
READ '1RRRR00', Byte0 // Fetch ROW 'RRRR' to BUFFER, Peek Buffer[0], Clear MEM_WR
READ '0000001', Byte1 // Peek Buffer[1]
Crc8 = FnCRC8(Byte0, Byte1) // Compute CRC-8 on 2 bytes read
WRITE '0100001', Crc8  // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR
```
24-bit EEPROM Write (Lower 3-Bytes)

Crc8 = FnCRC8(Byte0, Byte2, Byte3) // Pre-Compute CRC-8 for 24-bit data
WRITE '1RRRR00', Byte0 // Pre-fetch EEPROM ROW 'RRRR', Poke Buffer[0], Set MEM_WR
WRITE '0000010', Byte1 // Poke Buffer[1]
WRITE '0000010', Byte2 // Poke Buffer[2]
WRITE '0100001', Crc8 // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR

24-bit EEPROM Read (Lower 3-Bytes)

READ '1RRRR00', Byte0 // Fetch ROW 'RRRR' to BUFFER, Peek Buffer[0], Clear MEM_WR
READ '0000001', Byte1 // Peek Buffer[1]
READ '0000010', Byte2 // Peek Buffer[2]
Crc8 = FnCRC8(Byte0, Byte2, Byte3) // Compute CRC-8 on 3 bytes read
WRITE '0100001', Crc8 // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR

32-bit EEPROM Write (Full 4-Bytes)

Crc8 = FnCRC8(Byte0, Byte1, Byte2, Byte3) // Pre-Compute CRC-8 for 32-bit data
WRITE '1RRRR00', Byte0 // Pre-fetch EEPROM ROW 'RRRR', Poke Buffer[0], Set MEM_WR
WRITE '0000010', Byte1 // Poke Buffer[1]
WRITE '0000010', Byte2 // Poke Buffer[2]
WRITE '0000011', Byte3 // Poke Buffer[3]
WRITE '0100001', Crc8 // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR

32-bit EEPROM Read (Full 4-Bytes)

READ '1RRRR00', Byte0 // Fetch ROW 'RRRR' to BUFFER, Peek Buffer[0], Clear MEM_WR
READ '0000001', Byte1 // Peek Buffer[1]
READ '0000010', Byte2 // Peek Buffer[2]
READ '0000011', Byte3 // Peek Buffer[3]
Crc8 = FnCRC8(Byte0, Byte1, Byte2, Byte3) // Compute CRC-8 on 3 bytes read
WRITE '0100001', Crc8 // Poke Crc8 to CRCT trigger MEM write and re-check
READ '0000100', Status // Peek Status Register.
IF (Status && 0x03) THEN CALL bq2028_Error // B0 = CRCB_ERR, B1 = MEM_ERR
INTERNAL TEMPERATURE SENSOR

An internal die temperature sensor is available on the bq2028 to reduce the cost, power, and size of the external components necessary to measure temperature. Temperature sensing uses the \( V_{BE} \) method to present a voltage to a delta-sigma ADC converter. The host reads the ADC data over the HDQ interface and uses firmware to convert the data to Kelvin temperature units.

ADC data is formatted to 16-bits even though the data conversion performance may be limited to 10 effective bits. An ADC conversion starts when the Control:CONV bit is set to ‘1’ and is automatically cleared at the end of the data conversion cycle. At the start of data conversion, the device sets the Status:BUSY flag and automatically clears the Status:ADC_DRDY flag to indicate data conversion is in progress. When data conversion is complete, both the CONV bit and BUSY flag are cleared and the ADC_DRDY flag is set. To abort an ADC conversion in process, the host can clear the CONV bit to ‘0’.

The data in the ADC Data Registers is stored in 2s complement format. Full scale (7FFFh) is referred to the reference voltage (Vref), typically 1.225 V. A hardware protection circuit will not allow the converter to rollover from a full scale value (7FFFh) to a min scale value (8000h).

CLOCK GENERATOR CIRCUITS

The clock generator circuits are used to generate the internal clocks for the bq2028. The primary internal clocks are derived from the low frequency oscillator (32.768kHz), and the high frequency oscillator (8.389 MHz). The analog oscillator circuits are trimmed for accuracy, and then divided down for use throughout the device in both the analog and digital circuits. The bq2028 makes extensive use of clock gating to dynamically shutdown clocks to modules and interfaces not in use for low power operation. The low frequency oscillator (LFO) is required to run continuously during operation of the device with exception to a shutdown condition. The high frequency oscillator (HFO) is dynamically enabled and disabled as needed.

Low Frequency Oscillator Operation

The 32.768 kHz low frequency oscillator clock is generated from a fully integrated oscillator circuit with no requirements for external components. This circuit is trimmed for accuracy during factory production. The LFO trim value is stored in EEPROM memory Page 0. The LFO trim value is automatically read from EEPROM and written to the LFO trim register shortly after the device comes out of reset. The LFO output is divided down for various interfaces and modules in the device, as shown in Table 3.

<table>
<thead>
<tr>
<th>INTERFACE OR MODULE</th>
<th>REQUIRED WHEN:</th>
<th>FREQUENCY</th>
<th>DIVIDE</th>
</tr>
</thead>
<tbody>
<tr>
<td>HFO Trim Circuit</td>
<td>HFO is enabled</td>
<td>32.768 kHz</td>
<td>LFO</td>
</tr>
<tr>
<td>Reset Timer</td>
<td>Power up of device (4ms)</td>
<td>32.768 kHz</td>
<td>LFO</td>
</tr>
<tr>
<td>HDQ low timeout</td>
<td>HDQ line is pulled low for 2sec</td>
<td>128 Hz</td>
<td>LFO/256</td>
</tr>
</tbody>
</table>

High Frequency Oscillator Operation

The 8.389 MHz high frequency oscillator clock is generated from a fully integrated oscillator circuit with no requirements for external components. The bq2028 trims the 8.389MHz high frequency clock output internally by using an automatic high frequency trim circuit. Using the more accurate 32.768kHz clock as a reference, the high frequency clock is adjusted until it is determined to be within the desired operating frequency. The trim circuit continues to monitor and adjust the 8.389MHz clock as needed. Due to the nature of the trim algorithm, some small changes may be noticed in the 8.389MHz clock as it is adjusted based upon operating conditions and the 32.768kHz reference clock. The HFO output is divided down for various modules in the device.

<table>
<thead>
<tr>
<th>INTERFACE OR MODULE</th>
<th>REQUIRED WHEN:</th>
<th>FREQUENCY</th>
<th>DIVIDE</th>
</tr>
</thead>
<tbody>
<tr>
<td>HFO Trim Circuit</td>
<td>HFO is enabled</td>
<td>8.389 MHz</td>
<td>HFO</td>
</tr>
<tr>
<td>HDQ Communication</td>
<td>HDQ interface is enabled</td>
<td>1.049 MHz</td>
<td>HFO/8</td>
</tr>
<tr>
<td>HDQ Register Access</td>
<td>Writing or reading unmapped HDQ registers</td>
<td>1.049 MHz</td>
<td>HFO/8</td>
</tr>
<tr>
<td>EEPROM Access</td>
<td>Reading or programming EEPROM memory</td>
<td>1.049 MHz</td>
<td>HFO/8</td>
</tr>
<tr>
<td>ADC</td>
<td>ADC conversion enabled</td>
<td>65.536 kHz</td>
<td>HFO/128</td>
</tr>
</tbody>
</table>
REVISION HISTORY

Changes from Original (October 2012) to Revision A

- Changed from "Typ." to "Typical" in Features bullet ................................................................. 1
- Deleted footnote "Assured by design. Not production tested" from DC Electrical Characteristics table. ............................. 4
- Deleted footnote "Assured by design. Not production tested" from AC Electrical Characteristics table. ............................. 5

Changes from Revision A (October 2012) to Revision B

- Added Note 1 to $I_{CC}$ Supply Current ........................................................................................................ 4
## PACKAGE OPTION ADDENDUM

### PACKAGING INFORMATION

<table>
<thead>
<tr>
<th>Orderable Device</th>
<th>Status (1)</th>
<th>Package Type</th>
<th>Package Drawing</th>
<th>Pins</th>
<th>Package Qty</th>
<th>Eco Plan (2)</th>
<th>Lead/Ball Finish</th>
<th>MSL Peak Temp (3)</th>
<th>Op Temp (°C)</th>
<th>Top-Side Markings (4)</th>
<th>Samples</th>
</tr>
</thead>
<tbody>
<tr>
<td>BQ2028YZGR</td>
<td>ACTIVE</td>
<td>DSBGA</td>
<td>YZG</td>
<td>12</td>
<td>3000</td>
<td>Green (RoHS &amp; no Sb/Br)</td>
<td>SNAGCU</td>
<td>Level-1-260C-UNLIM</td>
<td>-40 to 85</td>
<td>BQ2028</td>
<td></td>
</tr>
<tr>
<td>BQ2028YZGT</td>
<td>ACTIVE</td>
<td>DSBGA</td>
<td>YZG</td>
<td>12</td>
<td>250</td>
<td>Green (RoHS &amp; no Sb/Br)</td>
<td>SNAGCU</td>
<td>Level-1-260C-UNLIM</td>
<td>-40 to 85</td>
<td>BQ2028</td>
<td></td>
</tr>
</tbody>
</table>

(1) The marketing status values are defined as follows:
**ACTIVE:** Product device recommended for new designs.
**LIFEBUY:** TI has announced that the device will be discontinued, and a lifetime-buy period is in effect.
**NRND:** Not recommended for new designs. Device is in production to support existing customers, but TI does not recommend using this part in a new design.
**PREVIEW:** Device has been announced but is not in production. Samples may or may not be available.
**OBSOLETE:** TI has discontinued the production of the device.

(2) Eco Plan - The planned eco-friendly classification: Pb-Free (RoHS), Pb-Free (RoHS Exempt), or Green (RoHS & no Sb/Br) - please check [http://www.ti.com/productcontent](http://www.ti.com/productcontent) for the latest availability information and additional product content details.

**TBD:** The Pb-Free/Green conversion plan has not been defined.

**Pb-Free (RoHS):** TI's terms "Lead-Free" or "Pb-Free" mean semiconductor products that are compatible with the current RoHS requirements for all 6 substances, including the requirement that lead not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, TI Pb-Free products are suitable for use in specified lead-free processes.

**Pb-Free (RoHS Exempt):** This component has a RoHS exemption for either 1) lead-based flip-chip solder bumps used between the die and package, or 2) lead-based die adhesive used between the die and leadframe. The component is otherwise considered Pb-Free (RoHS compatible) as defined above.

**Green (RoHS & no Sb/Br):** TI defines "Green" to mean Pb-Free (RoHS compatible), and free of Bromine (Br) and Antimony (Sb) based flame retardants (Br or Sb do not exceed 0.1% by weight in homogeneous material)

(3) MSL, Peak Temp. -- The Moisture Sensitivity Level rating according to the JEDEC industry standard classifications, and peak solder temperature.

(4) Multiple Top-Side Markings will be inside parentheses. Only one Top-Side Marking contained in parentheses and separated by a "~" will appear on a device. If a line is indented then it is a continuation of the previous line and the two combined represent the entire Top-Side Marking for that device.

**Important Information and Disclaimer:** The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.

In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis.
YZG (R–XBGA–N12)

DIE–SIZE BALL GRID ARRAY

D: Max = 2.38 mm, Min = 2.32 mm
E: Max = 1.52 mm, Min = 1.46 mm

NOTES:
A. All linear dimensions are in millimeters. Dimensioning and tolerancing per ASME Y14.5M–1994.
B. This drawing is subject to change without notice.
C. NanoFree™ package configuration.

NanoFree is a trademark of Texas Instruments.
IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES “AS IS” AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI’s products are provided subject to TI’s Terms of Sale (www.ti.com/legal/termsofsale.html) or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI’s provision of these resources does not expand or otherwise alter TI’s applicable warranties or warranty disclaimers for TI products.

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265
Copyright © 2019, Texas Instruments Incorporated