# MAX32625 ERRATA SHEET

# **Revision A2 Errata**

The errata listed below describe situations where components of this revision perform differently than expected or differently than described in the data sheet. Maxim Integrated Products, Inc., intends to correct these errata when the opportunity to redesign the product presents itself.

This errata sheet only applies to components of this revision. These components are branded on the topside of the package with a six-digit code in the form yywwRR, where yy and ww are two-digit numbers representing the year and work week of manufacture, respectively, and RR is the revision of the component. To obtain an errata sheet on other die revisions, visit the Maxim website at <u>www.maximintegrated.com/errata</u>.

# 1) SPI MASTER MAY NOT OPERATE AS EXPECTED IF SDIO IS OUTPUT PRIOR TO SLAVE SELECT

#### **Description:**

Setting the SPIMn\_SPCL\_CTRL.ss\_sample\_mode field causes unexpected behavior.

#### Workaround:

Do not use the SPI master sample mode feature. This erratum affects all instances of the I<sup>2</sup>C master peripheral.

#### 2) SPI MASTER BIT-SIZED TRANSACTIONS DO NOT OPERATE IN FEEDBACK MODE

#### **Description:**

The SPIM does not operate as expected if all the following conditions are met:

The SPIM is configured for SCLK feedback mode.

The Size Units field in the SPI transaction header is set to 0 (bits).

The Size field is greater than 7.

# Workaround:

Guarantee that the next header is not written to the FIFO until the Tx payload is complete (TX FIFO Word Count = 0).

Alternately, a transaction of more than 7 bits can be decomposed into two transactions composed of 1 or more bytes and the final transaction of the remaining number of bits.

# 3) SPI SLAVE TRANSMIT FIFO WORD COUNT MAY BE INCORRECT IN SPI MODES 1/3

# **Description:**

The Tx word count should be zero after all Tx data has been transmitted and the FIFO is empty. In Modes 1 and 3, if the Tx FIFO is empty and SCLK toggles while SS is inactive (master communicating to another slave) the register "Tx FIFO Entries" may read "1 byte." Only the Word Counter value read by software is affected. The FIFO empty flag sets properly when the last byte was transmitted and remains set until the user clears it. The FIFO itself is unaffected, and following data is not effected.

# Workaround:

Firmware work around is:

if (Tx No Data Interrupt == 0)

TX\_COUNT\_REMAINING = 0

else

TX\_COUNT\_REMAINING = "Tx FIFO Entries Register"



# 4) SPI MASTER MAY TRANSMIT INCORRECT DATA IF Tx FIFO STALLS

#### **Description:**

An SPI master may transmit incorrect data under the following conditions: 1. The SPI master stalls (runs out of data in the middle of a transaction).

2. The SPI mode and SCK high or low settings do not match these combinations.

| SPI MODE | SCK HIGH | SCK LOW |  |
|----------|----------|---------|--|
| 0        | 1        | 1–15    |  |
| 1        | 1–15     | 1       |  |
| 2        | 1–15     | 1       |  |
| 3        | 1        | 1–15    |  |

#### Workaround:

Use the above SCK settings in the table shown above.

Slower baud rates are set through the SPIM clock scaling registers:

- CLKMAN\_SYS\_CLK\_CTRL\_11\_SPI0.spi0\_clk\_scale
- CLKMAN\_SYS\_CLK\_CTRL\_12\_SPI1.spi1\_clk\_scale
- CLKMAN\_SYS\_CLK\_CTRL\_13\_SPI0.spi2\_clk\_scale

# 5) SPI SLAVE UNDERFOW INTERRUPT BUG

#### **Description:**

The SPI Slave Underflow Interrupt is asserted 2 SCLK cycles after the SPI Slave Tx FIFO is empty. The expected behavior is that the interrupt occurs on the first SCLK cycle following the assertion of the SPI Slave Underflow Interrupt.

#### Workaround:

None.

#### 6) SPI SLAVE SELECT ACTIVITY MAY NOT GENERATE EXPECTED INTERRUPT

#### **Description:**

The option is provided to generate an interrupt whenever a master has asserted and/or deasserted the slave select signal on an enabled slave select pin.

#### Workaround:

Do not use the slave select toggle interrupt feature. Configure the slave select pin as a GPIO and use the GPIO interrupt function to detect when a master has asserted and/or deasserted the slave select pin.

# 7) I<sup>2</sup>C PUSH/PULL MODE REGISTER IS WRITE ONLY

#### **Description:**

The IOMAN\_I2CM[n]\_REQ.push\_pull\_mode field is write only. Read-modify-write operations on the IOMAN\_I2CM[n]\_REQ register clears IOMAN\_I2CM[n]\_REQ.push\_pull\_mode. As a result, it is not possible to directly determine if the request has been accepted.

#### Workaround:

None.

### 8) IOMAN\_I2CM[n]\_ACK.PUSH\_PULL\_MODE FIELD DOES NOT MIRROR IOMAN\_I2CM[n]\_REQ. PUSH\_PULL\_MODE

#### **Description:**

The IOMAN\_I2CM[n]\_ACK.push\_pull\_mode field does not mirror the IOMAN\_I2CM[n]\_REQ.push\_pull\_mode field. As a result, it is not directly possible to verify the corresponding pin has implemented

push/pull feature. This affects all instances of the I<sup>2</sup>C master peripheral.

#### Workaround:

None.

### 9) P1.6 DOES NOT OPERATE AS EXPECTED WHEN 32kHz OUTPUT MODE ON P1.7 IS ENABLED

#### **Description:**

Enabling the 32kHz clock output mode on P1.7 configures P1.6 as an input with an internal pullup. The primary and secondary functions, pulse train output and timer input as unavailable in this configuration. P1.6 remains in this state until the 32kHz clock output mode on P1.7 is disabled. The internal pullup configuration increases power consumption in low power modes.

#### Workaround:

Do not use P1.6 except as a GPIO input while the 32kHz clock output mode is enabled.

#### 10) GPIO\_FREE\_P1.[7:6] ARE INCORRECT WHEN 32kHz OUTPUT MODE ON P1.7 IS ENABLED

#### **Description:**

When the 32kHz output mode on P1.7 is enabled, GPIO\_FREE\_P1.7 GPIO = 1 and GPIO\_FREE\_P1.6 = 0. Instead, the bits should be GPIO\_FREE\_P1.7 GPIO = 0 and GPIO\_FREE\_P1.6 = 1.

#### Workaround:

Software should recognize the bits are inverted when reading GPIO\_FREE\_P1.[7:6].

#### 11) SPI MASTER SCLK DUTY CYCLE NOT 50% AT 48MHz AND V<sub>DDIO</sub> $\approx$ 1.8V

#### **Description:**

When operating at 48MHz and V<sub>DDIO</sub> = 1.8V, t<sub>MCH</sub>  $\approx$  12ns and t<sub>MCL</sub>  $\approx$  8ns. At V<sub>DDIO</sub> = 3.3V, the duty cycle is approximately 50%. This may violate the minimum required setup time during slave read operations in modes 0, 2, and 3. This issue does not adversely affect operation in mode 1.

#### Workaround:

In modes 0 and 2, use the following procedure:

- 1. Set SPIMx\_GEN\_CTRL.enable\_sck\_fb\_mode = 1.
- 2. SPIMx\_GEN\_CTRL.invert\_sck\_fb\_clk = 1.
- 3. SPIMx\_MSTR\_CFG.inact\_delay  $\geq$  1.
- 4. SPIMx\_FIFO\_CTRL.rx\_fifo\_af\_lvl  $\leq$  29.
- 5. SPIMx\_SPCL\_CTRL.rx\_fifo\_margin = 3.
- In mode 3, increase the low SCLK period by setting SPIMn\_MSTR\_CFG.sck\_lo\_clk = 2.

# **Revision History**

| REVISION | REVISION | DESCRIPTION     | PAGES   |
|----------|----------|-----------------|---------|
| NUMBER   | DATE     |                 | CHANGED |
| 0        | 08/16    | Initial release | —       |

© 2016 Maxim Integrated Products, Inc. All rights reserved. The Maxim logo and Maxim Integrated are trademarks of Maxim Integrated Products, Inc. in the United States and other jurisdictions throughout the world.