

# Getting started with the AEK-COM-ISOSPI1, SPI to isolated SPI dongle based on the L9963T transceiver

### introduction

One of the most commonly used communication protocols for device control is the SPI one. In the traditional vehicle architecture, the SPI control is used to connect the device with the local microcontroller. With trends moving toward domain / zone architectures, the local microcontroller is disappearing, therefore the protocol has to evolve to cover longer distances to connect the device to the domain / zone controller. In addition, with electrification progressing inside the new vehicles, another desirable feature for such a protocol is the electrical isolation. Based on these requirements, the isolated SPI (ISOSPI) protocol has been defined.

The AEK-COM-ISOSPI1 board allows converting SPI signals into ISOSPI signals, reducing the number of necessary wires from 4 to 2, and ensuring an isolated differential communication highly immune to noise.

An ISOSPI signal can travel for several meters, maintaining a high ratio between signal and noise.

MASTER UNIT

any micro board with SPI interface i.e.
CHORUS 4 M

AEK-ISOSPI

SPI

transceiver
L9963T

SPI

transceiver
L9963T

SLAVE UNIT

any board with
SPI interface i.e.
- DISPLAY
- LED Controller

AEK-ISOSPI

Figure 1. SPI to ISOSPI conversion block diagram

The ISOSPI protocol features differential communication to ensure higher noise immunity and robustness for long distance communication. As the ISOSPI signals can travel for several meters, this protocol is particularly suitable for automotive high voltage applications where electrical isolation is required by the safety standards and the cable length can affect the communication among devices located in distant parts of the vehicle.

The AEK-COM-ISOSPI1 board is based on the L9963T integrated circuit, a general-purpose SPI to isolated SPI bi-directional transceiver, which can transfer communication data incoming from a classical 4-wire based SPI interface to a 2-wire isolated interface (and vice versa).

The L9963T hosted on the AEK-COM-ISOSPI1 can be configured either as a slave or as a master of the SPI bus and supports any protocol of 8-to-64-bit SPI frames. The SPI peripheral can work up to 10 MHz when configured as a slave. The SPI clock frequency can be programmed (250 kHz, 1 MHz, 4 MHz, or 8 MHz) when the device is configured as a master.



The transceiver is natively compatible with the L9963E IC isolated SPI port, allowing its usage in battery management system (BMS) applications. The basic BMS analog front-end node board is the AEK-POW-BMS63EN. From the microcontroller side, the AEK-COM-ISOSPI1 board can be connected via SPI with SPC5, Stellar and STM32 microcontroller families.

Figure 2. AEK-COM-ISOSPI1



UM3187 - Rev 1 page 2/35



### 1 Hardware overview



The AEK-COM-ISOSPI1 can be programmed through a microcontroller or using jumpers.

It is necessary to configure two parameters:

- The signal frequency
- The signal amplitude

To send a signal over a long distance, it is necessary to lower the frequency. Tune the signal frequency and amplitude according to the distance that you intend to reach.

To set these parameters, use the jumpers for TxAmp and IsoFreq. They can be arranged in two positions: closing pin 2 and pin 3 or closing pin 1 and pin 2.

JP1 NSLAVE
JP2 Txamp
JP3 TXEN
JP4 ISOfreq
JP5 BNE
JP6 DIS

Figure 4. Jumper configuration

Amplitude and frequency can be set through the microcontroller GPIO on the AEK-COM-ISOSPI1 DIS pin. You can enable or disable the AEK-COM-ISOSPI1 through jumpers on the DIS pin or through the microcontroller.

UM3187 - Rev 1 page 3/35



Figure 5. Jumpers on DIS pin



To enable this pin, use jumpers on TXEN or program the microcontroller to set the TXEN pin.

Figure 6. TXEN pin



NSLAVE can assume the value 0 (for the slave configuration) or 1 (for the master configuration).

### 1.1 L9963T

The L9963T is a general purpose SPI to isolated SPI transceiver IC, which acts as a bridge among devices located in different voltage domains.

The L9963T can transfer communication data incoming from a classical four-wire based SPI interface to a two-wire isolated interface (and vice versa).

The device can be configured either as slave or as master of the SPI bus and supports any protocol made of SPI frames (8 to 64 bits).

L9963T integrates two communication interfaces:

- a SPI interface used for the local data exchange with a master MCU or with a generic slave IC
- an isolated SPI interface for global/local isolated communication with another L9963T or with an ISOLine compatible device (such as L9963E).

The SPI peripheral can work up to 10 MHz when configured as a slave.

The SPI clock frequency can be programmed (250 kHz, 1 MHz, 4 MHz, or 8 MHz) when configured as a master.

The isolated SPI peripheral features two different operating modes: slow at 333 kbps and fast at 2.66 Mbps.

The L9963T is compatible with both 3.3 V and 5 V logic.

### 1.2 Pin description

### 1.2.1 SPI

SDO, SCK, SDI, NCS pins implement the SPI peripheral, whose configuration depends on the NSLAVE value latched at the first power-up:

SDI is always configured as a digital input. It is internally pulled down with RIN\_PD to generate a 0x0 frame
in case of pin loss (leading to CRC violation in safety applications). Its buffer is enabled only in the Normal
state.

UM3187 - Rev 1 page 4/35



- SDO is always configured as a digital output. Its buffer is enabled only if NCS is asserted. An external pull
  up/pull down resistor defines the inactive level of the line.
- SCK, NCS can be either configured as a digital input (NSLAVE = 0, SPI slave) or as a digital output (NSLAVE = 1, SPI master).

The selective enable/disable of the buffers helps reducing the power consumption of the device when the SPI works at high frequencies.

### 1.2.2 CPOL and CPHA

The following table shows CPOL and CPHA settings according to different SPI modes.

**CPOL** Capture SCK-Edge SPI mode СРНА Shift SCK-Edge 0 0 0 Falling Risina 0 1 1 Rising Falling 2 1 0 Falling Rising 3 1 1 Falling Rising

Table 1. SPI mode configuration

Clock polarity has no significant effect on the transfer format. The commutation of this bit causes the inversion of the clock signal (active high becomes active low and idle low becomes idle high). Clock phase settings, however, allow selecting one of two different transfer times. The master configures the clock polarity (CPOL) and the clock phase (CPHA) to be aligned with the slave device requirements. These parameters determine when data need to be changed according to the clock line and which is the clock level when the clock is not active.

CPOL assigns a clock level when the clock is not active. The clock signal (SCK) can be inverted (CPOL = 1) or not activated (CPOL = 0). For the inverted clock signal, the first clock edge is falling. For the first not inverted clock signal, the first clock edge is rising.

CPHA is used to move the capture phase. If CPHA = 0, data are sampled on the leading (first) clock edge.

There are four possible modes that can be used in a SPI protocol:

1. For CPOL = 0, the clock basic value is zero. For CPHA = 0, data are sampled on the clock rising edge and are shifted on the clock falling edge.





Figure 7. TXEN pin

UM3187 - Rev 1 page 5/35



2. For CPOL = 0, the clock basic value is zero. For CPHA = 1, data are sampled on the clock falling edge and are shifted on the clock rising edge.

Figure 8. SPI protocol mode 1



3. For CPOL = 1, the clock basic value is 1. For CPHA = 0, data are sampled on the clock rising edge and are shifted on the clock falling edge.

Figure 9. SPI protocol mode 2



UM3187 - Rev 1 page 6/35



For CPOL = 1, the clock basic value is 1. For CPHA = 1, data are sampled on the clock falling edge and shifted on the clock rising edge.

Figure 10. SPI mode 3

CPOL=1 CPHA=1

SCK SS 3 5 6 4 3 6 8 4

#### 1.2.3 **NSLAVE**

The NSLAVE pin is latched by the standby logic in the Trimming & Config Latch state. It must be either shorted to VDD or to GND. The internal pull-down is enabled only while in Trimming & Config Latch state. This allows reducing power consumption. Once Trimming & Config Latch state is left, the NSLAVE input buffer is permanently disabled, since it is no longer needed.

NSLAVE selects the SPI master (NSLAVE = 1) or slave (NSLAVE = 0) operation and determines the digital I/Os configuration.

To increase immunity to BCI and guarantee a correct latch of the NSLAVE pin during each power-up, the input is filtered with an integrated RC filter.

#### DIS 1.2.4

DIS is a digital input-output pin that features an internal pull-up resistor towards V3V3 STBY. Its purpose is to be driven by open-drain outputs. Its functionality is summarized as follows:

- Input: is an active high disabling input driven by the MCU:
  - When DIS is released by the MCU longer than TRC DELAY+TDIS DEGLITCH, the device starts the Go To Sleep sequence that brings the L9963T to the Stand-by state.
  - When DIS is pulled down by the MCU longer than TRC DELAY + (1/fSTBY OSC), the device moves from the Stand-by state to the Regulators enabling state and then to the Normal state.
- Output: when L9963T is in the Stand-by state, and a wake-up event by isolated SPI occurs, it moves to the Regulators enabling state and then to the Normal state. Once the latter is reached, DIS is internally pulled down by logic for TDIS\_PULLDOWN to trigger an interrupt in the MCU or a wake-up event. After TDIS PULLDOWN expires, DIS is released and, if not kept low by an external source, the L9963T moves back to the Stand-by state. To protect DIS internal open drain driver in case of external short to VDD, a current limitation circuitry limits the current to IDIS LIM.

#### 1.2.5 **BNE/CPOL**

BNE/CPOL is a digital input/output pin whose configuration depends on the value of NSLAVE latched during Trimming & Config Latch:

When NSLAVE = 0 (slave configuration), this pin acts as BNE (buffer not empty) digital output. Its purpose is to implement interrupt-based communication with the MCU. When asserted high, the RX queue stores at least one frame.

UM3187 - Rev 1 page 7/35



- When NSLAVE = 1 (master configuration), this pin acts as a digital input for the selection of CPOL (clock polarity):
  - CPOL = 0 (shorted to GND) implies that the clock inactive level (when NCS is high) is low.
  - CPOL = 1 (shorted to VDD) implies that the clock inactive level is high. The internal pull-down is always enabled during Trimming & Config Latch and in Normal state. The BNE output buffer is disabled if NSLAVE = 1 has been latched during Trimming & Config Latch. The CPOL input buffer is permanently enabled.

In case NSLAVE = 0 has been latched during Trimming & Config Latch, BNE output buffer is kept enabled while in the Normal state. A short to GND/VDD detection is implemented to protect the BNE output buffer. If the value forced on the BNE output buffer differs from the one sampled by the CPOL input buffer for more than TBNE\_SHORT\_DET, the BNE output buffer is put into HiZ. Automatic re-engagement of the BNE output buffer occurs upon the next wakeup sequence (MCU needs to toggle DIS pin).

#### 1.2.6 TXEN/CPHA

TXEN\_CPHA is a digital input pin whose configuration depends on the value of NSLAVE latched during Trimming & Config Latch:

- When NSLAVE = 0 (slave configuration) the pin works as a transmitter enabling TXEN:
  - The MCU should release TXEN (or pull it up actively) prior to NCS assertion to enable the transmission of the data from SDI input buffer to the TX queue (and then to the isolated SPI interface).
  - If the communication protocol does not feature any burst read capability, each command sent by the
    master unit generates a single answer from the addressed slave unit. Hence, the TXEN pin can be
    connected to VDD to keep the transmitter permanently enabled.
  - In case of burst read operations, where the user software has to empty the RX queue without transmitting any frame on the isolated SPI, the TXEN input must be pulled down before beginning the burst read.
  - Even if data on the SDI line is discarded while TXEN = 0, it is highly recommended that the MCU sends dummy frames (or intentionally corrupted frames) on the SDI line during the burst read.
     In the event of TXEN stuck high, such frames generate errors according to the implemented communication protocol.
    - To avoid chopping frames currently being transmitted, the TXEN pin is latched upon NCS assertion. Therefore, it must be stable at least TTXEN\_DEGLITCH + TTXEN\_SETUP before NCS assertion. Moreover, TXEN must be kept stable TTXEN\_HOLD after NCS assertion to fulfil hold time constraints.
- When NSLAVE = 1 (master configuration), this pin acts as a digital input for the selection of CPHA (clock phase). It is latched during Trimming & Config Latch and should be therefore either shorted to GND or to VDD:
  - CPHA = 0 (shorted to GND) implies that the SDI signal is sampled upon the first SCK edge after NCS assertion.
  - CPHA = 1 (shorted to VDD) implies that the SDI signal is sampled upon the second SCK edge after NCS assertion.

The internal pull-up is enabled when L9963T is in Trimming & Config Latch and is kept enabled in the Normal state to allow a correct driving of the pin by the open-drain output of the MCU. Moreover, in case of pin loss, the pull-up guarantees a limp home operation where the transmitter is always enabled. To guarantee stand-by consumption requirements, the pull-up is disabled while in the Stand-by state.

### **1.2.7 TXAMP**

TXAMP pin can be used to switch between the two possible ISOline TX amplitude configurations:

- TXAMP = 0 selects low TX amplitude (RDIFF\_ISO\_OUTL)
- TXAMP = 1 selects high TX amplitude (RDIFF ISO OUTH)

TXAMP sampling depends on the device state and configuration.

UM3187 - Rev 1 page 8/35



Table 2. TXAMP sampling strategy

| L9963T<br>state                                                                                                                                                                                              | L9963T<br>configuration      | TXAMP sampling                                                                                                                                                                                                                                                                                                                                    | Note                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Normal Slave (NSLAVE = 0)                                                                                                                                                                                    |                              | The TXAMP pin is latched upon NCS assertion. Therefore, it must be stable at least TTXAMP_DEGLITCH + TTXAMP_SETUP before NCS assertion. Moreover, TXAMP must be kept stable TTXAMP_HOLD after NCS assertion in order to fulfil hold time constraints.                                                                                             | In case several SPI frames<br>are being pushed into the<br>TX queue, the setting<br>applied depends on the last                               |
| State                                                                                                                                                                                                        | 0)                           | The new amplitude setting is applied to the TX interface after the SPI frame has been completely transmitted over the isolated SPI interface. This allows Managing ISOFREQ And TXAMP Pins For Communicating With L9963.                                                                                                                           | one latched (no pipelining supported).                                                                                                        |
| Normal state  Normal state  Normal state  Normal state  (TTXAMP_SETUP and TTXAMP_HOLI apply) and deglitched (TTXAMP_DEGLITO but it is not latched upon NCS assertion. setting is applied to the TX interface |                              | The TXAMP setting is simply resynchronized (TTXAMP_SETUP and TTXAMP_HOLD requirements still apply) and deglitched (TTXAMP_DEGLITCH filter still present), but it is not latched upon NCS assertion. The new amplitude setting is applied to the TX interface as soon as the transmission of the SPI frame over the isolated SPI interface begins. | In case several SPI frames are being pushed into the TX queue, the setting applied depends on the last one latched (no pipelining supported). |
| Stand-by<br>state                                                                                                                                                                                            | Slave/Master<br>(NSLAVE = X) |                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                               |
| Reset<br>state                                                                                                                                                                                               | Slave/Master<br>(NSLAVE = X) | The initial TXAMP setting is latched during the first power up sequence. Hence, the TXAMP pin shall be stable before VDD is applied and shall not change during TFIRST_POWERUP.                                                                                                                                                                   | -                                                                                                                                             |

It is recommended to apply the same TXAMP settings to all the devices communicating on the bus, to keep a constant SNR in every communication phase.

To meet stand-by consumption requirements, MCU must release the open drain output connected to TXAMP while L9963T is in the Stand-by state.

### 1.2.8 SPICLKFREQ

SPICLKFREQ pin is an analog input, compared to four thresholds by a set of analog comparators.

An external resistor RCLKPD must be connected between SPICLKFREQ and GND, in order to generate a voltage VSPICLKFREQ = RCLKPD \* ISPICLKFREQPU.

The code obtained from these 4 comparator outputs is latched in the Trimming & Config Latch to determine the SPI clock frequency when L9963T works in master mode (NSLAVE = 1).

In the AEK-COM-ISOSPI1 the SPICLKFREQ is fixed at 250 kHz.

### 1.2.9 ISOP and ISOM

The isolated SPI interface allows units with different ground levels and/or on different boards to communicate with each other. Physically, the interface is based on twisted-pair wire.

Table 3. Pins used as isolated SPI

| L9963T Pin | SPI function                       | Configuration       |
|------------|------------------------------------|---------------------|
| ISOP       | positive differential input/output | Analog Input/Output |
| ISOM       | negative differential input/output | Analog Input/Output |

Table 4. Isolated SPI quick look

| Parameter     | Description                                       |  |
|---------------|---------------------------------------------------|--|
| Protocol      | Half-Duplex / Out of frame                        |  |
| Max. Bit-rate | 2.66 Mbps (high speed configuration, ISOFREQ = 1) |  |

UM3187 - Rev 1 page 9/35



| Parameter                                                                        | Description |
|----------------------------------------------------------------------------------|-------------|
| 333 kbps (low speed configuration, ISOFREQ = 0, default if pin is left floating) |             |

The transmission line on the isolated SPI exploits a single twisted pair. Communication data is transmitted/received over a pulse-shaped signal, in a half-duplex protocol.

Line bit rate can be selected by programming the ISOFREQ device pin.

A single bit is made of a pulse time (TPULSE) followed by two pauses (2TPULSE):

- TPULSE = 2TBIT HIGH LOW FAST for the high speed configuration (ISOFREQ = 1)
- TPULSE = 2TBIT HIGH LOW SLOW for the low speed configuration (ISOFREQ = 0)

An isolated receiver and transmitter are connected to the couple of pins and ISOP/M. Depending on the communication phase, they can be enabled or disabled.

The receiver can convert a differential input signal into a single ended signal that is provided to the logic:

- While in Normal state, to guarantee correct communication, the input common mode must stand within VCM\_ISO\_IN limits.
- When in Stand-by state, the ISOP and ISOM pins are not biased with a common mode. If the device
  receives a series of differential pulses longer than NMIN\_ISO\_WAKEUP\_EDGES, a wakeup condition is
  triggered. Pulse amplitude must be higher than Wakeup thr to be counted.

### **1.2.10** ISOFREQ

ISOFREQ pin is a digital input used to switch ISOline bit rate:

- ISOFREQ = 1 selects fast operation: bit time is TBIT\_LENGTH\_FAST
- ISOFREQ = 0 selects slow operation: bit time is TBIT\_LENGTH\_SLOW

ISOFREQ sampling depends on device state and configuration.

Table 5. ISOFREQ sampling strategy

| L9963T<br>state                          | L9963T<br>configuration      | ISOFREQ sampling                                                                                                                                                                                                                                                           | Note                                                                                                                                                |
|------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          | Slave (NSLAVE =              | The ISOFREQ pin is latched upon NCS assertion. Therefore, it must be stable at least TISOFREQ_DEGLITCH + TISOFREQ_SETUP before NCS assertion. Moreover, ISOFREQ must be kept stable TISOFREQ_HOLD after NCS assertion in order to fulfil hold time constraints.            | In case several SPI frames                                                                                                                          |
| Normal<br>state                          | 0)                           | The new bit rate setting is immediately applied to the RX interface, while it is applied to the TX interface after the SPI frame has been completely transmitted over the isolated SPI interface. This allows Managing ISOFREQ And TXAMP Pins For Communicating With L9963 | are being pushed into the TX queue, the setting applied once the TX interface is in idle depends on the last one latched (no pipelining supported). |
|                                          | Master (NSLAVE = 1)          | The ISOFREQ setting is simply resynchronized (TISOFREQ_SETUP and TISOFREQ_HOLD requirements still apply) and deglitched (TISOFREQ_DEGLITCH filter still present), but it is not latched upon NCS assertion.                                                                |                                                                                                                                                     |
| Stand-by Slave/Master state (NSLAVE = X) |                              | The new ISOFREQ setting is latched during the wake up sequence. Hence, the ISOFREQ pin shall be stable TISOFREQ_SETUP before the DIS high → low transition is applied and shall not change during TWAKEUP.                                                                 | -                                                                                                                                                   |
| Reset<br>state                           | Slave/Master<br>(NSLAVE = X) | The initial ISOFREQ setting is latched during the first power up sequence. Hence, the ISOFREQ pin shall be stable before VDD is applied and shall not change duringTFIRST_POWERUP.                                                                                         | -                                                                                                                                                   |

UM3187 - Rev 1 page 10/35



### 2 Power supply

The figure below lists the product power supply ranges.



- Within the range of functionality, the part operates as specified and without parameter deviations. All the functionalities and the electrical parameters are guaranteed.
- If either the upper or the lower limited operating range is reached, the device may not operate properly.

  Only a limited set of functionalities and electrical parameters are guaranteed. However, neither damage nor parameter deviation occurs, and the device operates properly once returned to the range of functionality.
- If the absolute maximum rating (AMR) is violated, permanent damage or parametric deviation may occur.

Note: All voltages are related to the potential at substrate ground GND.

UM3187 - Rev 1 page 11/35



### 3 Finite state machine

Reset

Device is powered up by VDD
Power on reset negative released

Wakeup event (DIS pin pulled down or ISOline activity) or FirstPowerupDone = 0

Regulators enabling

FirstPowerupDone = 1
POR\_MAIN released

FirstPowerupDone = 0
POR\_MAIN released

FirstPowerupDone = 0
POR\_MAIN released

FirstPowerupDone = 1
FirstPowerupDone = 1
POR\_MAIN released

FirstPowerupDone = 1

Figure 12. Finite state machine

Different state transition sequences occur according to the following different scenarios:

- First power-up: Reset state → Stand-by state → Regulators enabling state → Trimming & Config Latch →
  Normal state. The first power-up sequence lasts TFIRST\_POWERUP.
- Wake up: Stand-by state → Regulators enabling state → Normal state. In case of wakeup triggered by DIS release, the state transition is the same. The wakeup sequence lasts TWAKEUP.
- Go To Sleep: Normal state → Regulators disabling state → Stand-by state. The go to sleep sequence lasts TGO2SLP.

### 3.1 Reset state

When VDD is below the value triggering the power-up, the device is not functional. No operation is possible while under reset.

### 3.2 Stand-by state

This state is entered either from the Reset state or from the Regulators disabling state:

- Transition from the Regulators disabling state only occurs upon DIS low → high transition while L9963T is
  in the Normal state. DIS input signal is filtered in both analog (TRC\_DELAY) and digital (TDIS\_DEGLITCH)
  domains.
- Transition from Reset state only occurs upon first power-up, after POR\_STBY release.

While in standby, the logic checks the FirstPowerupDone latch, whose reset value is '0' upon the first power-up:

- In case FirstPowerupDone = 0, the first power-up has never been accomplished. Hence, the device moves to the Regulators enabling state, regardless of any wakeup source state.
- In case FirstPowerupDone = 1, the first power-up has already been accomplished. Hence, the device is kept in the Stand-by state and eventual transitions are determined by the wakeup sources.

When a wakeup source is asserted, it triggers the wakeup sequence that moves the L9963T to the Regulators enabling state. The possible wakeup sources are:

- The de-assertion of DIS pin, pulled down by an external open drain source (TRC\_DELAY + (1/fSTBY\_OSC) filter applies).
- The detection of at least NMIN\_ISO\_WUP\_EDGES pulses within TWAKEUP\_TIMEOUT\_ISO on the ISOline.

### 3.3 Regulators enabling state

This is a transitional state reached from the Stand-by state.

While L9963T is in this state, it enables the V3V3 regulator and the OSCI\_MAIN.

During this process lasting TWAKEUP, the device must not be sensitive to DIS pin, SPI interface, and ISOline sources. Once a wakeup sequence starts, it cannot be interrupted.

UM3187 - Rev 1 page 12/35



The Regulators enabling state is left upon Fs\_MAIN release. The next state depends on the FirstPowerupDone latch:

- In case FirstPowerupDone = 0, the first power-up has never been accomplished. Hence, the device moves to the Trimming & Config Latch.
- In case FirstPowerupDone = 1, the first power-up has already been accomplished. Hence, the device
  moves to the Normal state.

### 3.4 Trimming and configuration latch state

This state is entered from the Regulators enabling state the first time the device is powered up (FirstPowerupDone = 0).

While in this state, the device must:

- Download the OTP data.
- Latch the configuration inputs (NSLAVE, CPHA, CPOL, SPICLKFREQ), storing them into the STBY logic registers.

SPICLKFREQ comes from a set of comparators that must be checked by an internal BIST before latching the comparator output. In case the BIST fails, a default 0 value (corresponding to the slowest SPI configuration) must be stored into the related stand-by internal register.

Stand-by registers hold their value as long as the POR\_STBY stays de-asserted.

While in this state, L9963T is not sensitive to SPI/VIF activity and wakeup conditions (DIS/VIF).

This phase must safely go to an end and may last a maximum time interval of TSETUP LATCH.

After this phase finishes, the FirstPowerupDone latch is set to "1" in the standby logic and the device moves to the Normal state.

### 3.5 Normal state

While in this state, all references and main logic are powered. Both communication interfaces are ready for data TX/RX activity.

This state is reached either from Trimming & Config Latch (first power up) or from Regulators enabling state (following a normal wakeup sequence):

• When woken up by an activity on the ISOline, once the Normal state is reached, the device must neglect the DIS pin value (even if it is high) and, on the contrary, it must drive the DIS pin low for TDIS\_PULLDOWN (DIS is an input/output pin). Such a strategy allows generating an interrupt into the MCU, or triggering a wakeup. Once TDIS\_PULLDOWN expires, L9963T releases the DIS pull down and unmasks the DIS deglitched input. If the MCU has been correctly woken up, it pulls down the DIS pin externally, so that L9963T is kept in the Normal state.

Otherwise, DIS is found asserted (high) and the IC moves back to the Regulators disabling state.

 When woken up by the DIS pin itself, the device must start listening to the deglitched DIS pin as soon as it enters the Normal state.

To detect a "Go to Sleep" condition, the DIS pin status must be constantly monitored through a synchronous deglitch filter (TDIS\_DEGLITCH, implemented in the main logic through the main oscillator).

Its effect is cascaded to the passive RC filter placed on the input comparator (TRC\_DELAY).

When DIS is sensed "high", the main logic raises a signal that triggers the "Go To Sleep" sequence in the IC FSM. L9963T moves to the Regulators disabling state and finally to the Stand-by state.

### 3.6 Regulators disabling state

This is a transitional state reached from the Normal state during a "Go To Sleep" sequence.

While in this state, the V3V3\_MAIN regulator and main oscillator enable signals are de-asserted, leading to POR MAIN assertion and reset of the main logic.

POR MAIN assertion marks the transition to the Stand-by state.

Even if the main logic is still alive while the device is in the Regulators disabling state, it must not be sensitive to external pins (wakeup sources, COM interfaces, etc.). Once started, a "Go To Sleep" sequence cannot be interrupted.

UM3187 - Rev 1 page 13/35



### 4 AutoDevKit ecosystem

The application development employing the AEK-COM-ISOSPI1 board takes full advantage of the AutoDevKit ecosystem, whose basic components are:

- AutoDevKit Studio IDE (STSW-AUTODEVKIT)
- PLS UDE and OpenOCD programmers and debuggers

### 4.1 Component folder structure

Figure 13. AEK-COM-ISOSPI1 component folder structure



The cfg folder contains all the configuration files.

The doc folder contains the doxygen documentation.

The lib folder contains the component header and source files.

### 4.2 Software component architecture (AEK-COM-ISOSP1 Component RLA)

The following image shows the architecture of the software components that we created for the AEK-COM-ISOSPI1 evaluation board, which consists of the following layer:

AEK-COM-ISOSPI1 IId

Figure 14. Software architecture



The AEK-COM-ISOSP1\_IId contains all the APIs:

- To configure L9963T transceiver as a master or a slave SPI.
- To configure amplitude and frequency of the ISOSP1 signal.
- To enable/disable the L9963T transceiver.
- To enable/disable ISOSPI communication.

UM3187 - Rev 1 page 14/35



### 5 Available APIs

The APIs listed in the following tables are declared in the "AEK\_COM\_ISOSPI1\_IId.h" file.

Table 6. APIs for the AEK-COM-ISOSPI1

| API name                                                                                  | Description                                                                                                                  |
|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| l9963t_PALWritePad (ISOSPI_Driver_t l9963t, ISOSPI_pal_ch_t l9963t_pal_ch, uint8_t value) | Sets the logical state of a pad of the AEK-COM-ISOSPI1.                                                                      |
| l9963t_PALReadPad (ISOSPI_Driver_t l9963t, ISOSPI_pal_ch_t l9963t_pal_ch)                 | Reads the logical state of a pad of the AEK-COM-ISOSPI1.                                                                     |
| AEK_COM_ISOSPI_SetAsSlave (ISOSPI_DEVICE dev)                                             | Sets the AEK-COM-ISOSPI1 as a slave.                                                                                         |
| AEK_COM_ISOSPI_EnableTransceiverComm (ISOSPI_DEVICE dev)                                  | Enables the transceiver communication.                                                                                       |
| AEK_COM_ISOSPI_DisableTransceiverComm (ISOSPI_DEVICE dev)                                 | Disables the transceiver communication.                                                                                      |
| AEK_COM_ISOSPI_SetAsMaster (ISOSPI_DEVICE dev)                                            | Sets the AEK-COM-ISOSPI1 as a master.                                                                                        |
| AEK_COM_ISOSPI_SampleSPI_firstclk (ISOSPI_DEVICE dev)                                     | Samples the SPI first clock.                                                                                                 |
| AEK_COM_ISOSPI_SampleSPI_secondclk (ISOSPI_DEVICE dev)                                    | Samples the SPI second clock.                                                                                                |
| AEK_COM_ISOSPI_CPOL_low (ISOSPI_DEVICE dev)                                               | Sets CPOL low (this function can be used only if NSLAVE = 1).                                                                |
| AEK_COM_ISOSPI_CPOL_high (ISOSPI_DEVICE dev)                                              | Sets CPOL high (this function can be used only if NSLAVE = 1).                                                               |
| AEK_COM_ISOSPI_EnableTransceiver (ISOSPI_DEVICE dev)                                      | Enables the transceiver.                                                                                                     |
| AEK_COM_ISOSPI_DisableTransceiver (ISOSPI_DEVICE dev)                                     | Disables the transceiver.                                                                                                    |
| AEK_COM_ISOSPI_SetISOCommSlow (ISOSPI_DEVICE dev)                                         | Sets the ISOFREQ to low (this establishes a slow communication equal to 333 kHz).                                            |
| AEK_COM_ISOSPI_SetISOCommFast (ISOSPI_DEVICE dev)                                         | Sets the ISOFREQ to high (this establishes a fast communication equal to 2.66 MHz).                                          |
| AEK_COM_ISOSPI_ISOTX_Attenuate (ISOSPI_DEVICE dev)                                        | Sets TXAMP to low (SPI signal not amplified).                                                                                |
| AEK_COM_ISOSPI_ISOTX_Amplify (ISOSPI_DEVICE dev)                                          | Sets TXAMP to high (SPI signal amplified).                                                                                   |
| AEK_COM_ISOSPI_GetFault (ISOSPI_DEVICE dev)                                               | Reads the value of the FAULT pin and updates a fault flag, which is included in the driver data structure (ISOSPI_Driver_t). |
| AEK_COM_ISOSPI_ConfigMode (ISOSPI_DEVICE dev, ISOSPI_mode_t l9963t_mode)                  | Configures the NSLAVE according to the user interface configuration.                                                         |
| AEK_COM_ISOSPI_ConfigISOFreq (ISOSPI_DEVICE dev, ISOSPI_iso_freq_t I9963t_iso_freq)       | Configures the ISOFREQ according to the user interface configuration.                                                        |
| AEK_COM_ISOSPI_ConfigISOAmp (ISOSPI_DEVICE dev, ISOSPI_tx_amp_t I9963t_tx_amp)            | Configures the TXAMP according to the user interface configuration.                                                          |
| AEK_COM_ISOSPI_ConfigCPOL (ISOSPI_DEVICE dev, ISOSPI_master_cpol_t I9963t_cpol)           | Configures the CPOL according to the user interface configuration.                                                           |
| AEK_COM_ISOSPI_ConfigCPHA (ISOSPI_DEVICE dev, ISOSPI_master_cpha_t l9963t_cpha)           | Configures the CPHA according to the user interface configuration.                                                           |
| config_Transceiver (ISOSPI_Driver_t driver)                                               | Comprehensive API, invoking ConfigMode, ConfigISOFreq, ConfigISOAmp, ConfigCPOL, ConfigCPHA functions.                       |
| slave_example_config (ISOSPI_DEVICE dev)                                                  | Slave configuration function example, which drives every configuration pin of the transceiver setting it as a slave.         |
| master_example_config (ISOSPI_DEVICE dev)                                                 | Master configuration function example, which drives every configuration pin of the transceiver setting it as a master.       |

UM3187 - Rev 1 page 15/35



### 6 Using AEK-COM-ISOSP1 within AutoDevKit

In this example, we created an application for the AEK-COM-ISOSP1 configured as a slave transceiver. We used the AEK-MCU-C4MLIT1 as the microcontroller board.

To recreate this scenario, follow the procedure below.

- Step 1. Create a new SPC5-STUDIO application for the SPC58EC series microcontroller and add the following components:
  - SPC58ECxx Init Package Component RLA
  - SPC58ECxx Low Level Drivers Component RLA
  - AutoDevKit Init Package Component

These components must be added immediately, or the other components will not be visible.



Figure 15. Adding components

- Step 2. Add the following additional components
  - AEK-COM-ISOSPI1 Component RLA



Figure 16. Adding components

UM3187 - Rev 1 page 16/35



Step 3. Select [AEK-COM-ISOSPI1 Component RLA] to open the [Application Configuration] window.

DeAllocation DeAllocation



Figure 17. Adding components

Step 4. Click on [+] to add a new element to the board list.



Figure 18. Adding components

UM3187 - Rev 1 page 17/35



**Step 5.** Double-click on the newly added element to configure the board.



Allocation Allocation

DeAllocation DeAllocation

Figure 19. AEK-COM-ISOPI1 configuration

UM3187 - Rev 1 page 18/35



#### Step 6.

- Select scenario "two"
- Select DSPI and CS
- Select the "cfg" configuration as "micro"
- Select TxAmp as "not amplified"
- Select ISOFreq as "333 KHz"
- Select Master Clock Frequency as "5 MHz"
- Select CPOL and CPHA as "low"

Figure 20. Available scenarios



UM3187 - Rev 1 page 19/35



Figure 21. AEK-COM-ISOPI1: scenario number two configuration



Step 7. Click on the "Allocation" button to allocate the AEK-POW-ISOSPI1 component.





Step 8. Click on "Board View" to see Hardware connection between the AEK-MCU-C4MLIT1 board and the AEK-COM-ISOSP1 dongle.

Figure 23. Hardware connection through the Board View



UM3187 - Rev 1 page 20/35



#### Step 9. Create your main application example as follows:

```
#include "components.h"
#include "AEK COM ISOSPI1 lld.h"
* Application entry point.
int main(void) {
 static <u>uint8 t</u> txbuf[512];
 static <u>uint8_t</u> rxbuf[512];
 /\star Initialization of all the imported components in the order specified in
    the application wizard. The function is generated automatically.*/
 componentsInit();
 irqIsrEnable();
  /*Set AEK_COM_ISOSPI1 as <a href="mailto:spi">spi</a> slave*/
 AEK COM ISOSPI SetAsSlave(ISOSPI DEVO);
 /*Set AEK COM ISOSPI1 as ISO fast speed*/
 AEK COM ISOSPI SetISOCommFast(ISOSPI DEVO);
  /*Set AEK COM ISOSPI1 as High Amplitude*/
 AEK_COM_ISOSPI_ISOTX_Amplify(ISOSPI_DEV0);
  /*Enable AEK COM ISOSPI1*/
 AEK COM ISOSPI EnableTransceiver(ISOSPI DEVO);
  /*Start SPI low level driver*/
 spi_lld_start(AEK_ISOSPI_ARRAY_DRIVER[0].spip, AEK_ISOSPI_ARRAY_DRIVER[0].spicfqp)
  /* Application main loop.*/
  for (;;) {
      /*Enable ISO communication AEK COM ISOSPI1*/
      AEK COM ISOSPI EnableTransceiverComm(ISOSPI DEV0);
      /*Send/Receive 512 byte via ISOSPI protocol*/
      spi lld exchange (AEK ISOSPI ARRAY DRIVER[0].spip, 512, txbuf, rxbuf);
      /*Disable ISO communication AEK COM ISOSPI1*/
      AEK_COM_ISOSPI_DisableTransceiverComm(ISOSPI_DEV0);
      /*Wait for 500 <u>msec</u>*/
      osalThreadDelayMilliseconds(500);
```

Note: This application is able to send and receive 512 bytes via ISOSPI protocol by using the AEK-COM-ISOSP1 board with L9963T.

UM3187 - Rev 1 page 21/35



Step 10. Generate and compile your application.

Figure 24. Application generation menu



**Step 11.** Open "UDE Starterkit" and import the ".wsx" file with workspace to flash your application.



Figure 25. UDE initial window

**Step 12.** Switch on your AEK-MCU-C4MLIT1 and enjoy your AEK-COM-ISOSP1 application.

UM3187 - Rev 1 page 22/35



### 6.1 Available demos for AEK-COM-ISOSP1

In the Autodevkit release 2.1.0 (or higher), there are the following available demos for the AEK-COM-ISOSP1:

- SPC58EC ISOSPI1\_LEDdriver test application for discovery, which is a demo application for the AEK-MCU-C4MLIT1 to drive an AEK-LED-21DISM1 LED driver board with the AEK-COM-ISOSP1;
- SPC582B ISOSPI1\_LEDdriver test application for discovery, which is a demo application for the AEK-MCU-C1MLIT1 to drive an AEK-LED-21DISM1 LED driver board with AEK-COM-ISOSP1.

#### 6.1.1 AEK-COM-ISOSP1 demo with the AEK-LED-21DISM1 LED driver

This application is based on the SPC58EC microcontroller. It is able to send multiple ReadROMRegisters to read the content of ROM\_DEVICE\_N4 (0x05) register of the AEK-LED-21DISM1 LED driver via ISOSP1 protocol by using the AEK-COM-ISOSP1 board transceiver configured as a SPI slave.

Find below the main code for the SPC58EC - ISOSPI1\_LEDdriver test application for discovery demo:

```
#include "components.h"
#include "AEK_COM_ISOSPI1_lld.h"
#include "AEK COM ISOSPI1 cfg.h"
#include "AEK LED 21DISM1.h"
#include "spi_lld.h"
#include "spi_lld_cfg.h"
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
* Application entry point.
* /
int main(void) {
 uint8 t Data[4];
  /* Initialization of all the imported components in the order specified in
    the application wizard. The function is generated automatically.*/
  componentsInit();
  /* Enable Interrupts. */
  irqIsrEnable();
  /* Enabling both the AEK-COM-ISOSP1 tranceiver */
  AEK COM ISOSPI EnableTransceiver (ISOSPI DEVO);
  AEK COM ISOSPI EnableTransceiver (ISOSPI DEV1);
  /* Reset AEK-LED-21DISM1 */
  ClearAndTrigger(AEK LED 21DISM1 DEV0);
  osalThreadDelayMicroseconds(50);
  /*Activate Boost 1 and 2 on AEK-LED-21DISM1*/
  ActivateBoostBuckOne (AEK LED 21DISM1 DEV0);
  ActivateBoostBuckTwo (AEK LED 21DISM1 DEV0);
  osalThreadDelayMicroseconds(50);
  /*Activate Buck 1 and 2 on AEK-LED-21DISM1*/
  ActivateBuckDev(AEK LED 21DISM1 DEV0,DEV1, BUCK1);
  ActivateBuckDev(AEK LED 21DISM1 DEV0, DEV1, BUCK2);
  /* Application main loop.*/
     ^{\prime\star} Asks multiple times to the AEK-LED-21DISM1 the value of one of ROM DEVICE N4 ^{\star\prime}
         AEK_LED_21DISM1drv_ReadROMRegisterSPC(AEK_LED_21DISM1_DEV0, ROM_DEVICE_N4 ,Data);
          AEK LED 21DISM1drv ReadROMRegisterSPC(AEK LED 21DISM1 DEV0, ROM DEVICE N4 ,Data);
          AEK LED 21DISM1drv ReadROMRegisterSPC(AEK LED 21DISM1 DEV0, ROM DEVICE N4 , Data);
          AEK_LED_21DISM1drv_ReadROMRegisterSPC(AEK_LED_21DISM1_DEV0, ROM_DEVICE_N4 ,Data);
          AEK LED 21DISM1drv ReadROMRegisterSPC(AEK LED 21DISM1 DEV0, ROM DEVICE N4 ,Data);
     osalThreadDelayMicroseconds(50);
```

UM3187 - Rev 1 page 23/35



### 7 Test results

The waveforms of the figure below show how a generic SPI signal is converted into an ISOSPI signal through the L9963T.

### In particular:

- The first and second waveforms from the bottom represent ISOL and ISOH signals, respectively, which are ISOSPI signals generated by the L9963T
- The middle waveform represents the CLK signal at a frequency of 250 KHz
- The top waveform represents the NCS signal: the Chip Select is falling at the beginning of the SPI packet and rising at the end of the SPI packet



Figure 26. Test result waveforms

UM3187 - Rev 1 page 24/35



## 8 Schematic diagram

Figure 27. AEK-COM-ISOSPI1 circuit schematic



UM3187 - Rev 1 \_\_\_\_\_\_ page 25/35



### 9 Bill of materials

Table 7. AEK-COM-ISOSPI1 bill of materials

| Item | Q.ty | Ref.                                                              | Part/Value                 | Description                                                | Manufacturer | Order code    |
|------|------|-------------------------------------------------------------------|----------------------------|------------------------------------------------------------|--------------|---------------|
| 1    | 2    | C1, C7                                                            | 22pF                       | 0603 - 50V - NP0 Class I                                   | WE           | 885012006053  |
| 2    | 2    | C2, C8                                                            | N.M.                       | 1206                                                       | N.M.         | N.M.          |
| 3    | 2    | C3, C4                                                            | 100nF                      | 0603 - 50V - X7R Class II                                  | WE           | 885012206095  |
| 4    | 1    | C5                                                                | 10nF                       | 0603 - 50V - X7R Class II                                  | WE           | 885012206089  |
| 5    | 3    | C6, C9, C10                                                       | 1uF                        | 0805 - 50V - X7R Class II                                  | WE           | 885012207103  |
| 6    | 2    | CN1, CN3                                                          |                            | 2.54mm - 1 row - KK254 - Male                              | WE           | 61900411121   |
| 7    | 1    | CN2                                                               |                            | 2.54mm - 1 row - KK254 - Male                              | WE           | 61900711121   |
| 8    | 1    | D1                                                                | SZMM3Z4V7T1G               | 4.7V Zener Voltage Regulators,<br>300mW                    | Onsemi       | SZMM3Z4V7T1G  |
| 9    | 1    | D2                                                                | Red                        | 0805 - Led Red - 2V                                        | WE           | 150080RS75000 |
| 10   | 1    | D3                                                                | Amber                      | 0805 - Led Amber - 2V                                      | WE           | 150080AS75000 |
| 11   | 1    | D4                                                                | Yellow                     | 0805 - Led Yellow - 2V                                     | WE           | 150080YS75000 |
| 12   | 1    | D5                                                                | Blue                       | 0805 - Led Blue - 3.2V                                     | WE           | 150080BS75000 |
| 13   | 2    | D6, D7                                                            | Green                      | 0805 - Led Green - 3.2V                                    | WE           | 150080GS75000 |
| 14   | 6    | JP1, JP2, JP3,<br>JP4, JP5, JP6                                   |                            | THT Vertical 3 pins Header, Pitch 2.54 mm, Single Row      | WE           | 61300311121   |
| 15   | 1    | JP7                                                               |                            | 2.54mm - 1 row                                             | WE           | 61300211121   |
| 16   | 1    | P1                                                                | 629004113921               | USB 2.0 Type A, Plug, Horizontal,<br>SMT, with Clip        | WE           | 629004113921  |
| 17   | 5    | Q1, Q2, Q3,<br>Q4, Q5                                             | BSS138Q                    | N-Channel Enhancement Mosfet                               | NEXPERIA     | BSS138Q-7-F   |
| 18   | 2    | R1, R3                                                            | 60.4                       | 0603 - ±1% - 0.1W                                          | Panasonic    | ERJ3EKF60R4V  |
| 19   | 11   | R2, R4, R5,<br>R9, R10, R11,<br>R18, R22,<br>R23, R24, R25        | 10K                        | 0603 - ±1% - 0.2W                                          | Panasonic    | ERJP03F1002V  |
| 20   | 2    | R6, R7                                                            | 680                        | 0603 - ±1% - 0.25W                                         | Panasonic    | ERJPA3F6800V  |
| 21   | 1    | R8                                                                | 0                          | 0603 - ±1% - 0.1W                                          | Panasonic    | ERJ3GEY0R00V  |
| 22   | 11   | R12, R17,<br>R19, R20,<br>R26, R27,<br>R28, R31,<br>R32, R33, R34 | 100                        | 0603 - ±1% - 0.25W                                         | Panasonic    | ERJPA3F1000V  |
| 23   | 3    | R13, R14, R21                                                     | 1.1k                       | 0603 - ±1% - 0.25W                                         | Panasonic    | ERJPA3F1101V  |
| 24   | 3    | R15, R16, R36                                                     | 750                        | 0603 - ±1% - 0.25W                                         | Panasonic    | ERJUP3D7500V  |
| 25   | 1    | R29                                                               | N.M.                       | 0603                                                       | N.M.         | N.M.          |
| 26   | 1    | R30                                                               | 110K                       | 0603 - ±1% - 0.25W                                         | Panasonic    | ERJPA3F1103V  |
| 27   | 1    | R35                                                               | N.M.                       | N.M.                                                       | N.M.         | N.M.          |
| 28   | 1    | T1                                                                | 125uH                      | Transformer for BMS                                        | WE           | 74941000      |
| 29   | 1    | U1                                                                | L9963T, SO-16              | Automotive general purpose SPI to isolated SPI transceiver | ST           | L9963T        |
| 30   | 1    | U2                                                                | USBLC6-2SC6Y2,<br>SOT23-6L | Automotive ESD protection for high speed interfaces.       | ST           | USBLC6-2SC6Y  |

UM3187 - Rev 1 page 26/35



| Item | Q.ty | Ref.        | Part/Value  | Description                                                 | Manufacturer | Order code  |
|------|------|-------------|-------------|-------------------------------------------------------------|--------------|-------------|
| 31   | 7    | for blister | 60900213421 | WR-PHD 2.54 mm Multi-Jumper<br>Jumper with Test Point       | WE           | 60900213421 |
| 32   | 2    | for blister | 61900411621 | WR-WTB 2.54 mm Female Terminal Housing                      | WE           | 61900411621 |
| 33   | 1    | for blister | 61900711621 | WR-WTB 2.54 mm Female Terminal Housing                      | WE           | 61900711621 |
| 34   | 16   | for blister | 61910113722 | WR-WTB 2.54 mm Female Crimp<br>Contact                      | WE           | 61910113722 |
| 35   | 4    | for blister | 970080365   | WA-SPAII Plastic Spacer Stud,<br>metric, internal/ internal | WE           | 970080365   |
| 36   | 4    | for blister | 97790403111 | WA-SCRW Pan Head Screw w. cross slot M3                     | WE           | 97790403111 |

UM3187 - Rev 1 page 27/35



## 10 Board versions

### Table 8. AEK-COM-ISOSPI1 versions

| Finished good        | Schematic diagrams                   | Bill of materials                   |  |  |
|----------------------|--------------------------------------|-------------------------------------|--|--|
| AEK\$COM-ISOSPI1A(1) | AEK\$COM-ISOSPI1A schematic diagrams | AEK\$COM-ISOSPI1A bill of materials |  |  |

<sup>1.</sup> This code identifies the AEK-COM-ISOSPI1 evaluation board first version.

UM3187 - Rev 1 page 28/35



### 11 Regulatory compliance information

### **Notice for US Federal Communication Commission (FCC)**

For evaluation only; not FCC approved for resale

FCC NOTICE - This kit is designed to allow:

(1) Product developers to evaluate electronic components, circuitry, or software associated with the kit to determine

whether to incorporate such items in a finished product and

(2) Software developers to write software applications for use with the end product.

This kit is not a finished product and when assembled may not be resold or otherwise marketed unless all required FCC equipment authorizations are first obtained. Operation is subject to the condition that this product not cause harmful interference to licensed radio stations and that this product accept harmful interference. Unless the assembled kit is designed to operate under part 15, part 18 or part 95 of this chapter, the operator of the kit must operate under the authority of an FCC license holder or must secure an experimental authorization under part 5 of this chapter 3.1.2.

### Notice for Innovation, Science and Economic Development Canada (ISED)

For evaluation purposes only. This kit generates, uses, and can radiate radio frequency energy and has not been tested for compliance with the limits of computing devices pursuant to Industry Canada (IC) rules.

À des fins d'évaluation uniquement. Ce kit génère, utilise et peut émettre de l'énergie radiofréquence et n'a pas été testé pour sa conformité aux limites des appareils informatiques conformément aux règles d'Industrie Canada (IC).

#### **Notice for the European Union**

This device is in conformity with the essential requirements of the Directive 2014/30/EU (EMC) and of the Directive 2015/863/EU (RoHS).

### Notice for the United Kingdom

This device is in compliance with the UK Electromagnetic Compatibility Regulations 2016 (UK S.I. 2016 No. 1091) and with the Restriction of the Use of Certain Hazardous Substances in Electrical and Electronic Equipment Regulations 2012 (UK S.I. 2012 No. 3032).

UM3187 - Rev 1 page 29/35



### **Revision history**

Table 9. Document revision history

| Date        | Revision | Changes          |
|-------------|----------|------------------|
| 14-Jun-2023 | 1        | Initial release. |

UM3187 - Rev 1 page 30/35



### **Contents**

| 1   | Hard                                       | dware overview                                                 | 3  |  |  |  |
|-----|--------------------------------------------|----------------------------------------------------------------|----|--|--|--|
|     | 1.1                                        | L9963T                                                         | 4  |  |  |  |
|     | 1.2                                        | Pin description                                                | 4  |  |  |  |
|     |                                            | 1.2.1 SPI                                                      | 4  |  |  |  |
|     |                                            | 1.2.2 CPOL and CPHA                                            | 5  |  |  |  |
|     |                                            | 1.2.3 NSLAVE                                                   | 7  |  |  |  |
|     |                                            | 1.2.4 DIS                                                      | 7  |  |  |  |
|     |                                            | 1.2.5 BNE/CPOL                                                 | 7  |  |  |  |
|     |                                            | 1.2.6 TXEN/CPHA                                                | 8  |  |  |  |
|     |                                            | 1.2.7 TXAMP                                                    | 8  |  |  |  |
|     |                                            | 1.2.8 SPICLKFREQ                                               | 9  |  |  |  |
|     |                                            | 1.2.9 ISOP and ISOM                                            |    |  |  |  |
|     |                                            | 1.2.10 ISOFREQ                                                 | 10 |  |  |  |
| 2   | Pow                                        | ver supply                                                     |    |  |  |  |
| 3   | Finit                                      | ite state machine                                              | 12 |  |  |  |
|     | 3.1                                        | Reset state                                                    | 12 |  |  |  |
|     | 3.2 Stand-by state                         |                                                                |    |  |  |  |
|     | 3.3                                        | Regulators enabling state                                      | 12 |  |  |  |
|     | 3.4 Trimming and configuration latch state |                                                                |    |  |  |  |
|     | 3.5                                        | Normal state                                                   | 13 |  |  |  |
|     | 3.6                                        | Regulators disabling state                                     | 13 |  |  |  |
| 4   | Auto                                       | oDevKit ecosystem                                              |    |  |  |  |
|     | 4.1                                        | Component folder structure                                     |    |  |  |  |
|     | 4.2                                        | Software component architecture (AEK-COM-ISOSP1 Component RLA) |    |  |  |  |
| 5   | Avai                                       | nilable APIs                                                   |    |  |  |  |
| 6   |                                            | ng AEK-COM-ISOSP1 within AutoDevKit                            |    |  |  |  |
|     | 6.1                                        | Available demos for AEK-COM-ISOSP1                             |    |  |  |  |
|     | 011                                        | 6.1.1 AEK-COM-ISOSP1 demo with the AEK-LED-21DISM1 LED driver  |    |  |  |  |
| 7   | Test                                       | t results                                                      |    |  |  |  |
| 8   |                                            | nematic diagram                                                |    |  |  |  |
| 9   |                                            | of materials                                                   |    |  |  |  |
|     |                                            |                                                                |    |  |  |  |
| 10  | Board versions                             |                                                                |    |  |  |  |
| 11  | Regulatory compliance information          |                                                                |    |  |  |  |
| Rev | ision                                      | ı history                                                      |    |  |  |  |



| List of tables  | 33 |
|-----------------|----|
| List of figures |    |

UM3187 - Rev 1



### **List of tables**

| Table 1. | SPI mode configuration            | j |
|----------|-----------------------------------|---|
| Table 2. | TXAMP sampling strategy9          | ) |
| Table 3. | Pins used as isolated SPI         | ) |
| Table 4. | Isolated SPI quick look           | ) |
| Table 5. | ISOFREQ sampling strategy         | ) |
| Table 6. | APIs for the AEK-COM-ISOSPI1      | j |
| Table 7. | AEK-COM-ISOSPI1 bill of materials | j |
| Table 8. | AEK-COM-ISOSPI1 versions          | 3 |
| Table 9. | Document revision history         | ) |



## **List of figures**

| Figure 1.  | SPI to ISOSPI conversion block diagram            | . 1 |
|------------|---------------------------------------------------|-----|
| Figure 2.  | AEK-COM-ISOSPI1                                   | . 2 |
| Figure 3.  | Hardware overview                                 | . 3 |
| Figure 4.  | Jumper configuration                              | . 3 |
| Figure 5.  | Jumpers on DIS pin                                | . 4 |
| Figure 6.  | TXEN pin                                          | . 4 |
| Figure 7.  | TXEN pin                                          | . 5 |
| Figure 8.  | SPI protocol mode 1                               | . 6 |
| Figure 9.  | SPI protocol mode 2                               | . 6 |
| Figure 10. | SPI mode 3                                        | . 7 |
| Figure 11. | Power supply ranges                               | 11  |
| Figure 12. | Finite state machine                              | 12  |
| Figure 13. | AEK-COM-ISOSPI1 component folder structure        | 14  |
| Figure 14. | Software architecture                             | 14  |
| Figure 15. | Adding components                                 | 16  |
| Figure 16. | Adding components                                 | 16  |
| Figure 17. | Adding components                                 | 17  |
| Figure 18. | Adding components                                 | 17  |
| Figure 19. | AEK-COM-ISOPI1 configuration                      | 18  |
| Figure 20. | Available scenarios                               | 19  |
| Figure 21. | AEK-COM-ISOPI1: scenario number two configuration | 20  |
| Figure 22. | Component allocation                              | 20  |
| Figure 23. | Hardware connection through the Board View        | 20  |
| Figure 24. | Application generation menu                       | 22  |
| Figure 25. | UDE initial window                                | 22  |
| Figure 26. | Test result waveforms                             | 24  |
| Figure 27. | AEK-COM-ISOSPI1 circuit schematic                 | 25  |



#### **IMPORTANT NOTICE - READ CAREFULLY**

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgment.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. For additional information about ST trademarks, refer to <a href="https://www.st.com/trademarks">www.st.com/trademarks</a>. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2023 STMicroelectronics – All rights reserved

UM3187 - Rev 1 page 35/35