

## BOS1921/BOS1931 Piezo Haptic Driver with Digital Front End

### 1 Features

- High-Voltage Low Power Piezo Driver
  - Drives 100 nF at 190 V<sub>pk-pk</sub> and 300 Hz while consuming only 350 mW
  - Drives Capacitive Loads up to 820 nF
  - Energy Recovery
  - Differential Output
  - Small Solution Footprint, QFN & WLCSP
- Advanced Piezo Sensing Capabilities (BOS1921 only)
  - 7.6 mV Sensing Resolution
  - Interrupt Generation
  - Automatic Triggering of Haptic Feedback
- Integrated Digital Front End with I<sup>3</sup>C/I<sup>2</sup>C
  - 1024 sample Internal FIFO Interface
  - 1.8 V to 5.0 V Digital I/O Supply
  - Waveform Synthesizer (WFS)
  - Supports Continuous Waveforms Playback
  - State Retention in SLEEP Mode
- Fast Start Up Time of Less Than 300  $\mu$ s
- Multi-Actuator Synchronization
- Wide Supply Voltage Range of 3 V to 5.5 V

### 2 Applications

- Mobile Phones and Tablets
- Portable Computers, Keyboards and Mice
- Gaming Controllers, Wearables
- Electronic Cooling
- Micropump



Figure 1: Simplified schematic

### 3 Description

The BOS1921 (driving + sensing) and BOS1931 (driving) are a single-chip piezo actuator driver with energy recovery, based on Boreas' patented CapDrive™ technology. It can drive actuators with waveforms up to 190 V<sub>pk-pk</sub> while operating from a 3 to 5.5 V supply voltage. Its low power and small size make it ideal for a variety of applications requiring minimal power consumption.

The BOS1921 features high-resolution piezo sensing capabilities, allowing haptic feedback to be automatically played when detection conditions are met.

The BOS1921/BOS1931 differential driver achieves low distortion waveforms and quiet actuator operation. All settings are adjustable through the digital front end to reduce the BOM.

Data and configuration parameters are easily communicated to the BOS1921/BOS1931 through its two-wire MIPI I<sup>3</sup>C interface. The MIPI I<sup>3</sup>C is also backward compatible with I<sup>2</sup>C for easy integration in most systems. A flexible deep FIFO enables the streaming of digital waveform data for playback or the transmission of burst data for more bandwidth efficiency. The BOS1921/BOS1931 also integrates a waveform synthesizer and 2 kB of RAM waveform memory to generate HD haptic waveforms with minimal communication bandwidth.

A dedicated SYNC pin can synchronize multiple BOS1921/BOS1931 controllers to simultaneously drive multiple actuators within 2  $\mu$ s.

With a typical start-up time of less than 300  $\mu$ s, the device latency is negligible in most systems.

Various safety systems protect the BOS1921/BOS1931 from damage in case of a fault.

See section 9 for package dimensions and section 11 for ordering information.

**TABLE OF CONTENT**

|                                                             |           |
|-------------------------------------------------------------|-----------|
| <b>1 FEATURES .....</b>                                     | <b>1</b>  |
| <b>2 APPLICATIONS .....</b>                                 | <b>1</b>  |
| <b>3 DESCRIPTION .....</b>                                  | <b>1</b>  |
| <b>4 PINS &amp; BUMPS CONFIGURATION AND FUNCTIONS.....</b>  | <b>3</b>  |
| <b>5 SPECIFICATIONS .....</b>                               | <b>5</b>  |
| 5.1 ABSOLUTE MAXIMUM RATINGS .....                          | 5         |
| 5.2 THERMAL RESISTANCE.....                                 | 5         |
| 5.3 RECOMMENDED OPERATING CONDITIONS .....                  | 5         |
| 5.4 ELECTRICAL CHARACTERISTICS.....                         | 6         |
| 5.5 TIMING CHARACTERISTICS.....                             | 7         |
| 5.6 TYPICAL PERFORMANCE CHARACTERISTICS .....               | 9         |
| <b>6 FUNCTIONAL DESCRIPTION .....</b>                       | <b>11</b> |
| 6.1 OVERVIEW .....                                          | 11        |
| 6.2 FEATURES .....                                          | 11        |
| 6.3 DIGITAL INTERFACE.....                                  | 20        |
| 6.4 PIEZO ACTUATOR SENSING (BOS1921 ONLY).....              | 26        |
| 6.5 DIRECT MODE .....                                       | 29        |
| 6.6 FIFO MODE.....                                          | 30        |
| 6.7 RAM PLAYBACK MODE.....                                  | 31        |
| 6.8 RAM SYNTHESIS MODE .....                                | 36        |
| 6.9 WFS COMMAND INTERPRETER.....                            | 53        |
| 6.10 REGISTER MAP .....                                     | 62        |
| <b>7 IMPLEMENTATION .....</b>                               | <b>80</b> |
| 7.1 DIFFERENTIAL OUTPUT CONFIGURATION.....                  | 80        |
| 7.2 SINGLE-ENDED CONFIGURATION .....                        | 81        |
| 7.3 EXTERNAL COMPONENTS.....                                | 81        |
| 7.4 INITIALIZATION.....                                     | 82        |
| 7.5 DESIGN METHODOLOGY: SELECTION OF COMPONENT.....         | 83        |
| 7.6 DESIGN METHODOLOGY: PROGRAMMING .....                   | 85        |
| 7.7 NOISE REDUCTION.....                                    | 87        |
| <b>8 PCB LAYOUT EXAMPLE.....</b>                            | <b>88</b> |
| <b>9 MECHANICAL .....</b>                                   | <b>90</b> |
| 9.1 QFN PACKAGE DESCRIPTION.....                            | 90        |
| 9.2 WLCSP PACKAGE DESCRIPTION.....                          | 92        |
| 9.3 TAPE AND REEL SPECIFICATIONS .....                      | 95        |
| <b>10 KNOWN ISSUES .....</b>                                | <b>96</b> |
| 10.1 INCORRECT ACTIVATION OF OUTPUT BRIDGE PROTECTION ..... | 96        |
| 10.2 TIMEOUT RESETS PLAY_SRATE .....                        | 96        |
| 10.3 WAVEFORM AMPLITUDE DRIFT WITH RELOFF OPTION.....       | 96        |
| 10.4 MINIMUM SLEW-RATE OF V <sub>BUS</sub> SUPPLY .....     | 96        |
| <b>11 ORDERING INFORMATION .....</b>                        | <b>97</b> |
| <b>12 DOCUMENT HISTORY .....</b>                            | <b>98</b> |
| <b>13 NOTICE AND WARNING .....</b>                          | <b>99</b> |

## 4 Pins & Bumps Configuration and Functions



Figure 2: QFN 24L 4.0mm x 4.0mm package with exposed thermal pad (TOP VIEW; NOT TO SCALE)

Table 1: QFN package pins description

| PIN NO. | NAME   | TYPE         | DESCRIPTION                                            |
|---------|--------|--------------|--------------------------------------------------------|
| 1       | OUT+   | Output       | Positive Differential Output                           |
| 2       | VDDP   | Power        | Intermediate Supply Voltage                            |
| 3       | VBUS   | Power        | Main Power Supply                                      |
| 4       | SCL    | Input        | I <sup>2</sup> C/I <sup>2</sup> C clock                |
| 5       | SYNC   | Input/Output | Synchronization pin, tie to ground if unused           |
| 6       | VDDIO  | Power        | Digital IO Power Supply                                |
| 7       | SDA    | Input/Output | I <sup>2</sup> C/I <sup>2</sup> C data                 |
| 8       | GND    | Power        | Supply Ground                                          |
| 9       | GPIO   | Input/Output | General-purpose input output                           |
| 10      | REG    | Power        | Internal 1.8 V Regulator Output                        |
| 11      | PUMP   | Power        | Internal 5 V Charge Pump Voltage                       |
| 12      | TST1   | -            | No connect                                             |
| 13      | RP/VDD | Power        | Current Sense Positive Input / Supply Voltage          |
| 14      | RM     | Input        | Current Sense Negative Input                           |
| 15      | TST0   | -            | Connect to GND                                         |
| 16      | SW     | Power        | Internal Power Converter Switch Pin                    |
| 17      | PGND   | Power        | Supply Ground of the Power Stage                       |
| 18      | GND    | Power        | Supply Ground                                          |
| 19      | GND    | Power        | Supply Ground                                          |
| 20      | PGND   | Power        | Supply Ground of the Power Stage                       |
| 21      | HV     | Power        | High-Voltage Output                                    |
| 22      | HV     | Power        | High-Voltage Output                                    |
| 23      | OUT-   | Output       | Negative Differential Output                           |
| 24      | VDDP   | Power        | Intermediate Supply Voltage                            |
| 25      | GND    | Power        | Exposed thermal pad is GND and must be soldered to PCB |



Figure 3: WLCSP 20B 2.1mm x 1.7mm package (TOP VIEW; NOT TO SCALE)

Table 2: WLCSP package bumps description

| BUMP NO. | NAME   | TYPE         | DESCRIPTION                                   |
|----------|--------|--------------|-----------------------------------------------|
| A1       | OUT-   | Output       | Negative Differential Output                  |
| A2       | VDDP   | Power        | Intermediate Supply Voltage                   |
| A3       | VBUS   | Power        | Main Power Supply                             |
| A4       | SCL    | Input        | I <sup>2</sup> C/I <sup>2</sup> C clock       |
| A5       | VDDIO  | Power        | Digital IO Power Supply                       |
| B1       | HV     | Power        | High-Voltage Output                           |
| B2       | OUT+   | Output       | Positive Differential Output                  |
| B3       | SYNC   | Input/Output | Synchronization pin                           |
| B4       | SDA    | Input/Output | I <sup>2</sup> C/I <sup>2</sup> C data        |
| B5       | REG    | Power        | Internal 1.8 V Regulator Output               |
| C1       | PGND   | Power        | Supply Ground of the Power Stage              |
| C2       | GND    | Power        | Supply Ground                                 |
| C3       | TST1   | -            | No connect                                    |
| C4       | GPIO   | Input/Output | General-purpose input output                  |
| C5       | PUMP   | Power        | Internal 5 V Charge Pump Voltage              |
| D1       | PGND   | Power        | Supply Ground of the Power Stage              |
| D2       | SW     | Power        | Internal Power Converter Switch Pin           |
| D3       | TST0   | -            | Connect to GND                                |
| D4       | RM     | Input        | Current Sense Negative Input                  |
| D5       | RP/VDD | Input        | Current Sense Positive Input / Supply Voltage |

## 5 Specifications

### 5.1 Absolute Maximum Ratings

Table 3: Absolute maximum ratings<sup>‡</sup>

|   | SYMBOL    | PARAMETER                          | MIN            | NOM | MAX | UNIT |
|---|-----------|------------------------------------|----------------|-----|-----|------|
| 1 |           | Voltage at pins HV, OUT+, OUT-, SW | -0.3           |     | 110 | V    |
| 2 |           | Voltage at all other pins          | -0.3           |     | 7   | V    |
| 3 | $T_{stg}$ | Storage temperature                | -65            |     | 150 | °C   |
| 4 | $T_J$     | Junction Temperature               | -40            |     | 150 | °C   |
| 5 | SOA       | Safe operating area                | See Figure 14. |     |     | -    |

<sup>‡</sup>Exceeding these values may cause permanent damage. Functional operation under these conditions is not guaranteed.

### 5.2 Thermal Resistance

Table 4: Thermal resistance<sup>‡</sup>

|   | SYMBOL        | PARAMETER                               | PACKAGE                 | MIN | NOM <sup>(1,2)</sup> | MAX | UNIT |
|---|---------------|-----------------------------------------|-------------------------|-----|----------------------|-----|------|
| 1 | $\Theta_{JA}$ | Thermal resistance: junction to ambient | QFN 24L 4.0mm × 4.0mm   |     | TBD                  |     | °C/W |
|   |               |                                         | WLCSP 20B 2.1mm × 1.7mm |     |                      |     | °C/W |

<sup>‡</sup>Power dissipated in the package is not obvious to calculate. Please consult Boréas Technologies before using these parameters.

### 5.3 Recommended Operating Conditions

Table 5: Recommended operating conditions

|   | SYMBOL                        | PARAMETER                   | TEST CONDITIONS                                                          | MIN  | NOM | MAX  | UNIT |
|---|-------------------------------|-----------------------------|--------------------------------------------------------------------------|------|-----|------|------|
| 1 | $T_A$                         | Operating Temperature       | Operating free-air temperature                                           | -40  |     | 85   | °C   |
| 2 | $V_{BUS}$ ,<br>$V_{DD}^{(1)}$ | Supply voltage              |                                                                          | 3.0  |     | 5.5  | V    |
| 3 | $V_{DDIO}^{(2)}$              | I/O Supply voltage          |                                                                          | 1.62 |     | 5.5  | V    |
| 4 | $C_L$                         | Load capacitance            | $V_{OUT} = 190 \text{ V}_{\text{pk-pk}}$ ,<br>$f_{OUT} = 300 \text{ Hz}$ |      |     | 100  | nF   |
|   |                               |                             | $V_{OUT} = 100 \text{ V}_{\text{pk-pk}}$ ,<br>$f_{OUT} = 220 \text{ Hz}$ |      |     | 470  | nF   |
|   |                               |                             | $V_{OUT} = 100 \text{ V}_{\text{pk-pk}}$ ,<br>$f_{OUT} = 130 \text{ Hz}$ |      |     | 820  | nF   |
| 5 | $L_1$                         | Inductance                  |                                                                          | 10   |     | 68   | µH   |
| 6 | $R_{sense}$                   | Sense resistor              |                                                                          | 0.2  |     | 1.0  | Ω    |
| 7 | $f_{OUT}$                     | Output frequency            | <a href="#">PLAY MODE[1:0] = 0x3</a>                                     | 3.9  |     | 1000 | Hz   |
| 8 | $I_{sw}$                      | Transient current at SW pin |                                                                          |      |     | 1.3  | A    |

(1) If the Unidirectional Power Input mode is enabled ([UPI](#) bit set to 0x1),  $V_{DD}$  may increase above the maximum recommended operating condition, see section 6.2.13.

(2) Digital I/O voltage ( $V_{DDIO}$ ) must match the communication interface voltage.

## 5.4 Electrical Characteristics

Table 6: Electrical characteristics. Conditions:  $T_A = 25^\circ\text{C}$ ,  $V_{BUS} = 3.6\text{ V}$  (unless otherwise noted)

|    | SYMBOL                | PARAMETER                                                          | TEST CONDITIONS                                                                                                                                                                                                                                                                                                                              | MIN                                                                              | NOM       | MAX              | UNIT          |
|----|-----------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------|------------------|---------------|
| 1  | $V_{REG}$             | Voltage at REG pin                                                 |                                                                                                                                                                                                                                                                                                                                              | 1.75                                                                             | 1.80      | 1.85             | V             |
| 2  | $V_{IL}$              | Digital low-level input voltage                                    | SDA, SCL, GPIO & SYNC pins                                                                                                                                                                                                                                                                                                                   |                                                                                  |           | 0.5              | V             |
| 3  | $V_{IH}$              | Digital high-level input voltage                                   |                                                                                                                                                                                                                                                                                                                                              | $V_{DDIO} \times 0.7$                                                            |           | $V_{DDIO} + 0.3$ | V             |
| 4  | $V_{OL}$              | Digital low-level output voltage                                   |                                                                                                                                                                                                                                                                                                                                              |                                                                                  |           | 0.4              | V             |
| 5  | $V_{OH}$              | Digital high-level output voltage                                  |                                                                                                                                                                                                                                                                                                                                              | $V_{DDIO} \times 0.8$                                                            |           |                  |               |
| 6  | $V_{OUT(FS)}$         | Full-scale output voltage                                          |                                                                                                                                                                                                                                                                                                                                              | 186                                                                              | 190       | 194              | $V_{pk-pk}$   |
| 7  | $I_{Q\_V_{BUS}}$      | $V_{BUS}$ Quiescent current                                        |                                                                                                                                                                                                                                                                                                                                              | SLEEP State <sup>(1)(2)</sup><br><u>OE</u> =0x0, <u>DS</u> =0x1, <u>RET</u> =0x1 | 0.6       | 10               | $\mu\text{A}$ |
|    |                       |                                                                    |                                                                                                                                                                                                                                                                                                                                              | SLEEP State<br><u>OE</u> =0x0, <u>DS</u> =0x1, <u>RET</u> =0x0                   | 2.4       |                  | $\mu\text{A}$ |
|    |                       |                                                                    |                                                                                                                                                                                                                                                                                                                                              | IDLE State<br><u>OE</u> =0x0, <u>DS</u> =0x0                                     | 530       |                  | $\mu\text{A}$ |
| 8  | $I_{BUS,AVG}$         | Average $V_{BUS}$ supply current during operation & <u>OE</u> =0x1 | <u>SENSING</u> =0x1 <sup>(3)</sup><br><br>$f_{OUT} = \text{DC}$<br>$V_{OUT} = 95\text{ V}$<br>$C_{Load} = 100\text{ nF}$<br><br>$f_{OUT} = 300\text{ Hz}$<br>$V_{OUT} = 190\text{ V}_{pk-pk}$<br>$C_{Load} = 100\text{ nF}$<br><br>$f_{OUT} = 200\text{ Hz}$<br>$V_{OUT} = 190\text{ V}_{pk-pk}$<br>$C_L = 10\text{ nF}$<br><u>CCM</u> = 0x0 | 1.9                                                                              |           |                  | mA            |
|    |                       |                                                                    |                                                                                                                                                                                                                                                                                                                                              | 3.7                                                                              |           |                  | mA            |
|    |                       |                                                                    |                                                                                                                                                                                                                                                                                                                                              | 90                                                                               |           |                  | mA            |
|    |                       |                                                                    |                                                                                                                                                                                                                                                                                                                                              | 14.5                                                                             |           |                  | mA            |
| 9  | THD+N                 | Total Harmonic Distortion + Noise <sup>(2)</sup>                   | $f_{OUT} = 300\text{ Hz}$<br>$V_{OUT} = 190\text{ V}_{pk-pk}$<br>$C_{Load} = 100\text{ nF}$                                                                                                                                                                                                                                                  |                                                                                  | 0.3       | 1                | %             |
| 10 | $f_{s-FIFO}$          | Programmable FIFO playback rate                                    | <u>PLAY_SRATE[2:0]</u> =0x0<br><u>PLAY_SRATE[2:0]</u> =0x7                                                                                                                                                                                                                                                                                   | 1008<br>7.875                                                                    | 1024<br>8 | 1040<br>8.125    | ksps          |
| 11 | PSR <sup>(3)</sup>    | Piezo Sensing Resolution                                           | <u>CONFIG.GAINS</u> =0x1                                                                                                                                                                                                                                                                                                                     |                                                                                  | 7.6       |                  | mV            |
| 12 | $t_{start}^{(2)}$     | Start-up Time                                                      | Time from SLEEP mode to haptic waveform playback                                                                                                                                                                                                                                                                                             |                                                                                  |           | 300              | $\mu\text{s}$ |
| 13 | DHL <sup>(2)(3)</sup> | Sensing Detection to Haptic Feedback Latency                       | Time from sensing detection event to automatic playback                                                                                                                                                                                                                                                                                      |                                                                                  |           | 30               | $\mu\text{s}$ |

(1) The  $V_{DDIO}$  supply should be powered off when state retention is disabled (RET bit set to 0x1) to minimize the total quiescent current of the device.

(2) Validated by design.

(3) BOS1921 only.

## 5.5 Timing Characteristics

### 5.5.1 I<sup>2</sup>C

Table 7: Timing characteristics. Condition: I<sup>2</sup>C communication mode,  $T_A = 25^\circ\text{C}$ ,  $V_{DDIO} = 1.8\text{ V}$ , SDA/SCL load = 50 pF

|    |               |                                                                           | FAST MODE |     | FAST MODE + |     |      |
|----|---------------|---------------------------------------------------------------------------|-----------|-----|-------------|-----|------|
|    | SYMBOL        | PARAMETER                                                                 | MIN       | MAX | MIN         | MAX | UNIT |
| 1  | $f_{SCL}$     | SCL clock frequency <sup>(1)</sup>                                        | 0         | 0.4 | 0           | 1.0 | MHz  |
| 2  | $t_{LOW}$     | SCL low period                                                            | 1300      |     | 500         |     | ns   |
| 3  | $t_{HIGH}$    | SCL high period                                                           | 600       |     | 260         |     | ns   |
| 4  | $t_R$         | SDA/SCL rise time <sup>(1)</sup>                                          | 20        | 300 | -           | 120 | ns   |
| 5  | $t_F$         | SDA/SCL fall time <sup>(1)</sup>                                          | -         | 300 | -           | 120 | ns   |
| 6  | $t_{SU\_DAT}$ | Data setup time <sup>(1)</sup>                                            | 100       |     | 50          |     | ns   |
| 7  | $t_{HD\_DAT}$ | Data hold time <sup>(1)</sup>                                             | 0         | -   | 0           | -   | ns   |
| 8  | $t_{SU\_STA}$ | Setup time for a repeated START condition <sup>(1)</sup>                  | 600       |     | 260         |     | ns   |
| 9  | $t_{HD\_STA}$ | Hold time for a (repeated) START condition <sup>(1)</sup>                 | 600       |     | 260         |     | ns   |
| 10 | $t_{SU\_STO}$ | Setup time for STOP condition <sup>(1)</sup>                              | 600       |     | 260         |     | ns   |
| 11 | $t_{BUF}$     | Bus free time (time between the STOP and START conditions) <sup>(1)</sup> | 1300      |     | 500         |     | ns   |
| 12 | $t_{SPIKE}$   | Spike suppression pulse width <sup>(1)</sup>                              | 0         | 50  | 0           | 50  | ns   |

(1) Validated by design.



Figure 4: I<sup>2</sup>C timing diagram

5.5.2 I<sup>2</sup>CTable 8: Timing characteristics. Condition: I<sup>2</sup>C push-pull,  $T_A = 25^\circ\text{C}$ ,  $V_{DDIO} = 1.8\text{ V}$ , SDA/SCL load = 50 pF

|    | SYMBOL                   | PARAMETER                                            | MIN                         | MAX                                                        | UNIT |
|----|--------------------------|------------------------------------------------------|-----------------------------|------------------------------------------------------------|------|
| 1  | $f_{SCL}$                | SCL clock frequency <sup>(1)</sup>                   | 0.01                        | 12.5                                                       | MHz  |
| 2  | $t_{LOW}$                | SCL low period                                       | 24                          |                                                            | ns   |
| 3  | $t_{HIGH}$               | SCL high period                                      | 24                          | 41 <sup>(2)</sup>                                          | ns   |
| 4  | $t_{CR}$                 | SCL rise time <sup>(1)</sup>                         |                             | The minimum between whether $150 \times 106/f_{SCL}$ or 60 | ns   |
| 7  | $t_{CF}$                 | SCL fall time <sup>(1)</sup>                         |                             | The minimum between whether $150 \times 106/f_{SCL}$ or 60 | ns   |
| 8  | $t_{SU}$                 | Data setup time                                      | 3                           |                                                            | ns   |
| 9  | $t_{HD}$<br>(controller) | Data hold time                                       | $t_{CR} + 3$ , $t_{CF} + 3$ |                                                            | ns   |
| 10 | $t_{HD}$ (target)        | Data hold time                                       | 0                           |                                                            | ns   |
| 11 | $t_{CBSr}$               | Clock before repeated START condition <sup>(1)</sup> | 19.2                        |                                                            | ns   |
| 12 | $t_{CAS}$                | Clock after START condition <sup>(1)</sup>           | 38.4                        |                                                            | ns   |
| 13 | $t_{CAsr}$               | Clock after repeated START condition <sup>(1)</sup>  | 38.4                        |                                                            | ns   |
| 14 | $t_{CBP}$                | Clock before STOP condition <sup>(1)</sup>           | 19.2                        |                                                            | ns   |
| 15 | $t_{AVAL}$               | Bus available <sup>(1)</sup>                         | 1                           |                                                            | μs   |

(1) Validated by design.

(2) This maximum high period may be exceeded when the signals can be safely seen by legacy I<sup>2</sup>C devices.

Figure 5: I<sup>2</sup>C push-pull timing diagram

## 5.6 Typical Performance Characteristics

Typical performance characteristics for the following conditions:  $T_A = 25^\circ\text{C}$ ,  $V_{\text{BUS}} = 3.6\text{ V}$ ,  $C_L = 100\text{ nF}$ ,  $V_{\text{OUT}} = 190\text{ V}_{\text{pk-pk}}$  and  $f_{\text{OUT}} = 200\text{ Hz}$  (unless otherwise noted).



Figure 6: Supply Current vs Output Voltage



Figure 7: Total Harmonic Distortion + Noise vs Output Voltage



Figure 8: Supply Current vs Output Voltage



Figure 9: Total Harmonic Distortion + Noise vs Output Voltage



Figure 10: Supply Current vs Operating free-air Temperature



Figure 11: Total Harmonic Distortion + Noise vs Operating free-air Temperature



Figure 12: Output Frequency Variation vs Operating free-air Temperature



Figure 13: Supply Quiescent Current in IDLE Mode vs Operating free-air Temperature



Figure 14: Safe Operating Area at  $I_{SW \max}$

## 6 Functional Description

### 6.1 Overview

The BOS1921/BOS1931 is a highly integrated low-power piezo actuator driver with an integrated digital front end and energy recovery, based on Boreas's patented CapDrive™ technology. The device requires a single low-voltage supply and 7 passive components to generate waveforms of up to 190 V<sub>pk-pk</sub>.

The digital interface enables the transmission of the digital waveform data from any MCU with an I<sup>2</sup>C or I<sup>2</sup>C interface to the BOS1921/BOS1931. A flexible FIFO interface enables the generation of haptic playback by streaming the digital waveform data or transmitting the digital waveform data in groups for more bandwidth efficiency. Waveforms can be generated by reading data from the FIFO at various sampling rates.

The BOS1921/BOS1931 integrates a Waveform Synthesizer (WFS) and a 2 kB on-chip 1024×16 RAM that enable haptic waveform generation using RAM Playback mode and RAM Synthesis mode. The WFS allows the generation of customized continuous haptic waveforms with minimal intervention by the host MCU.

The BOS1921 features an advanced sensing interface that allows mechanical buttons to be replaced with an enhanced user interface. Piezo actuator press/release trigger conditions allow the detection of an interaction with a piezo actuator and automatically trigger haptic waveform feedback within 30 µs. A GPIO pin can be used as an interrupt to indicate the MCU that a sensing voltage event has occurred or a change in the device state.

The BOS1921/BOS1931 can use any commercial off-the-shelf (COTS) inductor. The inductor value can be chosen to optimize the power, size or performance depending on the user's application. With a start-up time of less than 300 µs from its low-power mode, the device can be used in applications requiring low latency.

### 6.2 Features

#### 6.2.1 Digital Front-End Interface

The BOS1921/BOS1931 uses an I<sup>2</sup>C target interface supporting SDR communication up to 12.5 Mbps. This high-speed communication interface enables multiple ICs to share a common communication bus. Its digital front-end enables waveform data to be stored in memory. The digital interface also provides access to internal registers which control the BOS1921/BOS1931 operation and performance, see section 6.3 for more details.

#### 6.2.2 GPIO

A General-Purpose Input / Output (GPIO) pin in the VDDIO domain is available and supports an open-drain (default) or push-pull configuration. The GPIO is active-low and can be used as an interrupt to notify the host MCU of various events such as sense voltage events or an error. The GPIO can also be used as an input to trigger a predefined haptic waveform output.

The GPIO pin can be configured with the following register bits:

- [COMM.GPIODIR](#) is used to set the GPIO pin as input or output.
- [COMM.GPIOSEL\[2:0\]](#) is used to select the signal that is output to the GPIO pin.
- [COMM.OD](#) is used to set the GPIO pin to push-pull or open-drain configuration.

### 6.2.3 Flexible Waveform Generation

The output waveform voltage range can be selected between  $\pm 95$  V and  $\pm 13.25$  V as detailed in Table 9.

Table 9: Output Voltage Ranges List

| REGISTER                     | REGISTER VALUE | OUTPUT RANGE (V) | OUTPUT RESOLUTION (V) |
|------------------------------|----------------|------------------|-----------------------|
| <a href="#">CONFIG.GAIND</a> | 0x1            | $\pm 13.25$      | 0.0076                |
| <a href="#">CONFIG.GAIND</a> | 0x0            | $\pm 95$         | 0.0545                |

#### 6.2.3.1 Direct Mode

With [PLAY MODE\[1:0\]](#) bits set to 0x0, the haptic waveform samples are played as they are sent from the host MCU to the RAM using [REFERENCE](#) register. The rate at which the RAM data is read to generate the haptic waveform is set by [PLAY SRATE\[2:0\]](#) bits. See section 6.5 for details.

#### 6.2.3.2 FIFO Mode

The digital front-end gives access to RAM as a 1024-sample FIFO for waveform playback with [PLAY MODE\[1:0\]](#) bits set to 0x1. FIFO entries are appended every time waveform samples are written in the [REFERENCE](#) register. Digital samples are represented as 12-bit unsigned values. If [OE](#) bit is set to 0x1, the FIFO entries are read automatically out of the FIFO at a rate set by [PLAY SRATE\[2:0\]](#) bits. See section 6.6 for details.

#### 6.2.3.3 RAM Playback Mode

RAM Playback mode is selected with [PLAY MODE\[1:0\]](#) bits set to 0x2. In RAM Playback mode, on-chip RAM of 2 kB is used to store arbitrary haptic waveforms as waveform amplitude samples in 12-bit unsigned format. The waveform is sampled at a rate set by [PLAY SRATE\[2:0\]](#) bits. See section 6.7 for more details.

#### 6.2.3.4 RAM Synthesis Mode

RAM Synthesis mode is selected with bits [PLAY MODE\[1:0\]](#) set to 0x3. With this mode, the BOS1921/BOS1931 uses the Waveform Synthesizer (WFS) to generate waveforms using parameters stored in the 2 kB RAM. RAM Synthesis mode allows generation of sine waveforms of various amplitudes and frequencies without having to send every sample of the waveform to RAM as is the case with RAM Playback mode. This allows complex waveforms to be produced with minimal data communication. See section 6.8 for details.

### 6.2.4 Piezo Sensing (BOS1921 Only)

The BOS1921 can use a piezo actuator as a force sensor by measuring the voltage across its terminals.

The BOS1921 also features an embedded sensing comparator that can be configured to automatically trigger an already programmed waveform.

The GPIO pin can inform the MCU that a sensing voltage event occurred or a triggered waveform has finished playing using [GPIOSEL\[2:0\]](#) bits. Voltage sensed is available with [SENSE VALUE\[11:0\]](#) bits, which can be read at any time when sensing is activated ([CONFIG.SENSE](#) bit set to 0x1) and is useful for MCU-based customized sensing algorithms. See section 6.4 for more detail.

The sensing resolution can be selected between 7.6 mV and 54.5 mV as detailed in Table 10.

Table 10: Sensing Ranges List

| REGISTER                     | REGISTER VALUE | INPUT RANGE (V) | SENSING RESOLUTION (V) |
|------------------------------|----------------|-----------------|------------------------|
| <a href="#">CONFIG.GAINS</a> | 0x1            | ±13.25          | 0.0076                 |
| <a href="#">CONFIG.GAINS</a> | 0x0            | ±95             | 0.0545                 |

### 6.2.5 Continuous Mode

With RAM Synthesis or RAM Playback mode, it is possible to play a waveform for an indefinite amount of time without the intervention of an external MCU. This feature is well suited for cooling or micropump applications that need to operate for long periods of time while minimizing overall system power and resource usage.

### 6.2.6 SLEEP Mode

When no output waveform is being requested, no sensing is needed (BOS1921 only) and the output is disabled (bit [OE](#) set to 0x0), the device can enter in one of its two low-power modes by the use of the bit [DS](#): IDLE or SLEEP mode. By default, power mode is IDLE (bit [DS](#) set to 0x0). SLEEP mode is selected when bit [DS](#) is set to 0x1.

In SLEEP mode, the BOS1921/BOS1931 preserve its RAM and the contents of the registers by default ([RET](#) bit set to 0x0). By setting [RET](#) bit set to 0x1, SLEEP mode does not preserve RAM and neither the contents of the registers to reduce the power consumption. Note that to reduce the total quiescent current of the device, the following should be done:

- Disabled state retention (set [RET](#) bit to 0x1)
- Power off VDDIO supply.

The BOS1921/BOS1931 wakes up from SLEEP mode when a communication occurs on its I<sup>2</sup>C/I3C interface (the data will not have any effect on the configuration of the registers).

### 6.2.7 Low Latency Startup

The BOS1921/BOS1931 features a fast start-up time. From IDLE or SLEEP mode, the device takes less than 300 µs to start playing the waveform. This makes the device a very small contributor to system latency.

### 6.2.8 Device Reset

The BOS1921/BOS1931 device has software-based reset functionality. When [RST](#) bit is set to 0x1, all registers are set to their default value and IC goes in IDLE state. [RST](#) bit self-clears once the reset is complete.

The following sequence must be done to safely reset the device while playing a waveform in FIFO or Direct mode:

1. Set [CONFIG.OE](#) bit must be set to 0x0.
2. Wait for the device to be in IDLE by polling [IC\\_STATUS.STATE\[1:0\]](#) bits.
3. Reset the device by setting [RST](#) bit to 0x1.

### 6.2.9 Device Synchronization

Multiple BOS1921/BOS1931 devices can be synchronized using SYNC pin to play haptic waveforms simultaneously on their respective piezo actuator with a phase delay of less than 2 µs between them.

Synchronization is achieved by connecting the SYNC pin of all devices with each other. A 10 k $\Omega$  pull-up resistor is needed between SYNC node and V<sub>DDIO</sub>. The sequence to use device synchronisation is the following:

- 1) Set OE bit and SENSE bit to 0x0 on all devices.
- 2) Set SYNC bit to 0x1 on all devices.
- 3) For Each devices set OE bit to 0x1. The devices will wait on each other before starting to play the waveform and will synchronize the haptic waveforms within less than 2  $\mu$ s during playback.

Note that SYNC pin must be tied to ground if unused.

### 6.2.10 Adjustable Current Limit

The maximum current of the power converter must be limited to avoid damage to both the L<sub>1</sub> inductor and the BOS1921/BOS1931 device by selecting the appropriate R<sub>sense</sub> value (see section 7.5.3). The BOS1921/BOS1931 determine the current flowing through the L<sub>1</sub> inductor by measuring the voltage drop across R<sub>sense</sub>, which is positioned between the RP/VDD and RM pins.

The current limit flowing through SW pin should be selected based on the following:

- Ensure that the current is lower than the saturation limit of the inductor L1.
- Ensure that the current is high enough to allow sufficient energy transfer to and from the piezo actuator.

The solution should be tested during its worst-case operation to ensure that the BOS1921/BOS1931 meets the bandwidth requirement of the application.

### 6.2.11 Internal Charge Pump

The BOS1921/BOS1931 has an internal 5 V charge pump which requires a 0.1  $\mu$ F capacitor (C<sub>PUMP</sub>) with a 6.3 V voltage rating or more to be connected on HV pin.

### 6.2.12 Energy Recovery

The BOS1921/BOS1931 IC implements bidirectional power transfer: input to output, and output to input. Such architecture enables the recovery of the energy accumulated on the capacitive load and transfers it back to the input. The internal controller automatically determines the direction of the power flow during waveform playback.

### 6.2.13 Unidirectional Power Input (UPI)

The BOS1921/BOS1931 can sink and source current from the power delivery network (PDN) during normal operation thanks to its energy recovery feature. If the PDN can't sink current (e.g., if the device is powered by batteries), the Unidirectional Power Input (UPI) must be configured by setting UPI bit to 0x1. UPI allows the device to appear as a resistive load to the power supply (the device only sinks current) and reducing RMS current flowing in the PDN. UPI does not affect the efficiency of the BOS1921/BOS1931, but it causes the following to happen:

- First, power is drawn from the input source when the amplitude of the output waveform increases.
- Second, energy recovered accumulates on the input capacitor (C<sub>VDD</sub>) when the amplitude of the output waveform decreases.

Energy accumulation on the C<sub>VDD</sub> capacitor causes the voltage at VDDP pin to increase, as shown in Figure 16. The voltage increase can be adjusted by first calculating the maximum energy that may be recovered

from the load and then sizing  $C_{VDD}$  appropriately to achieve the desired voltage increase (see section 7.5.5). Voltage at VDDP pin should never exceed 5.5 V.



Figure 15: Block diagram of the Unidirectional Power Input (UPI)



Figure 16: Voltage increases at VDDP pin during energy recovery when bit [UPI](#) is set to 0x1,  $C_{VDD} = 100 \mu F$ ,  $C_{Load} = 100 nF$

#### 6.2.14 Adjustable Internal Clock

The internal clock oscillator frequency is trimmed during fabrication using hardware fuses. When initialized, the BOS1921/BOS1931 retrieves the hardware fuse values and push them to the TRIM block to adjust the oscillator frequency based on the fuse values (see Figure 34). The [TRIM](#) register allows modifying the TRIM values to adjust oscillator frequency.

The feature can be used to match the external system clock frequency with the BOS1921/BOS1931 internal clock frequency, which is used to determine the FIFO read-out rate. This might be needed to minimize waveform distortion if the user writes waveform data at a constant rate to the FIFO, without managing space available in it. To successfully adjust internal clock frequency, [OE](#) bit needs to be set to 0x0.

The internal oscillator can be adjusted with the following sequence:

1. Set [CONFIG.OE](#) bit to 0x0.
2. Set [TRIM.TRIMRW\[1:0\]](#) bits to one of the following values:
  - a. Set to 0x1 to latch the Hardware Fuses to Trim Block and push them to the [TRIM](#) register, or
  - b. Set to 0x2 to retrieve the oscillator trim value contained in the TRIM block and push the value to the [TRIM](#) register.
3. Wait 1 ms.
4. Read [TRIM.TRIM OSC\[5:0\]](#) bits (using bits [COMM.RDADDR\[4:0\]](#)) to get the internal oscillator trim value specific to the device.
5. In one transaction, set the [TRIM](#) register with the following field:
  - a. [TRIM OSC\[5:0\]](#) bits set to the desired value.
  - b. [TRIMRW\[1:0\]](#) bits set to 0x3 to write [TRIM OSC\[5:0\]](#) value to TRIM block.

The same procedure can be used to adjust the internal 1.8 V regulator voltage (pin REG) using bits [TRIM.TRIM REG\[2:0\]](#) instead of [TRIM.TRIM OSC\[5:0\]](#) bits.

### 6.2.15 Fault and Warning Behaviour

This section lists the various faults detected by the device. Note that faults detected by the device may be caused by the following:

- Device operating outside of its safe operating conditions.
- Wrong component value (e.g.,  $R_{sense}$ ,  $C_{HV}$ ,  $C_{VDD}$  or  $L_1$ ).
- Noise induced by improper printed circuit board layout.

#### 6.2.15.1 Overvoltage Fault

The overvoltage fault is triggered to prevent damage when voltage level on OUT+ or OUT- pin relative to  $V_{BUS}$  voltage is outside safe operating conditions. The fault is triggered in the following situations:

- When playing haptic waveforms with high gain in the following conditions:
  - [OE](#) bit set to 0x1.
  - [SENSE](#) bit set to 0x0.
  - [GAIND](#) bit set to 0x0.
  - Voltage level on OUT+ pin relative to  $V_{BUS}$  is above 100 V or voltage level on OUT- pin relative to  $V_{BUS}$  is below -100 V.
- When playing haptic waveforms with low gain in the following conditions:
  - [OE](#) bit set to 0x1.
  - [SENSE](#) bit set to 0x0.
  - [GAIND](#) bit set to 0x1.
  - Voltage level on OUT+ pin relative to  $V_{BUS}$  is above 14 V or voltage level on OUT- pin relative to  $V_{BUS}$  is below -14 V.
- When using piezo actuator sensing with the BOS1921 and high gain in the following conditions:
  - [OE](#) bit set to 0x1.
  - [SENSE](#) bit set to 0x1.
  - [GAINS](#) bit set to 0x0.
  - Voltage level on OUT+ pin relative to  $V_{BUS}$  is above 100 V or voltage level on OUT- pin relative to  $V_{BUS}$  is below -100 V.

- When using piezo actuator sensing with the BOS1921 and low gain in the following conditions:
  - OE bit set to 0x1.
  - SENSE bit set to 0x1.
  - GAINS bit set to 0x1.
  - Voltage level on OUT+ pin relative to V<sub>BUS</sub> is above 14 V or voltage level on OUT- pin relative to V<sub>BUS</sub> is below -14 V.

If an overvoltage condition is detected during waveform generation, the following events occur:

- IC\_STATUS.OVV fault bit is set.
- IC\_STATUS.STATE[1:0] bits are changed to 0x3 (ERROR state).
- Output voltage ramp down to VDD.

The OVV bit will clear automatically and the BOS1921/BOS1931 state will change to IDLE (bits STATE[1:0] set to 0x0) with the following conditions:

- OE bit is 0x0.
- Output voltage is lower than the maximum allowed V<sub>OUT(FS)</sub>.

### 6.2.15.2 Output Short Circuit Fault

The BOS1921/BOS1931 has an output short circuit protection to prevent excessive current to flow because of a shorted load. In case a short circuit is detected, the following events occur:

- IC\_STATUS.SC fault bit is set.
- IC\_STATUS.STATE[1:0] bits are changed to 0x3 (ERROR state).
- Output voltage ramp down to VDD.

The SC bit will clear automatically and the BOS1921/BOS1931 state will change to IDLE (bits STATE[1:0] is 0x0) with the following conditions:

- Bit OE is 0x0.
- Output voltage is lower than the maximum allowed V<sub>OUT(FS)</sub>.

### 6.2.15.3 Over Temperature Fault

The BOS1921 has an internal temperature sensor that puts the BOS1921/BOS1931 in ERROR state in case the die junction temperature exceeds 145 °C. In this case, the following events occur:

- IC\_STATUS.OVT fault bit is set.
- IC\_STATUS.STATE[1:0] bits are changed to 0x3 (ERROR state).
- Output voltage ramp down to VDD.

The OVT bit will clear automatically and the BOS1921/BOS1931 state will change to IDLE (STATE [1:0] bits are 0x0) with the following conditions:

- OE bit is 0x0.
- Output voltage is lower than the maximum allowed V<sub>OUT(FS)</sub>.

The low power dissipation of the BOS1921/BOS1931 makes it unlikely that its temperature will reach 145 °C even when it is continuously operated at the maximum Z<sub>L</sub> in the operating temperature range T<sub>A</sub>.

### 6.2.15.4 Under Voltage Fault

The BOS1921/BOS1931 monitor  $V_{BUS}$ , and if its voltage is below 2.875 V during waveform generation, the following events occur:

- [IC\\_STATUS.UVLO](#) bit is set.
- [IC\\_STATUS.STATE\[1:0\]](#) bits are changed to 0x3 (ERROR state).
- Output voltage ramp down to  $V_{DD}$ .

[UVLO](#) bit will self-clear and the BOS1921/BOS1931 state will change to IDLE ([STATE\[1:0\]](#) bits are set to 0x0) with the following conditions:

- [OE](#) bit is 0x0.
- Output voltage is lower than the maximum allowed  $V_{OUT(FS)}$ .

### 6.2.15.5 Current Detection Status Fault

For proper operation, the BOS1921 monitors the current using  $R_{sense}$  resistor connected to RP and RM pins. If no current is detected during waveform generation, the following event occurs:

- [IC\\_STATUS.IDAC](#) fault bit is set.
- [IC\\_STATUS.STATE\[1:0\]](#) bits are changed to 0x3 (ERROR state).

[IDAC](#) errors are typically triggered by incorrect component sizing (see section 7.5) or inadequate waveform data. If component sizing and waveform data are correct, see section 6.2.18 for details on other circumstances that can cause an IDAC error and strategies to avoid them.

To recover from an IDAC error, a software reset must be done using [CONFIG.RST](#) bit. [IC\\_STATUS.IDAC](#) bit does not self-clear.

### 6.2.15.6 Maximum Power Warning

During waveform playback, if the current in  $R_{sense}$  is equal or greater to the current limit defined in section 7.5.3, a maximum power warning is raised, and the following happens:

- [IC\\_STATUS.MXPWR](#) warning bit is set.
- [IC\\_STATUS.STATE\[1:0\]](#) bits remain 0x2 (RUN state).
- The waveform continues to play but is likely distorted.

[IC\\_STATUS.MXPWR](#) bit does self-clears when the current in  $R_{sense}$  is lower than current limit defined in section 7.5.3.

### 6.2.15.7 Brownout

The BOS1921/BOS1931 has internal brownout protections and if  $V_{REG}$  goes below 1 V. In this case, the following event occurs:

- The chip issues a reset signal, and all registers are set to their default values.

When  $V_{REG}$  goes back to its specified operating voltage, the BOS1921/BOS1931 will be in IDLE state ([STATE\[1:0\]](#) bits set to 0x0).

### 6.2.16 Output Timeout

Setting [TOUT](#) bit to 0x1 enables a timeout mechanism that forces the BOS1921 into SLEEP mode if no new communication has been received within 4 ms while playing a waveform in Direct or FIFO mode ([PLAY\\_MODE\[1:0\]](#) bits set to 0x0 or 0x1).

Note that [PLAY\\_SRATE\[2:0\]](#) bits are reset to 0x7 when the device enters SLEEP following a timeout event.

More specifically, the BOS1921/BOS1931 enters SLEEP mode when the following conditions are met:

- [COMM.TOUT](#) bit is set to 0x1.
- [CONFIG.OE](#) bit is set to 0x1.
- [PLAY MODE\[1:0\]](#) bits are set to 0x0 or 0x1.
- The FIFO is empty when using FIFO mode ([PLAY MODE\[1:0\]](#) bits set to 0x1).
- The BOS1921/BOS1931 did not receive any communication on its digital interface for more than 4 ms.

### 6.2.17 Interrupt

The BOS1921/BOS1931 features interrupt capabilities for different events enabled with the [INT\\_ENABLE](#) register. The status of interrupts is read with the [INT\\_STATUS](#) register.

The GPIO pin can be used to notify the MCU when one of the interrupts has occurred by setting [GPIOSEL\[2:0\]](#) bits set to 0x5.

There are up to 7 distinct interrupt events that can be configured. Each event can be enabled by programming the corresponding bit in the [INT\\_ENABLE](#) register. A bit in the [INT\\_STATUS](#) register is set when the condition corresponding to its event changes from *false* to *true* (i.e. rising edge condition).

All the [INT\\_STATUS](#) register bits are automatically cleared in the following situations:

- [INT\\_STATUS](#) register is read
- A soft reset is performed
- Device goes to SLEEP

The [INT\\_STATUS](#) register bits are not cleared when setting its corresponding [INT\\_ENABLE](#) register bits to 0x0.

Note that if the interrupt condition is already *true* when the interrupt is enabled, the interrupt can be immediately triggered and its corresponding [INT\\_STATUS](#) register bits will be set to 0x1. It is thus recommended to clear any existing interrupt by reading [INT\\_STATUS](#) register after enabling interrupts.

Note that the desired [PLAY MODE](#) bits should be set prior to configure interrupts.

The [INT\\_ENABLE](#) register can be used to enable interrupts on the following events:

- [IE\\_FHE](#) bit enables an interrupt when FIFO is at least half empty. Interrupt triggers when FIFO is more than half empty.
- [IE\\_STCHG](#) bit enables an interrupt when the BOS1921/BOS1931 state change. Interrupt triggers when [STATE\[1:0\]](#) bits changed.
- [IE\\_MXERR](#) bit enables an interrupt when there is a difference between the waveform played on the output and the setpoint.
- [IE\\_SENSF](#) bit enables an interrupt when a sensing event occurred (BOS1921 only), i.e., it triggers when [SENS\\_FLAG](#) bit is set to 0x1.
- [IE\\_PLAY](#) bit enables an interrupt when the waveform playback status is set, i.e., it triggers when [PLAYST](#) bit is set to 0x1.
- [IE\\_MAXP](#) enables an interrupt when a maximum power error occurred, i.e., it triggers when [MXPWR](#) bit is set to 0x1.
- [IE\\_ERR](#) enables an interrupt when the BOS1921/BOS1931 state changes for ERROR, i.e., it triggers when [STATE\[1:0\]](#) bits are set to 0x3.

The following sequence presents an example on how to use the interrupt feature along with FIFO mode:

1. Set [CONFIG.PLAY\\_MODE\[1:0\]](#) bits to 0x1 to select FIFO mode.
2. Set bit [CONFIG.OE](#) to 0x1 to enable the output.
3. Set [INT\\_ENABLE.IE\\_FHE](#) bit to 0x1 to enable the interrupt when the FIFO is half empty.
4. Set [COMM.RDADDR\[4:0\]](#) bits to 0x1F and read the [INT\\_STATUS](#) register to clear existing interrupt.
5. Set [GPIOSEL\[2:0\]](#) bits to 0x5 to output the interrupt on the GPIO pin.
6. Set [COMM.RDADDR\[4:0\]](#) bits to 0x11, read [FIFO\\_STATE](#) register and use [FIFO\\_STATE.FIFO\\_SPACE\[9:0\]](#) bits to determine space available in FIFO for new data.
7. Write as many 12-bit waveform data as possible according to space available in FIFO into the [REFERENCE](#) register.
8. Wait for a falling edge on the GPIO pin to occur, which indicates an interrupt occurred.
9. Set [COMM.RDADDR\[4:0\]](#) bits to 0x1F and read the [INT\\_STATUS](#) register. The [INT\\_STATUS.IS\\_FHE](#) bit should be 0x1 and will be immediately cleared after reading register.
10. Repeat steps 5 to 8 until the desired waveform is completed.

### 6.2.18 Output Bridge Protection

The BOS1921/BOS1931 includes a protection preventing the internal output bridge from changing polarity if a voltage greater than 4.4 V is present between the OUT+ and OUT- pins when playing a waveform. This protection is essential especially for BOS1921 when using sensing feature since the voltage on the piezoelectric ceramic terminal increases or decreases as it is deformed. Residual voltage can thus be present on the output of the BOS1921 when a waveform is requested to be played.

The bridge protection triggers in the following conditions:

- Play a positive haptic waveform when a negative voltage smaller than -4.4 V has built up on the piezoelectric ceramic.
- Play a negative haptic waveform when a positive voltage greater than 4.4 V has built up on the piezoelectric ceramic.

The bridge protection triggering causes a waveform played in the wrong polarity with or without IDAC error (see section 6.2.15.5). The bridge protection triggering can be caused by incorrect component sizing (see section 7.5) or inadequate waveform data.

To prevent the bridge protection to trigger, one could reset the voltage on the piezoelectric ceramic before starting to play the haptic waveform. This can be achieved by playing one of the following sets of data before the desired haptic waveform:

- Several 0 V data points.
- Voltage data points increasing from -2 V to 0 V if a positive waveform is intended to be played.
- Voltage data points decreasing from 2 V to 0 V if a negative waveform is intended to be played.

## 6.3 Digital Interface

A MIPI I3C target port enables communication with the BOS1921/BOS1931. I3C is backward compatible with legacy I<sup>2</sup>C devices, but I3C bus supports significantly higher speed. It is used to write data to the registers, whose content can also be read back.

### 6.3.1 General Communication Protocol

The controller MCU can transfer data with the target BOS1921/BOS1931 using I3C or I<sup>2</sup>C standards.

#### 6.3.1.1 Write Transactions

Both I<sup>2</sup>C and I3C can do write transactions with the following:

- The first byte contains the register address corresponding to the register to write to.
- Two bytes of register data; the first byte corresponds to the MSBs of the register data and the second byte corresponds to the LSBs of register data.

To write more than one register, three behaviours are possible:

1. Register address = 0x00: All subsequent 2-byte words will automatically be written to the [REFERENCE](#) register. The communication frame must be stopped from accessing the other registers.
2. [STR](#) bit set to 0x1: The register address other than 0x00 will automatically be incremented every two bytes to allow writing multiple registers in the same transmission frame and reduce the number of bits used in the communication. The communication frame must be stopped to skip the remaining register addresses.
3. [STR](#) bit set to 0x0: A byte of address for each target register must be sent (no automatic address incrementation).

#### 6.3.1.2 Read transactions

Each communication transaction returns two bytes of data corresponding to the value of the register whose address is specified in [RDADDR\[4:0\]](#). Burst reads are not supported, i.e., it is not possible to read multiple registers in a single access. However, the [RDADDR\[4:0\]](#) bits can automatically be incremented by 1 after each read by setting [RDAI](#) bit to 0x1. This allows setting [RDADDR\[4:0\]](#) bits once with the address of the first register to be read, then issuing a sequence of reading accesses to read a series of registers.

### 6.3.2 I3C Interface

The I3C target functionality implemented in the BOS1921/BOS1931 is based on MIPI® Alliance Specification for I3C<sup>SM</sup>, version 1.1.1. I3C is a 2-wire bidirectional serial bus which always has one controller and one or more targets. The two wires are designated SDA and SCL: SDA is a bidirectional data signal, SCL is a clock signal. They connect respectively to BOS1921/BOS1931 SDA and SCL pins.

Table 11: Serial interface pin description

| PIN NAME | PIN DESCRIPTION           |
|----------|---------------------------|
| SDA      | Bidirectional Data Signal |
| SCL      | Controller Clock Signal   |

I3C communication is initiated by the controller which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions. All I3C communication occurs within a frame. The basic frame begins with a START, followed by the header, the data, and a STOP (see Figure 17 for more details). The header following a START allows for bus arbitration. The controller uses the header to address target device(s). Each target is addressed by a unique 7-bit target address plus a read-write bit.



Figure 17: Typical I3C write communication frame

The I3C bus uses transitions on SDA while the clock is at logic high to indicate START and STOP conditions. A high-to-low transition on the SDA signal indicates a START, and a low-to-high transition indicates a STOP. All devices share the same SDA signals through a bidirectional bus using a wired-AND connection. The data transition on SDA must occur while the clock period is low.

The implemented I3C target of the BOS1921/BOS1931 has a legacy I<sup>2</sup>C default static address (7'h44). The 4 LSBs of the address can be changed by assigning the I2C\_ADDR bits. The BOS1921/BOS1931 will act as an I<sup>2</sup>C target using that address up until it is assigned a dynamic address. Once assigned a dynamic address, the BOS1921/BOS1931 will only operate as an I3C target until it is reset.

A 50 ns spike filter is included in the BOS1921/BOS1931. By default, the spike filter is active at power up. To operate in I3C, the user first needs to write to the broadcast address 0x7E at I<sup>2</sup>C speed. The filter will automatically be deactivated, and the user can then use I3C communication speed.

### 6.3.2.1 I<sup>2</sup>C Communication

The BOS1921/BOS1931 acts by default as an I<sup>2</sup>C target using its static address (7'h44). Figure 18 shows a basic data-transfer sequence with I<sup>2</sup>C static addressing. Following a START, the controller generates the 7-bit target address and the read-write (R/W) bit to communicate with a target device. The target device then holds the SDA signal low during the next clock period to indicate acknowledgment to the controller. When this acknowledgment occurs, the controller transmits the next byte(s) of the sequence.

There are two addresses used to access a register. The first is the target address used to select the BOS1921/BOS1931. The second address is an 8-bit register address sent in the first byte transferred in a write operation. The register address points to a specific register (section 6.10). Automatic increments of address pointer can be set using STR bit. The address pointer is automatically incremented every two bytes, allowing continuous write operations.



Figure 18: Basic data transfer write sequence with  $I^2C$  static addressing

Figure 19 presents a typical communication sequence in  $I^2C$ . MSB is always sent first.

A typical write sequence from power up is the following:

1. Write with static address 0x44 with dummy data to wake-up the device.
2. Configure registers as needed.

Figure 20 presents a single communication transaction to access several main registers using STR bit set to 0x1 to access several main registers.

A 50 ns spike filter is included and activated at power up.



Figure 19: Typical data-transfer sequences with  $I^2C$  static addressing

Figure 20: Typical data-transfer sequences with I<sup>2</sup>C static addressing with [STR](#) bit set to 0x1

### 6.3.2.2 I3C Communication

BOS1921/BOS1931 I3C interface is compliant with MIPI® Alliance Specification for I3C<sup>SM</sup>, version 1.1.1 and features the following:

1. Target only
2. SDR (Single Data RATE) up to 12.5 MHz
3. I<sup>2</sup>C compatibility with static address: 7'h44
4. Supports basic Common Command Codes (CCC) (see Table 12 for more details)
5. Does not support Hot Join (HJM)
6. Does not support In-Band Interrupt (IBI)
7. Provisional ID = 0x08A207814000 (see Table 13 or more details)
8. Bus Characteristic Register = 0x00
9. Device Characteristic Register = 0x25

Table 12: Common Command Codes (CCC) support

| COMMAND NAME | TYPE      | CODE | DESCRIPTION                      |
|--------------|-----------|------|----------------------------------|
| ENECA        | Broadcast | 0x00 | Enable events command            |
| DISECA       | Broadcast | 0x01 | Disable events command           |
| ENTAS0       | Broadcast | 0x02 | Enter activity state 0           |
| ENTAS1       | Broadcast | 0x03 | Enter activity state 1           |
| ENTAS2       | Broadcast | 0x04 | Enter activity state 2           |
| ENTAS3       | Broadcast | 0x05 | Enter activity state 3           |
| RSTDAA       | Broadcast | 0x06 | Reset dynamic address assignment |
| ENTDAA       | Broadcast | 0x07 | Enter dynamic address assignment |
| ENECA        | Direct    | 0x80 | Enable events command            |
| DISECA       | Direct    | 0x81 | Disable events command           |
| ENTAS0       | Direct    | 0x82 | Enter activity state 0           |
| ENTAS1       | Direct    | 0x83 | Enter activity state 1           |

| COMMAND NAME | TYPE   | CODE | DESCRIPTION                         |
|--------------|--------|------|-------------------------------------|
| ENTAS2       | Direct | 0x84 | Enter activity state 2              |
| ENTAS3       | Direct | 0x85 | Enter activity state 3              |
| RSTDAA       | Direct | 0x86 | Reset dynamic address assignment    |
| SETNEWDA     | Direct | 0x88 | Set new dynamic address             |
| GETPID       | Direct | 0x8D | Get provisional ID                  |
| GETBCR       | Direct | 0x8E | Get bus characteristics register    |
| GETDCR       | Direct | 0x8F | Get device characteristics register |
| GETSTATUS    | Direct | 0x90 | Get device status                   |
| GETCAPS      | Direct | 0x95 | Get HDR Capability                  |

Table 13: Defaults provisional ID details

| FIELD                    | WIDTH | VALUE               |
|--------------------------|-------|---------------------|
| Provisional ID (default) | 48    | 0x08A207814000      |
| Manufacturer ID          | 15    | 0x0451              |
| Part ID                  | 16    | 0x0781              |
| Instance ID              | 4     | 0x4 (I2C_ADDR[3:0]) |
| Vendor Defined           | 12    | 0x000               |

The BOS1921/BOS1931 will operate as an I3C target only after it is assigned a dynamic address by the controller using command ENTDA with I<sup>2</sup>C timing constraints. A dummy write to address 0x7E can be performed prior to ENTDA command to clear the 50 ns spike filter and enable communication at I3C speed without I<sup>2</sup>C constraints. A typical write sequence from devices power up is the following:

1. Send start condition with broadcast address 0x7E at I<sup>2</sup>C speed to clear I<sup>2</sup>C spike filter.
2. Send ENTDA command.
3. Wake-up the chip with a dummy write.
4. Configure registers as needed.

### 6.3.3 Resolving I<sup>2</sup>C/I3C Address Conflicts

It is possible to connect multiple BOS1921/BOS1931 on the same I<sup>2</sup>C or I3C bus. By default, they all have the same address, so they all respond simultaneously to the same commands. However, it is possible to assign different addresses to each IC to allow accessing each one individually. The process requires to first configure the GPIO as a "Chip Select" before setting the I2C\_ADDR[3:0] bits. The procedure is the same for I<sup>2</sup>C or I3C protocols, but I3C mode requires the additional steps of resetting and reassigning the dynamic address after having set I2C\_ADDR[3:0] bits (see section 6.3.2.2).

The steps to reassign the I<sup>2</sup>C target address are the following:

1. Set the [COMM.GPIODIR](#) bit to 0x1 bit to use the GPIO as an input.
2. Apply a logic level low on the target device GPIO pin.
3. Set the [SUP\\_RISE.I2C\\_ADDR\[3:0\]](#) bits with the desired target device address. The new address will take effect immediately.
4. Wait at least 1  $\mu$ s after the completion of the I<sup>2</sup>C access performed during the previous step, after which the GPIO pin no longer needs to be used to access to the target device.
5. Using the new I<sup>2</sup>C address, perform a register access to make sure that the address change was successful.

Note that in I3C Mode the [SUP\\_RISE.I2C\\_ADDR\[3:0\]](#) bits are used to set the 4-bit Instance ID (i.e., bits [15:12] of the Provisional ID, see Table 13).

## 6.4 Piezo Actuator Sensing (BOS1921 Only)

The BOS1921 can sense the voltage across a piezo actuator and use it as a force sensor. The sensed voltage can be read to implement a custom detection algorithm.

The device can also be configured to generate an event when a sensing voltage threshold has been crossed. The sensed voltage event can result in the following:

1. Sense Voltage Alert: alert a MCU of the sensed voltage event.
2. Sense Voltage Trigger for Automatic Haptic Playback: The communication frame must be stopped to access other registers.

The following notes apply to the piezo actuator sensing feature:

- The [CONFIG.SENSE](#) bit activates the sensing of the actuator voltage without forcing a voltage on OUT+ and OUT- pins. This bit allows the piezo actuator voltage to vary freely as the user physically interacts with it.
- The [CONFIG.OE](#) bit enables the measurement of the HV pin voltage by the device, which is required for sensing feature to work.
- No haptic waveform should be playing while setting [CONFIG.SENSE](#) bit to 0x1. Wait until the [IC\\_STATUS.PLAYST](#) bit is 0x1 before setting [CONFIG.SENSE](#) bit to 0x1.
- When sensing is activated, no haptic waveform can be output.
- One can activate piezo actuator sensing feature after playing a haptic waveform by simply setting the [CONFIG.SENSE](#) bit to 0x1 (no need to reset the [CONFIG.OE](#) bit to 0x0 and set it back to 0x1).
- To stop the sensing feature, it is recommended to reset the device using [RST](#) bit to reset registers and RAM.

### 6.4.1 Sensed Voltage Reading

The sensed voltage can be read at any time to implement more complex sensing algorithms running in a MCU such as slope detection or voltage profile pattern recognition.

When sensing is activated, sensed voltage is continually updated and pushed to the [SENSE\\_VALUE](#) register so the latest value can be read at any time. There is no required reading rate.

Note that [SENSE\\_VALUE\[11:0\]](#) bits set to 0x0 means that the differential voltage is 0 V. However, when the circuit is in sensing and no signal is generated by a piezo actuator, a negative differential voltage of approximately -350 mV is read.

The following bits of the [SENSE VALUE](#) register are used to read sensed voltage:

- [SENSE VALUE\[11:0\]](#) bits are the 12-bit signed representation of the sensed voltage.
- [SENSE](#) bit indicates if sensing mode is activated.

### 6.4.1.1 Polling Sequence Example

A typical communication sequence to poll the sensed voltage is as follows:

1. Set [CONFIG.ONCOMP](#) to 0x0 to prevent sensed voltage from triggering a sensing event.
2. Set [CONFIG.SENSE](#) to 0x1 to enable piezo actuator sensing.
3. Set [CONFIG.OE](#) to 0x1 to start sensing.
4. Read [SENSE VALUE\[11:0\]](#) bits.
5. Repeat the step 4) as needed.

### 6.4.2 Sense Voltage Alert

An internal sensing comparator allows to detect when the sensed voltage on the piezo actuator crosses a configurable threshold voltage. When the detection conditions are met, the [SENSE FLAG](#) bit is set to 0x1. The [SENSE\\_FLAG](#) bit can be reset by reset [ONCOMP](#) bit to 0x0.

The sensing voltage alert settings are the following:

- [CONFIG.ONCOMP](#) bit enables the embedded comparator which triggers the alert. It must be set to 0x1 to enable comparison.
- [SENSING.SIGN](#) defines whether the voltage feedback value must be above or below the threshold for the detection to succeed.
- [SENSING.REP\[2:0\]](#) bits define how long the voltage must be above or below the threshold for detection to succeed (hold time).
- [SENSING.STHRESH\[11:0\]](#) bits define a differential voltage threshold to be crossed for the detection to succeed.
- [SENSE VALUE.SENSE FLAG](#) bit indicates when a detection has occurred.
- [COMM.GPIOSEL\[2:0\]](#) bits set to 0x6 configure the GPIO pin to indicate when a sense voltage alert has occurred (note that the interrupt mechanism can also be used by setting [GPIOSEL\[2:0\]](#) to 0x5).

### 6.4.3 Sense Voltage Trigger for Automatic Haptic Playback

The BOS1921 can detect force on the piezo actuator and automatically play a pre-programmed waveform using FIFO (section 6.6), RAM Playback (section 6.7) or RAM Synthesis (section 6.8) modes with minimal intervention needed by the MCU.

GPIO pin can notify the MCU that the waveform playback is completed.

The following is used to enable and monitor Automatic Haptic Playback:

- A waveform must be armed (see section 6.8.7 for an example). The waveform must be armed again each time an automatic waveform playback occurs.
- [CONFIG.SENSE](#) bit enables piezo actuator sensing. The bit self-clears and must be enabled again each time an automatic waveform playback occurs.
- [CONFIG.ONCOMP](#) bit enables the embedded comparator which triggers the automatic waveform playback. [ONCOMP](#) bit must be disabled and then enabled again each time an automatic waveform playback occurs.
- [CONFIG.AUTO](#) bit enable Automatic Haptic Playback. The bit self-clears and must be enabled again each time an automatic waveform playback occurs.
- [SENSE VALUE.SENSE FLAG](#) bit indicates when a detection has occurred.
- [IC STATUS.PLAYST](#) bit indicates when waveform playback has finished.
- [COMM.GPIOSEL\[2:0\]](#) bits set to 0x6 configure the GPIO pin to notify that a sense voltage event has occurred. Note that the interrupt mechanism can also be used by setting [GPIOSEL\[2:0\]](#) to 0x5.

### 6.4.3.1 Sequence Example for Button Press Sensing with Automatic Playback

A typical communication sequence to configure a press button Automatic Haptic Playback is as follows:

1. Program waveform using RAM Playback (section 6.5) or RAM Synthesis (section 6.8) mode.
2. Set [COMM.GPIOSEL\[2:0\]](#) to 0x6 to be notified on the GPIO pin that a sense voltage event has occurred .
3. Set [SENSING.REP\[2:0\]](#) to 0x5 to set 2048  $\mu$ s hold time.
4. Set [SENSING.THRESH\[11:0\]](#) to 0x7 to set 750 mV threshold.
5. Set [SENSING.SIGN](#) bit to 0x0 to trigger on a voltage above the threshold (detect an increasing voltage).
6. Set [CONFIG.AUTO](#) bit to 0x1 to play a pre-programmed RAM Playback or RAM Synthesis waveform automatically on a successful detection.
7. Set [CONFIG.ONCOMP](#) bit to 0x1 to enable the embedded sensing comparator.
8. Set [CONFIG.SENSE](#) bit to 0x1 to enable piezo actuator sensing.
9. Set [CONFIG.OE](#) bit to 0x1 to start sensing.

Note that all bits in [CONFIG](#) register may be set in the same I<sup>2</sup>C/I3C instruction.

### 6.4.3.2 Sequence Example for Button Release Sensing with Automatic Playback

Once a detection occurred, sensing can be set again for a release button Automatic Playback using a communication sequence as follows:

1. Set [CONFIG.ONCOMP](#) bit to 0x0 to reset the sensing comparator.
2. Arm the next waveform depending on playback mode used as follows:
  - a. RAM Playback: issue an [RAM PLAYBACK](#) WFS command.
  - b. RAM Synthesis: issue an [RAM Synthesis](#) WFS command
3. Set [SENSING.REP\[2:0\]](#) to 0x5 to set 2048 µs hold time.
4. Set [SENSING.THRESH\[11:0\]](#) bits to 0xFFE to set -200mV threshold.
5. Set [CONFIG.SIGN](#) to 0x1 to trigger a haptic playback on voltage below the threshold (detect a decreasing voltage).
6. Set [CONFIG.ONCOMP](#) to 0x1 to enable the sensing comparator.
7. Set [CONFIG.SENSE](#) bit to 0x1 to enable piezo actuator sensing.
8. Set [CONFIG.AUTO](#) bit to 0x1 to play a pre-programmed RAM Playback or RAM Synthesis waveform automatically on a successful detection.
9. Set [CONFIG.OE](#) to 0x1 to start sensing.

Note that all bits in [CONFIG](#) register may be set in the same I<sup>2</sup>C/I3C instruction.

## 6.5 Direct Mode

In Direct mode ([PLAY\\_MODE\[1:0\]](#) bits set to 0x0), the haptic waveform samples are played as they are sent from the host MCU to the [REFERENCE](#) register. The rate at which the data is read to generate the haptic waveform is set by [PLAY\\_SRATE\[2:0\]](#) bits. An interpolation is done between user samples to generate the output waveform when [PLAY\\_SRATE\[2:0\]](#) bits are 0x1 to 0x7.

Data management and synchronization can be facilitated by setting [GPIOSEL\[2:0\]](#) bit to 0x5 and [IE\\_PLAY](#) to 0x1 to allow the corresponding GPIO to generate an interruption that notifies the MCU when the BOS1921/BOS1931 is ready to receive the next sample. Interpolation between user samples is done to generate the output waveform.

In Direct mode, the RAM is not used, and its content previously written using RAM Playback mode (section 6.7) or RAM Synthesis mode (section 6.8) is preserved.

Note that waveforms should begin and end with 0 V amplitude.

### 6.5.1 Typical Operation Sequence

The following sequence shows how to use Direct mode to play haptic waveforms:

1. Set [COMM.GPIOSEL\[2:0\]](#) bits to 0x1 to monitor when one more sample is ready to be sent.
2. Set [CONFIG.PLAY\\_MODE\[1:0\]](#) bits to 0x0 to select Direct mode.
3. Set [CONFIG.OE](#) bit to 0x1 to enable output.
4. Write a waveform sample to the [REFERENCE\[11:0\]](#) bits.
5. On a GPIO pin falling edge, go to step 4. to send the next waveform sample to the device.
6. Set [CONFIG.OE](#) bit to 0x0 once the desired waveform is completed.

## 6.6 FIFO Mode

In FIFO mode, the device uses RAM to implement a 1024-sample FIFO. The FIFO entries are appended every time waveform data is written in the [REFERENCE](#) register. When output is enabled, the FIFO entries are read automatically out of the FIFO at a rate set by [PLAY\\_SRATE\[2:0\]](#) bits to output a haptic waveform. An interpolation is done between user samples to generate the output waveform when [PLAY\\_SRATE\[2:0\]](#) bits are 0x1 to 0x7.

Note the following:

- For waveform playback streaming, the FIFO data write rate must match the readout rate of the waveform playback set by [PLAY\\_SRATE\[2:0\]](#) bits to always keep valid data inside the FIFO. The [PLAYST](#) bit is set to 0x1 when the FIFO becomes empty, causing the FIFO to hold the last valid data and keep the output waveform in a steady state.
- Burst data transfers can be used to minimize the communication interface usage. Packets of 16-bit words can be sent in the same data payload to be written in the FIFO. The [FULL](#) bit is set when the FIFO becomes full and cannot accept more data. The [FIFO\\_SPACE\[9:0\]](#) bits can be read to check available space before sending new data.
- In case [OE](#) bit is set to 0x0 during waveform playback, the waveform will continue to play until the FIFO is empty.
- When the FIFO is empty, the last FIFO entry will remain on the device output.
- It is recommended to start and end waveforms with 0 V.
- It is recommended to terminate waveforms with 0 V before setting the [OE](#) bit to 0x0, otherwise the output voltage will slowly decrease to 0 V.

### 6.6.1 FIFO Depth

FIFO mode uses the RAM to implement the FIFO. Using FIFO mode with the default FIFO depth of 1024 locations could overwrite any waveform previously programmed using RAM Playback and RAM Synthesis modes.

FIFO mode can be used jointly with either RAM Synthesis or RAM Playback mode by configuring the FIFO dimension with a smaller number of RAM locations using the [FIFO\\_DEPTH](#) command.

### 6.6.2 Typical Operation Sequence

The following sequence shows how to use FIFO mode to play haptic waveforms:

1. Set [CONFIG.PLAY\\_MODE\[1:0\]](#) bits to 0x1 to select FIFO mode.
2. Set [CONFIG.OE](#) bit to 0x1 to enable the output.
3. Set [COMM.RDADDR\[4:0\]](#) bits to 0x11 and read [FIFO\\_STATE](#) register.
  - a. If [FIFO\\_STATE.FULL](#) bit is 0x1 skip to step 5.
  - b. If [FIFO\\_STATE.FULL](#) bit is 0x0, use [FIFO\\_STATE.FIFO\\_SPACE\[9:0\]](#) bits to determine space available in FIFO for new data.
4. Write as many 12-bit waveform data as possible according to space available in FIFO into the [REFERENCE](#) register.
5. Repeat steps 3 and 4 until the desired waveform is completed.
6. Set [CONFIG.OE](#) bit to 0x0 once the desired waveform is completed.

In the above example, the output is enabled prior to start filling the FIFO with data. It is also possible to fill the waveform in the FIFO before enabling the output, and then add samples to the FIFO as needed.

## 6.7 RAM Playback Mode

In RAM Playback mode ([PLAY MODE\[1:0\]](#) bits set to 0x2), a point-by-point waveform need to be stored in chronological order in the RAM using [BURST RAM WRITE](#) command. The waveform is played when the output is enabled ([OE](#) bit is set to 0x1).

Note that waveforms should begin and end with 0 V amplitude.

### 6.7.1 RAM Programming

The samples are written to the RAM using [BURST RAM WRITE](#) command. More than one waveform can be stored in the RAM. The 2 kB RAM can store up to 1024 words of 16 bits. Each word is defined by 12-bit data in the same format as the [REFERENCE\[11:0\]](#) bits. Start and end addresses are defined using the [RAM PLAYBACK](#) command and indicate the samples to be fetched when the playback is initiated.

When playback starts, the data is read out sequentially at the sample rate set by [PLAY SRATE\[2:0\]](#) bits. An interpolation is done between user samples to generate the output waveform when [PLAY SRATE\[2:0\]](#) bits are 0x1 to 0x7.

Once the waveform has been played, it must be rearmed to be played again by writing the RAM start and end addresses again using the [RAM PLAYBACK](#) command. The waveform will immediately start if these addresses are set while [OE](#) bit is already set to 0x1.

No waveform should be playing while programming RAM to avoid unexpected behaviour.

### 6.7.2 Continuous Waveform Playback

A waveform can be played continuously by using the [RAM PLAYBACK](#) command with the following field:

1. Set the [RPT](#) field to 0x1.
2. Set the [REPEAT START ADDRESS\[9:0\]](#) to the RAM address at which the desired continuous waveform starts.
3. Set the [END ADDRESS\[9:0\]](#) to the RAM address at which the desired continuous waveform goes back to the [REPEAT START ADDRESS\[9:0\]](#).
4. Set the [START ADDRESS\[9:0\]](#) to the RAM address at which the waveform starts. The [START ADDRESS\[9:0\]](#) may be different or identical to the [REPEAT START ADDRESS\[9:0\]](#).

The [RAM PLAYBACK](#) command allows playing an initial waveform segment only once before looping over an adjacent segment continuously. This is done by specifying a [REPEAT START ADDRESS\[9:0\]](#) located between the [START ADDRESS\[9:0\]](#) and the [END ADDRESS\[9:0\]](#). The segment between [START ADDRESS\[9:0\]](#) and [REPEAT START ADDRESS\[9:0\]](#) will be played once, then the segment between [REPEAT START ADDRESS\[9:0\]](#) and [END ADDRESS\[9:0\]](#) will be repeated continuously. By specifying the [START ADDRESS\[9:0\]](#) the same as the [REPEAT START ADDRESS\[9:0\]](#), the entire segment is repeated.

To end a waveform being played continuously, a new [RAM PLAYBACK](#) command must be issued with [RPT](#) field set to 0x0 and the [END ADDRESS\[9:0\]](#) equals to or greater than the [END ADDRESS\[9:0\]](#) of the previous command (the [START ADDRESS\[9:0\]](#) and [REPEAT START ADDRESS\[9:0\]](#) fields will be ignored). Specifying an [END ADDRESS\[9:0\]](#) greater than the previously entered [END ADDRESS\[9:0\]](#) allows a final waveform segment to be played only once. Specifying an [END ADDRESS\[9:0\]](#) smaller than the previous [END ADDRESS\[9:0\]](#) is not advised as it can result in unpredictable behaviour.

It is also possible to send consecutive [RAM PLAYBACK](#) commands with [RPT](#) field set to 0x1. When a segment is being played continuously and a new [RAM PLAYBACK](#) command is received with [RPT](#) field set to 0x1, the following applies:

- The [END ADDRESS\[9:0\]](#) of the new command must be equal to or greater than the previously entered [END ADDRESS\[9:0\]](#).
- The REPEATED START ADDRESS of the new command must be smaller than or equal to the new [END ADDRESS\[9:0\]](#).
- The [START ADDRESS\[9:0\]](#) field is ignored.
- If REPEATED START ADDRESS is greater than the previous [END ADDRESS\[9:0\]](#), the segment between the previous [END ADDRESS\[9:0\]](#) and the new REPEATED START ADDRESS, referred as the *middle segment*, will be played only once.
- It is not possible to play non-contiguous segments when [RPT](#) field is set to 0x1, i.e., the *middle segment*, between the two non-contiguous segments will always be played.

### 6.7.3 Typical Operation Sequences

The following sections show different methods of launching a haptic waveform using RAM Playback mode.

Note that any previous waveform must have finished playing before programming RAM.

#### 6.7.3.1 Triggered Start Sequence

The triggered start sequence is used to start playing a haptic waveform after programming the [CONFIG.OE](#) bit to 0x1.

The sequence is the following:

1. If not already done, set [CONFIG.OE](#) bit to 0x0.
2. Set [CONFIG.PLAY MODE\[1:0\]](#) bits to 0x2 to select RAM playback mode.
3. Write waveform data to RAM using [BURST RAM WRITE](#) command. See section 6.7.5 for a detailed example.
4. Write the RAM start and end addresses using [RAM PLAYBACK](#) WFS command.
5. Set [CONFIG.OE](#) bit to 0x1 when ready for haptic waveform playback.
6. The haptic waveform starts playing.
7. [CONFIG.OE](#) bit self-clears once the waveform is completed.

#### 6.7.3.2 Immediate Start Sequence

The immediate start sequence is used to start a haptic waveform playback after issuing the RAM PLAYBACK WFS command. The sequence requires the [CONFIG.OE](#) bit to be set to 0x1 before issuing the RAM PLAYBACK WFS command.

The sequence is the following:

1. If not already done, set [CONFIG.OE](#) bit to 0x0.
2. Set [CONFIG.PLAY MODE\[1:0\]](#) bits to 0x2 to select RAM playback mode.
3. Set [CONFIG.OE](#) bit to 0x1 to enable output.
4. Write waveform data to RAM using [BURST RAM WRITE](#) command. See section 6.7.5 for a detailed example.
5. Write the RAM start and end addresses using [RAM PLAYBACK](#) command.
6. The haptic waveform starts playing.
7. [CONFIG.OE](#) bit is set to 0x0 once the waveform is completed.

### 6.7.3.3 Sensing Detection Sequence (BOS1921 Only)

The sequence is used to start haptic waveform playback when previously establish sensing detection conditions are met. The sequence requires the [CONFIG.AUTO](#), [CONFIG.ONCOMP](#) and [CONFIG.SENSE](#) bits to be set to 0x1.

The sequence is the following:

1. If not already done, set [CONFIG.OE](#) bit to 0x0.
2. Set [CONFIG.PLAY MODE\[1:0\]](#) bits to 0x2 to select RAM playback mode.
3. Write waveform data to RAM using [BURST RAM WRITE](#) command. See section 6.7.5 for a detailed example.
4. Write the RAM start and end addresses using [RAM PLAYBACK](#) command.
5. Configure sensing detection condition as per section 6.4.3.
6. Set [CONFIG.OE](#) bit 0x1 to enable output.
7. The haptic waveform starts playing once sense detection conditions are met.

### 6.7.4 Waveform Example

Table 14 RAM PLAYBACK waveform examples

| # | RAM PLAYBACK COMMAND CONTENT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | WAVEFORM PLAYBACK                                                                    |
|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| 1 | <p><b>Reference waveform for further examples.</b></p> <p><u>RAM PLAYBACK</u> command 1:</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x0</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000</li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>END ADDRESS[9:0]</u> = 0x3F0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| 2 | <p><u>RAM PLAYBACK</u> command 1 (start):</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x1</li> <li>- <u>START ADDRESS[9:0]</u> = 0x080</li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x080</li> <li>- <u>END ADDRESS[9:0]</u> = 0x300</li> </ul> <p><u>RAM PLAYBACK</u> command 2 (stop):</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x0</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>END ADDRESS[9:0]</u> = 0x300</li> </ul>                                                                                                                                                                                                                                                                    |    |
| 3 | <p><u>RAM PLAYBACK</u> command 1 (start):</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x1</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000</li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x080</li> <li>- <u>END ADDRESS[9:0]</u> = 0x300</li> </ul> <p><u>RAM PLAYBACK</u> command 2 (stop):</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x0</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>END ADDRESS[9:0]</u> = 0x370</li> </ul>                                                                                                                                                                                                                                                                    |  |
| 4 | <p><u>RAM PLAYBACK</u> command 1 (start):</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x1</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000</li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x080</li> <li>- <u>END ADDRESS[9:0]</u> = 0x300</li> </ul> <p><u>RAM PLAYBACK</u> command 2:</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x1</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x370</li> <li>- <u>END ADDRESS[9:0]</u> = 0x3F0</li> </ul> <p><u>RAM PLAYBACK</u> command 3 (stop):</p> <ul style="list-style-type: none"> <li>- <u>RPT</u> = 0x0</li> <li>- <u>START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>REPEAT START ADDRESS[9:0]</u> = 0x000<sup>1</sup></li> <li>- <u>END ADDRESS[9:0]</u> = 0x3F0</li> </ul> |  |

### 6.7.5 I<sup>2</sup>C Communication Example

In RAM Playback, waveform samples need to be first stored in the RAM to be fetched later. A typical RAM programming sequence is presented in Figure 21 which consist of programming a waveform using 10 samples to be played. The OE bit is set to 0x1 to start playing immediately after the RAM Playback command is issued.

| I <sup>2</sup> C Communication Sequence |                                                                       |
|-----------------------------------------|-----------------------------------------------------------------------|
| Transaction 1                           |                                                                       |
| Code                                    | Description / Configure RAM Playback Mode                             |
| 0x44                                    | I <sup>2</sup> C address                                              |
| 0x05                                    | Select CONFIG register                                                |
| 0x1407                                  | Set RAM Playback Mode                                                 |
| Transaction 2                           |                                                                       |
| Code                                    | Description / Configure Burst RAM Write                               |
| 0x44                                    | I <sup>2</sup> C address                                              |
| 0x00                                    | Select REFERENCE register to use a WFS command                        |
| 0x0014                                  | WFS command : BURST RAM WRITE                                         |
| 0x0000                                  | Set RAM start address                                                 |
| 0x000A                                  | Set Data count (10 samples to be written starting at address 0x0000). |
| 0x0000                                  | Sample data                                                           |
| 0x00AE                                  | Sample data                                                           |
| 0x015C                                  | Sample data                                                           |
| 0x020A                                  | Sample data                                                           |
| 0x02B8                                  | Sample data                                                           |
| 0x02B8                                  | Sample data                                                           |
| 0x020A                                  | Sample data                                                           |
| 0x015C                                  | Sample data                                                           |
| 0x00AE                                  | Sample data                                                           |
| 0x0000                                  | Sample data                                                           |
| Transaction 3                           |                                                                       |
| Code                                    | Description / Set RAM Playback Start and End Addresses                |
| 0x44                                    | I <sup>2</sup> C address                                              |
| 0x00                                    | Select REFERENCE register to use a WFS command                        |
| 0x0013                                  | WFS command : RAM Playback                                            |
| 0x0009                                  | Set RAM playback end address.                                         |
| 0x0000                                  | Set start address and no repetition                                   |

**RAM Content**

| RAM Address | RSVD | Samples |
|-------------|------|---------|
| 0x0000      | 0x0  | 0x000   |
| 0x0001      | 0x0  | 0x0AE   |
| 0x0002      | 0x0  | 0x15C   |
| 0x0003      | 0x0  | 0x20A   |
| 0x0004      | 0x0  | 0x2B8   |
| 0x0005      | 0x0  | 0x2B8   |
| 0x0006      | 0x0  | 0x20A   |
| 0x0007      | 0x0  | 0x15C   |
| 0x0008      | 0x0  | 0x0AE   |
| 0x0009      | 0x0  | 0x000   |

Figure 21: RAM Playback setup example

<sup>1</sup> The field is ignored.

## 6.8 RAM Synthesis Mode

In RAM Synthesis mode ([PLAY\\_MODE\[1:0\]](#) bits set to 0x3), sine wave parameters stored by the user in RAM are used to generate simple to complex waveforms. Two types of information are stored in RAM:

- 1) SLICEs, written in the RAM using the [RAM ACCESS](#) command. Each SLICE contains a group of parameters used to produce a sine wave of defined amplitude, frequency, and number of cycles. It may also be ramped up and down (as shown in Figure 24). See section 6.8.1 for more details.
- 2) WAVEs, written in the RAM in predefined location using the [RAM ACCESS](#) command. A maximum of 15 WAVE blocks can be written in predefined RAM address. A WAVE defines a series of SLICEs to be played successively. All SLICEs of a WAVE must be written in order and contiguously in the RAM. See section 6.8.2 for more details.

A SEQUENCE is defined using the [RAM SYNTHESIS](#) command and point to 1 to 15 WAVE block RAM addresses to be played sequentially to create an output haptic waveform. See section 6.8.3 for more details.

A haptic waveform can be played by sending the desired START and END WAVE number using the [RAM SYNTHESIS](#) command. Once the waveform has been played, it can be played again by setting the START and END WAVE number again in the [RAM SYNTHESIS](#) command. The waveform will immediately start playing if the [RAM SYNTHESIS](#) command is issued while [OE](#) bit is set to 0x1.

No waveform should be playing while programming RAM using the [RAM ACCESS](#) command to avoid unexpected behaviour.

The WAVE and SLICE data are stored in RAM, as shown in Figure 22. WAVE must be located between RAM address 0x00 and 0x2C. SLICE blocks can be located at any free locations and arranged in any order, but they must not overlap.

Note that waveforms should begin and end with 0 V amplitude.



Figure 22: Representation of WAVE and SLICE blocks organized in RAM

### 6.8.1 SLICE Blocks

SLICE blocks in RAM contains the parameters used to synthesize sine waveforms. Each SLICE block contains three words grouping all parameters needed as described in Table 15. Figure 23 shows an example on how several SLICES can be organized in RAM. Figure 24 illustrates an example of how these parameters shape a SLICE waveform. Many SLICES may be successively played to form more complex waveforms.

Note that [SLICE.MODE\[1:0\]](#) should be unipolar (set to 0x1 or 0x3) if [SLICE.AMPLITUDE\[11:0\]](#) is set to 0.

Table 15: SLICE block description

| 15            | 14   | 13        | 12   | 11              | 10   | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 7 | 6 | 5 | 4            | 3 | 2 | 1 | 0 |  |  |  |  |  |
|---------------|------|-----------|------|-----------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|--------------|---|---|---|---|--|--|--|--|--|
| NOT USED: 0x0 |      |           |      | AMPLITUDE[11:0] |      |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |              |   |   |   |   |  |  |  |  |  |
| CYCLES[7:0]   |      |           |      |                 |      |      | FREQUENCY[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |   |   |              |   |   |   |   |  |  |  |  |  |
| NOT USED: 0x0 |      |           | CONT | MODE[1:0]       | HCYC | P180 | SHAPEUP[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   | SHAPEDN[3:0] |   |   |   |   |  |  |  |  |  |
| WORD          | BITS | NAME      |      |                 |      |      | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |              |   |   |   |   |  |  |  |  |  |
| 1             | 11:0 | AMPLITUDE |      |                 |      |      | <p>Sets the voltage amplitude of the output waveform.</p> <p>For bipolar waveforms (<a href="#">SLICE.MODE[1:0]</a> set to 0x0), the relation between the output peak-to-peak voltage (<math>V_{OUT-pkpk}</math>) and AMPLITUDE[11:0] is defined as follows:</p> $AMPLITUDE[11:0] = \frac{4095 \times V_{OUT-pkpk}}{190}$ <p>For unipolar waveforms (<a href="#">SLICE.MODE[1:0]</a> set to 0x1 or 0x3), the relation between the output peak voltage (<math>V_{OUT-pk}</math>) and AMPLITUDE[11:0] is defined as follows:</p> $AMPLITUDE[11:0] = \frac{4095 \times V_{OUT-pk}}{95}$ <p>This AMPLITUDE[11:0] value calculation is valid only for RAM Synthesis mode (<a href="#">PLAY MODE[1:0]</a> bits set to 0x3).</p> <p>Note that the SLICE must be unipolar positive (<a href="#">SLICE.MODE[1:0]</a> set to 0x1) if AMPLITUDE[11:0] is set to 0.</p> |   |   |   |              |   |   |   |   |  |  |  |  |  |
| 2             | 15:8 | CYCLES    |      |                 |      |      | <p>Sets the number of times a full sine wave period is repeated, excluding <a href="#">SHAPEUP[3:0]</a> &amp; <a href="#">SHAPEDN[3:0]</a> ramp times. The field is ignored if <a href="#">CONT</a> is set to 0x1. The total number of sine wave cycles played, <math>CYCLE_{TOTAL}</math>, (excluding ramp-up and ramp-down) is defined by:</p> $CYCLE_{TOTAL} = CYCLES[7:0] + HCYC \times 0.5$ <p>Note that <math>CYCLE_{TOTAL}</math> must be greater than 0.</p>                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |              |   |   |   |   |  |  |  |  |  |
| 2             | 7:0  | FREQUENCY |      |                 |      |      | <p>Defines the sine wave frequency. The waveform synthesizer has a frequency resolution of 3.9 Hz. FREQUENCY value must be greater than 0.</p> <p>The synthesized sine wave frequency (<math>f_{OUT}</math>) is defined by:</p> $f_{OUT} [HZ] = 3.9 \times FREQUENCY$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |   |              |   |   |   |   |  |  |  |  |  |
| 3             | 12   | CONT      |      |                 |      |      | <p>Enables the SLICE repeat for continuous waveform playback. When enabled, the sine wave period is repeated until either a <a href="#">STOP</a> or <a href="#">NXTSL</a> bit is set to 0x1 is sent using the <a href="#">RAM SYNTHESIS</a> command.</p> <p>0x0: Continuous waveform playback disabled.</p> <p>0x1: Continuous waveform playback enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |              |   |   |   |   |  |  |  |  |  |

| 15            | 14    | 13           | 12   | 11              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 9    | 8    | 7              | 6 | 5 | 4 | 3            | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
|---------------|-------|--------------|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|----------------|---|---|---|--------------|---|---|---|--|--|--|--|--|--|--|--|
| NOT USED: 0x0 |       |              |      | AMPLITUDE[11:0] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| CYCLES[7:0]   |       |              |      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |      | FREQUENCY[7:0] |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| NOT USED: 0x0 |       |              | CONT | MODE[1:0]       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | HCYC | P180 | SHAPEUP[3:0]   |   |   |   | SHAPEDN[3:0] |   |   |   |  |  |  |  |  |  |  |  |
| WORD          | BITS  | NAME         |      |                 | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| 3             | 11:10 | MODE         |      |                 | <p>Sets the waveform type.</p> <p>0x0: Bipolar wave.</p> <p>0x1: Unipolar &amp; positive:<br/>In this mode, the amplitude of the waveform is half a bipolar waveform and shifted up by half the maximum amplitude of a bipolar waveform.</p> <p>0x2: Reserved.</p> <p>0x3: Unipolar &amp; negative:<br/>In this mode, the amplitude of the waveform is half a bipolar waveform and shifted up by half the maximum amplitude of a bipolar waveform.</p>                                                                                                                                                                                                                                                                                                   |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| 3             | 9     | HCYC         |      |                 | <p>Plays an additional half cycle at the end of the SLICE.</p> <p>When <u>CONT</u> is set to 0x1, an extra half cycle will be played at the end of the slice after a SLICE termination request has been made with either a <u>STOP</u> or <u>NXTSL</u> bit set to 0x1 using the <u>RAM SYNTHESIS</u> command.</p> <p>0x0: Do not add half-cycle at the end of the waveform.</p> <p>0x1: Add half-cycle at the end of the waveform.</p>                                                                                                                                                                                                                                                                                                                   |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| 3             | 8     | P180         |      |                 | <p>Adds a 180° phase shift on the waveform.</p> <p>0x0: No phase shift added. SLICE starts at min peak and increments.</p> <p>0x1: A 180° phase shift is added. SLICE starts at max peak and decrements.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| 3             | 7:4   | SHAPEUP[3:0] |      |                 | <p>SHAPEUP[3:0] sets the ramp-up time of the waveform from 0 V to <math>V_{pk}</math>.</p> <p>SHAPEDN[3:0] sets the ramp-down time of the waveform from <math>V_{pk}</math> to 0 V.</p> <p>SHAPEUP and SHAPEDN duration must be greater than the waveform period and are added to the total SLICE waveform duration (<math>t_{SLICE}</math>), which can be calculated as follows:</p> $t_{SLICE}[ms] = SHAPEUP[ms] + \frac{CYCLES[7:0] + HCYC \times 0.5}{f_{OUT}[HZ]} + SHAPEDN[ms]$ <p>0x0: 0 ms<br/>0x1: 32 ms<br/>0x2: 64 ms<br/>0x3: 96 ms<br/>0x4: 128 ms<br/>0x5: 160 ms<br/>0x6: 192 ms<br/>0x7: 224 ms<br/>0x8: 256 ms<br/>0x9: 512 ms<br/>0xA: 768 ms<br/>0xB: 1024 ms<br/>0xC: 1280 ms<br/>0xD: 1536 ms<br/>0xE: 1792 ms<br/>0xF: 2048 ms</p> |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |
| 3             | 3:0   | SHAPEDN[3:0] |      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |      |                |   |   |   |              |   |   |   |  |  |  |  |  |  |  |  |

| RAM Address    | RAM Content       |           |
|----------------|-------------------|-----------|
| 0x02D          | AMPLITUDE         |           |
| 0x02E          | CYCLES            | FREQUENCY |
| 0x02F          | SHAPEUP   SHAPEDN |           |
| 0x030          | AMPLITUDE         |           |
| 0x031          | CYCLES            | FREQUENCY |
| 0x032          | SHAPEUP   SHAPEDN |           |
| .              |                   |           |
| .              |                   |           |
| .              |                   |           |
| .              |                   |           |
| 0x02D+3(M-1)   | AMPLITUDE         |           |
| 0x02D+3(M-1)+1 | CYCLES            | FREQUENCY |
| 0x02D+3(M-1)+2 | SHAPEUP   SHAPEDN |           |

Figure 23: Sine wave SLICE parameters illustration



Figure 24: Sine wave SLICE parameters illustration

### 6.8.2 WAVE Blocks

A maximum of 15 WAVE blocks (numbered 0x0 to 0xE) can be written in RAM in fixed predefined location between RAM address 0x0000 and 0x002A as detailed in Table 17. Figure 25 presents how the WAVE blocks are organized in RAM.

A WAVE block in RAM contains three words and is described Table 16.

1. The [SLICE START ADDRESS\[11:0\]](#).
2. The [SLICE END ADDRESS\[11:0\]](#).
3. The [WAVE COUNT\[15:0\]](#).
4. SLICEs to be played sequentially must be placed in order and contiguously in RAM between the [SLICE START ADDRESS\[11:0\]](#) and the [SLICE END ADDRESS\[11:0\]](#).

Table 16: WAVE block description

| 15            | 14   | 13                  | 12 | 11                                                                                                                                                                                                                                                                                                                                                                                              | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|------|---------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| NOT USED: 0x0 |      |                     |    | SLICE START ADDRESS[11:0]                                                                                                                                                                                                                                                                                                                                                                       |    |   |   |   |   |   |   |   |   |   |   |
| NOT USED: 0x0 |      |                     |    | SLICE END ADDRESS[11:0]                                                                                                                                                                                                                                                                                                                                                                         |    |   |   |   |   |   |   |   |   |   |   |
| COUNT[15:0]   |      |                     |    |                                                                                                                                                                                                                                                                                                                                                                                                 |    |   |   |   |   |   |   |   |   |   |   |
| WORD          | BITS | NAME                |    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                     |    |   |   |   |   |   |   |   |   |   |   |
| 1             | 11:0 | SLICE START ADDRESS |    | Defines RAM address of the first word of the first SLICE to be fetched for waveform playback.                                                                                                                                                                                                                                                                                                   |    |   |   |   |   |   |   |   |   |   |   |
| 2             | 11:0 | SLICE END ADDRESS   |    | Defines RAM address of the third word of the last SLICE to be fetched for waveform playback.                                                                                                                                                                                                                                                                                                    |    |   |   |   |   |   |   |   |   |   |   |
| 3             | 15:0 | COUNT               |    | Sets the number of times the WAVE block is repeated from <a href="#">SLICE START ADDRESS[11:0]</a> to <a href="#">SLICE END ADDRESS[11:0]</a> for waveform playback. If COUNT[15:0] is set to 0x0, the WAVE block will repeat indefinitely for continuous waveform playback until either a <a href="#">STOP</a> or NXTW bit set to 0x1 is sent using the <a href="#">RAM SYNTHESIS</a> command. |    |   |   |   |   |   |   |   |   |   |   |

Table 17: WAVE block number association with WAVE RAM ADDRESS.

| WAVE BLOCK NUMBER | PREDEFINED WAVE RAM ADDRESS |
|-------------------|-----------------------------|
| 0x0 <sup>2</sup>  | 0x0000                      |
| 0x1 <sup>3</sup>  | 0x0003                      |
| 0x2               | 0x0006                      |
| 0x3               | 0x0009                      |
| 0x4               | 0x000C                      |
| 0x5               | 0x000F                      |
| 0x6               | 0x0012                      |
| 0x7               | 0x0015                      |
| 0x8               | 0x0018                      |
| 0x9               | 0x001B                      |
| 0xA               | 0x001E                      |
| 0xB               | 0x0021                      |
| 0xC               | 0x0024                      |
| 0xD               | 0x0027                      |
| 0xE               | 0x002A                      |

<sup>2</sup> WAVE block number 0x0 can be triggered using GPIO pin and [KP.XTRIGR](#) configuration bit.<sup>3</sup> WAVE block number 0x1 can be triggered using GPIO pin and [KP.XTRIGF](#) configuration bit.

| RAM Address | RAM Content |                     |
|-------------|-------------|---------------------|
| 0x000       | NOT USED    | SLICE START ADDRESS |
| 0x001       | NOT USED    | SLICE END ADDRESS   |
| 0x002       | CYCLE COUNT |                     |
| 0x003       | NOT USED    | SLICE START ADDRESS |
| 0x004       | NOT USED    | SLICE END ADDRESS   |
| 0x005       | CYCLE COUNT |                     |
| .           | .           |                     |
| .           | .           |                     |
| .           | .           |                     |
| 0x02A       | NOT USED    | SLICE START ADDRESS |
| 0x02B       | NOT USED    | SLICE END ADDRESS   |
| 0x02C       | CYCLE COUNT |                     |

WAVE Block Number 0x0

WAVE Block Number 0x1

WAVE Block Number 0xE

Figure 25: All 15 WAVE Blocks in RAM organized in RAM

### 6.8.3 SEQUENCE

A SEQUENCE is a haptic waveform to be played defined by the START and END WAVE number sent using the [RAM SYNTHESIS](#) command. For example, if [START WAVE\[3:0\]](#) is set to 0x3 and [END WAVE\[3:0\]](#) is set to 0x5, the waveform played will be composed of the WAVE blocks at RAM addresses 0x9, 0xC and 0xF, played sequentially.

The smallest sequence is when [START WAVE\[3:0\]](#) is equal to [END WAVE\[3:0\]](#) and thus only one WAVE block is played.

The largest waveform SEQUENCE to be played covers the 15 WAVE blocks, from WAVE number 0x0 to 0xE.

A SEQUENCE is repeated by issuing the [RAM SYNTHESIS](#) command with [RPT](#) field set to 0x1.

### 6.8.4 Continuous Waveform Playback

In RAM SYNTHESIS mode, any type of waveform segments (SEQUENCE, WAVE or SLICE) may be repeated indefinitely.

The Table 18 details how to start and stop the continuous waveform playback of any segment type.

A SEQUENCE that is being played continuously can be terminated by issuing a new [RAM SYNTHESIS](#) command with its field contents identical to the initial [RAM SYNTHESIS](#) command except with the [RPT](#) field set to 0x0.

A WAVE block being repeated continuously can be stopped by issuing a [RAM SYNTHESIS](#) command with the [NXTWV](#) field set to 0x1, which will instruct the WFS to play the next WAVE block of the SEQUENCE or end the waveform playback if the current WAVE block is the last one of the SEQUENCE. Similarly, a

SLICE block being repeated continuously can be stopped by issuing a [RAM SYNTHESIS](#) command with [NXTSL](#) field set to 0x1, which will instruct the WFS to play the next SLICE block or end the waveform if the current SLICE is the last SLICE of the SEQUENCE.

Using [RAM SYNTHESIS](#) command with [NXTSL](#) or [NXTWV](#) field set to 0x1 does not necessarily stop playback: any subsequent SLICE or WAVE block of the SEQUENCE will finish playing and may repeat indefinitely if configured that way.

Issuing a [RAM SYNTHESIS](#) command with [STOP](#) field set to 0x1 will play the next SLICE or WAVE block in the SEQUENCE only once, regardless of the state of [SLICE.CYCLES\[7:0\]](#), [SLICE.CONT](#), [WAVE.COUNT\[15:0\]](#) or [RAM SYNTHESIS.RPT](#) and thus preventing any of them of being repeated indefinitely. There are no options to force an immediate and sudden end of the haptic waveform playback.

Note the following:

- Issuing a [RAM SYNTHESIS](#) command with any of [NXTWV](#), [NXTSL](#) or [STOP](#) field set to 0x1, stop the current SLICE or WAVE block being played even if it is not configured to play continuously. For instance, such a command could be used to put an early end to a long duration waveform.
- When a [RAM SYNTHESIS](#) command with any of [NXTWV](#), [NXTSL](#) or [STOP](#) field set to 0x1 to stop a waveform of being played, the [START WAVE\[3:0\]](#) and [END WAVE\[3:0\]](#) fields must be set again.

Table 18: Summary of how to start and stop the continuous waveform playback.

| SEGMENT TYPE | HOW TO START CONTINUOUS PLAYBACK                                                        | HOW TO STOP CONTINUOUS PLAYBACK                                                           |
|--------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| SEQUENCE     | Issue an <a href="#">RAM SYNTHESIS</a> command with <a href="#">RPT</a> bit set to 0x1. | Issue an <a href="#">RAM SYNTHESIS</a> command with <a href="#">RPT</a> bit set to 0x0.   |
| WAVE         | <a href="#">WAVE.COUNT[15:0]</a> is set to 0x0.                                         | Issue an <a href="#">RAM SYNTHESIS</a> command with <a href="#">NXTWV</a> bit set to 0x1. |
| SLICE        | <a href="#">SLICE.CONT</a> is set to 0x1.                                               | Issue an <a href="#">RAM SYNTHESIS</a> command with <a href="#">NXTSL</a> bit set to 0x1. |

## 6.8.5 Typical Operation Sequences

The following sections show different methods of launching a haptic waveform using RAM Synthesis mode.

Note that any previous waveform must have finished playing before programming RAM.

### 6.8.5.1 Triggered Start Sequence

The triggered start sequence is used to start playing a haptic waveform after programming the [CONFIG.OE](#) bit to 0x1.

The sequence is the following:

- If not already done, set [CONFIG.OE](#) bit to 0x0.
- Set [CONFIG.PLAY MODE\[1:0\]](#) bits to 0x3 to select RAM synthesis mode.
- Use [RAM ACCESS](#) WFS command to write WAVE and SLICE blocks in RAM. Multiple write sequences might be required, see section 6.8.7 for some examples.
- Write START and END WAVE number to be played using [RAM SYNTHESIS](#) WFS command.
- Set [CONFIG.OE](#) bit to 0x1 when ready for haptic waveform playback.
- The haptic waveform starts playing.
- [CONFIG.OE](#) bit is set to 0x0 once the waveform is completed.

#### 6.8.5.2 GPIO Triggered Start Sequence

The GPIO triggered start sequence is used to start playing a haptic waveform using a GPIO falling edge signal and/or rising edge signal.

Note that [KP.XTRIGR](#) bit enables the GPIO rising edge triggering of WAVE block number 0x0 and [KP.XTRIGF](#) bit enables the GPIO falling edge triggering of WAVE block number 0x1.

The sequence is the following:

1. If not already done, set [CONFIG.OE](#) bit to 0x0.
2. Set [CONFIG.PLAY\\_MODE\[1:0\]](#) bits to 0x3 to select RAM synthesis mode.
3. Use [RAM ACCESS](#) WFS command to write WAVE and SLICE blocks in RAM. Multiple write sequences might be required, see section 6.8.7 for some examples.
4. Write START and END WAVE number to be played using [RAM SYNTHESIS](#) WFS command.
5. Set [COMM.GPIODIR](#) to 0x1 to configure GPIO pin as an input.
6. Set [KP.XTRIGR](#) to 0x1 to enable rising edge triggering and/or set [KP.XTRIGF](#) bit to 0x1 to enable falling edge triggering.
7. Set [CONFIG.OE](#) bit to 0x1 when ready for haptic waveform playback.
8. The haptic waveform starts playing on GPIO signal.
9. [CONFIG.OE](#) bit is set to 0x0 once the waveform is completed.

#### 6.8.5.3 Immediate Start Sequence

The immediate start sequence is used to start a haptic waveform playback after issuing the [RAM SYNTHESIS](#) WFS command. The sequence requires the [CONFIG.OE](#) bit to be set to 0x1 before issuing the [RAM SYNTHESIS](#) WFS command.

The sequence is the following:

1. If not already done, set [CONFIG.OE](#) bit to 0x0.
2. Set [CONFIG.PLAY\\_MODE\[1:0\]](#) bits to 0x3 to select RAM synthesis mode.
3. Set [CONFIG.OE](#) bit to 0x1 to enable output.
4. Use [RAM ACCESS](#) WFS command to write WAVE and SLICE blocks in RAM. Multiple write sequences might be required, see section 6.8.7 for some examples.
5. Write START and END WAVE number to be played using [RAM SYNTHESIS](#) WFS command.
6. The haptic waveform starts playing.
7. [CONFIG.OE](#) bit is set to 0x0 once the waveform is completed.

#### 6.8.5.4 Sensing Detection Sequence (BOS1921 Only)

The sequence is used to start haptic waveform playback when previously establish sensing detection conditions are met. The sequence requires the [CONFIG.AUTO](#), [CONFIG.ONCOMP](#) and [CONFIG.SENSE](#) bits to be set to 0x1.

The sequence is the following:

1. If not already done, set [CONFIG.OE](#) bit to 0x0.
2. Set [CONFIG.PLAY MODE\[1:0\]](#) bits to 0x3 to select RAM synthesis mode.
3. Use [RAM ACCESS](#) WFS command to write WAVE and SLICE blocks in RAM. Multiple write sequences might be required, see section 6.8.7 for some examples.
4. Write START and END WAVE number to be played using [RAM SYNTHESIS](#) WFS command.
5. Configure sensing detection condition as per section 6.4.3.
6. Set [CONFIG.OE](#) bit to 0x1 to enable output.
7. The haptic waveform starts playing once sense detection conditions are met.

## 6.8.6 Waveform Examples

Table 19: SLICE waveforms examples

| OUTPUT WAVEFORM                                                                    | SLICE PARAMETERS                                                                                                                                                                                                                                | OUTPUT WAVEFORM                                                                     | SLICE PARAMETERS                                                                                                                                                                                                                                | OUTPUT WAVEFORM                                                                      | SLICE PARAMETERS                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x01<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x0<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |   | <u>AMPLITUDE[11:0]</u> = 0x7FF<br><u>CYCLES[7:0]</u> = 0x03<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x0<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0  |   | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x01<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x0<br><u>HCYC</u> = 0x0<br><u>P180</u> = 1x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |
|   | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x01<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x1<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |   | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x01<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x3<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |   | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x1<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |
|  | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x1<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |  | <u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x3<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |  | <u>AMPLITUDE[11:0]</u> = 0x3FF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x3<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0  |

|                                                                                    |                                                                                                                                                                                                                                                                       |                                                                                    |                                                                                                                                                                                                                                                                       |                                                                                     |                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>OUTPUT WAVEFORM</b>                                                             | <b>SLICE PARAMETERS</b>                                                                                                                                                                                                                                               | <b>OUTPUT WAVEFORM</b>                                                             | <b>SLICE PARAMETERS</b>                                                                                                                                                                                                                                               | <b>OUTPUT WAVEFORM</b>                                                              | <b>SLICE PARAMETERS</b>                                                                                                                                                                                                                                               |
|   | <b>SLICE J</b><br><br><u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x3<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |  | <b>SLICE K</b><br><br><u>AMPLITUDE[11:0]</u> = 0x3FF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x3<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0  |  | <b>SLICE L</b><br><br><u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x03<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x0<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x1<br><u>SHAPEDN[3:0]</u> = 0x1 |
|   | <b>SLICE M</b><br><br><u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x03<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x1<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x1<br><u>SHAPEDN[3:0]</u> = 0x1 |  | <b>SLICE N</b><br><br><u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x03<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x3<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x1<br><u>SHAPEDN[3:0]</u> = 0x1 |  | <b>SLICE O</b><br><br><u>AMPLITUDE[11:0]</u> = 0xFFFF<br><u>CYCLES[7:0]</u> = 0x00<br><u>FREQUENCY[7:0]</u> = 0x1A<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x0<br><u>HCYC</u> = 0x1<br><u>P180</u> = 0x1<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |
|  | <b>SLICE P</b><br><br><u>AMPLITUDE[11:0]</u> = 0x0000<br><u>CYCLES[7:0]</u> = 0x01<br><u>FREQUENCY[7:0]</u> = 0x34<br><u>CONT</u> = 0x0<br><u>MODE[1:0]</u> = 0x1<br><u>HCYC</u> = 0x0<br><u>P180</u> = 0x0<br><u>SHAPEUP[3:0]</u> = 0x0<br><u>SHAPEDN[3:0]</u> = 0x0 |                                                                                    |                                                                                                                                                                                                                                                                       |                                                                                     |                                                                                                                                                                                                                                                                       |

Table 20: Waveform examples built from a single WAVE block

| WAVE BLOCK CONTENT                                                                                                                                              | WAVEFORM                                                                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| SLICEs : F + O + J<br><u>WAVE.COUNT[15:0]</u> = 0x1<br><u>RELOFF</u> = 0x0<br><i>Note that waveform features a smooth start and stop for optimal integrity.</i> |    |
| SLICEs : H + A + J<br><u>WAVE.COUNT[15:0]</u> = 0x1<br><u>RELOFF</u> = 0x0<br><i>Note that SLICE A can be repeated to output a sinewave.</i>                    |    |
| SLICE : D<br><u>WAVE.COUNT[15:0]</u> = 0x3<br><u>RELOFF</u> = 0x0                                                                                               |   |
| SLICEs : F + O + J + P<br><u>WAVE.COUNT[15:0]</u> = 0x3<br><u>RELOFF</u> = 0x0                                                                                  |  |
| SLICEs: I + B + K<br><u>WAVE.COUNT[15:0]</u> = 0x1<br><u>RELOFF</u> = 0x1                                                                                       |  |

### 6.8.7 I<sup>2</sup>C Communication Examples

Figure 26 to Figure 29 give two examples showing how to program in RAM a waveform:

- Example 1 uses only 1 SLICE and 1 WAVE programmed with a single communication transaction.
- Example 2 uses 4 SLICEs and 3 WAVEs programmed with a communication transaction for each WFS command.

Both examples use OE bit set to 0x1 to start playing immediately after the RAM SYNTHESIS command is issued.

| I <sup>2</sup> C Communication Sequence |                                                    |
|-----------------------------------------|----------------------------------------------------|
| Transaction 1 :                         |                                                    |
| Code                                    | Description / Configure RAM Synthesis Mode         |
| 0x44                                    | I <sup>2</sup> C address                           |
| 0x05                                    | Select CONFIG register                             |
| 0x1600                                  | Set RAM Synthesis Mode                             |
| Code                                    | Description / Program one WAVE in RAM              |
| 0x0001                                  | WFS command : set to RAM ACCESS                    |
| 0x0000                                  | Set RAM start address for WAVE block programming   |
| 0x0100                                  | WAVE Data : Set RAM start address of first SLICE   |
| 0x0102                                  | WAVE Data : Set RAM end address of last SLICE      |
| 0x0001                                  | WAVE Data : Set WAVE cycle count (played once)     |
| Code                                    | Description / Program one SLICE in RAM             |
| 0x0001                                  | WFS command : set to RAM ACCESS                    |
| 0x0100                                  | Set RAM ADDRESS for SLICE block programming        |
| 0xFFFF                                  | SLICE Data : Set AMPLITUDE (full scale)            |
| 0x0440                                  | SLICE Data : Set CYCLES (4) and FREQUENCY (250 Hz) |
| 0x0000                                  | SLICE Data : Set bipolar waveform                  |
| Code                                    | Description / Set Start and End Sequencer Entries  |
| 0x0012                                  | WFS command : set sequencer start and end numbers  |
| 0x0000                                  | Set start and end sequence to 0x0                  |

**RAM Content**

| RAM Address | WAVE   |       |
|-------------|--------|-------|
| 0x0000      | 0x00   | 0x100 |
| 0x0001      | 0x00   | 0x102 |
| 0x0002      | 0x0001 |       |
|             |        |       |

**RAM Content**

| RAM Address | SLICE |         |
|-------------|-------|---------|
| 0x0100      | 0x0   | 0xFFFF  |
| 0x0101      | 0x04  | 0x40    |
| 0x0102      | 0x00  | 0x0 0x0 |
|             |       |         |

Figure 26: RAM synthesis mode setup example 1

### I<sup>2</sup>C Communication Sequence

| Transaction 1 |                                            |
|---------------|--------------------------------------------|
| Code          | Description / Configure RAM Synthesis Mode |
| 0x44          | I <sup>2</sup> C address                   |
| 0x05          | Select CONFIG register                     |
| 0x1600        | Set RAM Synthesis Mode                     |

  

| Transaction 2 |                                                     |
|---------------|-----------------------------------------------------|
| Code          | Description / Program WAVE #1 in RAM                |
| 0x44          | I <sup>2</sup> C address                            |
| 0x00          | Select REFERENCE register to access to WFS Register |
| 0x0001        | WFS command : RAM ACCESS                            |
| 0x0000        | Set RAM start address for WAVE block programming    |
| 0x0100        | WAVE #1 Data : Set RAM start address of SLICE #1    |
| 0x0102        | WAVE #1 Data : Set RAM end address of SLICE #1      |
| 0x000E        | WAVE #1 Data : Set WAVE cycle count (14 times)      |

  

| Transaction 3 |                                                       |
|---------------|-------------------------------------------------------|
| Code          | Description / Program SLICE #1 in RAM                 |
| 0x44          | I <sup>2</sup> C address                              |
| 0x00          | Select REFERENCE register to access to WFS Register   |
| 0x0001        | WFS command : RAM ACCESS                              |
| 0x0100        | Set RAM address for SLICE block programming           |
| 0x0FFF        | SLICE #1 Data : Set AMPLITUDE (full scale)            |
| 0x01FF        | SLICE #1 Data : Set CYCLES (1) and FREQUENCY (995 Hz) |
| 0x0000        | SLICE #1 Data : Set bipolar waveform                  |

  

| Transaction 4 |                                                     |
|---------------|-----------------------------------------------------|
| Code          | Description / Program WAVE #2 in RAM                |
| 0x44          | I <sup>2</sup> C address                            |
| 0x00          | Select REFERENCE register to access to WFS Register |
| 0x0001        | WFS command : RAM ACCESS                            |
| 0x0003        | Set RAM address for WAVE block programming          |
| 0x0200        | WAVE #2 Data : Set RAM start address of SLICE #2    |
| 0x0202        | WAVE #2 Data : Set RAM end address of SLICE #2      |
| 0x001D        | WAVE #2 Data : Set WAVE cycle count (29 times)      |

  

| Transaction 5 |                                                         |
|---------------|---------------------------------------------------------|
| Code          | Description / Program SLICE #2 in RAM                   |
| 0x44          | I <sup>2</sup> C address                                |
| 0x00          | Select REFERENCE register to access to WFS Register     |
| 0x0001        | WFS command : RAM ACCESS                                |
| 0x0200        | Set RAM start address for SLICE block programming       |
| 0x0CCC        | SLICE #2 Data : Set AMPLITUDE (156V)                    |
| 0x1033        | SLICE #2 Data : Set CYCLES (16) and FREQUENCY (200 Hz)  |
| 0x0021        | SLICE #2 Data : Set SHAPEUP (64 ms) and SHAPEDN (32 ms) |

RAM Content

| RAM Address | WAVE #1 |       |
|-------------|---------|-------|
| 0x0000      | 0x00    | 0x100 |
| 0x0001      | 0x00    | 0x102 |
| 0x0002      | 0x000E  |       |

RAM Content

| RAM Address | SLICE #1 |        |
|-------------|----------|--------|
| 0x0100      | 0x0      | 0xFFFF |
| 0x0101      | 0x01     | 0xFF   |
| 0x0102      | 0x00     | 0x0    |

RAM Content

| RAM Address | WAVE #2 |       |
|-------------|---------|-------|
| 0x0003      | 0x00    | 0x200 |
| 0x0004      | 0x00    | 0x202 |
| 0x0005      | 0x001D  |       |

RAM Content

| RAM Address | SLICE #2 |       |
|-------------|----------|-------|
| 0x0200      | 0x0      | 0xCCC |
| 0x0201      | 0x10     | 0x33  |
| 0x0202      | 0x00     | 0x2   |

Figure 27: RAM synthesis mode setup example 2

### *I<sup>2</sup>C Communication Sequence*

#### Transaction 6

| Code          | Description / Program WAVE #3 in RAM                |
|---------------|-----------------------------------------------------|
| 0x44          | I <sup>2</sup> C address                            |
| 0x00          | Select REFERENCE register to access to WFS Register |
| <b>0x0001</b> | WFS command : RAM ACCESS                            |
| 0x0006        | Set RAM start address for WAVE block programming    |
| 0x0203        | WAVE #3 Data : Set RAM start address of SLICE #3    |
| 0x0208        | WAVE #3 Data : Set RAM end address of SLICE #4      |
| 0x01EE        | WAVE #3 Data : Set WAVE cycle count (494 times)     |

| RAM Content |         |        |
|-------------|---------|--------|
| RAM Address | WAVE #3 |        |
| 0x0006      | 0x00    | 0x203  |
| 0x0007      | 0x00    | 0x208  |
| 0x0008      |         | 0x01EE |

#### Transaction 7

| Code          | Description / Program SLICE #3 in RAM                   |
|---------------|---------------------------------------------------------|
| 0x44          | I <sup>2</sup> C address                                |
| 0x00          | Select REFERENCE register to access to WFS Register     |
| <b>0x0001</b> | WFS command : RAM ACCESS                                |
| 0x0203        | Set RAM start address for SLICE block programming       |
| 0x0AAA        | SLICE #3 Data : Set AMPLITUDE (130V)                    |
| 0x0A1A        | SLICE #3 Data : Set CYCLES (10) and FREQUENCY (100 Hz)  |
| 0x0012        | SLICE #3 Data : Set SHAPEUP (32 ms) and SHAPEDN (64 ms) |

| RAM Content |          |         |
|-------------|----------|---------|
| RAM Address | SLICE #3 |         |
| 0x0203      | 0x0      | 0xAAA   |
| 0x0204      | 0x0A     | 0x1A    |
| 0x0205      | 0x00     | 0x1 0x2 |

#### Transaction 8

| Code          | Description / Program SLICE #4 in RAM                  |
|---------------|--------------------------------------------------------|
| 0x44          | I <sup>2</sup> C address                               |
| 0x00          | Select REFERENCE register to access to WFS Register    |
| <b>0x0001</b> | WFS command : set to RAM SYNTHESIS WRITE               |
| 0x0206        | Set RAM start address for SLICE block programming      |
| 0x0000        | SLICE #4 Data : Set AMPLITUDE (0 V)                    |
| 0x1F1A        | SLICE #4 Data : Set CYCLES (31) and FREQUENCY (100 Hz) |
| 0x0000        | SLICE #4 Data : Set SHAPEUP (0 ms) and SHAPEDN (0 ms)  |

| RAM Content |          |         |
|-------------|----------|---------|
| RAM Address | SLICE #4 |         |
| 0x0206      | 0x0      | 0x000   |
| 0x0207      | 0x1F     | 0x1A    |
| 0x0208      | 0x00     | 0x0 0x0 |

#### Transaction 10

| Code          | Description / Set Start and End Sequencer Entries   |
|---------------|-----------------------------------------------------|
| 0x44          | I <sup>2</sup> C address                            |
| 0x00          | Select REFERENCE register to access to WFS Register |
| <b>0x0012</b> | WFS command : RAM Synthesis                         |
| 0x2000        | Set start to SEQUENCE 0x0 and end to SEQUENCE 0x2   |

Figure 28: RAM synthesis mode setup example 2 (continued)

| RAM Address |      |        |     |  |
|-------------|------|--------|-----|--|
| 0x0000      | 0x00 | 0x100  |     |  |
| 0x0001      | 0x00 | 0x102  |     |  |
| 0x0002      |      | 0x000E |     |  |
| 0x0003      | 0x00 | 0x200  |     |  |
| 0x0004      | 0x00 | 0x202  |     |  |
| 0x0005      |      | 0x001D |     |  |
| 0x0006      | 0x00 | 0x203  |     |  |
| 0x0007      | 0x00 | 0x208  |     |  |
| 0x0008      |      | 0x01EE |     |  |
|             |      | •      |     |  |
|             |      | •      |     |  |
|             |      | •      |     |  |
| 0x0100      | 0x0  | 0xFFFF |     |  |
| 0x0101      | 0x01 | 0xFF   |     |  |
| 0x0102      | 0x00 | 0x0    | 0x0 |  |
| 0x0200      | 0x0  | 0xCCC  |     |  |
| 0x0201      | 0x10 | 0x33   |     |  |
| 0x0202      | 0x00 | 0x2    | 0x1 |  |
| 0x0203      | 0x0  | 0xAAA  |     |  |
| 0x0204      | 0x0A | 0x1A   |     |  |
| 0x0205      | 0x00 | 0x1    | 0x2 |  |
| 0x0206      | 0x0  | 0x000  |     |  |
| 0x0207      | 0x1F | 0x1A   |     |  |
| 0x0208      | 0x00 | 0x0    | 0x0 |  |

Figure 29: RAM Synthesis mode setup example 2 RAM summary

## 6.9 WFS Command Interpreter

The BOS1921/BOS1931 RAM is programmed using the WFS Command Interpreter accessible through [REFERENCE](#) register. WFS commands interpreter are used to store RAM Playback data and RAM Synthesis configuration data into RAM or to set FIFO DEPTH. WFS command list is summarized in Table 21, where word 0 is the command and the following words are the command payload.

Table 21 WFS commands list

| COMMAND                             | WORD | 15  | 14 | 13 | 12 | 11 | 10 | 9                  | 8 | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0                                                                              |
|-------------------------------------|------|-----|----|----|----|----|----|--------------------|---|---|-----------------|---|---|---|---|---|--------------------------------------------------------------------------------|
| <a href="#">RAM ACCESS</a>          | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0x0001                                                         |
|                                     | 1    |     |    |    |    |    |    | R/W                |   |   |                 |   |   |   |   |   | ADDRESS[9:0]                                                                   |
|                                     | 2    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | DATA1[15:0]: required when write access is requested by setting R/W bit to 0x0 |
|                                     | 3    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | DATA2[15:0]: required when write access is requested by setting R/W bit to 0x0 |
|                                     | 4    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | DATA3[15:0]: required when write access is requested by setting R/W bit to 0x0 |
| <a href="#">FIFO DEPTH</a>          | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0x0003                                                         |
|                                     | 1    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | FIFO DEPTH[2:0]                                                                |
| <a href="#">RAM SYNTHESIS</a>       | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0x0012                                                         |
|                                     |      |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   |                                                                                |
|                                     | 1    |     |    |    |    |    |    | END WAVE[3:0]      |   |   | START WAVE[3:0] |   |   |   |   |   | RELOFF STOP NXTW NXTSL RPT V                                                   |
| <a href="#">RAM PLAYBACK</a>        | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0x0013                                                         |
|                                     | 1    | RPT |    |    |    |    |    | START ADDRESS[4:0] |   |   |                 |   |   |   |   |   | END ADDRESS[9:0]                                                               |
|                                     | 2    |     |    |    |    |    |    | START ADDRESS[9:5] |   |   |                 |   |   |   |   |   | REPEAT START ADDRESS[9:0]                                                      |
| <a href="#">BURST RAM WRITE</a>     | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0x0014                                                         |
|                                     | 1    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | START ADDRESS[9:0]                                                             |
|                                     | 2    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | DATA COUNT [9:0]                                                               |
|                                     | 3    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | DATA1[15:0]                                                                    |
|                                     | ...  |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | ...                                                                            |
|                                     | 2+n  |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | DATAAn (n = DATA COUNT[9:0])                                                   |
| <a href="#">FULL RAM READ</a>       | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0x0015                                                         |
| <a href="#">FULL RAM READ BREAK</a> | 0    |     |    |    |    |    |    |                    |   |   |                 |   |   |   |   |   | COMMAND[15:0] = 0xFF15                                                         |

Figure 30 and Figure 31 present two different I<sup>2</sup>C communication sequence examples using either a single communication transaction for each WFS command or a single communication transaction to use several WFS commands. The first word of each WFS command is the command identifier. The number of following words to send depends on the command used.

| Transaction 1 |                                                |
|---------------|------------------------------------------------|
| Code          | Description / WFS command 1                    |
| 0x44          | I <sup>2</sup> C address                       |
| 0x00          | Select REFERENCE register to use a WFS command |
| 0x0000        | WFS command 1                                  |
| 0x0000        | Expected word for command 1                    |

  

| Transaction 2 |                                                |
|---------------|------------------------------------------------|
| Code          | Description / WFS command 2                    |
| 0x44          | I <sup>2</sup> C address                       |
| 0x00          | Select REFERENCE register to use a WFS command |
| 0x0000        | WFS comamnd 2                                  |
| 0x0000        | Expected word for command 2                    |

  

| Transaction 3 |                                                |
|---------------|------------------------------------------------|
| Code          | Description / WFS command 3                    |
| 0x44          | I <sup>2</sup> C address                       |
| 0x00          | Select REFERENCE register to use a WFS command |
| 0x0000        | WFS command 3                                  |
| 0x0000        | Expected word for command 3                    |

Figure 30: Generic I<sup>2</sup>C communication sequence example to use a WFS command with a transaction

| Transaction 1 |                                                |
|---------------|------------------------------------------------|
| Code          | Description / WFS command 1                    |
| 0x44          | I <sup>2</sup> C address                       |
| 0x00          | Select REFERENCE register to use a WFS command |
| 0x0000        | WFS command 1                                  |
| 0x0000        | Write expected word for command 1              |

  

| Transaction 2 |                                   |
|---------------|-----------------------------------|
| Code          | Description / WFS command 2       |
| 0x0000        | WFS command 2                     |
| 0x0000        | Write expected word for command 2 |

  

| Transaction 3 |                                   |
|---------------|-----------------------------------|
| Code          | Description / WFS command 3       |
| 0x0000        | WFS command 3                     |
| 0x0000        | Write expected word for command 3 |

Figure 31: Generic I<sup>2</sup>C communication sequence example to use several WFS commands with a single transaction

### 6.9.1 0x0001 RAM ACCESS

Table 22: RAM ACCESS details

| COMMAND: 0x0001 RAM ACCESS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------|----|----|-------------|----|---------------|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                              | 14                                        | 13 | 12 | 11          | 10 | 9             | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | COMMAND[15:0] = 0x0001                                                          |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | NOT USED: 0x00                                                                  |                                           |    |    | R/W         |    | ADDRESS [9:0] |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DATA1 [15:0]: required when write access is requested by setting R/W bit to 0x0 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DATA2 [15:0]: required when write access is requested by setting R/W bit to 0x0 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DATA3 [15:0]: required when write access is requested by setting R/W bit to 0x0 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| WORD, BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                 | NAME                                      |    |    | DESCRIPTION |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [10]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W                                                                             | 0: RAM Write Enable<br>1: RAM Read Enable |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 2,<br>Bit [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ADDRESS                                                                         | Write/read start address within the RAM   |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| The RAM ACCESS command is used to either read a single location from RAM or writing a block of 3 words to RAM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| In RAM Synthesis mode, a WAVE or SLICE block can be written to RAM with the following sequence (as described in Figure 32):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <ol style="list-style-type: none"> <li>1. Set <a href="#">PLAY MODE[1:0]</a> to 0x3 to select RAM Synthesis mode.</li> <li>2. Write 0x0001 to the <a href="#">REFERENCE</a> register to use the RAM ACCESS command</li> <li>3. Write the following to the <a href="#">REFERENCE</a> register:             <ol style="list-style-type: none"> <li>a. Set R/W to 0x0 and set the ADDRESS [9:0] to the RAM start address.</li> <li>b. Write the three words of either a WAVE or SLICE block to the <a href="#">REFERENCE</a> register to store in RAM. See section 6.8 for details on the content of these words. The RAM address is automatically incremented between each word.</li> </ol> </li> </ol> |                                                                                 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| In either RAM Synthesis or RAM Playback, an RAM location can be read with the following sequence (as described in Figure 33):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <ol style="list-style-type: none"> <li>1. Set <a href="#">PLAY MODE[1:0]</a> to 0x2 or 0x3 to select RAM Playback or RAM Synthesis mode.</li> <li>2. Set <a href="#">RDADDR[4:0]</a> to 0x1B to select <a href="#">RAM DATA</a> reading.</li> <li>3. Write 0x0001 to the <a href="#">REFERENCE</a> register to use the RAM ACCESS command.</li> <li>4. Write the following to the <a href="#">REFERENCE</a> register:             <ol style="list-style-type: none"> <li>a. R/W bit set to 0x1.</li> <li>b. ADDRESS [9:0] bits set to the RAM address to read.</li> </ol> </li> <li>5. Read 2 bytes.</li> </ol>                                                                                       |                                                                                 |                                           |    |    |             |    |               |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Transaction 1 : Set RAM Synthesis Mode |                                        |
|----------------------------------------|----------------------------------------|
| Code                                   | Description                            |
| 0x44+ W                                | I <sup>2</sup> C address, write access |
| 0x05                                   | Select CONFIG register                 |
| 0x2697                                 | Set RAM Synthesis Mode                 |

  

| Transaction 2 : Set the RAM SYNTHESIS WRITE register |                                                     |
|------------------------------------------------------|-----------------------------------------------------|
| Code                                                 | Description                                         |
| 0x44+ W                                              | I <sup>2</sup> C address                            |
| 0x00                                                 | Select REFERENCE register to access to WFS Register |
| 0x0001                                               | WFS command : set to RAM SYNTHESIS WRITE            |
| 0x0063                                               | Set RAM start address 0x063 for write access        |
| 0x0100                                               | DATA 1                                              |
| 0x0102                                               | DATA 2                                              |
| 0x000E                                               | DATA 3                                              |

Figure 32: I<sup>2</sup>C communication sequence for RAM write using [RAM ACCESS](#) command

| Transaction 1 : Set RAM Synthesis Mode |                                        |
|----------------------------------------|----------------------------------------|
| Code                                   | Description                            |
| 0x44+ W                                | I <sup>2</sup> C address, write access |
| 0x05                                   | Select CONFIG register                 |
| 0x2697                                 | Set RAM Synthesis Mode                 |

  

| Transaction 2 : Configure Broadcast |                                        |
|-------------------------------------|----------------------------------------|
| Code                                | Description                            |
| 0x44+ W                             | I <sup>2</sup> C address, write access |
| 0x02                                | Select READ register                   |
| 0x002B                              | Set bit BC for RAM_DATA reading        |

  

| Transaction 3 : Set the RAM SYNTHESIS WRITE register |                                                     |
|------------------------------------------------------|-----------------------------------------------------|
| Code                                                 | Description                                         |
| 0x44+ W                                              | I <sup>2</sup> C address, write access              |
| 0x00                                                 | Select REFERENCE register to access to WFS Register |
| 0x0001                                               | WFS command : set to RAM SYNTHESIS WRITE            |
| 0x0463                                               | Set RAM address 0x063 for read access               |

  

| Transaction 4 : Set the RAM SYNTHESIS WRITE register |                                       |
|------------------------------------------------------|---------------------------------------|
| Code                                                 | Description                           |
| 0x44+ R                                              | I <sup>2</sup> C address, read access |
| 0x0000                                               | Read 2-byte                           |

Figure 33: RAM ACCESS sequence for RAM read

### 6.9.2 0x0003 FIFO DEPTH

Table 23: FIFO DEPTH details

| COMMAND: 0x0003 FIFO DEPTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                        |    |                                                                                                                                                                                                            |    |    |    |   |   |   |   |   |   |   |   |   |                 |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|--|
| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 15                     | 14 | 13                                                                                                                                                                                                         | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | COMMAND[15:0] = 0x0003 |    |                                                                                                                                                                                                            |    |    |    |   |   |   |   |   |   |   |   |   |                 |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | NOT USED: 0x0000       |    |                                                                                                                                                                                                            |    |    |    |   |   |   |   |   |   |   |   |   | FIFO DEPTH[2:0] |  |
| WORD, BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | NAME                   |    | DESCRIPTION                                                                                                                                                                                                |    |    |    |   |   |   |   |   |   |   |   |   |                 |  |
| Word 1,<br>Bit [2:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | FIFO DEPTH             |    | 0x0: 1024 locations (default)<br>0x1: 512 locations<br>0x2: 256 locations<br>0x3: 128 locations<br>0x4: 64 locations<br>All other values: 1024 locations. The RAM address ranges are detailed in Table 24. |    |    |    |   |   |   |   |   |   |   |   |   |                 |  |
| The FIFO DEPTH command defines RAM locations to be used as a FIFO, used in FIFO mode. The RAM address ranges are detailed in Table 24.<br>By default, the FIFO depth corresponds to full 1024 RAM locations. Using a smaller FIFO allows preserving sections of RAM that could be used for RAM Synthesis or RAM Playback modes.<br><u>PLAY_MODE</u> bits must first be set to RAM PLAYBACK or RAM SYNTHESIS mode (0x2 or 0x3) and <u>CONFIG.OE</u> bit must be set to 0x0 before issuing a FIFO DEPTH command. |                        |    |                                                                                                                                                                                                            |    |    |    |   |   |   |   |   |   |   |   |   |                 |  |

Table 24: RAM address range used by FIFO according to FIFO DEPTH value

| FIFO DEPTH[2:0] | NUMBER OF RAM LOCATION | RAM ADDRESS RANGE FOR FIFO |       |
|-----------------|------------------------|----------------------------|-------|
|                 |                        | BEGIN                      | END   |
| 0               | 1024                   | 0x000                      | 0x3FF |
| 1               | 512                    | 0x200                      | 0x3FF |
| 2               | 256                    | 0x300                      | 0x3FF |
| 3               | 128                    | 0x380                      | 0x3FF |
| 4               | 64                     | 0x3C0                      | 0x3FF |

### 6.9.3 0x0012 RAM SYNTHESIS

Table 25: RAM SYNTHESIS command details

| COMMAND: 0x0012 RAM SYNTHESIS |                        |    |                                                                                                                                                 |                 |    |    |   |               |   |   |        |      |       |       |     |   |  |  |  |  |  |  |  |  |  |  |
|-------------------------------|------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----|----|---|---------------|---|---|--------|------|-------|-------|-----|---|--|--|--|--|--|--|--|--|--|--|
| Word                          | 15                     | 14 | 13                                                                                                                                              | 12              | 11 | 10 | 9 | 8             | 7 | 6 | 5      | 4    | 3     | 2     | 1   | 0 |  |  |  |  |  |  |  |  |  |  |
| 0                             | COMMAND[15:0] = 0x0012 |    |                                                                                                                                                 |                 |    |    |   |               |   |   |        |      |       |       |     |   |  |  |  |  |  |  |  |  |  |  |
| 1                             | END WAVE[3:0]          |    |                                                                                                                                                 | START WAVE[3:0] |    |    |   | NOT USED: 0x0 |   |   | RELOFF | STOP | NXTWV | NXTSL | RPT |   |  |  |  |  |  |  |  |  |  |  |
| WORD, BIT                     | NAME                   |    | DESCRIPTION                                                                                                                                     |                 |    |    |   |               |   |   |        |      |       |       |     |   |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bits [15:12]       | END WAVE               |    | Sets the WAVE number (numbered 0x0 to 0xE), which points to the first word of the last WAVE block of the SEQUENCE to play (see section 6.8.2).  |                 |    |    |   |               |   |   |        |      |       |       |     |   |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bits [11:8]        | START WAVE             |    | Sets the WAVE number (numbered 0x0 to 0xE), which points to the first word of the first WAVE block of the SEQUENCE to play (see section 6.8.2). |                 |    |    |   |               |   |   |        |      |       |       |     |   |  |  |  |  |  |  |  |  |  |  |

| COMMAND: 0x0012 RAM SYNTHESIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---------------|---|--------|------|-------|-------|-----|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 15                     | 14 | 13 | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 11 | 10 | 9             | 8 | 7      | 6    | 5     | 4     | 3   | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | COMMAND[15:0] = 0x0012 |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | END WAVE[3:0]          |    |    | START WAVE[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    | NOT USED: 0x0 |   | RELOFF | STOP | NXTWV | NXTSL | RPT |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| WORD, BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | NAME                   |    |    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [3]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RELOFF                 |    |    | Add a DC offset to each SLICE of the waveform matching the last sample of its previous SLICE.<br>The offset added on the first SLICE is calculated so that it starts at 0V.<br>The RELOFF option can be used to add a DC offset to the waveform played.<br>When RELOFF is used and set to 0x1, the <a href="#">SLICE.MODE</a> of each SLICE blocks of the waveform must be 0x0.<br>Note the following: <ul style="list-style-type: none"> <li>• Waveform will begin at 0 V amplitude.</li> <li>• Waveform should end with 0 V amplitude.</li> <li>• The SLICE parameters <a href="#">SHAPEUP[3:0]</a> and <a href="#">SHAPEDN[3:0]</a> must be set to 0x0.</li> </ul> |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [3]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | STOP                   |    |    | Request to stop playing waveform by preventing SLICEs, WAVEs and SEQUENCE from being repeated (see section 6.8.2).<br>Once the STOP command is issued, the WFS will play only a single cycle (or half-cycle) of all the remaining SLICE or WAVE block(s) of the SEQUENCE. There are no options to force an immediate and sudden end of the haptic waveform playback.<br>This option applies to any waveform being played whether continuously or not. The <a href="#">RPT</a> field must be set to 0x0 when setting STOP to 0x1.                                                                                                                                      |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [2]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NXTWV                  |    |    | Plays the next WAVE of the SEQUENCE after reaching the end of the current WAVE. This option is used to stop a WAVE being played continuously.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NXTSL                  |    |    | Plays the next SLICE of the SEQUENCE after reaching the end of the current SLICE. This option is used to stop a SLICE being played continuously.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RPT                    |    |    | Enables the SEQUENCE to be repeated indefinitely. When the WAVE block associated with the <a href="#">END WAVE[3:0]</a> has been played, the WAVE block associated with the <a href="#">START WAVE[3:0]</a> will start playing again.                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| In RAM Synthesis (bits <a href="#">PLAY_MODE[1:0]</a> set to 0x3), the device plays all WAVE blocks starting from <a href="#">START WAVE[3:0]</a> up to <a href="#">END WAVE[3:0]</a> , which is referred as the SEQUENCE.<br>Any write with the RAM SYNTHESIS command indicates that the waveform from <a href="#">START WAVE[3:0]</a> up to <a href="#">END WAVE[3:0]</a> is ready to be played. If <a href="#">OE</a> bit is already set to 0x1, the waveform will start to play immediately after the RAM SYNTHESIS command is issued.<br>If the <a href="#">AUTO</a> bit is set to 0x1, the waveform will be automatically played upon a sense voltage event. See section 6.4.3 for more detail.<br>The communication sequence to use the RAM SYNTHESIS command includes the following: |                        |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1. Write 0x0012 to <a href="#">REFERENCE</a> register to use the RAM SYNTHESIS command.<br>2. Write the following word to <a href="#">REFERENCE</a> register: <ol style="list-style-type: none"> <li>Bits 15:12 with <a href="#">END WAVE[3:0]</a> (0x0 to 0xE).</li> <li>Bits 11:8 with <a href="#">START WAVE[3:0]</a> (0x0 to 0xE).</li> <li>Bits 3:0 with <a href="#">STOP</a>, <a href="#">NXTWV</a>, <a href="#">NXTSL</a> &amp; <a href="#">RPT</a>.</li> </ol> Note that the communication sequence assumes that bits <a href="#">PLAY_MODE[1:0]</a> are set to 0x3.                                                                                                                                                                                                                 |                        |    |    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |               |   |        |      |       |       |     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### 6.9.4 0x0013 RAM PLAYBACK

Table 26: RAM PLAYBACK command details

| COMMAND: 0x0013 RAM PLAYBACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                         |                    |    |    |                                                                                                                                                                                                                                                                                                                                                                            |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------------------|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 15                      | 14                 | 13 | 12 | 11                                                                                                                                                                                                                                                                                                                                                                         | 10 | 9                         | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | COMMAND[15:0] = 0x0013  |                    |    |    |                                                                                                                                                                                                                                                                                                                                                                            |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RPT                     | START ADDRESS[4:0] |    |    |                                                                                                                                                                                                                                                                                                                                                                            |    | END ADDRESS[9:0]          |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0                     | START ADDRESS[9:5] |    |    |                                                                                                                                                                                                                                                                                                                                                                            |    | REPEAT START ADDRESS[9:0] |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| WORD, BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         | NAME               |    |    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 1,<br>Bit [15]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RPT                     |                    |    |    | Enables waveform repeat for continuous waveform playback. When enabled, the next sample after the sample fetched at <a href="#">END ADDRESS[9:0]</a> is at <a href="#">REPEAT START ADDRESS[9:0]</a> . When disabled, the waveform ends after fetching the sample at <a href="#">END ADDRESS[9:0]</a> .<br>0x1: Waveform repeat enabled.<br>0x0: Waveform repeat disabled. |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 1,<br>Bits [14:10]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | START<br>ADDRESS[4:0]   |                    |    |    | Sets the 10-bit RAM start address for fetching RAM Playback samples where the 5 LSBs (START ADDRESS[4:0]) are sent in Word 1 and the 5 MSBs (START ADDRESS[9:5]) are sent in Word 2.                                                                                                                                                                                       |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 2,<br>Bits [14:10]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | START<br>ADDRESS[9:5]   |                    |    |    | The START ADDRESS[9:0] field is ignored when continuous waveform playback is already in progress and <a href="#">RPT</a> bit has been set to 0x1 in a previous RAM PLAYBACK command.                                                                                                                                                                                       |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 1,<br>Bits [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | END ADDRESS             |                    |    |    | Sets the 10-bit RAM end address for fetching RAM Playback samples, which corresponds to the address of the last sample to be played before the playback ends (if <a href="#">RPT</a> bit is set to 0x0) or before the playback is repeated (if <a href="#">RPT</a> bit is set to 0x1).                                                                                     |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 2,<br>Bits [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | REPEAT START<br>ADDRESS |                    |    |    | Sets the 10-bit RAM repeat start address for fetching RAM Playback samples when <a href="#">RPT</a> bit is set to 0x1. The field is ignored if <a href="#">RPT</a> bit is set to 0x0.                                                                                                                                                                                      |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| <p>The <a href="#">START</a> and <a href="#">END ADDRESS[9:0]</a> entered with the RAM PLAYBACK command indicate the location in RAM of the samples to be fetched for waveform playback when the RAM Playback is initiated.</p> <p>The waveform segment between <a href="#">REPEAT START ADDRESS[9:0]</a> and <a href="#">END ADDRESS[9:0]</a> is repeated when setting <a href="#">RPT</a> to 0x1. To end a waveform playback repetition, a new RAM PLAYBACK command must be issued with <a href="#">RPT</a> set to 0x0 with the <a href="#">END ADDRESS</a> equals to or greater than the initial <a href="#">END ADDRESS[9:0]</a>.</p> <p>The 16-bit samples in RAM use the same format as for Direct Mode (see section 6.5) and FIFO mode (see section 6.6) and includes the bits [11:0] as the waveform amplitude, see <a href="#">REFERENCE[11:0]</a> bits description.</p> <p>The samples in RAM are written using <a href="#">BURST RAM WRITE</a> command.</p> <p>The use of the RAM PLAYBACK command indicates that the waveform is ready to be played. Thus, if <a href="#">OE</a> bit is set 0x1, the waveform will start to play when issuing a RAM Playback command.</p> <p>The communication sequence to program the <a href="#">START ADDRESS[9:0]</a> and <a href="#">END ADDRESS[9:0]</a> using the RAM PLAYBACK command includes the following:</p> <ol style="list-style-type: none"> <li>1. Write waveform data in RAM using <a href="#">BURST RAM WRITE</a> command.</li> <li>2. Write 0x0013 to the <a href="#">REFERENCE</a> register to use the RAM PLAYBACK command.</li> <li>3. Write word 1 to the <a href="#">REFERENCE</a> register.</li> <li>4. Write word 2 to the <a href="#">REFERENCE</a> register.</li> </ol> <p>Note that the communication sequence assumes that bits <a href="#">PLAY MODE[1:0]</a> are set to 0x2.</p> |                         |                    |    |    |                                                                                                                                                                                                                                                                                                                                                                            |    |                           |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

## 6.9.5 0x0014 BURST RAM WRITE

Table 27: BURST RAM WRITE command details

| COMMAND: 0x0014 BURST RAM WRITE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |               |    |    |                                                                                                                                                                                             |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 15                     | 14            | 13 | 12 | 11                                                                                                                                                                                          | 10 | 9 | 8 | 7                   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | COMMAND[15:0] = 0x0014 |               |    |    |                                                                                                                                                                                             |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NOT USED: 0x00         |               |    |    |                                                                                                                                                                                             |    |   |   | START ADDRESS [9:0] |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NOT USED: 0x00         |               |    |    |                                                                                                                                                                                             |    |   |   | DATA COUNT [9:0]    |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DATA [15:0]            |               |    |    |                                                                                                                                                                                             |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| WORD, BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        | NAME          |    |    | DESCRIPTION                                                                                                                                                                                 |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 1,<br>Bits [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        | START ADDRESS |    |    | Defines the 10-bit address from where to start writing in the RAM with the following constraint:<br>$0 \leq \text{START ADDRESS} \leq 1023$                                                 |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 2,<br>Bits [9:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        | DATA COUNT    |    |    | Defines the number of data words to be written on the RAM with the following constraint:<br>DATA COUNT has a maximum value of 1023.<br>$\text{DATA COUNT} \leq 1023 - \text{START ADDRESS}$ |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Word 3,<br>Bits [15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                        | DATA          |    |    | Defines data to be written in the RAM using the same format as the <a href="#">REFERENCE[11:0]</a> bits.                                                                                    |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| <p>The BURST RAM WRITE command is used to write multiple words to the RAM when using RAM Playback mode (<a href="#">PLAY MODE[1:0]</a> set to 0x2). The data format uses the same format as the <a href="#">REFERENCE[11:0]</a> bits.</p> <p>The communication sequence to write to RAM using the BURST RAM WRITE WFS command includes the following:</p> <ol style="list-style-type: none"> <li>1. Write 0x0014 to the <a href="#">REFERENCE</a> register to use the BURST RAM WRITE command.</li> <li>2. Write the RAM <a href="#">START ADDRESS</a> word to the <a href="#">REFERENCE</a> register.</li> <li>3. Write the <a href="#">DATA COUNT</a> word to the <a href="#">REFERENCE</a> register.</li> <li>4. Write the number of <a href="#">REFERENCE[15:0]</a> words equal to <a href="#">DATA COUNT</a>. RAM write address is incremented automatically between words.</li> </ol> <p>Note that the communication sequence assumes that <a href="#">PLAY MODE[1:0]</a> bits are set to 0x2.</p> |                        |               |    |    |                                                                                                                                                                                             |    |   |   |                     |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

### 6.9.6 0x0015 FULL RAM READ

Table 28: FULL RAM READ command details

| COMMAND: 0x0015 FULL RAM READ                                                                                                                                                                                                                                                                                                                 |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Word                                                                                                                                                                                                                                                                                                                                          | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0                                                                                                                                                                                                                                                                                                                                             | COMMAND[15:0] = 0x0015 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| In RAM Synthesis or RAM Playback mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x2 or 0x3), the FULL RAM READ command is used to read the full RAM content on the communication interface. The device will stay in this mode until all the 1024 RAM addresses have been read or until the <a href="#">FULL RAM READ BREAK</a> command is used. |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The communication sequence to use the FULL RAM READ command includes the following:

1. Set bits [RDADDR\[4:0\]](#) to 0x1B to select [RAM DATA](#) reading.
2. Write 0x0015 to [REFERENCE](#) register to use the FULL RAM READ command.
3. Write 0x0000 (or any value except 0xFF15) to [REFERENCE](#) register.
4. Read 2 bytes
5. Repeat step 3) and 4) until the last RAM address or until using the [FULL RAM READ BREAK](#) command. The RAM address is automatically incremented.

Note that the communication sequence requires that [PLAY\\_MODE\[1:0\]](#) bits are set to 0x2 or 0x3.

### 6.9.7 0xFF15 FULL RAM READ BREAK

Table 29: FULL RAM READ BREAK command

| COMMAND: 0xFF15 FULL RAM READ BREAK                                                                                                         |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Word                                                                                                                                        | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0                                                                                                                                           | COMMAND[15:0] = 0xFF15 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| The FULL RAM READ BREAK command 0xFF15 is used to stop the RAM content reading loop started with the <a href="#">FULL RAM READ</a> command. |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## 6.10 Register Map

Table 30: Main register map

| ADDR. | NAME                                      | DEFAULT VALUE         | TYPE <sup>4</sup> | 15                    | 14                  | 13                   | 12                   | 11          | 10            | 9              | 8        | 7                 | 6            | 5               | 4 | 3        | 2 | 1                       | 0             |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
|-------|-------------------------------------------|-----------------------|-------------------|-----------------------|---------------------|----------------------|----------------------|-------------|---------------|----------------|----------|-------------------|--------------|-----------------|---|----------|---|-------------------------|---------------|-------------------------|---------------|---------|----------|----------|----------|---------|---------|--------|--|--|--|--|--|
| 0x00  | <a href="#">REFERENCE</a>                 | 0x0000                | RW                | DATA[15:0]            |                     |                      |                      |             |               |                |          |                   |              |                 |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x01  | <a href="#">ION_BL</a>                    | 0x03A0                | RW                | RSVD                  |                     |                      |                      | FSWMAX[1:0] |               | SB[1:0]        |          | I_ON_SCALE[7:0]   |              |                 |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x02  | <a href="#">DEADTIME</a>                  | 0x046A                | RW                | RSVD                  |                     |                      |                      | DHS[6:0]    |               |                |          |                   |              |                 |   |          |   | DLS[4:0]                |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x03  | <a href="#">KP</a>                        | 0x0080                | RW                | RSVD                  |                     |                      | XTRIGF               |             | XTRIGR        |                | KP[10:0] |                   |              |                 |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x04  | <a href="#">KPA_KI</a>                    | 0x02A0                | RW                | RSVD                  |                     |                      |                      | KIBASE[3:0] |               |                |          | KPA[7:0]          |              |                 |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x05  | <a href="#">CONFIG</a>                    | 0x1000                | RW                | ONCOMP <sup>(1)</sup> | AUTO <sup>(1)</sup> | SENSE <sup>(1)</sup> | GAINS <sup>(1)</sup> | GAIND       |               | PLAY_MODE[1:0] |          | RET               |              | SYNC            |   | RST      |   | POL_SENS <sup>(1)</sup> | OE            | DS                      | PLAY_SRATE    |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x06  | <a href="#">PARCAP</a>                    | 0x003A                | RW                | RSVD                  |                     |                      |                      | CCM         |               | UPI            |          | RSVD              |              | PARCAP          |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x07  | <a href="#">SUP_RISE</a>                  | 0x4967                | RW                | I2C_ADDR[3:0]         |                     |                      |                      | LP          |               | VDD[4:0]       |          |                   |              | TI_RISE[5:0]    |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x08  | <a href="#">INT_ENABLE</a>                | 0x0000                | RW                | RSVD                  |                     |                      |                      |             |               |                |          |                   |              | IE_FHE          |   | IE_STCHG |   | IE_MXERR                |               | IE_SENSF <sup>(1)</sup> | IE_PLAY       | IE_MAXP | IE_ERR   |          |          |         |         |        |  |  |  |  |  |
| 0x09  | <a href="#">SENSING<sup>(1)</sup></a>     | 0x0000                | RW                | SIGN                  |                     | REP[2:0]             |                      |             | STHRESH[11:0] |                |          |                   |              |                 |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x0A  | <a href="#">TRIM</a>                      | 0x0000                | RW                | TRIMRW[1:0]           |                     |                      | RSVD                 |             |               |                | TRIM_OSC |                   |              |                 |   |          |   |                         |               |                         | TRIM_REG[2:0] |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x0B  | <a href="#">COMM</a>                      | 0x001E                | RW                | RSVD                  |                     |                      | RDAI                 |             | STR           |                | OD       |                   | GPIOSEL[2:0] |                 |   | GPIODIR  |   | TOUT                    |               | RDADDR[4:0]             |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x10  | <a href="#">IC_STATUS</a>                 | 0x0001                | RO                | RSVD                  |                     |                      |                      |             |               |                |          |                   |              | STATE[1:0]      |   | OVV      |   | OVT                     |               | MXPWR                   |               | IDAC    | UVLO     | SC       | FULL     | PLAYST  |         |        |  |  |  |  |  |
| 0x11  | <a href="#">FIFO_STATE</a>                | 0x4400                | RO                | RSVD                  |                     |                      |                      | ERROR       |               | FULL           |          | EMPTY             |              | FIFO_SPACE[9:0] |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x18  | <a href="#">SENSE_VALUE<sup>(1)</sup></a> | 0x06CF                | RO                | POL_SENS              |                     | SENSE                |                      | GAIN        |               | SENS_FLAG      |          | SENSE_VALUE[11:0] |              |                 |   |          |   |                         |               |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x1B  | <a href="#">RAM_DATA</a>                  | 0x0000                | RO                | RSVD                  |                     |                      |                      |             |               |                |          |                   |              | RAM_DATA[15:0]  |   |          |   |                         | CHIP_ID[11:0] |                         |               |         |          |          |          |         |         |        |  |  |  |  |  |
| 0x1E  | <a href="#">CHIP_ID</a>                   | 0x3781 <sup>(1)</sup> | RO                | CHIP_REV[3:0]         |                     |                      |                      | RSVD        |               |                |          |                   |              |                 |   |          |   | IS_FHE                  |               |                         |               |         | IS_STCHG | IS_MXERR | IS_SENSF | IS_PLAY | IS_MAXP | IS_ERR |  |  |  |  |  |
| 0x1F  | <a href="#">INT_STATUS</a>                | 0x0000                | RO                | RSVD                  |                     |                      |                      |             |               |                |          |                   |              | IS_FHE          |   | IS_STCHG |   | IS_MXERR                |               | IS_SENSF                |               | IS_PLAY |          | IS_MAXP  |          | IS_ERR  |         |        |  |  |  |  |  |

(1) BOS1921 only.

<sup>4</sup> RO are read-only registers.

RW are read/write registers.

### 6.10.1 0x00 REFERENCE

Table 31: REFERENCE register details

| ADDRESS: 0x00 REFERENCE DEFAULT: 0x0000 |           |    |    |                 |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |  |  |
|-----------------------------------------|-----------|----|----|-----------------|----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|
| 15                                      | 14        | 13 | 12 | 11              | 10 | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| RSVD                                    |           |    |    | REFERENCE[11:0] |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |  |  |
| REFERENCE[15:0]                         |           |    |    |                 |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |   |   |   |   |   |   |  |  |
| BITS                                    | NAME      |    |    | DEFAULT         |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |  |  |
| 11:0                                    | REFERENCE |    |    | 0x000           |    | RW   | <p>In Direct or FIFO mode (<a href="#">PLAY MODE[1:0]</a> set to 0x0 or 0x1), defines the desired amplitude of the output in 12-bit two's complement format. The device will work with a lower-resolution waveform: shift data left to align MSBs. The amplitude in volts is determined by:</p> $Amplitude[V_{pk}] = \frac{REFERENCE}{2^{11} - 1} \times V_{ref} \times FB_{ratio}$ <p>Where REFERENCE is REFERENCE[11:0] decimal value, <math>V_{ref} = 3.6</math> is the internal ADC input range and <math>FB_{ratio}</math> is the feedback ratio of the device defined by <a href="#">GAIND</a>.</p> <p>REFERENCE[11:0] must be set between 0x931 and 0x6CF to output <math>\pm 95</math> V when <a href="#">GAIND</a> is set to 0x0, and output <math>\pm 13.3</math> V when <a href="#">GAIND</a> is set to 0x1.</p> |   |   |   |   |   |   |   |   |  |  |
| 15:0                                    | REFERENCE |    |    | 0x0000          |    | RW   | <p>In RAM Playback or RAM Synthesis mode (<a href="#">PLAY MODE[1:0]</a> set to 0x2 or 0x3), defines the Waveform Synthesizer (WFS) commands, see section 6.9 for more detail.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |  |  |

### 6.10.2 0x01 ION\_BL

Table 32: ION\_BL register details

| ADDRESS: 0x01 ION_BL DEFAULT: 0x03A0 |        |    |    |             |    |         |                                                                                                                                                                     |                 |   |   |   |   |   |   |   |
|--------------------------------------|--------|----|----|-------------|----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---|---|---|---|---|---|---|
| 15                                   | 14     | 13 | 12 | 11          | 10 | 9       | 8                                                                                                                                                                   | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RSVD                                 |        |    |    | FSWMAX[1:0] |    | SB[1:0] |                                                                                                                                                                     | I_ON_SCALE[7:0] |   |   |   |   |   |   |   |
| BITS                                 | NAME   |    |    | DEFAULT     |    | TYPE    | DESCRIPTION                                                                                                                                                         |                 |   |   |   |   |   |   |   |
| 11:10                                | FSWMAX |    |    | 0x0         |    | RW      | <p>Sets boost converter maximum switching frequency.</p> <p>0x0: 1 MHz<br/>0x1: 833 kHz<br/>0x2: 666 kHz<br/>0x3: 500 kHz</p> <p>A value of 0x1 is recommended.</p> |                 |   |   |   |   |   |   |   |
| 9:8                                  | SB     |    |    | 0x3         |    | RW      | <p>Sets boost converter blanking time.</p> <p>0x0: 35 ns<br/>0x1: 44 ns<br/>0x2: 53 ns<br/>0x3: 62 ns</p> <p>Default value should work for most applications.</p>   |                 |   |   |   |   |   |   |   |

| ADDRESS: 0x01 |            |    |    | ION_BL      |    | DEFAULT: 0x03A0 |                                                                                                                                                                                                                                                                                                                                                                   |                 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|---------------|------------|----|----|-------------|----|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
| 15            | 14         | 13 | 12 | 11          | 10 | 9               | 8                                                                                                                                                                                                                                                                                                                                                                 | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| RSVD          |            |    |    | FSWMAX[1:0] |    | SB[1:0]         |                                                                                                                                                                                                                                                                                                                                                                   | I_ON_SCALE[7:0] |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| BITS          | NAME       |    |    | DEFAULT     |    | TYPE            | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                       |                 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| 7:0           | I_ON_SCALE |    |    | 0xA0        |    | RW              | Sets the minimum current required to turn on High-Side (HS) switch. I_ON_SCALE[7:0] is determined by:<br><br>$I_{ON\_SCALE}[7:0] = \text{round} \left( \frac{\text{Latency}}{L_1 \times 2^{-12}} \times R_{sense} \times FB_{ratio} \right)$ Where Latency = 50 ns and FB <sub>ratio</sub> is the feedback ratio of the device defined by <a href="#">GAIND</a> . |                 |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

### 6.10.3 0x02 DEADTIME

Table 33: DEADTIME register details

| ADDRESS: 0x02 |      |    |    | DEADTIME |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DEFAULT: 0x046A |   |          |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
|---------------|------|----|----|----------|----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---|----------|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|
| 15            | 14   | 13 | 12 | 11       | 10 | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7               | 6 | 5        | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |
| RSVD          |      |    |    | DHS[6:0] |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |   | DLS[4:0] |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| BITS          | NAME |    |    | DEFAULT  |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |   |          |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| 11:5          | DHS  |    |    | 0x23     |    | RW   | Sets the delay between the Low-Side (LS) switch turns off and the High-Side (HS) switch turns on (t <sub>dead-HS</sub> ), as per:<br><br>$t_{dead-HS} = DHS[6:0] \times 1.1 \text{ ns}$ DHS[6:0] can be adjusted using the following relation:<br><br>$DHS[6:0] = \frac{2\pi\sqrt{L_1 \times C_{SW}}}{4 \times 1.1 \times 10^{-9}}$ Where C <sub>SW</sub> is the parasitic capacitance measured on the node connecting SW pin to L <sub>1</sub> . C <sub>SW</sub> is influenced by the parasitic capacitance and & PCB metal trace connected on SW pin.<br>DHS[6:0] can be adjusted for optimization. |                 |   |          |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |
| 4:0           | DLS  |    |    | 0x0A     |    | RW   | Sets the delay between the High-Side (HS) switch turn off and the Low-Side (LS) switch turn on (t <sub>dead-LS</sub> ), as per:<br><br>$t_{dead-LS} = DLS[4:0] \times 4.4 \text{ ns}$ Default value provides a delay of 44 ns minimum and should work for most applications but DLS[4:0] can be adjusted for optimization.                                                                                                                                                                                                                                                                            |                 |   |          |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |

### 6.10.4 0x03 KP

Table 34: KP register details

| ADDRESS: 0x03 |        | KP     |        | DEFAULT: 0x0080 |    |      |                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|---------------|--------|--------|--------|-----------------|----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
| 15            | 14     | 13     | 12     | 11              | 10 | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |
| RSVD          |        | XTRIGF | XTRIGR | KP[10:0]        |    |      |                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| BITS          | NAME   |        |        | DEFAULT         |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| 12            | XTRIGF |        |        | 0x0             |    | RW   | Activates waveform triggering of WAVE block number 0x1 (see Table 17) on GPIO falling edge using RAM Synthesis ( <a href="#">PLAY MODE[1:0]</a> bits set to 0x3).<br><a href="#">GPIODIR</a> must be set to 0x1 to set the GPIO as an input and use the GPIO external trigger functionality.<br>0x1: Falling edge external trigger activated on GPIO<br>0x0: Falling edge external trigger disabled. |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| 11            | XTRIGR |        |        | 0x0             |    | RW   | Activates waveform triggering of WAVE block number 0x0 (see Table 17) with GPIO rising edge using RAM Synthesis ( <a href="#">PLAY MODE[1:0]</a> bits set to 0x3).<br><a href="#">GPIODIR</a> must be set to 0x1 to set the GPIO as an input and use the GPIO external trigger functionality.<br>0x1: Rising edge external trigger activated on GPIO<br>0x0: Rising edge external trigger disabled.  |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| 10:0          | KP     |        |        | 0x080           |    | RW   | Sets the physical value ( $kp_{physical}$ ) of the integrated PI controller proportional gain, which is determined by:<br>$Kp_{physical}[A/V] = \frac{KP \times 2^{-14}}{R_{sense}}$                                                                                                                                                                                                                 |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |

### 6.10.5 0x04 KPA\_KI

Table 35: KPA\_KI register details

| ADDRESS: 0x04 |        | KPA_KI |    | DEFAULT: 0x02A0 |    |      |                                                                                                                                                                                                                                                             |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|--------|--------|----|-----------------|----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 15            | 14     | 13     | 12 | 11              | 10 | 9    | 8                                                                                                                                                                                                                                                           | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RSVD          |        |        |    | KIBASE[3:0]     |    |      |                                                                                                                                                                                                                                                             | KPA[7:0] |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| BITS          | NAME   |        |    | DEFAULT         |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                 |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11:8          | KIBASE |        |    | 0x2             |    | RW   | Determines the pole location ( $f_{pole}$ ) of the integrated PI controller, which is determined by:<br>$f_{pole}[kHz] = \frac{1024}{2^{KIBASE}}$                                                                                                           |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7:0           | KPA    |        |    | 0xA0            |    | RW   | Determines the proportional gain (Kpc) used in the integrated PI controller, which is calculated by:<br>$Kpc = KP + 2 \times KPA \times AMPLITUDE$<br>Where KP is <a href="#">KP[10:0]</a> and AMPLITUDE is <a href="#">REFERENCE[11:0]</a> decimal values. |          |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 6.10.6 0x05 CONFIG

Table 36: CONFIG register details

| ADDRESS: 0x05 |                          | CONFIG |       | DEFAULT: 0x1000 |                |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
|---------------|--------------------------|--------|-------|-----------------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----------|----|----|-----------------|---|---|--|--|--|--|--|--|--|
| 15            | 14                       | 13     | 12    | 11              | 10             | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 7    | 6   | 5         | 4  | 3  | 2               | 1 | 0 |  |  |  |  |  |  |  |
| ONCOMP        | AUTO                     | SENSE  | GAINS | GAIND           | PLAY_MODE[1:0] |      | RET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SYNC | RST | POL_SENSE | OE | DS | PLAY_SRATE[2:0] |   |   |  |  |  |  |  |  |  |
| BITS          | NAME                     |        |       | DEFAULT         |                | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
| 15            | ONCOMP<br>(BOS1921 only) |        |       | 0x0             |                | RW   | Activates the sensing comparator to detect a piezo signal meeting the threshold defined by <a href="#">STHRESH[11:0]</a> and automatically set <a href="#">SENS_FLAG</a> to 0x1. <a href="#">SENSE</a> needs to be set to 0x1 to use the sensing comparator.<br>0x1: Active<br>0x0: Inactive<br>ONCOMP needs to be set back to 0x0 to clear <a href="#">SENS_FLAG</a> after a detection. Set ONCOMP back to 0x1 to reactivate an automatic detection.                                                                                                     |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
| 14            | AUTO<br>(BOS1921 only)   |        |       | 0x0             |                | RW   | Enables a programmed waveform to be triggered automatically. This feature needs <a href="#">ONCOMP</a> and <a href="#">SENSE</a> set to 0x1. See section 6.4.3 for more detail on for Automatic Haptic Playback.<br>0x1: Enable<br>0x0: Disable<br>The AUTO bit is cleared automatically after the waveform is played. Set AUTO bit back to 0x1 to enable again the programmed waveform to be triggered automatically.                                                                                                                                    |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
| 13            | SENSE<br>BOS1921 only)   |        |       | 0x0             |                | RW   | Enables piezo sensing by setting OUT+ and OUT- pins to high impedance to read the piezo actuator voltage that can be read with <a href="#">SENSE_VALUE[11:0]</a> .<br>0x1: Enable<br>0x0: Disable<br>Note the following:<br>- <a href="#">PLAYST</a> bit must be 0x1 before setting SENSE bit to 0x1.<br>- <a href="#">ONCOMP</a> , <a href="#">SIGN</a> & <a href="#">AUTO</a> bits and <a href="#">SENSING</a> register have no effect if SENSE bit is set to 0x0.<br>- If <a href="#">AUTO</a> is set to 0x1, a successful detection clears SENSE bit. |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
| 12            | GAINS<br>(BOS1921 Only)  |        |       | 0x1             |                | RW   | Sets the sensing resolution by fixing the gain of the feedback loop ( $FB_{ratio}$ ).<br>0x0: <a href="#">SENSE_VALUE[11:0]</a> LSB is set to 54.5 mV & $FB_{ratio}$ is set to 31<br>0x1: <a href="#">SENSE_VALUE[11:0]</a> LSB is set to 7.6 mV & $FB_{ratio}$ is set to 4.33                                                                                                                                                                                                                                                                            |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
| 11            | GAIND                    |        |       | 0x0             |                | RW   | Sets the output voltage ( $V_{OUT}$ ) range by fixing the gain of the feedback loop ( $FB_{ratio}$ ).<br>0x0: $V_{OUT}$ range set to $\pm 95$ V & $FB_{ratio}$ set to 31<br>0x1: $V_{OUT}$ range set to $\pm 13.28$ V & $FB_{ratio}$ set to 4.33                                                                                                                                                                                                                                                                                                          |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |
| 10:9          | PLAY_MODE                |        |       | 0x0             |                | RW   | Sets haptic waveform playback mode.<br>0x0: Direct mode (see section 6.5)<br>0x1: FIFO mode (see section 6.6)<br>0x2: RAM Playback mode (see section 6.7)<br>0x3: RAM Synthesis mode (see section 6.8)                                                                                                                                                                                                                                                                                                                                                    |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |  |

| ADDRESS: 0x05 |                             | CONFIG |       | DEFAULT: 0x1000 |                |      |                                                                                                                                                                                                                                                                                                                       |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
|---------------|-----------------------------|--------|-------|-----------------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----------|----|----|-----------------|---|---|--|--|--|--|--|--|
| 15            | 14                          | 13     | 12    | 11              | 10             | 9    | 8                                                                                                                                                                                                                                                                                                                     | 7    | 6   | 5         | 4  | 3  | 2               | 1 | 0 |  |  |  |  |  |  |
| ONCOMP        | AUTO                        | SENSE  | GAINS | GAIND           | PLAY_MODE[1:0] |      | RET                                                                                                                                                                                                                                                                                                                   | SYNC | RST | POL_SENSE | OE | DS | PLAY_SRATE[2:0] |   |   |  |  |  |  |  |  |
| BITS          | NAME                        |        |       | DEFAULT         |                | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                           |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 8             | RET                         |        |       | 0x0             |                | RW   | Enables state and data retention of registers and RAM when using SLEEP mode ( <a href="#">DS</a> set to 0x1).<br>0x0: Registers and RAM data retention is enabled<br>0x1: Registers and RAM data retention is disabled                                                                                                |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 7             | SYNC                        |        |       | 0x0             |                | RW   | Activates multi-chip synchronization.<br>0x1: Enable<br>0x0: Disable                                                                                                                                                                                                                                                  |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 6             | RST                         |        |       | 0x0             |                | RW   | Initiates a software reset. The device resets internal registers to default values and goes to IDLE mode. RST bit self-clears once the reset is completed.<br>Make sure <a href="#">REFERENCE[11:0]</a> is 0x0 when setting RST to 0x1 in Direct or FIFO mode.<br>0x1: Device software reset<br>0x0: Normal operation |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 5             | POL_SENSE<br>(BOS1921 Only) |        |       | 0x0             |                | RW   | Defines the polarity of the OUT+/OUT- pins when the device is sensing ( <a href="#">SENSE</a> bit is set to 0x1).<br>0x1: OUT+ pin is connected to VDD<br>0x0: OUT- pin is connected to VDD                                                                                                                           |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 4             | OE                          |        |       | 0x0             |                | RW   | Enables haptic waveform playback or piezo actuator sensing (BOS1921 only).<br>0x1: Enable<br>0x0: Disable<br>OE bit will clear automatically at the end of a waveform if <a href="#">PLAY_MODE[1:0]</a> is set to 0x2 or 0x3.                                                                                         |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 3             | DS                          |        |       | 0x0             |                | RW   | Sets the power mode when the device is not playing waveform (e.g., bit <a href="#">OE</a> is set to 0x0).<br>0x0: IDLE<br>0x1: SLEEP                                                                                                                                                                                  |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |
| 2:0           | PLAY_SRATE                  |        |       | 0x0             |                | RW   | Defines the sample rate used to create the haptic waveform in Direct, FIFO or RAM Playback mode ( <a href="#">PLAY_MODE[1:0]</a> bits set to 0x0, 0x1 or 0x2), as follows:<br>0x0: 1024 ksps<br>0x1: 512 ksps<br>0x2: 256 ksps<br>0x3: 128 ksps<br>0x4: 64 ksps<br>0x5: 32 ksps<br>0x6: 16 ksps<br>0x7: 8 ksps        |      |     |           |    |    |                 |   |   |  |  |  |  |  |  |

## 6.10.7 0x06 PARCAP

Table 37: PARCAP register details

| ADDRESS: 0x06 PARCAP DEFAULT: 0x003A |        |    |    |         |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |   |   |   |   |   |   |   |  |  |
|--------------------------------------|--------|----|----|---------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|---|---|---|---|---|---|--|--|
| 15                                   | 14     | 13 | 12 | 11      | 10  | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| RSVD                                 |        |    |    |         | CCM | UPI  | RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | PARCAP[7:0] |   |   |   |   |   |   |   |  |  |
| BITS                                 | NAME   |    |    | DEFAULT |     | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             |   |   |   |   |   |   |   |  |  |
| 10                                   | CCM    |    |    | 0x0     |     | RW   | <p>Enables the BOS1921/BOS1931 to automatically choose whether to operate the buck-boost converter in continuous conduction mode (CCM) or discontinuous conduction mode (DCM). Otherwise, the device operates only in DCM mode.</p> <p>0x0: DCM mode only<br/>0x1: BOS1921/BOS1931 chooses between DCM or CCM mode</p> <p>It is recommended to set CCM bit to 0x1 only when the inductor in the design has a value of 10 <math>\mu</math>H.</p> <p>Using CCM mode allow for greater device output drive capacity at the expense of more noise.</p> |             |   |   |   |   |   |   |   |  |  |
| 9                                    | UPI    |    |    | 0x0     |     | RW   | <p>Enables the Unidirectional Power Input.</p> <p>0x0: Disable<br/>0x1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |   |   |   |   |   |   |   |  |  |
| 7:0                                  | PARCAP |    |    | 0x3A    |     | RW   | <p>Internal parameter determined by:</p> $PARCAP[7:0] = \sqrt{\frac{C_{SW}}{L_1}} \times R_{sense} \times FB_{ratio}$ <p>Where <math>C_{SW}</math> is the parasitic capacitance measured on the node connecting SW pin to <math>L_1</math>. <math>C_{SW}</math> is influenced by the parasitic capacitance and &amp; PCB metal trace connected on SW pin and PCB layout and <math>FB_{ratio}</math> is the feedback ratio of the device defined by <a href="#">GAIND</a>.</p>                                                                      |             |   |   |   |   |   |   |   |  |  |

### 6.10.8 0x07 SUP\_RISE

Table 38: SUP\_RISE register details

| ADDRESS: 0x07 |          | SUP_RISE |    | DEFAULT: 0x4967 |          |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |              |   |   |   |   |   |  |  |  |  |
|---------------|----------|----------|----|-----------------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|--------------|---|---|---|---|---|--|--|--|--|
| 15            | 14       | 13       | 12 | 11              | 10       | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7 | 6 | 5            | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| I2C_ADDR[3:0] |          |          |    | LP              | VDD[4:0] |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   | TI_RISE[5:0] |   |   |   |   |   |  |  |  |  |
| BITS          | NAME     |          |    | DEFAULT         |          | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |   |              |   |   |   |   |   |  |  |  |  |
| 15:12         | I2C_ADDR |          |    | 0x4             |          | RW   | <p>Sets the 4 LSBs of the 7-bit legacy I<sup>2</sup>C static address, i.e., I<sup>2</sup>C address = (0x4, I2C_ADDR[3:0]).</p> <p>Also sets the I3C 4-bit Instance ID (i.e., bits [15:12] of the Provisional ID, see Table 13).</p> <p>The value of I2C_ADDR[3:0] can be changed only if <a href="#">GPIODIR</a> is set to 0x1 and GPIO pin is at a logic-level low.</p> <p>The I2C_ADDR[3:0] value is not reset by a software reset (<a href="#">RST</a> set to 0x1) and is preserved when the device goes to SLEEP mode, regardless of the state of the <a href="#">RET</a> bit.</p> <p>A value of 0x0 is returned on a read, regardless of the I2C_ADDR[3:0] value.</p> |   |   |              |   |   |   |   |   |  |  |  |  |
| 11            | LP       |          |    | 0x1             |          | RW   | <p>Enables lower power when chip is in IDLE mode. Default value should work for most applications.</p> <p>0x1: Enable low power<br/>0x0: Disable low power</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |              |   |   |   |   |   |  |  |  |  |
| 10:6          | VDD      |          |    | 0x05            |          | RW   | <p>Represents the supply voltage seen at RP/VDD pin and is defined by:</p> $VDD[4:0] = \frac{\left(\frac{V_{DD}[V]}{0.026}\right) - 128}{2}$ <p>For VDD[4:0] &gt; 31, use 0x1F.<br/>For VDD[4:0] &lt; 0, use 0x00.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |              |   |   |   |   |   |  |  |  |  |
| 5:0           | TI_RISE  |          |    | 0x27            |          | RW   | <p>Sets the proportional gain for the offset determined by:</p> $TI_{RISE}[5:0] = \frac{T_{CLK} \times 31.25}{L_1} \times \frac{FB_{ratio}}{R_{sense}}$ <p>Where TCLK = 70 ns and FB<sub>ratio</sub> is the feedback ratio of the device defined by <a href="#">GAIND</a>.</p>                                                                                                                                                                                                                                                                                                                                                                                             |   |   |              |   |   |   |   |   |  |  |  |  |

### 6.10.9 0x08 INT\_ENABLE

Table 39: INT\_ENABLE register details

| ADDRESS: 0x08 |          | INT_ENABLE |         | DEFAULT: 0x0000 |      |                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
|---------------|----------|------------|---------|-----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--------|----------|----------|----------|---------|---------|--------|
| 15            | 14       | 13         | 12      | 11              | 10   | 9                                                                                                                                                                                                                                                                                                              | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |          |          |          |         |         |        |
| RSVD          |          |            |         |                 |      |                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   | IE_FHE | IE_STCHG | IE_MXERR | IE_SENSF | IE_PLAY | IE_MAXP | IE_ERR |
| BITS          | NAME     |            | DEFAULT |                 | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                    |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 6             | IE_FHE   |            | 0x0     |                 | RW   | Enables the FIFO Half Empty Interrupt.<br>In FIFO mode ( <a href="#">PLAY MODE[1:0]</a> set to 0x1), the interrupt triggers when the FIFO is at least half empty.<br>1: interrupt is enabled<br>0: interrupt is disabled                                                                                       |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 5             | IE_STCHG |            | 0x0     |                 | RW   | Enables Device State Change Interrupt.<br>The interrupt triggers when the device state indicated by <a href="#">STATE[1:0]</a> changes.<br>1: interrupt is enabled<br>0: interrupt is disabled                                                                                                                 |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 4             | IE_MXERR |            | 0x0     |                 | RW   | Enables Max Error Interrupt.<br>The interrupt triggers when there is a difference between the waveform played on the output and the setpoint, which typically occurs when the output haptic waveform is too abrupt, or the capacitive load is too high.<br>1: interrupt is enabled<br>0: interrupt is disabled |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 3             | IE_SENSF |            | 0x0     |                 | RW   | Enables Sense Voltage Event Interrupt.<br>The interrupt triggers when a Sense Voltage Event is detected (see section 6.4).<br>1: interrupt is enabled<br>0: interrupt is disabled                                                                                                                              |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 2             | IE_PLAY  |            | 0x0     |                 | RW   | Enables Waveform Playback Status Interrupt.<br>The interrupt triggers when <a href="#">PLAYST</a> is set to 0x1.<br>1: interrupt is enabled<br>0: interrupt is disabled                                                                                                                                        |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 1             | IE_MAXP  |            | 0x0     |                 | RW   | Enables Max Power Interrupt.<br>The interrupt triggers when maximum amount of power is used and <a href="#">MXPWR</a> is set to 0x1.<br>1: interrupt is enabled<br>0: interrupt is disabled                                                                                                                    |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |
| 0             | IE_ERR   |            | 0x0     |                 | RW   | Enables Error State Interrupt.<br>The interrupt triggers when the device is in error state and <a href="#">STATE[1:0]</a> is set to 0x3.<br>1: interrupt is enabled<br>0: interrupt is disabled                                                                                                                |   |   |   |   |   |   |   |   |        |          |          |          |         |         |        |

### 6.10.10 0x09 SENSING (BOS1921 Only)

Table 40: SENSING register details

| ADDRESS: 0x09 |          | SENSING |               | DEFAULT: 0x0000 |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
|---------------|----------|---------|---------------|-----------------|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|
| 15            | 14       | 13      | 12            | 11              | 10 | 9    | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |
| SIGN          | REP[2:0] |         | STHRESH[11:0] |                 |    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| BITS          | NAME     |         |               | DEFAULT         |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| 15            | SIGN     |         |               | 0x0             |    | RW   | Defines if voltage feedback value should be above or below the threshold (STHRESH[11:0]) to generate a sense voltage event (ONCOMP must be set to 0x1).<br>0x1: Below<br>0x0: Above                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| 14:12         | REP      |         |               | 0x0             |    | RW   | Amount of time the sense voltage needs to be above or below STHRESH[11:0] to generate a sense voltage event (ONCOMP must be set to 0x1).<br>0x0: 8 μs<br>0x1: 16 μs<br>0x2: 256 μs<br>0x3: 512 μs<br>0x4: 1024 μs<br>0x5: 2048 μs<br>0x6: 4088 μs<br>0x7: 8168 μs                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |
| 11:0          | STHRESH  |         |               | 0x000           |    | RW   | Sets the differential voltage required at OUT+/OUT- pins to generate a sense voltage event (ONCOMP must be set to 0x1).<br>The amplitude (V) in volts is determined by:<br>$V = \frac{STHRESH[11:0]}{2^{11} - 1} \times V_{ref} \times FB_{ratio}$ Where $V_{ref} = 3.6$ V is the internal ADC input range, $FB_{ratio}$ is the feedback ratio of the device defined by GAINS and STHRESH[11:0] is a 12-bit signed number.<br>With GAINS set to 0x1, the following limits apply: <ul style="list-style-type: none"><li>Maximum allowable STHRESH[11:0] value is 0x6CF, corresponding to 13.28 V</li><li>Minimum allowable STHRESH[11:0] value is 0xFD0, corresponding to -350 mV</li></ul> |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |

### 6.10.11 0x0A TRIM

Table 41: TRIM register details

| ADDRESS: 0x0A TRIM DEFAULT: 0x0000 |          |    |    |         |    |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |
|------------------------------------|----------|----|----|---------|----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|
| 15                                 | 14       | 13 | 12 | 11      | 10 | 9             | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |
| TRIMRW[1:0]                        | RSVD     |    |    |         |    | TRIM_OSC[6:0] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |
| BITS                               | NAME     |    |    | DEFAULT |    | TYPE          | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |   |   |   |   |   |   |   |  |  |  |  |  |
| 15:14                              | TRIMRW   |    |    | 0x0     |    | RW            | <p>Trim control bits for adjusting the internal clock oscillator frequency (<a href="#">TRIM_OSC[6:0]</a>) and 1.8 V internal regulator voltage (<a href="#">TRIM_REG[2:0]</a>), see Figure 34. Hardware fuses values vary from chip-to-chip. More detail is available in the section 6.2.14.</p> <p><a href="#">TRIMRW[1:0]</a> bits are automatically reset to 0x0 after each operation.</p> <p>0x0: Default behaviour where Hardware fuses are latched to the Trim Block at power-up</p> <p>0x1: Resets the Trim Block with the Hardware Fuses and then transfers Trim Block data to <a href="#">TRIM_OSC[6:0]</a> &amp; <a href="#">TRIM_REG[2:0]</a> for reading (wait for 1 ms before reading)</p> <p>0x2: Transfers Trim Block data to <a href="#">TRIM_OSC[6:0]</a> &amp; <a href="#">TRIM_REG[2:0]</a> for reading (wait for 1 ms before reading)</p> <p>0x3: Writes <a href="#">TRIM_OSC[6:0]</a> &amp; <a href="#">TRIM_REG[2:0]</a> to Trim Block and transfers back Trim Block data to <a href="#">TRIM_OSC[6:0]</a> &amp; <a href="#">TRIM_REG[2:0]</a> for reading (wait for 1 ms before reading)</p> |   |   |   |   |   |   |   |   |  |  |  |  |  |
| 9:3                                | TRIM_OSC |    |    | 0x00    |    | RW            | <p>Oscillator trimming bits in two's complement. The step size is approximately 150 kHz.</p> <p>Maximum frequency at 0x1F.</p> <p>Minimum frequency at 0x20.</p> <p>Excessive change in oscillator frequency may induce circuit malfunction. This is an advanced feature.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   |   |   |   |   |   |  |  |  |  |  |
| 2:0                                | TRIM_REG |    |    | 0x0     |    | RW            | <p>The internal 1.8 V regulator (REG pin) trimming bits in two's complement. The step size is approximately 22 mV.</p> <p>Maximum voltage at 0x3</p> <p>Minimum voltage at 0x4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |   |   |   |   |   |   |   |  |  |  |  |  |



Figure 34: Trim control block diagram

### 6.10.12 0x0B COMM

Table 42: COMM register details (BOS1921)

| ADDRESS: 0x0B |      | COMM |         | DEFAULT: 0x001E |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |   |         |      |             |   |   |   |   |  |  |  |  |  |  |  |  |  |
|---------------|------|------|---------|-----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---------|------|-------------|---|---|---|---|--|--|--|--|--|--|--|--|--|
| 15            | 14   | 13   | 12      | 11              | 10   | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 8 | 7 | 6       | 5    | 4           | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |
| RSVD          |      | RDAI |         | STR             | OD   | GPIOSEL[2:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   | GPIODIR | TOUT | RDADDR[4:0] |   |   |   |   |  |  |  |  |  |  |  |  |  |
| BITS          | NAME |      | DEFAULT |                 | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |         |      |             |   |   |   |   |  |  |  |  |  |  |  |  |  |
| 12            | RDAI |      | 0x0     |                 | RW   | Activates an auto-increment of <a href="#">RDADDR[4:0]</a> bits after a read operation.<br>0x0: <a href="#">RDADDR[4:0]</a> bits are not modified<br>0x1: <a href="#">RDADDR[4:0]</a> bits increment after a register read<br>If <a href="#">RDADDR[4:0]</a> bits are 0x1F, the incremented value will be 0x00.                                                                                                                                                         |   |   |         |      |             |   |   |   |   |  |  |  |  |  |  |  |  |  |
| 11            | STR  |      | 0x0     |                 | RW   | Enables automatic incrementing of the register address during communication. Allows writing several consecutive registers using only the address of the first register (see Figure 20).<br>0x1: Address auto-increment every two bytes<br>0x0: No address auto-increment<br>Regardless the STR bit value, an address of 0x00 ( <a href="#">REFERENCE</a> register) will not automatically increment to allow more efficient writes to the FIFO or Waveform Synthesizer. |   |   |         |      |             |   |   |   |   |  |  |  |  |  |  |  |  |  |
| 10            | OD   |      | 0x0     |                 | RW   | Sets the GPIO output type.<br>0x0: Open-Drain<br>0x1: Push-Pull                                                                                                                                                                                                                                                                                                                                                                                                         |   |   |         |      |             |   |   |   |   |  |  |  |  |  |  |  |  |  |

| ADDRESS: 0x0B |         |    |      | COMM    |    | DEFAULT: 0x001E |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |         |      |             |   |   |   |   |  |  |
|---------------|---------|----|------|---------|----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|------|-------------|---|---|---|---|--|--|
| 15            | 14      | 13 | 12   | 11      | 10 | 9               | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7 | 6       | 5    | 4           | 3 | 2 | 1 | 0 |  |  |
| RSVD          |         |    | RDAI | STR     | OD | GPIOSEL[2:0]    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   | GPIODIR | TOUT | RDADDR[4:0] |   |   |   |   |  |  |
| BITS          | NAME    |    |      | DEFAULT |    | TYPE            | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |         |      |             |   |   |   |   |  |  |
| 9:7           | GPIOSEL |    |      | 0x0     |    | RW              | Selects the active low signal that is output on the GPIO pin when GPIODIR is set to 0x0.<br>0x0: Device Reset State<br>Indicates if the device is in reset process.<br>0: Device is in reset state<br>1: Device is not in reset state and is ready for operation<br><br>0x1: Waveform Playback Status<br>Indicates the state of <a href="#">PLAYST</a> bit.<br>0: PLAYST bit is 0x1<br>1: PLAYST bit is 0x0<br><br>0x2: Error State<br>Indicates if the device is in error state ( <a href="#">STATE[1:0]</a> set to 0x3):<br>0: Error detected<br>1: No error detected<br><br>0x3: Max Power<br>Indicates if maximum amount of power is used (state of <a href="#">MXPWR</a> ):<br>0: Maximum power, distortion likely<br>1: Amount of power is acceptable<br><br>0x4: FIFO Full<br>In FIFO mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x1), indicates if the FIFO is FULL (state of <a href="#">FULL</a> bit):<br>0: FIFO is full<br>1: FIFO is not full<br><br>0x5: Interrupt<br>Indicates if one of the interrupts of <a href="#">INT_STATUS</a> register is 0x1:<br>0: Interrupt pending<br>1: No Interrupt pending<br><br>0x6: Sense Trigger<br>Indicates if sensed data met the detection trigger conditions (state of <a href="#">SENS_FLAG</a> bit):<br>0: Sense detection condition met<br>1: Sense detection condition not met<br><br>0x7: FIFO Half Empty<br>In FIFO mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x1), indicates if the FIFO is at least half empty:<br>0: At least half of the FIFO locations are available<br>1: Less than half of the FIFO locations are available |   |         |      |             |   |   |   |   |  |  |
| 6             | GPIODIR |    |      | 0x0     |    | RW              | Sets the direction of the GPIO pin.<br>0x0: GPIO is an output<br>0x1: GPIO is an input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |         |      |             |   |   |   |   |  |  |

| ADDRESS: 0x0B |        | COMM |      | DEFAULT: 0x001E |    |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |         |      |             |   |   |   |   |  |
|---------------|--------|------|------|-----------------|----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|------|-------------|---|---|---|---|--|
| 15            | 14     | 13   | 12   | 11              | 10 | 9            | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7 | 6       | 5    | 4           | 3 | 2 | 1 | 0 |  |
| RSVD          |        |      | RDAI | STR             | OD | GPIOSEL[2:0] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   | GPIODIR | TOUT | RDADDR[4:0] |   |   |   |   |  |
| BITS          | NAME   |      |      | DEFAULT         |    | TYPE         | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |         |      |             |   |   |   |   |  |
| 5             | TOUT   |      |      | 0x0             |    | RW           | Enables a timeout mechanism which forces the device into SLEEP if it fails to receive the necessary data samples during waveform playback.<br>The conditions for the timeout are the following: <ul style="list-style-type: none"> <li>Waveform playback mode is either FIFO or Direct mode (<a href="#">PLAY_MODE[1:0]</a> bits set to 0x0 or 0x1).</li> <li>The output is enabled (<a href="#">OE</a> bit set to 0x1).</li> <li>The <a href="#">PLAYST</a> bit has been 0x1 for at least 4 ms.</li> </ul> 0x1: Enable<br>0x0: Disable<br>Note that <a href="#">PLAY_SRATE[2:0]</a> bits are reset to 0x7 when the device enters SLEEP following a timeout event. |   |         |      |             |   |   |   |   |  |
| 4:0           | RDADDR |      |      | 0x1E            |    | RW           | Address of the internal register whose content is returned on the communication bus during a read.<br>Reset value is <a href="#">CHIP_ID</a> register address (0x1E).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |         |      |             |   |   |   |   |  |

### 6.10.13 0x10 IC\_STATUS

Table 43: IC\_STATUS register details

| ADDRESS: 0x10 |       | IC_STATUS |    | DEFAULT: 0x0001 |    |            |                                                                                                                                                                                                                                                                                                                                                                      |     |     |       |      |      |    |      |        |  |
|---------------|-------|-----------|----|-----------------|----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------|------|------|----|------|--------|--|
| 15            | 14    | 13        | 12 | 11              | 10 | 9          | 8                                                                                                                                                                                                                                                                                                                                                                    | 7   | 6   | 5     | 4    | 3    | 2  | 1    | 0      |  |
| RSVD          |       |           |    |                 |    | STATE[1:0] |                                                                                                                                                                                                                                                                                                                                                                      | OVV | OVT | MXPWR | IDAC | UVLO | SC | FULL | PLAYST |  |
| BITS          | NAME  |           |    | DEFAULT         |    | TYPE       | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                          |     |     |       |      |      |    |      |        |  |
| 9:8           | STATE |           |    | 0x0             |    | RO         | Indicates the state of the device. STATE[1:0] = 0x3 indicates that one of the following errors occurred: <a href="#">OVV</a> , <a href="#">OVT</a> , <a href="#">IDAC</a> , <a href="#">UVLO</a> or <a href="#">SC</a> .<br>0x0: IDLE<br>0x1: CALIBRATION<br>0x2: RUN.<br>0x3: ERROR                                                                                 |     |     |       |      |      |    |      |        |  |
| 7             | OVV   |           |    | 0x0             |    | RO         | Ovvoltage fault bit. The voltage level that triggers the fault depends on <a href="#">GAIND</a> value. If <a href="#">GAIND</a> is set to 0x0, the fault is triggered at 100 V and above. If <a href="#">GAIND</a> is set to 0x1, the fault is triggered at 14 V and above.<br>0x1: Output voltage exceeded the maximum voltage allowed<br>0x0: Output voltage is OK |     |     |       |      |      |    |      |        |  |
| 6             | OVT   |           |    | 0x0             |    | RO         | Overtemperature fault bit.<br>0x1: Overtemperature detected on the device<br>0x0: Device temperature is OK                                                                                                                                                                                                                                                           |     |     |       |      |      |    |      |        |  |
| 5             | MXPWR |           |    | 0x0             |    | RO         | Maximum Power warning bit.<br>Indicates that $R_{sense}$ reached the maximum allowed current.<br>0x1: Maximum power, distortion likely<br>0x0: Acceptable amount of power                                                                                                                                                                                            |     |     |       |      |      |    |      |        |  |

| ADDRESS: 0x10 |        |    |    |         |    | IC_STATUS  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DEFAULT: 0x0001 |     |       |      |      |    |      |        |  |  |  |
|---------------|--------|----|----|---------|----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|-------|------|------|----|------|--------|--|--|--|
| 15            | 14     | 13 | 12 | 11      | 10 | 9          | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7               | 6   | 5     | 4    | 3    | 2  | 1    | 0      |  |  |  |
| RSVD          |        |    |    |         |    | STATE[1:0] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | OVV             | OVT | MXPWR | IDAC | UVLO | SC | FULL | PLAYST |  |  |  |
| BITS          | NAME   |    |    | DEFAULT |    | TYPE       | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |     |       |      |      |    |      |        |  |  |  |
| 4             | IDAC   |    |    | 0x0     |    | RO         | IDAC status bit.<br>0x1: Problem with current detection<br>0x0: No problem with current detection<br>A problem with the IDAC most likely indicates that $R_{sense}$ or $L_1$ is disconnected.<br>To recover from an IDAC error, a software reset must be done using <a href="#">CONFIG.RST</a> bit.                                                                                                                                                                                                                                                                                                                                                 |                 |     |       |      |      |    |      |        |  |  |  |
| 3             | UVLO   |    |    | 0x0     |    | RO         | $V_{DD}$ Under-voltage fault bit.<br>0x1: $V_{DD}$ under-voltage detected while trying to output a waveform<br>0x0: $V_{DD}$ voltage is high enough                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 |     |       |      |      |    |      |        |  |  |  |
| 2             | SC     |    |    | 0x0     |    | RO         | Piezo load short circuit fault bit.<br>0x1: Short circuit detected on the piezo load<br>0x0: No short circuit detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |     |       |      |      |    |      |        |  |  |  |
| 1             | FULL   |    |    | 0x0     |    | RO         | Indicates if the FIFO is full when using FIFO mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x1).<br>0x1: FIFO is full<br>0x0: FIFO is not full                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |     |       |      |      |    |      |        |  |  |  |
| 0             | PLAYST |    |    | 0x1     |    | RO         | Waveform playback multi-function status bit. Its function depends on <a href="#">PLAY_MODE[1:0]</a> value.<br>In Direct mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x0), PLAYST bit indicates when new data is needed:<br>0: No sample required<br>1: Next sample required<br>In FIFO mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x1), PLAYST bit indicates when FIFO is empty:<br>0: FIFO is not empty<br>1: FIFO is empty<br>In RAM Synthesis or RAM playback mode ( <a href="#">PLAY_MODE[1:0]</a> set to 0x2 or 0x3), PLAYST bit indicates when the haptic waveform has finished playing:<br>0: Waveform is not done<br>1: Waveform is done |                 |     |       |      |      |    |      |        |  |  |  |

### 6.10.14 0x11 FIFO\_STATE

Table 44: FIFO\_STATE register details

| ADDRESS: 0x11 |            | FIFO_STATE |      | DEFAULT: 0x4400 |                 |      |                                                                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|---------------|------------|------------|------|-----------------|-----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| 15            | 14         | 13         | 12   | 11              | 10              | 9    | 8                                                                                                                                                                                                                                                                                                                                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
| RSVD          |            | ERROR      | FULL | EMPTY           | FIFO_SPACE[9:0] |      |                                                                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| BITS          | NAME       |            |      | DEFAULT         |                 | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 12            | ERROR      |            |      | 0x0             |                 | RO   | Indicates if the device is in error state ( <a href="#">STATE[1:0]</a> set to 0x3), i.e., any of the following faults has occurred: <a href="#">OVV</a> , <a href="#">OVT</a> , <a href="#">IDAC</a> , <a href="#">UVLO</a> or <a href="#">SC</a> .<br><br>0x1: An internal error occurred<br>0x0: No error                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 11            | FULL       |            |      | 0x0             |                 | RO   | Same as <a href="#">FULL</a> bit.                                                                                                                                                                                                                                                                                                                |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 10            | EMPTY      |            |      | 0x1             |                 | RO   | Same as <a href="#">PLAYST</a> bit.                                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 9:0           | FIFO_SPACE |            |      | 0x000           |                 | RO   | Indicates the amount of free space available in FIFO for new data. When FIFO Depth is set to 1024 (using <a href="#">FIFO_DEPTH</a> command), a FIFO_SPACE value of 0x000 indicates that either there are 1024 free spaces available (if <a href="#">EMPTY</a> bit is 0x1) or that there is no free space (if <a href="#">EMPTY</a> bit is 0x0). |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

### 6.10.15 0x18 SENSE\_VALUE (BOS1921 Only)

Table 45: SENSE\_VALUE register details

| ADDRESS: 0x18 |           | SENSE_VALUE |           | DEFAULT: 0x06CF   |    |      |                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|---------------|-----------|-------------|-----------|-------------------|----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| 15            | 14        | 13          | 12        | 11                | 10 | 9    | 8                                                                                                                                                                                                                                                                                   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
| POL_SENSE     | SENSE     | GAIN        | SENS_FLAG | SENSE_VALUE[11:0] |    |      |                                                                                                                                                                                                                                                                                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| BITS          | NAME      |             |           | DEFAULT           |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                         |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 15            | POL_SENSE |             |           | 0x0               |    | RO   | Indicates the polarity of the output when using sensing mode ( <a href="#">SENSE</a> is set to 0x1).<br><br>0x1: OUT+ pin is connected to $V_{DD}$<br>0x0: OUT- pin is connected to $V_{DD}$                                                                                        |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 14            | SENSE     |             |           | 0x0               |    | RO   | Indicates if the device is in sensing mode (SENSE bit is set to 0x1). If the value is not 0x1, then the <a href="#">SENS_FLAG</a> and <a href="#">SENSE_VALUE[11:0]</a> bits should be ignored.<br><br>0x0: The device is not in sensing mode<br>0x1: The device is in sensing mode |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 13            | GAIN      |             |           | 0x0               |    | RO   | Gain of the feedback loop ( $FB_{ratio}$ ) being used by the controller. In normal operation, this value corresponds to <a href="#">GAINS</a> bit when the device is in sensing mode (SENSE bit set to 0x1), otherwise it corresponds to <a href="#">GAIND</a> bit.                 |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 12            | SENS_FLAG |             |           | 0x0               |    | RO   | Flag indicating when the voltage sensed is above or below the threshold in sense mode. To reset the flag, set <a href="#">ONCOMP</a> to 0x0.<br><br>0x1: signal above/below threshold<br>0x0: Nothing detected                                                                      |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| ADDRESS: 0x18 |             |      |           | SENSE_VALUE       |    | DEFAULT: 0x06CF |                                                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   |   |   |  |  |  |  |
|---------------|-------------|------|-----------|-------------------|----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|
| 15            | 14          | 13   | 12        | 11                | 10 | 9               | 8                                                                                                                                                                                                                                                                                                                            | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| POL_SENSE     | SENSE       | GAIN | SENS_FLAG | SENSE_VALUE[11:0] |    |                 |                                                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   |   |   |  |  |  |  |
| BITS          | NAME        |      |           | DEFAULT           |    | TYPE            | DESCRIPTION                                                                                                                                                                                                                                                                                                                  |   |   |   |   |   |   |   |   |  |  |  |  |
| 11:0          | SENSE_VALUE |      |           | 0x6CF             |    | RO              | Signed representation of the sensed signal. The amplitude in volts is defined by:<br>$Amplitude[V] = \frac{SENSE\_VALUE[11:0]}{2^{11} - 1} \times V_{ref} \times FB_{ratio}$ Where $V_{ref} = 3.6$ V is the internal ADC input range and $FB_{ratio}$ is the feedback ratio of the device defined by <a href="#">GAINS</a> . |   |   |   |   |   |   |   |   |  |  |  |  |

### 6.10.16 0x1B RAM\_DATA

Table 46: RAM\_DATA register details

| ADDRESS: 0x1B  |          |    |    | RAM_DATA |    | DEFAULT: 0x0000 |                                                                                                                                                        |   |   |   |   |   |   |   |   |  |  |  |  |
|----------------|----------|----|----|----------|----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|
| 15             | 14       | 13 | 12 | 11       | 10 | 9               | 8                                                                                                                                                      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| RAM_DATA[15:0] |          |    |    |          |    |                 |                                                                                                                                                        |   |   |   |   |   |   |   |   |  |  |  |  |
| BITS           | NAME     |    |    | DEFAULT  |    | TYPE            | DESCRIPTION                                                                                                                                            |   |   |   |   |   |   |   |   |  |  |  |  |
| 15:0           | RAM_DATA |    |    | N/A      |    | RO              | Value of data read from RAM. To be used in conjunction with the <a href="#">FULL RAM READ</a> or <a href="#">RAM ACCESS</a> WFS commands in read mode. |   |   |   |   |   |   |   |   |  |  |  |  |

### 6.10.17 0x1E CHIP\_ID

Table 47: CHIP\_ID register details

| ADDRESS: 0x1E |          |    |    | CHIP_ID |    | DEFAULT: 0x3781 (BOS1921), 0x378B (BOS1931) |                                                                                       |   |   |   |   |   |   |   |   |  |  |  |  |
|---------------|----------|----|----|---------|----|---------------------------------------------|---------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|--|--|--|--|
| 15            | 14       | 13 | 12 | 11      | 10 | 9                                           | 8                                                                                     | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| CHIP_REV[3:0] |          |    |    |         |    | CHIP_ID[11:0]                               |                                                                                       |   |   |   |   |   |   |   |   |  |  |  |  |
| BITS          | NAME     |    |    | DEFAULT |    | TYPE                                        | DESCRIPTION                                                                           |   |   |   |   |   |   |   |   |  |  |  |  |
| 15:12         | CHIP_REV |    |    | 0x3     |    | RO                                          | Indicates the chip revision.<br>0x3: Revision D<br>0x2: Revision C<br>0x1: Revision B |   |   |   |   |   |   |   |   |  |  |  |  |
| 11:0          | CHIP_ID  |    |    | 0x781   |    | RO                                          | Indicates the chip ID.<br>0x781: BOS1921<br>0x78B: BOS1931                            |   |   |   |   |   |   |   |   |  |  |  |  |

## 6.10.18 0x1F INT\_STATUS

Table 48: INT\_STATUS register details

| ADDRESS: 0x1F |          | INT_STATUS |    | DEFAULT: 0x0000 |    |      |                                                                                                                                                                                                                                                                                                                                 |        |          |          |          |         |         |        |   |  |
|---------------|----------|------------|----|-----------------|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------|----------|----------|---------|---------|--------|---|--|
| 15            | 14       | 13         | 12 | 11              | 10 | 9    | 8                                                                                                                                                                                                                                                                                                                               | 7      | 6        | 5        | 4        | 3       | 2       | 1      | 0 |  |
| RSVD          |          |            |    |                 |    |      |                                                                                                                                                                                                                                                                                                                                 | IS_FHE | IS_STCHG | IS_MXERR | IS_SENSF | IS_PLAY | IS_MAXP | IS_ERR |   |  |
| BITS          | NAME     |            |    | DEFAULT         |    | TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                     |        |          |          |          |         |         |        |   |  |
| 6             | IS_FHE   |            |    | 0x0             |    | RO   | FIFO Half Empty Interrupt Status. Cleared on read.<br>In FIFO mode ( <a href="#">PLAY MODE[1:0]</a> set to 0x1), the interrupt triggers when the FIFO is at least half empty.<br>1: interrupt is active<br>0: interrupt is not active                                                                                           |        |          |          |          |         |         |        |   |  |
| 5             | IS_STCHG |            |    | 0x0             |    | RO   | State Change Interrupt Status. Cleared on read.<br>The interrupt triggers when the device state indicated with <a href="#">STATE[1:0]</a> has changed.<br>1: interrupt is active<br>0: interrupt is not active                                                                                                                  |        |          |          |          |         |         |        |   |  |
| 4             | IS_MXERR |            |    | 0x0             |    | RO   | Max Error Interrupt Status. Cleared on read.<br>The interrupt triggers when there is a difference between the waveform played on the output and the setpoint, which typically occurs when the output haptic waveform is too abrupt, or the capacitive load is too high.<br>1: interrupt is active<br>0: interrupt is not active |        |          |          |          |         |         |        |   |  |
| 3             | IS_SENSF |            |    | 0x0             |    | RO   | Sense Trigger Interrupt Status. Cleared on read.<br>The interrupt triggers when sensed data meet the detection trigger conditions and <a href="#">SENS FLAG</a> is set to 0x1.<br>1: interrupt is active<br>0: interrupt is not active                                                                                          |        |          |          |          |         |         |        |   |  |
| 2             | IS_PLAY  |            |    | 0x0             |    | RO   | Waveform Playback Interrupt Status. Cleared on read.<br>The interrupt triggers when <a href="#">PLAYST</a> is set to 0x1.<br>1: interrupt is active<br>0: interrupt is not active                                                                                                                                               |        |          |          |          |         |         |        |   |  |
| 1             | IS_MAXP  |            |    | 0x0             |    | RO   | Max Power Interrupt Status. Cleared on read.<br>The interrupt triggers when maximum amount of power is used and <a href="#">MXPWR</a> is set to 0x1.<br>1: interrupt is active<br>0: interrupt is not active                                                                                                                    |        |          |          |          |         |         |        |   |  |
| 0             | IS_ERR   |            |    | 0x0             |    | RO   | Error State Interrupt Status. Cleared on read.<br>The interrupt triggers when the device is in error state and <a href="#">STATE[1:0]</a> is set to 0x3.<br>1: interrupt is active<br>0: interrupt is not active                                                                                                                |        |          |          |          |         |         |        |   |  |

## 7 Implementation

This section presents the following different BOS1921/BOS1931 configurations:

- Typical configuration, using [UPI](#) bit set to 0x0.
- UPI configuration, using [UPI](#) bit set to 0x1.
- Differential output configuration, driving a bipolar voltage on a single piezo actuator.
- Single-ended output configuration, driving a unipolar voltage on 2 piezo actuators.

Note that shorting the VBUS pin with the RP/VDD pin in the typical configuration is not mandatory but allows for better power efficiency.

### 7.1 Differential Output Configuration

Differential output configuration is required for applications using both sensing and driving capabilities. In this configuration, piezoelectric actuator is driven with one terminal connected to OUT+ pin and the other terminal connected to OUT- pin. This configuration can achieve a differential output voltage of 190 V<sub>pk-pk</sub>.

Typical application schematics of the differential output configuration are shown in Figure 35 and Figure 36, without and with Unidirectional Power Input (UPI) configuration. The BOM list is detailed in Table 49.



Figure 35: Schematic using differential output and typical configuration ([UPI](#) bit set to 0x0)



Figure 36: Schematic using differential output and UPI configuration (UPI bit set to 0x1)

## 7.2 Single-Ended Configuration

When sensing is not needed (BOS1921 and BOS1931), the single-ended output configuration allows driving two actuators independently to reduce the bill-of-material, see Figure 37. With this configuration, the piezo actuators positive terminal must be connected respectively to OUT+ and OUT- while both actuators negative terminals are connected to VDD.

This configuration can output up to 95 V waveform with positive polarity on each actuator. A bipolar waveform must be programmed to output a waveform on 2 actuators. The positive programmed voltage will output on Load 1 while the negative programmed voltage will output on Load 2.



Figure 37: Typical schematic with single-ended output configuration (UPI bit set to 0x0)

## 7.3 External Components

Typical values of external components are presented in Table 49. See section 7.5 and application notes for details on selecting components.

Table 49: Recommended external components for 190 V<sub>pk-pk</sub> / 100 nF load

| COMPONENT              | DESCRIPTION                     | TYPICAL VALUE FOR MAXMUM LOAD                                                                         | TYPICAL VALUE FOR 10 nF LOAD |
|------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------|------------------------------|
| $C_L$                  | Load capacitance                | 100 nF                                                                                                | 10 nF                        |
| $C_{VDD}$              | $V_{DD}$ capacitor              | 10 $\mu$ F ( <a href="#">UPI</a> bit set to 0x0)<br>100 $\mu$ F ( <a href="#">UPI</a> bit set to 0x1) | 10 $\mu$ F                   |
| $C_{REG}$              | REG pin capacitor               | 100 nF                                                                                                |                              |
| $C_{PUMP}$             | PUMP pin capacitor              |                                                                                                       |                              |
| $C_{VDDIO}$            | $V_{DDIO}$ decoupling capacitor |                                                                                                       |                              |
| $C_{HV}$               | Capacitor on HV pin to VBUS     | 10 nF                                                                                                 | 1 nF                         |
| $C_{HV2}$ <sup>5</sup> | Capacitor on HV pin to GND      | 3.9 nF                                                                                                | 1.5 nF                       |
| $R_{sense}$            | Current sense resistor          | 0.2 $\Omega$                                                                                          | 1 $\Omega$                   |
| $L_1$                  | Boost inductor                  | 10 $\mu$ H                                                                                            | 68 $\mu$ H                   |

## 7.4 Initialization

### 7.4.1 Power-Up Sequence

1. Apply power to the BOS1921/BOS1931 device with the following criteria:
  - a. The  $V_{BUS}$  voltage must ramp-up at a minimum rate of 1 V/ms .
  - b. The  $V_{DDIO}$  pin must be powered up after the  $V_{BUS}$  pin or at the same time.
2. Wait for 3 ms during which the BOS1921/BOS1931 starts-up with the following sequence:
  - a. Power-up
  - b. Initialization
  - c. Going to SLEEP mode.

As shown in Figure 38,  $V_{BUS}$ , GPIO & REG pin voltage can be monitored to assess device initialisation.

3. Wake-up from SLEEP by writing on the I<sup>2</sup>C/I3C bus (see section 6.3.2.1 for I<sup>2</sup>C and 6.3.2.2 for I3C).
4. Wait 50  $\mu$ s for the BOS1921/BOS1931 to reach IDLE mode.
5. Program the desired internal registers according to your application.
6. BOS1921/BOS1931 is ready for waveform playback.

<sup>5</sup> $C_{HV2}$  is recommended for reduction of high frequency noise.

Figure 38: Typical  $V_{BUS}$ , GPIO & REG pin voltage during initialisation

#### 7.4.2 Start-Up Sequence

After the initial power-up sequence, the following start-up sequence applies:

- From SLEEP mode, one must perform steps 3 to 6 of the section 7.4.1.
- From IDLE mode, BOS1921/BOS1931 is ready for waveform playback.

### 7.5 Design Methodology: selection of component

#### 7.5.1 Load Selection

The BOS1921/BOS1931 is designed to drive a capacitive load impedance ( $Z_L$ ) of up to 5.3 kΩ at 190 V<sub>pk-pk</sub>, which gives 100 nF at 300 Hz. Larger load capacitances can be driven if the waveform amplitude is reduced (see Figure 14). The conditions must be selected so as not to exceed the maximum peak transient current at SW pin ( $I_{SW}$ ) of 1.3 A, which is limited by  $R_{sense}$  (see section 7.5.3 for  $R_{sense}$  selection).

You can use the following procedure to estimate  $I_{SW}$  using the desired conditions ( $I_{SW}$  could be higher in practice):

1. Set the output signal maximum frequency ( $f_{OUT}$ ). e.g., 200 Hz.
2. Set the maximum amplitude of the waveform ( $V_{pk}$ ). e.g., 95 V for a 190 V<sub>pk-pk</sub> output.
3. Set the minimum supply voltage ( $V_{BUS}$ ) value during operation. e.g., 3 V.
4. Calculate the  $I_{SW}$  and ensure it does not exceed 1.3 A:

#### Bipolar Waveform

$$V_{out} = V_{pk} \sin(45^\circ) + V_{BUS}$$

$$\overline{I_{out}} = 2\pi f_{OUT} C_L V_{pk} \cos(45^\circ)$$

#### Unipolar Waveform

$$V_{out} = \frac{V_{pk}}{2} (1 + \sin(30^\circ)) + V_{BUS} \quad (1)$$

$$\overline{I_{out}} = \pi f_{OUT} C_L V_{pk} \cos(30^\circ) \quad (2)$$

5. Calculate the average input current using:

$$\overline{I_{in}} = 1.5 \times \frac{\overline{I_{out}} \times V_{out}}{V_{BUS}} \quad (3)$$

6. Calculate the inductor peak current (current at SW pin):

$$I_{SW} = C \times \overline{I_{in}} \quad (4)$$

With  $C$  equals to 2 if only DCM mode is used ([CCM](#) bit set to 0x0) or equals to 1.5 if CCM or DCM mode is used ([CCM](#) bit set to 0x1).

### 7.5.2 $C_{HV}$ Selection

Load capacitance ( $C_L$ ) defines the required value of component  $C_{HV}$  (up to 10 nF):

$$C_{HV} = 5\% C_L \quad (5)$$

The  $C_{HV}$  capacitor should have a voltage rating of at least the peak output waveform amplitude. A  $C_{HV}$  capacitor with a minimum voltage rating of 95 V is required to output the full-scale output voltage.

### 7.5.3 $R_{sense}$ Selection

The value of  $R_{sense}$  must enable a current range appropriate for the  $I_{SW}$  value calculated in equation (4).  $R_{sense}$  value is determined using equation (6). The current limit of the power converter is set by  $R_{sense}$  components.

$$R_{sense} \leq \frac{0.256 \text{ [V]}}{I_{SW}} \quad (6)$$

$$\text{Current limit} = \frac{0.256 \text{ [V]}}{R_{sense}} \quad (7)$$

### 7.5.4 $L_1$ Selection

The BOS1921/BOS1931 can use any COTS inductor. An  $L_1$  inductor greater than 10  $\mu$ F is recommended but the inductance can be chosen to optimize the power / size / performance trade-off according to the user application as follows:

- Select lower inductance together with a higher switching frequency using [FSWMAX\[1:0\]](#) bits to optimize distortion (i.e., THD+N).
- Select larger inductance to reduce the switching frequency. In general, lower switching frequency corresponds to lower power consumption.

A  $f_{sw\min}$  value of 300 kHz is recommended.

Use the following procedure to select the first inductor value and then experiment with other values to optimize your application if required:

1. Calculate the ideal duty ratio of the power converter stage:

$$D = 1 - \frac{V_{BUS}}{V_{BUS} + V_{pk}} \quad (8)$$

2. Calculate the maximum  $L_1$  inductor value:

$$L_1 \leq \frac{V_{BUS}D}{I_{pk}f_{sw\min}} \quad (9)$$

Select an  $L_1$  inductor with a saturation current higher than  $I_{sw}$  and higher than the current limit determined in equation (7).

### 7.5.5 Input Capacitor ( $C_{VDD}$ )

An input capacitor ( $C_{VDD}$ ) must be placed next to the inductor because of the current requirement of the power converter. A low-ESR capacitor of at least 10  $\mu\text{F}$  is recommended.

If the Unidirectional Power Input mode is enabled ([UPI](#) bit set to 0x1), the energy recovered from the load in buck conversion accumulates on the  $C_{VDD}$ . Energy accumulation on  $C_{VDD}$  causes the input voltage to increase. The voltage increase must not make the total voltage on  $C_{VDD}$  exceed the maximum absolute 5.5 V limit ( $V_{DD\_max}$ ). Use equation (10) to determine the minimum capacitance value.

$$C_{VDD} = \frac{C_L V_{pk}^2}{V_{DD\_max}^2 - V_{BUS\_max}^2} \quad (10)$$

When selecting the capacitor, make sure to select a capacitor with an effective capacitance close to the capacitance value determined by equation (10).

## 7.6 Design Methodology: programming

Many operational settings are adjustable through the digital front end. One should program the following parameters according to its specific design. For details, see section 7.5.

### 7.6.1 Waveform Playback

The readout rate for waveform playback is set using the following parameter:

- Set FIFO readout speed using [PLAY\\_SRATE\[2:0\]](#) bits.

### 7.6.2 Power Converter

The internal buck-boost converter can be optimized using the following parameters:

- Set the maximum switching frequency of the power converter using [FSWMAX\[1:0\]](#) bits.
- Set the Power Input mode using [UPI](#) bits.

### 7.6.3 Loop Controller

The BOS1921/BOS1931 implements a proportional-integral (PI) control loop feedback that can be optimized if required with the following parameters:

- Proportional gain is set using [KP\[10:0\]](#)
- Proportional gain term related to waveform amplitude is used with [KPA\[7:0\]](#)
- Integral term is set with [KIBASE\[3:0\]](#)

Table 50 shows the recommended value for a 100 nF load operating at up to 190 V<sub>pk-pk</sub> at 300 Hz with  $L_1 = 10 \mu\text{H}$  and  $R_{sense} = 0.2 \Omega$  sense resistor.

Table 50: Loop controller parameters

| PARAMETER                   | RECOMMENDED VALUE    | COMMENT                                             |
|-----------------------------|----------------------|-----------------------------------------------------|
| <a href="#">KP[10:0]</a>    | 128 (0x080), default | Reduce value for smaller loads                      |
| <a href="#">KPA[7:0]</a>    | 160 (0xA0), default  | Reduce value for smaller loads                      |
| <a href="#">KIBASE[3:0]</a> | 2 (0x2), default     | Increase value up to 4 when using a larger inductor |

### 7.6.4 Power Efficiency

The power efficiency of the BOS1921/BOS1931 and the haptic waveform integrity can be optimized by configuring the internal controller and the switching timing of the internal low-side and high-side switches. This optimization can be done by adjusting the following registers based on selected inductor value ( $L_1$ ) and current sense limit (set by  $R_{sense}$ ):

- Optimize Loop Controller (see section 7.6.3).
- Adjust power switch deadtime using [DHS\[6:0\]](#) and [DLS\[6:0\]](#) bits.
- Adjust minimum current required to turn-on HS using [IONSCALE\[7:0\]](#) bits.
- Adjust typical capacitance value on pin SW using [PARCAP\[7:0\]](#) bits.
- Adjust proportional gain for the offset using [TI\\_RISE\[5:0\]](#) bits.

Set the nominal supply voltage (VDD) of the design using [VDD\[4:0\]](#) bits.

## 7.7 Noise Reduction

It may be required to enable continuous conduction mode (CCM) by setting the [CCM](#) bit to 0x1 to drive a high capacitance load at high frequencies. In such a situation, the noise level on the supply nodes (i.e.,  $V_{DDIO}$ ,  $V_{BUS}$  and  $V_{DD}$ ) may be higher than what is acceptable for some applications. Electrical noise can be reduced by using one or multiple of the following strategies:

1. Follow the PCB layout recommendations listed in the section 8.
2. Place a Schottky diode as close as possible to the BOS1921/BOS1931 device with a low threshold voltage and fast recovery time in the following locations:
  - a. Between the HV and SW pins, as shown in Figure 39.
  - b. Between the SW and PGND pins, as shown in Figure 39.

In the case where only one diode can be used due to cost or space, the Schottky diode between the HV and SW pins will generally have a more significant impact on noise reduction and should be prioritized rather than the diode placed between SW and PGND.

3. Decrease the maximum switching frequency of the BOS1921/BOS1931 by increasing [FSWMAX\[2:0\]](#) to up to 0x3 to increase the input power threshold for entering CCM mode.



Figure 39: Simplified schematic with a Schottky diode between SW/HV and SW/PGND pins for noise reduction

## 8 PCB Layout Example

UPI configuration 4-layer PCB layout examples are presented in Figure 40. The recommended layers are as following:

- Top layer: Components and main routing.
- Layer 2: Full ground plane, avoid interruptions/slot as much as possible.
- Layer 3: Power plane split between  $V_{BUS}$ ,  $V_{DD}$  and  $V_{DDIO}$ .
- Bottom layer: Routing.

Layout considerations:

1. Keep SW node as small as possible.
2. Place and route components  $L_1$ ,  $R_s$ ,  $C_{VDD}$ ,  $C_{HV}$  and  $C_{HV2}$  close to each other to minimize area of the high  $di/dt$  current loop and reduce high voltage ringing & spikes.
3. Create a GND island on Top layer connecting GND pads of  $C_{VDD}$  and  $C_{HV2}$  with the following criteria:
  - Connect this copper region to PGND pads of BOS1921/BOS1931.
  - Connect with vias to Layer 2 ground plane.
  - This GND island must not be tied to the Top layer ground polygon/plane (if applicable).
4. Route RP/VDD & RM sensing lines parallel to each other.
5. Create a HV copper region on Top layer connecting VDD pads of  $C_{HV}$  and  $C_{HV2}$ .
  - Connect this copper region directly to HV pad(s) of BOS1921/BOS1931.
  - Keep this region as close as possible to BOS1921/BOS1931.
  - Keep this region as small as possible.
6. This consideration applies to QFN version only - Create a  $V_{DD}$  copper region on Top layer connecting VDD pad of  $C_{HV}$ :
  - Connect this copper region directly to VDDP pads (2 and 24 pins) of BOS1921/BOS1931.
  - Connect with vias to Layer 3  $V_{DD}$  plane.

Notes on important components:

- The layout examples are sized for a piezo actuator with a capacitance of 100 nF driven at 190 V<sub>pk-pk</sub> and 300 Hz.
- Beware of capacitors DC bias, i.e., the decrease in capacitance with increasing DC voltage, which affects the effective value of a capacitor at a given operating voltage. Generally, high capacitance & high-voltage ceramic capacitors are subject to this phenomenon, but COG/NPO dielectric and tantalum capacitors do not exhibit any DC bias behavior. Refer to  $C_{HV2}$  and  $C_{VDD}$  components in Table 51.
- Component requirements must be reevaluated for each application.



Figure 40: UPI configuration PCB layout examples for QFN 24L 4.0mm × 4.0mm (left) and typical configuration for WLCSP 20B 2.1mm × 1.7mm (right)

Table 51: Bill of Materials for layout examples

| DESIGNATOR                    | QTY | VALUE  | DESCRIPTION                               | MANUFACTURER                       | PART NUMBER          |
|-------------------------------|-----|--------|-------------------------------------------|------------------------------------|----------------------|
| CHV                           | 1   | 0.01µF | 10000PF 250V X7R 0805                     | TDK Corporation                    | CGA4J3X7R2E103K125AA |
| CHV2                          | 1   | 3900pF | 3900PF 250V COG/NPO 0805                  | TDK Corporation                    | C2012C0G2E392J125AE  |
| CPUMP, CREG,<br>CVBUS, CVDDIO | 4   | 0.1µF  | 0.1UF 25V X5R 0402                        | Taiyo Yuden                        | TMK105BJ104KV-F      |
| CVDD                          | 1   | 100µF  | TANT POLY 100UF 6.3V 1206                 | KEMET                              | T527I107M006ATE070   |
| L1                            | 1   | 10µH   | IND 10UH 1.48A 415 MOHM<br>3x3 mm package | TDK Corporation                    | VLS3012HBX-100M      |
| RS                            | 1   | 0.2    | 0.2 OHM 1% 1/8W 0402                      | TE Connectivity<br>Passive Product | RLP73N1ER20FTDF      |

## 9 Mechanical

### 9.1 QFN Package Description

#### 9.1.1 Physical Outline Dimension (POD)



Figure 41: QFN 24L 4.0mm x 4.0mm package outline drawing

Table 52: QFN 24L 4.0mm x 4.0mm package dimensions

| SYMBOL | MILLIMETERS |       |       |
|--------|-------------|-------|-------|
|        | MIN         | NOM   | MAX   |
| A      | 0.500       | 0.550 | 0.600 |
| A1     | 0.000       | -     | 0.050 |
| b      | 0.200       | 0.250 | 0.300 |
| D      | 3.950       | 4.000 | 4.050 |
| D2     | 2.350       | 2.400 | 2.450 |
| E      | 3.950       | 4.000 | 4.050 |
| E2     | 2.350       | 2.400 | 2.450 |
| e      | 0.500 BSC   |       |       |
| K      | 0.325       | 0.400 | 0.475 |
| L      | 0.350       | 0.400 | 0.450 |

#Reference: JEDEC MO-220-WGGD. BSC: Basic Spacing between Center.

Four lines are branded on the package:

- (1) Company Name: BOREAS
- (2) Device Marking: AAAA (1921 or 1931)
- (3) Wafer Batch Number: XXXXXX
- (4) Assembly Date Code: YY (year), WW (week) and ZZ (assembly house code)

**9.1.2 QFN Package Soldering Footprint**

Figure 42: QFN 24L 4.0mm x 4.0mm soldering footprint (NOT TO SCALE)

**9.1.3 QFN Reflow**

The QFN package soldering reflow profile should be determined based on the recommended reflow profile made by the manufacturer of the solder paste used. Also, it is important to take into consideration that the circuit board dimensions, other board components and the reflow soldering oven may affect the reflow profile.

Finally, please note that the quality of the solder paste plays an important role in board assembly and allows for a reliable and repeatable assembly process.

## 9.2 WLCSP Package Description

### 9.2.1 Physical Outline Dimension (POD)



Figure 43: WLCSP 20B 2.1mm x 1.7mm package outline drawing with top, side, and bottom view

Table 53: WLCSP 20B 2.1mm x 1.7mm package dimensions

| SYMBOL | MILLIMETERS |       |       |
|--------|-------------|-------|-------|
|        | MIN         | NOM   | MAX   |
| A      | 0.585       | 0.625 | 0.665 |
| A1     | 0.180       | 0.200 | 0.220 |
| A2     | 0.380       | 0.400 | 0.420 |
| A3     | 0.022       | 0.025 | 0.028 |
| E      | 2.055       | 2.075 | 2.095 |
| D      | 1.655       | 1.675 | 1.695 |
| E1     | 1.60 BSC    |       |       |
| D1     | 1.20 BSC    |       |       |
| e      | 0.40 BSC    |       |       |
| b      | 0.245       | 0.265 | 0.285 |

BSC: Basic Spacing between Center.

Four lines are branded on the package:

- (1) Company Name: BOREAS
- (2) Device Marking: AAAA (1921 or 1931)
- (3) Wafer Batch Number: XXXXXX
- (4) Assembly Date Code: YY (year), WW (week) and ZZ (assembly house code)

### 9.2.2 WLCSP Package Soldering Footprint



Figure 44: WLCSP 20B 2.1mm x 1.7mm soldering footprint (NOT TO SCALE)

The use of non-solder mask defined (NSMD) pads is recommended, with 0.05 mm solder mask expansion as shown in Figure 44.

### 9.2.3 WLCSP Reflow

BOS1921CW have SAC405 bumps which supports JEDEC J-STD-020D.1 reflow profile. Figure 45 presents the recommended reflow profile which may be optimized for specific PCB assembly conditions. Note that it is recommended to use solder paste to obtain reliable solders.



Figure 45: WLCSP reflow profile

Table 54: Reflow profile parameters

| PARAMETER  | DESCRIPTION                        | VALUE     |
|------------|------------------------------------|-----------|
| $T_{Smin}$ | Preheat minimum temperature        | 150°C     |
| $T_{Smax}$ | Preheat maximum temperature        | 200°C     |
| $t_s$      | Time from $T_{Smin}$ to $T_{Smax}$ | 60-120 s  |
|            | Ramp-up rate from $T_L$ to $T_P$   | 3°C/s max |
| $T_L$      | Liquidous temperature              | 217°C     |
| $T_P$      | Peak package temperature           | 260°C     |
| $t_L$      | Time above $T_L$                   | 60-150 s  |
|            | Ramp-down rate from $T_P$ to $T_L$ | 6°C/s max |
|            | Time 25 °C to peak temperature     | 8 min max |

### 9.3 Tape and Reel Specifications



Figure 46: Embossed carrier tape and reel outline drawing

Table 55: Tape and reel dimensions

| PART NUMBER | PACKAGE TYPE            | A0 (mm) | B0 (mm) | K0 (mm) | P1 (mm) | W (mm) | ØA (mm) | W1 (mm) |
|-------------|-------------------------|---------|---------|---------|---------|--------|---------|---------|
| BOS1921CQ   | QFN 24L 4.0mm x 4.0mm   | 4.250   | 4.250   | 0.750   | 8.00    | 12.00  | 330     | 12.4    |
| BOS1931CQ   | QFN 24L 4.0mm x 4.0mm   | 4.250   | 4.250   | 0.750   | 8.00    | 12.00  | 330     | 12.4    |
| BOS1921CW   | WLCSP 20B 2.1mm x 1.7mm | 2.275   | 1.875   | 0.825   | 4.00    | 8.00   | 178     | 9       |
| BOS1931CW   | WLCSP 20B 2.1mm x 1.7mm | 2.275   | 1.875   | 0.825   | 4.00    | 8.00   | 178     | 9       |

## 10 Known Issues

### 10.1 Incorrect Activation of Output Bridge Protection

*Affected product revision: B*

The output bridge protection (section 6.2.18) is activated under the following conditions:

- Play a positive haptic waveform when a negative voltage smaller than -2.5 V has built up on the piezoelectric ceramic.
- Play a negative haptic waveform when a positive voltage greater than 2.5 V has built up on the piezoelectric ceramic.

In these conditions, the device may output the waveform with the wrong polarity and generate an IDAC fault.

To avoid this issue, one must reset the voltage on the piezoelectric ceramic before starting to play the haptic waveform. This can be achieved by playing one of the following sets of data before the desired haptic waveform:

- Several 0 V data points.
- Voltage data points increasing from -2 V to 0 V if a positive waveform is intended to be played.
- Voltage data points decreasing from 2 V to 0 V if a negative waveform is intended to be played.

### 10.2 Timeout resets PLAY\_SRATE

*Affected product revision: All*

When using the timeout feature with the [TOUT](#) bit set to 0x1, the [PLAY\\_SRATE\[2:0\]](#) bits are reset to 0x7 when the device enters SLEEP after a timeout event.

### 10.3 Waveform Amplitude Drift with RELOFF Option

*Affected product revision: All*

When using RAM Synthesis mode with the [RELOFF](#) option enabled, an offset may cumulate when 2 SLICEs of different amplitudes are repeatedly played. This cumulative offset can cause waveform amplitude to drift, potentially leading the device to enter an ERROR state.

To prevent this waveform amplitude drift, avoid repeating SLICE with different amplitudes while using the [RELOFF](#) option, ensure that each SLICE has identical amplitude or reduce the number of times the SLICEs are repeated.

### 10.4 Minimum Slew-Rate of V<sub>BUS</sub> Supply

*Affected product revision: A, B & C*

The V<sub>BUS</sub> voltage must ramp-up at a minimum rate of 3 V/ms to ensure proper device initialisation.

## 11 Ordering Information

Table 56: Ordering information

| ORDERING PART NUMBER | FEATURES    | PACKAGE DESCRIPTION     | PACKING FORMAT | QUANTITY    | MSL LEVEL, PEAK TEMP. | FLOOR LIFE | OPERATING TEMPERATURE | DEVICE MARKING |
|----------------------|-------------|-------------------------|----------------|-------------|-----------------------|------------|-----------------------|----------------|
| BOS1921CQR           | DRIVE+SENSE | QFN 24L 4.0mm × 4.0mm   | Tape & Reel    | 2500 / Reel | Level 3, 260°C        | 168Hrs     | -40°C to 85°C         | 1921           |
| BOS1931CQR           | DRIVE       | QFN 24L 4.0mm × 4.0mm   | Tape & Reel    | 2500 / Reel | Level 3, 260°C        | 168Hrs     | -40°C to 85°C         | 1931           |
| BOS1921CWR           | DRIVE+SENSE | WLCSP 20B 2.1mm × 1.7mm | Tape & Reel    | 4000 / Reel | Level 1, 260°C        | Unlimited  | -40°C to 85°C         | 1921           |
| BOS1931CWR           | DRIVE       | WLCSP 20B 2.1mm × 1.7mm | Tape & Reel    | 4000 / Reel | Level 1, 260°C        | Unlimited  | -40°C to 85°C         | 1931           |

### NOTE

- (1) Ordering Part Number where last letter indicates packing format.
- (2) All parts are RoHS compliant and halogen free.
- (3) Contact [sales@boreas.ca](mailto:sales@boreas.ca) to order.
- (4) MSL: Moisture Sensitivity Levels, IPC/JEDEC J-STD-020.

## 12 Document History

Table 57: Document changes between previous and current versions

| ISSUE | DATE        | DOCUMENT NUMBER | CHANGES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | Oct., 2024  | BT015DDS01.01   | <p>Added BOS1931 device</p> <p>Added <math>I_{BUS,AVG}</math> in sensing (section 5.4)</p> <p>Typo corrected (section 6.2.11)</p> <p>Changed minimum <math>V_{BUS}</math> ramp-up rate (section 7.4.1)</p> <p>Changed known issue name (section 10.1)</p> <p>Added known issue Waveform Amplitude Drift with RELOFF Option (section 10.3)</p> <p>Added known issue Minimum Slew Rate of VBUS Supply (section 10.4)</p> <p>Updated ordering information (section 11)</p> <p>Added <math>C_{HV2}</math> to Figure 35</p> <p>Corrected wheel width for BOS1921CW (Table 55)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5     | April, 2024 | BT015CDS01.01   | <p>Added a note about Device Reset feature (section 6.2.8)</p> <p>Clarified the Adjustable Internal Clock (section 6.2.14)</p> <p>Updated Current Detection Status Fault description (section 6.2.15.5)</p> <p>Clarified interrupt mechanism (section 6.2.17)</p> <p>Added Output Bridge protection description (section 6.2.18)</p> <p>Updated digital interface terminology (section 6.3)</p> <p>Corrected FIFO descriptions (section 6.6)</p> <p>Clarified SLICE.AMPLITUDE[11:0] definition (section 6.8.1)</p> <p>Clarified FSWMAX[1:0] field description (section 6.10.2)</p> <p>Added CHIP_REV[3:0] register field (section 6.10.17)</p> <p>Changed power-up sequence for VDDIO (section 7.4.1)</p> <p>Added guidelines for noise reduction (section 7.7)</p> <p>Modified layout recommendations (section 8)</p> <p>Changed known issue name IDAC fault bit (section 10.1)</p> <p>Added issue Timeout resets PLAY_SRATE (section 10.2)</p> <p>Corrected RAM Playback example (Figure 21)</p> <p>Corrected Figure 23</p> <p>Corrected examples in Table 20</p> |

## 13 Notice and Warning

### Warning High Voltage



For safety, this integrated circuit must be used by qualified and skilled personnel familiar with all applicable safety standards.

### ESD Caution



This integrated circuit is ESD (Electrostatic Discharge) sensitive. Therefore, proper ESD precautions and procedures are recommended for handling and installation to avoid damage.

Information relating to products and circuits furnished herein by Boréas Technologies Inc. is believed to be reliable. However, Boréas Technologies assumes no liability for errors that may appear in this document, or for liability otherwise arising from the application or use of any such information which may result from such application or use. The products, their specifications and the information appearing in the document are subject to change by Boréas Technologies without notice. Trademarks and registered trademarks are the property of their respective owners.

Boréas's products are provided subject to the Boréas's Terms & Conditions available at:

<https://www.boreas.ca/pages/general-terms-and-conditions>

#### Boréas Technologies Datasheet Status:

Advance Information Datasheet: Design Data

Preliminary Information Datasheet: Prototype information

Final Datasheet: Production information

# Mouser Electronics

Authorized Distributor

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

[Boreas Technologies:](#)

[BOS1931CWR](#)