

# AN4300 Application note

# Advanced light control and diagnostics using SPC56xBx/RPC56xBx and SPC56xCx microcontrollers

## Introduction

The members of the SPC56xBx/RPC56xBx and SPC56xCx families are high performance microcontrollers developed for car body application needs. These devices are especially useful in automotive light management applications and offer features to assist the car body system developer in writing optimized firmware with a very low CPU load.

This document offers an interesting example about the interconnection between the eMIOS, CTU, and ADC modules of the SPC56EC74 (one member of the SPC56xB/RPC56xBx/Cx family) in a lighting application, including the support of circuitry diagnostics, without placing an additional load on the MCU's CPU. This example is easily applied to each device of the SPC56xB/RPC56xBx/Cx family.

October 2015 DocID024675 Rev 3 1/40

Contents AN4300

## **Contents**

| 1   | Ligh | Lighting application design challenge 6         |      |  |
|-----|------|-------------------------------------------------|------|--|
|     | 1.1  | General light application aspects               | 6    |  |
|     | 1.2  | Driver signals characteristics                  | 7    |  |
| 1.3 |      | System proposal                                 | 7    |  |
|     | 1.4  | Diagnosis check                                 | 8    |  |
|     |      | 1.4.1 Digital diagnosis                         | 9    |  |
|     |      | 1.4.2 Analog diagnosis                          | 9    |  |
|     |      | 1.4.3 Serial diagnosis                          | 9    |  |
| 2   | SPC  | 56xBx/RPC56xBx features to cover lighting needs | . 11 |  |
|     | 2.1  | eMIOS (enhanced Modular Input/Output Subsystem) | 11   |  |
|     | 2.2  | CTU (Cross Triggering Unit)                     | 12   |  |
|     | 2.3  | ADC (Analog-to-Digital Converter)               | 13   |  |
| 3   | Ligh | nting application example architecture          | . 14 |  |
|     | 3.1  | Hardware architecture                           | 15   |  |
|     |      | 3.1.1 Generalities on M0-6                      | 15   |  |
|     | 3.2  | Software Implementation                         | 16   |  |
|     |      | 3.2.1 Synchronous diagnosis                     | 16   |  |
|     | 3.3  | Synchronous Analog Diagnosis                    | 18   |  |
|     | 3.4  | Implementation of the synchronous diagnosis     | 19   |  |
| 4   | MCL  | J initialization                                | . 20 |  |
|     | 4.1  | Setting up Mode Entry and clocks                | 20   |  |
|     | 4.2  | DSPI configuration                              | 21   |  |
|     | 4.3  | eMIOS_0 and EMIOS_1 modules                     | 22   |  |
|     |      | 4.3.1 eMIOS_0 and eMIOS_1 module initialization | 22   |  |
|     | 4.4  | DMA module                                      | 27   |  |
|     | 4.5  | ADC module                                      | 31   |  |
|     |      | 4.5.1 Check Voltage Battery function            |      |  |
|     | 4.6  | CTU module                                      | 35   |  |
|     | 4.7  | Micro Resources summary                         | 36   |  |
|     |      |                                                 |      |  |



| 5        | Conc   | lusion              | 37 |
|----------|--------|---------------------|----|
| Appendix | A R    | eference documents  | 38 |
|          | A.1    | Reference documents | 38 |
|          | A.2    | Acronyms            | 38 |
| Revision | histor | " <b>V</b>          | 39 |



List of tables AN4300

## List of tables

| Table 1. | Resources allocated on the microcontroller | 36 |
|----------|--------------------------------------------|----|
| Table 2. | Acronyms                                   | 38 |
| Table 3. | Document revision history                  | 39 |

DocID024675 Rev 3



AN4300 List of figures

# List of figures

| Figure 1.  | Lamp light bulb characteristics                                   |
|------------|-------------------------------------------------------------------|
| Figure 2.  | System solution for light application                             |
| Figure 3.  | Light management                                                  |
| Figure 4.  | eMIOS, ADC and CTU interconnection scheme                         |
| Figure 5.  | eMIOS-OPWMT mode                                                  |
| Figure 6.  | Lighting application—example system concept                       |
| Figure 7.  | SPC56EC74L7 Minimodule + M0-6 Board                               |
| Figure 8.  | Initial Configuration flowchart                                   |
| Figure 9.  | Vbat measurement and duty-cycle update flowchart                  |
| Figure 10. | Delay between the CS_Sync and Output channel/Current Sense signal |
| Figure 11. | MC_Mode_Init function7                                            |
| Figure 12. | PLL initialization function                                       |
| Figure 13. | DSPI master init function                                         |
| Figure 14. | eMIOS init function                                               |
| Figure 15. | eMIOS clock init function                                         |
| Figure 16. | eMIOS_0 configuration code                                        |
| Figure 17. | eMIOS_1 Ch23 and Ch0 configuration code                           |
| Figure 18. | eMIOS_1 Ch1 and Ch2 configuration code                            |
| Figure 19. | eMIOS_1 Ch25, Ch26 and Ch 17 configuration code                   |
| Figure 20. | eMIOS_1 Ch18 configuration code                                   |
| Figure 21. | Init DMA Vbat function                                            |
| Figure 22. | SPI_Vbat_SetTCD function                                          |
| Figure 23. | initDMA_1 function part 1                                         |
| Figure 24. | initDMA_1 function part 2                                         |
| Figure 25. | init DMA_1 function part 3                                        |
| Figure 26. | ADC init function                                                 |
| Figure 27. | ADC_0 CH0 EoC interrupt service routine                           |
| Figure 28. | Check Voltage Battery function part1                              |
| Figure 29. | Check Voltage Battery function part2                              |
| Figure 30. | bctu init function                                                |



## 1 Lighting application design challenge

## 1.1 General light application aspects

In an automotive lighting application it is necessary to drive two types of lights:

- 1. Bulb lamp
- 2. LED

When controlling the lamp light bulb, two points must be addressed:

- Lamp power supply variations
- Lamp lifetime

Lamp power supply voltage may differ when compared to its nominal value. *Figure 1* displays how lamp lifetime depends on power supply voltage. The impact of 5 % overvoltage (630 mV at 12.6 V) on light bulb performance is significant, as indicated by the vertical line in the figure. The light bulb luminous flux grows up to 120 % and the light bulb lifetime is reduced to less than 60 %, when compared to nominal values. Therefore, the lamp power supply voltage should be regulated to the nominal value to maintain lamp lifetime. The most common control technique is the PWM, which can also be used for lamp light beam intensity control.



Figure 1. Lamp light bulb characteristics

A lamp's lifetime is limited and it can be shortened if the lamp is connected in a faulty environment. If the design includes lamp diagnostics and protection, the lamp's nominal lifetime can be preserved. Usually the load drivers report various diagnosis information and the light application has to collect and check this information. These factors must taken into account when designing a lighting module.

## 1.2 Driver signals characteristics

The signals that drive the light loads must satisfy the following requirements:

Capability to drive up to 60 channels with PWM signals

Capability to drive different load types using PWM signals with different characteristics:

Bulb lamp

PWM frequency: ~100 Hz Duty cycle: 50 to 100 %

Duty cycle adjustment precision: usually 5 %

– LED

PWM frequency: 150 to 200 Hz

Duty cycle: 10 % to 100 % (as much as 2 % to 100 % for high efficiency LED)

Duty cycle adjustment precision: usually 1-2 %

The variation of the duty cycle is performed to maintain constant power on the lamps when the battery voltage changes.

The duty cycle variation is based on the following expression:

#### **Equation 1**

$$\delta = \frac{V_{ref}^{2}}{V_{bat}^{2}} \qquad \text{If Vbat >Vref}$$

where

V<sub>ref</sub> is the nominal value of the battery voltage

V<sub>bat</sub> is the actual battery voltage

If  $V_{bat} \le V_{ref}$ , the duty cycle is equal to 100 %, else the expression is applied. The adaptation of the duty cycle is performed one time per period.

A typical battery voltage value for automotive applications is 13.2 V, so if, for example, the application reads a  $V_{bat}$  equal to 16 V, a duty cycle of 68 % applies.

When turning the lamp light bulb on, the bulb current applied to a cold filament can reach up to 10 times the rated current. The total current of several lamps causes a significant power supply voltage drop and an increase in the electromagnetic interference (or EMI) emissions. Therefore, it is essential not to drive all lamps together and it is necessary to introduce a delay between each pair of rising edges of the PWM signals (see *Figure 3*).

## 1.3 System proposal

In a typical system solution for a light application, the SPC56xB/SPC56xCx/RPC56xB microcontroller family can manage several power drivers, depending on how the power is managed and the number of channels to be driven.

Some devices are driven by an SPI link. Using this link, the application can configure the signals, that are generated inside the driver device, to drive the loads.



Other devices need an input signal (PWM signals) for each load to generate the output signal to drive the loads.

It is possible to use both the microcontroller and the power devices for the solution shown in *Figure 2*. This solution is configured with an STMicroelectronics power driver and the SPC56EC74 microcontroller.



Figure 2. System solution for light application

This system uses devices that are driven by PWM input signals and other devices that use an SPI connection to configure the drivers.

## 1.4 Diagnosis check

Today's requests for automotive systems are based not only upon technical features and reliability, but also upon increasingly important safety concepts. To fulfill these requirements, a system must provide and communicate feedback on its behavior to external devices. This, in turn, makes it possible to detect faults and react to them in a specified time.

The power drivers used in light applications provide diagnostic signals that give information about the status of loads driven. These signals must be read and interpreted to give feedback to the application. It is important to understand if there are faults and to execute protective action to obtain a safe and robust system.

Three different diagnosis types exist:

- Digital
- Analog
- Serial

The diagnosis types are explained in the following sections.

5//

## 1.4.1 Digital diagnosis

To read the digital diagnosis it is necessary to read an I/O pin of the driver for each load driven. To read this type of diagnosis the microcontroller has to read the digital pin in polling mode or by connecting this signal to an external interrupt line.

#### 1.4.2 Analog diagnosis

To read the analog diagnosis a current sense pin is available for each load driven. This pin is used to read a proportional current (voltage using a resistor) that flows in the load. Comparing this current with certain thresholds can determine if problems on the load exist. To read the voltage of the current sense pin, an analog-to-digital conversion must be performed.

The analog diagnosis has to be read in synchronous mode to the input (PWM) signal which is available after a delay from the rising edge of the input signals. The analog-to-digital conversion has to be triggered with a delay from the rising edge of the input signals to allow the load current to stabilize.

#### 1.4.3 Serial diagnosis

When the power devices provide serial diagnosis, they usually save the type of fault in internal registers. The microcontroller, using the SPI link, then performs a query on the specified register to examine the fault status.

The application can perform the following types of diagnosis inspection:

- During T ON (time when the PWM input signal is switched on) of the input signal
  - Open-load
  - Overtemperature
  - Undervoltage
  - Short-circuit to GND
  - Short-circuit to V<sub>CC</sub>
- During T\_OFF (time when the PWM signal is switched off) of the input signal
  - Open-load
  - Short-circuit to V<sub>CC</sub>

The digital and serial diagnosis can usually be read asynchronously with respect to the PWM input signals and the diagnosis action can be performed during a noncritical instant of the system cycle. The CPU load used to collect this information is not an important aspect.

The analog diagnosis consists of checking the current that flows in the loads. The input signal status must be known to collect diagnosis information in a specific instant of the loads' activity. The reading of the diagnosis and the input signal must be synchronized to determine the status of the input signal.

The input signal is a PWM signal, making it necessary to select if the diagnosis is occurred in the  $T_ON$  or  $T_OFF$  phase of the input signal. Furthermore, a delay exists between the rising (falling) edge and the instant when the diagnosis read occurs because the current sense signal is stabilized only after a transitory time (about 300  $\mu$ s).





Figure 3. Light management

The SPC56xBx/RPC56xBx and SPC56xCx devices offer dedicated features to cover the light application requirements with very low CPU load, especially when the analog diagnosis has to be managed. Section 2: SPC56xBx/RPC56xBx features to cover lighting needs describes the device features that are used to manage the analog diagnosis.

47/

# 2 SPC56xBx/RPC56xBx features to cover lighting needs

The SPC56EC74 is a member of the SPC56xBx/RPC56xBx and SPC56xCx 32-bit microcontroller unit family. It operates at speeds of up to 120 MHz and provides a variety of peripherals (DSPI, IIC, ADC, CTU, eMIOS, FlexCAN, LINFlex) balanced with relatively large Flash, RAM, and emulated EEPROM memory.

The following modules are essential parts of the lighting application suitable for lamp bulb as well as for LED control:

- eMIOS (enhanced Modular I/O Subsystem)—provides functionality to generate or measure time events and then to generate PWM signals
- CTU (Cross Trigger Unit)—allows triggering analog-to-digital conversion synchronized to a PWM signal
- ADC—allows converting analog signals synchronized to a PWM signal and allows holding the converted value in different register for each ADC channel

The three module descriptions are covered in Section 2.1: eMIOS (enhanced Modular Input/Output Subsystem) Section 2.2: CTU (Cross Triggering Unit) and Section 2.3: ADC (Analog-to-Digital Converter). It is also recommended to read the SPC56xBx/RPC56xBx and SPC56xCx device reference manual see Section Appendix A: Reference documents.

The eMIOS channels are connected to event configuration registers of the CTU, where it links an eMIOS trigger to a specified ADC channel conversion (see *Figure 4*). Inside each event configuration, that is connected in a fixed way to an eMIOS channel, it is possible to write an ADC channel that is triggered when an event from the eMIOS channel arrives.



Figure 4. eMIOS, ADC and CTU interconnection scheme

## 2.1 eMIOS (enhanced Modular Input/Output Subsystem)

The SPC56EC74 includes two identical eMIOS modules that together provide up to 64 channels with input and output capability. Each eMIOS module provides 32 channels with OPWMT mode, especially suited for the lighting application. In OPWMT mode, a channel is in PWM mode, making it possible to configure a compare match, anywhere in the period, to



trigger—using the CTU—an analog-to-digital conversion at a specified point of the period. This is especially suited for lighting applications.

When configuring channels UC[0], UC[8], UC[16], UC[23], and UC[24] in modulus Counter Mode (MC), the A1 register determines the counting period.



Figure 5. eMIOS-OPWMT mode

When configuring a channel in OPWMT mode, the channel can be linked to:

- Internal counter (only for the channels that have this feature)
- Counter bus A driven by UC[23]
- Counter buses B, C, D, E driven by UC[0], UC[8], UC[16], UC[24]

In a channel configured in OPWMT mode, the A1 register value defines the PWM leading-edge and the B1 register value defines the PWM trailing edge (duty cycle). The A2 register is the sampling point for diagnostic purposes (the ADC channel trigger using the CTU), and in B2, the buffered value of the trailing edge, which is, on A1 match, loaded into the B1 register (see the eMIOS chapter of the device reference manual see *Section Appendix A: Reference documents*). When the B2 value equals the A1 value, the PWM duty cycle is 0 %. When a B2 value is higher than the channel period, the PWM duty cycle reaches 100 %. The PWM output signal polarity is dependent on the user's choice.

When configuring channels UC[0], UC[8], UC[16], UC[23] and UC[24] in Modulus Counter (MC) mode, the A1 register determines the counting period.

## 2.2 CTU (Cross Triggering Unit)

When the eMIOS OPWMT channel counter reaches the A2 value, the specific ADC channel conversion is initiated by the CTU module. The ADC channel number is specified in the CTU event configuration register by the user. When configuring the event configuration register, be aware, that:

- The CTU channel 0–15 event can trigger any of the ADC channels 0–15
- The CTU channel 32-47 event can trigger any of the ADC channels 32–47
- The CTU channel 48–95 event can trigger any of ADC channels 48–95

For more details, see the Cross Triggering Unit chapter in the device reference manual (see *Section Appendix A: Reference documents*).



## 2.3 ADC (Analog-to-Digital Converter)

The 2 ADC module convert analog signals into digital form; ADC\_0 with a 10-bit resolution and ADC\_1 with a 12-bit resolution offering normal, injected and trigger-injected modes. The ADC module can be configured to provide up to 62 single-ended input channels with no additional external logic, expandable to 90 channels using an external multiplexer, all driven by the ADC module logic.

When using the SPC56EC74:

- The ADC channels 0–15 correspond to ANP pins 0–15 with a resolution of 10-bit or 12-bit (depending on the choice of ADC\_0 (10-bit resolution) or ADC\_1 (12-bit resolution); in both cases the used pins are the same (precision channels)
- The ADC\_0 channels 32–60 (28 channels) correspond to ANS pins 0–27 (extended channel, medium occurrence) while the ADC\_1 channels 32-44 correspond to ANS pins 0-12
- The ADC channels 64–95 correspond to ANX pins 0–3 (external multiplexer driven by MA0–2 ADC pins; external channel, medium accuracy)

For the family SPC56xBx/RPC56xBx/SPC56xCx, 6 + 3 analog watchdogs (6 on 10-bit ADC, 3 on 12-bit ADC) are present on the ADC peripheral.

The analog watchdogs provide the capability to generate an interrupt for continuous hardware monitoring to determine if the converted channel value lies within a given guarded area defined by user-specified threshold values. If the converted value lies outside the guarded area, an interrupt is generated. The analog watchdog interrupts are well suited for light bulb diagnostic purposes.

With SPC56xBx/RPC56xBx/SPC56xCx devices, the diagnosis value can be collected in hardware mode, thus reducing the load on the CPU for this task. Moreover, one time within an input signal period, a load is placed on the CPU when these values collected in hardware mode are checked and when they are compared to certain thresholds.

The analog watchdog feature can reduce this CPU load by triggering an interrupt only when a fault occurs, instead of one time for the period, because the diagnosis check is performed in automatic mode.



## 3 Lighting application example architecture

The lighting application example code introduces essential SPC56EC74 initialization and configuration for demonstrating eMIOS and ADC synchronization using the CTU. An example is based on the LA system study depicted in *Figure 6* that is suitable for lamp bulb as well as for LED control.



Figure 6. Lighting application—example system concept

The demonstration is based on the SPC56EC74L7 176LQFP EVB, and the application code is written in C language using the Green Hills compiler.

The purpose of the application code is to show how the external triggering capability of SPC56xBx/RPC56xBx/SPC56xCx device brings "system" advantage in highly complex body application such as:

- Minimal microcontroller resources required
- · Low Interrupt and CPU load
- · Minimized usage of Memory resources
- · Few ADC channels and pins needed

The example application code has been implemented using the M0-6 Mother board for Power PC applications connected with the SPC56EC74L7 minimodule and the EVB using the J1 connector on the board following the connection reported in *Figure 6* and in *Figure 7*.





Figure 7. SPC56EC74L7 Minimodule + M0-6 Board

## 3.1 Hardware architecture

The hardware system as described in the Figure 6 uses:

- The same DSPI channel (DSPI 0) to drive all the M0-6 devices
- A dedicated chip selected for each M0-6 device
- A PWM channel (EMIOS Channel) shared for all M0-6 devices to provide a common time base (M0-6 Clock)
- Four eMIOS channels configured in SAIC to manage the trigger signals
- An ADC channel for each M0-6 device shared for the four channels inside the same M0-6 device.

#### 3.1.1 Generalities on M0-6

As power devices we have used the STMicroelectronics M0-6 devices:

- VNQ6040S
- VNQ6004S

These devices are made using STMicroelectronics VIPower technology. They are intended for driving resistive or inductive loads directly connected to ground. Devices are protected against voltage transient on Vcc pin. Programming, control and diagnostics are



implemented via the SPI Bus through the dedicated pins. Each device offers four channels that can drive different loads in term of power.

## 3.2 Software Implementation

The software implements the following features:

Support of the SPI configuration of 16 channel of four M0-6

Adapt the PWM signal to drive the loads to the V\_bat variations

Collect the current sense values for each channel and for each period

Low CPU load to collect the Current Sense

The code allows to initialize the configuration of M0-6 devices and at the beginning of each period (10 msec) performs the following steps:

Vbat Measurement via ADC

Duty cycle update for all channels of M0-6 devices

SPI frame for new information configuration

Digital diagnosis on all M0-6 devices

## 3.2.1 Synchronous diagnosis

Figure 8 and Figure 9 represent the initial configuration of the Microcontroller and the Vbat measurement strategy in order to update the duty-cycle of the PWM signal.

57



Figure 8. Initial Configuration flowchart



Figure 9. Vbat measurement and duty-cycle update flowchart

## 3.3 Synchronous Analog Diagnosis

The reading of the current sense is done in a synchronous way with the M0-6 output signals. In the following application code, current sense is read during TON of the period, 300  $\mu$ s after CS\_sync rising edge. It should be noticed that the microcontroller has to be synchronized with the outputs of the M0-6 device.



Figure 10. Delay between the CS Sync and Output channel/Current Sense signal

Depending on Vbat values, M0-6 can be either in PWM mode or in DC mode. In the former case synchronous diagnosis is triggered by the rising edge of the CS\_Sync signal for each active channel, by an internal timer expiration (e.g. 10 ms) of the micro in the latter.

- When in PWM mode, the CS\_Sync signals is used to trigger the ADC conversion of the Current Sense of a channel after a 300 µs delay from its rising edge.
- The End of Conversion of the ADC activates a DMA channel that transfers the ADC value from the peripheral register to a SRAM location.
- At the end of a period all Current Sense are available to the same memory structure.

## 3.4 Implementation of the synchronous diagnosis

In order to trigger ADC conversions to perform analog diagnosis synchronous with external events (CS sync arrival) the following resources of the microcontroller have been used:

- A Channel of the eMIOS is configured as Input Capture
- The arrival of the input signal on the Input Capture triggers a DMA transfer intended to trigger a second eMIOS channel previously configured as SAOC (Single Action Output Compare mode) counting 300 μs
- The SAOC End of Counting event triggers another eDMA transfer triggering the ADC conversion.

After the conversion the following action are performed:

- The end of ADC conversion triggers a DMA transfer moving the ADC values to a buffer in RAM.
- Via channel linking, a DMA transfer sends an SPI frame to a given M0-6 in order to link the multiplexer to the next current sense/CS Sync.



## 4 MCU initialization

In this section are described the most significant functions used in the application example code.

## 4.1 Setting up Mode Entry and clocks

This module enables clocks to all peripherals and sets the 12 MHz bus clock using the PLL.

Figure 11. MC\_Mode\_Init function7

```
void MC_MODE_INIT(void)
   /* [RM] system clock driven by FIRC */
  CGM.SC_SS.R = 0x0;
  /* keep the zO divider for division of 2*/
  CGM \ ZO \ DCR = 0x010000000;
   /* keep the FEC divider for division of 2*/
  CGM_FEC_DCR = 0x010000000;
   /* keep the FLASH divider for division of 2*/
  CGM FLASH DCR = 0x01000000;
  /* Enable system clock dividers with value =1*/
  CGM.SC DC[0].R = 0x80;
  CGM.SC DC[1].R = 0x80;
  CGM.SC_DC[2].R = 0x80;
   //Modes Configurations
  ME.MER.R = 0x000005FF;
                                       // enable all modes
   //Setting RUN Configuration Register ME RUN PC[0]
  ME.RUNPC[0].R=0x0000000FE; // Peripheral ON in every modes
  //re-enter in DRUN mode to update the DRUN config
  ME.MCTL.R = 0x30005AF0; // Mode & Key
  ME.MCTL.R = 0x3000A50F;
                                // Mode & Key
                                           /* Wait for mode entry to complete */
  while(ME.GS.B.S MTRANS==1);
  while(ME.GS.B.S_CURRENTMODE!=0x3);
                                         /* Check DRUN mode has been entered */
}
```

Figure 12. PLL initialization function

```
void PLL 12MHZ()
11
 /* Enable CLKOUT pin so clock frequency can be verified */
 /* Configure CLKOUT on PAO */
 SIU.PCR[0].R = 0x0\lambda00; /* PAO clkout
                                                       */
                  = 1; /* Enable Output Clock */
IV = 2; /* Divide Output Clock by 4 */
  CGM.OC EN.R
  /* Enable external osc */
 /* 10 */
  CGM.FMPLL_CR.B.IDF = 0x9;
  CGM.FMPLL CR.B.ODF = 0x3;
                              /* 16 */
  CGM.FMPLL_CR.B.NDIV = 48;
                              /* 48 */
 ME.MCTL.R = 0x40005AF0; /* Mode & Key */
ME.MCTL.R = 0x4000A50F; /* Mode & Key in
                             /* Mode & Key inverted */
  while(ME.GS.B.S MTRANS==1) {};  /* Wait for mode entry to complete */
```

The PA[0] pin is configured as Clock output in order to verify the clock bus frequency provided by the PLL. The CGM module allows to tune the dividers in order to provide a clock source of 12MHz starting from an external oscillator of 40 MHz.

## 4.2 DSPI configuration

The following function allows to initialize the DSPI module used for the SPI transmission.

It configures the DSPI\_0 as master and the following pins as:

- Pad PA[12] as DSPI\_0 SIN (Serial input)
- Pad PA[13] as DSPI 0 SOUT (Serial output)
- Pad PA[14] as DSPI 0 SCK (Serial Communication Clock)
- Pad PA[15] as DSPI 0 PCS0 (Peripheral Chip Select 0)
- Pad PF[10] as DSPI\_0 PCS1 (Peripheral Chip Select\_1)
- Pad PF[11] as DSPI\_0 PCS2 (Peripheral Chip Select\_2)
- Pad PE[06] as DSPI\_0 PCS3 (Peripheral Chip Select\_3)

The CTAR register defines the following parameters:

- · Set Double Baud rate disabled
- Frame size equal to 16
- Baud Rate Prescaler value equal to 3
- Baud Rate Scaler equal to 4
- Delay after Transfer Scaler equal to 32
- PCS to SCK delay Prescaler equal to 7

Figure 13. DSPI master init function

## 4.3 eMIOS 0 and EMIOS 1 modules

## 4.3.1 eMIOS\_0 and eMIOS\_1 module initialization

The following function allows to configure the two eMIOS and the following pins as:

- Set PCR[1] as E0UC[1] using PA[1]
- Set PCR[89] as E1UC[1] using PF[9]
- Set PCR[112] as E1UC[2] using PH[0]
- Set PCR[92] as E1UC[25] using PF[12]
- Set PCR[93] as E1UC[26] using PF[13]
- Set PCR[104] as E1UC[17] using PG[8]
- Set PCR[105] as E1UC[18] using PG[9]

#### Figure 14. eMIOS init function

```
void eMIOS_Config_loc(void)
{
    EMIOS_O.MCR.R = 0;
    EMIOS_1.MCR.R = 0;
    SIU.PCR[1].R = 0x0600;
    SIU.PCR[89].R = 0x0600;
    SIU.PCR[112].R = 0x0600;
    SIU.PCR[92].R = 0x0500;
    SIU.PCR[93].R = 0x0500;
    SIU.PCR[104].R = 0x0500;
    SIU.PCR[105].R = 0x0500;
}
```

Figure 15. eMIOS clock init function

For eMIOS\_1, the bus clock is divided by one in the system clock Prescaler, while for eMIOS\_0 the Prescaler is set to 12.

EMIOS\_0 Ch23 is configured in MC to drives the Bus A with a period of 1 msec, due to the value of 1000 used as PWM\_PERIOD.

eMIOS\_0 CH1 is configured in SAOC mode, with an internal counter period of 300 µsec.

#### Figure 16. eMIOS 0 configuration code

```
* EMIOS O Ch23 is configured in Modulus Counter to drives the Bus A
 with a period of 1 msec( because the prescaler is 12 and the Sys Clock is 12 MHZ ---> 1MHz to the eMIOSO)*/
                             = PWM PERIOD; /* Period will be 1000 clocks (imsec) Frequency 1KHz*/
= 0x10; /* Mode is Modulus Counter, internal clock */
 EMIOS_O.CH[23].CADR.K

EMIOS_O.CH[23].CCR.B.MODE = 0x10;

COMPAND.CCR.B.BSL = 0x3;
 EMIOS O.CH[23].CADR.R
                                                  /* Bus Selected: all channels: internal counter */
 EMIOS O.CH[23].CCR.B.UCPRE = 0x0;
                                                  /* Set channel prescaler to divide by 1 */
 EMIOS_O.CH[23].CCR.B.FREN = 0;
                                                   /* Normal Operation, no freeze channel counting when in debug mode */
 EMIOS O.CH[23].CCR.B.UCPEN = 1;
                                                  /* Enabled prescaler; uses default divide by 1 */
 EMIOS_0.CH[23].CCR.B.EDPOL = 1;
                                                   /* Edge Polarity bit: trigger on a rising edge */
                             = 1;
 EMIOS_O.CH[23].CCR.B.FEN
                                                   /* Enable interrupt on FLAG */
//Channel used as counter after the trigger
* EMIOS O Ch1 is configured in SAOC (Single Action Output Compare), with internal counter, period of 300 usec*/
                         = 0;
 EMIOS O.CH[1].CCR.R
                                                  /* Initialization of the register */
                              = 0;
 EMIOS O.CH[1].CADR.R
 EMIOS O.CH[1].CBDR.R
 EMIOS O.CH[1].CCNTR.R
//*emios0_siu[1] = 0x0600; /* Set the eMIOS1 pad for eMIOS o/p SIU.PCR[1].R = 0x0600; */
 EMIOS_O.CH[1].CADR.R
                              = 300;
                                                  /* Set period 300 clocks (300usec) with a internal freq of 3.3KHz */
 EMIOS_O.CH[1].CCR.B.MODE = 0x3;
                                                   /* Mode is SAOC */
```

eMIOS 1 CH23, configured in MC, drives bus A with a period of 19.417 µsec (51.5 KHz)

eMIOS\_1 CH0, configured in MC, drives bus B with a period of 10 msec (100 Hz)

eMIOS\_1 CH1 is configured in OPWMT driven by bus A (51.5 KHz) with a duty cycle of 50% to give the PWM clock to M0-6 devices.

eMIOS\_1 CH2 is configured in OPWMT driven by bus B, with the same period of the PWM generated by M0-6 devices (100 Hz) and it is used to give an internal counter to check the Vbat once for each period or to trigger the collection of the diagnosis collection when the M0-6 devices work in DC mode.

eMIOS\_1 CH17 is configured in SAIC mode and it is connected to the Sync\_mux of the M0-6\_3. Internally it triggers DMA\_MUX 21.

eMIOS\_1 CH18 is configured in SAIC mode and it is connected to the Sync\_mux of the M0-6\_4. Internally it triggers DMA\_MUX 22.

eMIOS\_1 CH25 is configured in SAIC mode and it is connected to the Sync\_mux of the M0-6\_1. Internally it triggers DMA\_MUX 23.

eMIOS\_1 CH26 is configured in SAIC mode and it is connected to the Sync\_mux of the M0-6\_2. Internally it triggers DMA\_MUX 24.

#### Figure 17. eMIOS 1 Ch23 and Ch0 configuration code

```
/* Configure the PWM Clock MO6 1 */
/* EMIOS 1 Ch23 is configured in Modulus Counter drives
  busk with a period of 19,417 usec (51.5 KHz)
  (because the prescaler is 1 and the Sys Clock is 12MHz
   --> 12 MHz to the eMIOS1*/
   EMIOS 1.CH[23].CADR.R
                    = COUNTER_PERIOD;/* Feriod will be 233 clocks (19,417 usec) Frequency 51.5 KHz*/
   EMIOS_1.CH[23].CCR.B.MODE = 0x10; /* Mode is Modulus Counter, internal clock */
  /\star EMIOS 1 chO is configured in Modulus Counter drives
   busB with a period of 10 msec (100 Hz)
   (because the Bus[A] has internal frequency of 51.5 KHz*/
   EMICS 1.CH[0].CADR.R = LAMP PERIOD; /* Period will be 515 clocks (10 msec) Frequency 100 Hz*/
   EMIOS_1.CH[0].CCR.B.MODE = 0x10; /* Mode is Modulus Counter, internal clock */
  EMIOS_1.CH[0].CCR.B.FEN = 1;
                                 /* Enable interrupt on FLIG */
```

Figure 18. eMIOS\_1 Ch1 and Ch2 configuration code

```
// PMM Clock
/* EMIOS_1 ch1 is configured in OPUMT driven by busA (51.5 KHz)
  with a duty cycle of 50% to give the PWM clock to MO6 devices*/
  //\text{*emios1\_siu[1] = 0x0600; }/\text{* Set the eMIOS1 pad for eMIOS o/p */ }/\text{SIU.PCR[89].R = 0x600//}
   EMIOS 1.CH[1].CADR.R
                             = 1;
                                                     /* Set Initial Duty Cycle */
                             = COUNTER_PERIOD/2; /* Set Initial Duty Cycle */
   EMIOS_1.CH[1].CBDR.R
                              = (ENIOS_UCPRE(O)
    EMIOS_1.CH[1].CCR.R
                                                    /* Channel Prescaler div 1 */
                               ENIOS EDPOL
                               |ENIOS_BSL(OxO)
                                                    /* Select Bus A */
                                                      /* Set mode OPWMT and EDPOL 1 to trigger on a rising edge */
                                10xA6);
   // Timer for VBat read
/* EMIOS_1 ch2 is configured in OPWMT driven by busB (100Hz)
   and it is used to give internal counter to check the Vbat
    once for each period or to trigger the collection of the
    diagnosis when the MO6 devices work in DC mode.*/
  //*emios1 siu[2] = 0x0600; /* Set the eMIOS1 pad for eMIOS o/p SIU.PCR[112].R = 0x0600*/
   EMIOS_1.CH[2].CADR.R
                                                 /* Set Initial Duty Cycle */
                             = 1;
   EMIOS_1.CH[2].CBDR.R
                              = LAMP_PERIOD/2;
                                                     /* Set Initial Duty Cycle
                            = 1;
                                                     /* Set period */
   EMIOS 1.CH[2].ALTCADR.R
                              = (ENIOS_UCPRE(0x0) /* Channel Prescaler div 1 */
    EMIOS_1.CH[2].CCR.R
                                |ENIOS EDPOL
                                [ENIOS_BSL(Ox1)
                                                     /* Select Bus B */
                                EMIOS_FEN
                                |EMIOS_DMA
                                [OxA6];
                                                     /* Set mode OPWNT and EDPOL 1 to trigger on a rising edge */
```

#### Figure 19. eMIOS\_1 Ch25, Ch26 and Ch 17 configuration code

```
/* ENIOS 1 ch 25 is configured in SAIC mode and it is connected
 to the Sync_mux of the MO6_1. Internally it triggers DMA_MUX23 ^{\star}/
  //*emios1 siu[25] = 0x0500; /* Set the eMIOS2 pad for eMIOS input SIU.PCR[92].R = 0x0500*/
                           = (EMIOS_UCPRE(O) /* Channel Prescaler div 1 */
   EMIOS 1.CH[25].CCR.R
                              EMIOS UCPREN
                               |EMIOS EDPOL
                               [EMIOS_FEN
                               |EMIOS DMA
                               |EMIOS BSL(0x0)
                                                  /* Select Bus A */
                                                   /* Set mode SAIC */
                               [0x2]:
/* ENIOS 1 ch 26 is configured in SAIC mode and it is connected
 to the Sync mux of the MO6 2. Internally it triggers DMA MUX24*/
   //*emics1 siu[26] = 0x0500; /* Set the eMIOS2 pad for eMIOS input SIU.PCR[93].R = 0x0500*/
   EMIOS 1.CH[26].CCR.R
                             = (EMIOS_UCPRE(O) /* Channel Prescaler div 1 */
                               |EMIOS UCPREN
                                                  /* Enable ch Prescaler
                               EMIOS_EDPOL
                               |EMIOS FEN
                               |EMIOS DMA
                               |EMIOS BSL(0x0)
                                                  /* Select Bus A
                                                  /* Set mode SAIC
                               0x2):
/* ENIOS_1 ch 17 is configured in SAIC mode and it is connected
 to the Sync_mux of the MO6_3. Internally it triggers DMA_MUX21*/
//*emios1 siu[17] = 0x0500; /* Set the eMIOS2 pad for eMIOS input SIU.PCR[104].R = 0x0500*/
                             EMIOS_1.CH[17].CCR.R
                               |EMIOS_UCPREN
                                                  /* Enable ch Prescaler
                               |EMIOS_EDPOL
                               EMIOS FEN
                               EMIOS DMA
                               [EMIOS BSL(0x0)
                                                   /* Select Bus A
                                                                             */
                               [0x2];
                                                   /* Set mode SAIC
```

#### Figure 20. eMIOS\_1 Ch18 configuration code

```
/ ^{\pm} EMIOS 1 ch 18 is configured in SAIC mode and it is connected
  to the Sync mux of the MO6 4. Internally it triggers DMA MUX22*/
//*emios1 siu[18] = 0x0500; /* Set the eMIOS2 pad for eMIOS input SIU.PCR[105].R = 0x0500*/
   EMIOS_1.CH[18].CCR.R
                            = (EMIOS_UCPRE(0) /* Channel Prescaler div 1 */
                              ENIOS UCPREN
                                                /* Enable ch Prescaler */
                              ENIOS EDPOL
                               ENIOS FEN
                               |ENIOS DMA
                               |ENIOS_BSL(OxO)
                                                /* Select Bus &
                                                                           #/
                              [0x2);
                                                 /* Set mode SAIC
   ENIOS 1.CH[18].CSR.R
                        = 1:
   INTC.PSR[166].B.PRI
                        = 1; /* Set to 1 the priority of the EMIOSFLAG register [F18,F19] */
   count = 0;
   EMIOS 1.CH[23].CCR.B.UCPEN = 1; /* Enable prescaler; uses default divide by 1 */
   EMIOS_1.CH[0].CCR.B.UCPEN = 1;
                                         /* Enable prescaler; uses default divide by 1 */
}
```

## 4.4 DMA module

The initDMA\_Vbat function permits to configure DMA channel number 6 to be used to transfer, by SPI, the configuration to M0-6 devices about the PWM waves generation.

This DMA channel is configured to be triggered by DSPI0\_TX signal each time when Vbat is read and PWM configuration is needed.

The scatter gather feature allows to change the TCD descriptor to send the duty-cycle configuration for 16 channels, for all M0-6 (4 channels for 4 M0-6) and it allows to change the TCD descriptor to wait the new manual trigger to send M06\_PWM control register for the next period.

Figure 21. Init DMA Vbat function

```
tuis initDHA Vbat (void)

(
tu32 fail = 0;
//SPI_UBat_SetTCD(*tcd, ch, start, dest, inSire, outLoop, interrupt);
//SPI_UBat_SetTCD (&tcdSSC_PWMC), 0, (tu32)msg_PWM, (tu32)msf_FVM, (tu32)0xFFF90034, 4, MOS_NUMBER, 0); //Create a the TCD structure for the SG_FVM vector[0]
tcdSG_PWM[0].DLAST_SGA = (tu32) &tcdSG_PWM[1]; // point to address of TCD for scatter gather
tcdSG_PWM[0].DLAST_SGA = (tu32) &tcdSG_PWM[1]; // Enable Scatter/Gather
tcdSG_PWM[0].D_REQ = 0; // first transfer will not clear ERQR, 2nd one will

SPI_VBat_SetTCD (&tcdSG_PWM[1], 0, (tu32)DHA_MOS_VBAT, (tu32)0xFFF90034, 4, MOS_NUMBER*NCHANNEL, 0); //Create a the TCD structure for the SG_FVM vector[1]
tcdSG_PWM[1].DLAST_SGA = (tu32) &tcdSG_PVM[0]; // point to address of TCD for scatter gather
tcdSG_PVM[1].DLAST_SGA = (tu32) &tcdSG_PVM[0]; // point to address of TCD for scatter gather
tcdSG_PVM[1].D_REQ = 1; // tanable Scatter/Gather

SPI_VBat_SetTCD (0, 6, (tu32)msg_PVM, (tu32)0xFFF90034, 4, MOS_NUMBER, 0); //Set the TCD for the SPI communication of the msg_PVM using the EDMA ch6
EDMA.TCD[0].D_REQ = 0; // this transfer will not clear ERQR

DMANUX.CHCONFIG[0].D_REQ = 0; // this transfer will not clear ERQR

DMANUX.CHCONFIG[0].D_REQ = 0; // DMA Channel Source, specifies which DMA source is routed to a particular DMA Channel
if (fail)
    return (FAIL);
else
    return (FAIL);
else
    return (FAIL);
else
    return (FAIL);
```

The function SPI\_Vbat\_SetTCD allows to create a TCD structure for the SG\_PWM vectors 0 and 1 and for the DMA channel 6.

#### Figure 22. SPI Vbat SetTCD function

```
void SPI_VBat_SetTCD (volatile struct EDMA_TCD_STD_tag *tcd, tU16 ch, tU32 start, tU32 dest, tU32 inSize,
 if (ted == 0) { ted = &EDMA.TCD[ch]; }
/* Set up TCD */
   tcd->SADDR = start;
                           // Start address
                                // Destination Address
   tcd->DADDR = dest:
                                // Source address modulo
   tcd->SMOD = 0x00;
   tcd->DMOD = 0x00:
                                // Destination address modulo
   tcd->DSIZE = 2;
tcd->SSIZE = 2;
tcd->SOFF = 4;
tcd->NBYTES = inSize;
tcd->SLAST = 0;
                                // Destination transfer size : 32 Bits
                                // Source transfer size : 8 Bits
                                // Signed source address offset
                                // Inner "minor" byte count
                                // last Signed source address adjust
   tcd->SLAST = 0;
   tcd->DOFF = 0:
                                // Signed destination address offset
   tcd->DLAST_SGA = 0;
                                 // Signed destination address adjust
   tcd->BITERE LINK = 0x0;
   tcd->BITER = outLoop;
                                 // begining "major" iteration count
   tcd->CITERE_LINK = 0x0;
   tcd->CITER= outLoop;
                                // Current "major" iteration count Disabled
                                // Bandwidth control : No DMA Stalls
   tcd->BMC = OxO:
   tcd->MAJORLINKCH = 0x00; // Major Channel number
tcd->MAJORE_LINK = 0; // Major Channel Link : Disabled
tcd->DONF = 0:
                                 // Channel Done
   tcd->DONE = 0;
                         // Channel ACtive
   tcd->ACTIVE = 0;
   tcd->E_SG = 0;
tcd->D_REQ = 0;
                                // Enable Scatter/Gather : Disabled
   } /* end of SPI SetTCD */
```

The function InitDMA\_1 configures the eDMA channels to collect the diagnosis automatically. For this reason the following channels are configured as described below:

- DMA CH0, CH7, CH8 and CH9 are configured to trigger the start counter of the eMIOS0\_CH1 when the SYNC\_MUX comes from M0-6\_1, M0-6\_2, M0-6\_3 and M0-6\_4 respectively.
- DMA CH1 is configured to trigger the stop of counter of the eMIOS0\_CH1
- DMA CH1 is linked to DMA CH2. In this way when the CH1 finishes it starts the DMA CH2 transmission which allows the start of the ADC conversion.
- DMA CH5 is configured to send, by SPI, the configuration to the MUX for the active M0-6 to select the right channel connected to the CS and with CS SYNC.
- DMA CH4 is configured to transfer the value of the 4 Data Registers relative to the 4 ADC channels linked to the 4 M0-6 to a buffer in the memory, this is done at each trigger event because it is necessary to read all ADC channels that can trigger DMA transfers.
- DMA CH10 is configured to transfer the value converted by ADC to the final RAM structure. The scatter gather feature is used to change the TDC to adapt the ADC Data Register and Memory location relative to the M0-6 Channel selected.



#### Figure 23. initDMA 1 function part 1

```
tU16 initDMA 1 (void)
{
   tU32 fail = 0;
   DMA STEP1[0] = (EMIOS UCPRE(0)
                                      /* Channel Prescaler div 1 */
                  EMIOS UCPREN
                                      /* Enable ch Prescaler */
                  EMIOS EDPOL
                  |EMIOS FEN
                  |EMIOS DMA
                                      /* Select Internal Bus
                  |EMIOS_BSL(0x3)
                                                                 */
                  [0x3];
                                       /* Set mode SAOC
                                                                  */
   /* ChO of DMA is configured to trigger the start counter of the eMIOSO ch1 when arrives the SYNC MUX from MO6 1*/
   SetTCD (0, 0, (tU32)DMA STEP1, (tU32)&(EMIOS 0.CH[1].CCR.R), 4, 1, 0); //Start SAOC MO6 1
   /* Ch7 of DMA is configured to trigger the start counter of the eMIOSO chi when arrives the SYMC MUX from MO6 2*/
   SetTCD (0, 7, (tU32)DMA STEP1, (tU32)&(EMIOS O.CH[1].CCR.R), 4, 1, 0); //Start SAOC MO6 2
   /* Ch8 of DMA is configured to trigger the start counter of the eMIOSO ch1 when arrives the SYNC MUX from MO6 3*/
   SetTCD (0, 8, (tU32)DMA_STEP1, (tU32)&(EMIOS_0.CH[1].CCR.R), 4, 1, 0); //Start SAOC MO6_3
   /* Ch9 of DMA is configured to trigger the start counter of the eMIOSO ch1 when arrives the SYNC_MUX from MO6_4*/
   SetTCD (0, 9, (tU32)DMA_STEP1, (tU32)&(ENIOS_0.CH[1].CCR.R), 4, 1, 0); //Start SAOC M06_4
   /* Ch1 of DNA is configured to trigger the stop of counter of the eMIOSO ch1 */
   SetTCD (0, 1, (tU32)DMA STEP2, (tU32)&(EMIOS O.CH[1].CCR.R), 4, 1, 0); //STOP SAOC MO1
   EDMA.TCD[1].MAJORE_LINK = 1;
                                   /* enable link on major loop */
   /# Ch1 is linked to Ch2 so when it finish its transfer start ch2 and allows to start the ADC conversion*/
   EDMA.TCD[1].MAJORLINKCH = 2; /* link to next channel */
```



#### Figure 24. initDMA 1 function part 2

```
/* Ch2 of DMA is configured to trigger the start of conversion of the ADC*/
SetTCD (0, 2, (tU32)DMA STEP3, (tU32)OxFFE00000, 4, 1, 0);
                                                                           //Start ADC conversion
SetTCD (&tcd5G[0], 0, (tU32)ADC_DR_M06[1], (tU32)&CS_M06[1], 4, 4, 0); //Moves read CS in the memory
tedSG[0].DOFF
                                            /* Signed destination address offset */
                       = 4;
                                            /* enable link on minor loop */
tedSG[0].CITERE LINK
                        = 1;
                      = 1;
                                            /* enable link on minor loop */
tedSG[0].BITERE_LINK
tcdSG[0].CITER |= 5<<9;
tcdSG[0].BITER |= 5<<9;
                                            /* link to next channel */
                                            /* link to next channel */
tedSG[0].MAJORE LINK
                                            /* enable link on major loop */
                       = 1;
tcdSG[0].MAJORLINKCH = 5;
                                            /* link to next channel */
tcdSG[O].DLAST_SGA
                       - (tU32) &tcdSG[1]; /* point to address of TCD for scatter gather */
                                            /* Enable Scatter/Gather */
tedSG[0].E SG
                       = 1;
= 0;
tcdSG[0].D_REQ
                                            /* first transfer will not clear ERQR, 2nd one will */
SetTCD (&tcdSG[1], 0, (tU32)ADC DR MO6[2], (tU32)&CS MO6[2], 4, 4, 0);
                                                                           //Moves read CS in the memory
tcdSG[1].DOFF
                                            /* Signed destination address offset */
                       - 4;
                                            /* enable link on minor loop */
tcdSG[1].CITERE LINK
                        = 1;
tedSG[1].BITERE LINK
                       = 1;
                                            /* enable link on minor loop */
tcdSG[1].CITER |= 5<<9;
tcdSG[1].BITER |= 5<<9;
                                            /* link to next channel */
                                            /* link to next channel */
tcdSG[1].MAJORE_LINK = 1;
tcdSG[1].MAJORLINKCH = 5;
                                            /* enable link on major loop */
                                            /* link to next channel */
tedSG[1].DLAST_SGA
                       = (tU32) &tcdSG[2]: /* point to address of TCD for scatter gather */
                                            /* Enable Scatter/Gather */
tcdSG[1].E SG
                       = 1;
tedSG[1].D REQ
                       - 0;
                                            /* first transfer will not clear ERQR, 2nd one will */
SetTCD (&tcd5G[2], 0, (tU32)ADC_DR_M06[3], (tU32)&CS_M06[3], 4, 4, 0);
                                                                          //Moves read CS in the memory
tedSG[2].DOFF
                                            /* Signed destination address offset */
                       - 4:
tedSG[2].CITERE LINK
                       = 1;
                                            /* enable link on minor loop */
tcdSG[2].BITERE_LINK
                       = 1;
                                            /* enable link on minor loop */
                 |= 5<<9;
|= 5<<9;
                                            /* link to next channel */
tedSG[2].CITER
                                            /* link to next channel */
tedSG[2].BITER
tcdSG[2].MAJORE_LINK
                       = 1;
                                            /* enable link on major loop */
tedSG[2].NAJORLINKCH = 5;
                                            /* link to next channel */
tcdSG[2].DLAST_SGA
                       = (tU32) &tcdSG[3]; /* point to address of TCD for scatter gather */
                       = 1;
                                            /* Enable Scatter/Gather */
tedSG[2].E SG
                                            /\,\text{*} first transfer will not clear ERQR, 2nd one will \text{*}/\,
tcdSG[2].D REQ
                      = 0;
```



#### Figure 25. init DMA\_1 function part 3

```
SetTCD (&tcdSG[3], 0, (tU32)ADC_DR_MO6[0], (tU32)&CS_MO6[0], 4, 4, 0); //Moves read CS in the memory
tedSG[3].DOFF = 4;
tedSG[3].CITERE_LINK = 1;
                                             /* Signed destination address offset */
                                            /* enable link on minor loop */
                                           /* enable link on minor loop */
/* link to next channel */
tcdSG[3].BITERE_LINK = 1;
tcdSG[3].CITER |= 5<<9;
tcdSG[3].BITER |= 5<<9;
                                            /* link to next channel */
tedSG[3].MAJORE_LINK = 1;
tedSG[3].MAJORLINKCH = 5;
tedSG[3].DLAST SGA
                                            /* enable link on major loop */
                                             /* link to next channel */
tedSG[3].DLAST_SGA
                        = (tU32) &tcdSG[0]; /* point to address of TCD for scatter gather */
tedsG[3].E_SG
                        = 1; /* Enable Scatter/Gather */
tcdSG[3].D_REQ
                       = 0;
                                             /* first transfer will not clear ERQR, 2nd one will */
/* Ch4 of DMA is configured to transfer the Value converted by ADC to a RAM structure. The scatter gater
SetTCD (0, 4, (tU32)ADC_DR_MO6[0], (tU32)CS_MO6, 4, 4, 0);
                                                                      //Moves read CS in the memory
EDMA.TCD[4].DOFF = 4; /* Signed destination address offset */
EDMA.TCD[4].DLAST_SGA - (tU32) &tcdSG[0]; /* point to address of TCD for scatter gather */
                               /* enable link on minor loop */
EDMA.TCD[4].CITERE LINK = 1;
                                            /* enable link on minor loop */
EDMA.TCD[4].BITERE_LINK = 1;
/* link to next channel */
                                            /* link to next channel */
                                            /* enable link on major loop */
EDMA.TCD[4].MAJORE LINK = 1;
                                            /* link to next channel */
EDMA.TCD[4].MAJORLINKCH = 5;
                                             /* Enable Scatter/Gather */
EDMA.TCD[4].E\_SG = 1;
EDMA.TCD[4].D REQ
                       = 0:
                                             /* first transfer will not clear ERQR, 2nd one will */
/st Ch5 pf DMA is configured to send, by SPI, the configuration to the MUX for the active MO6 to select t1
SetTCD (0, 5, (tU32)SEQ_MD6, (tU32)OxFFF90034, 4, 16, 0);
                                                                       //Configures the next CS
EDMA.TCD[5].SOFF = 4; /* Signed source address offset */
EDMA.TCD[5].SLAST = -(4*16);
                                             /* last Signed source address adjust */
EDMA.SERQ.R - 1; //Set enable request and the corresponding bit in EMDA ERORL
EDMA.SERQ.R = 4; //Set enable request and the corresponding bit in EMDA ERQRL
```

#### 4.5 ADC module

The dadc\_init function initializes ADC module enabling the CTU trigger. It selects the ADC channels used for the conversion. ADC\_0 CH0 is used to convert the VBat and a End of Conversion interrupt is set on this channel.

EMIOS1\_CH2 is used as counter to read Vbat. When this counter elapses, the CTU\_CH34 (connected to eMIOS1\_CH2) will trigger the ADC\_0 CH0 to convert the Vbat.

At the EoC an interrupt will be raised to adapt the Duty Cycle of the PWM signals to the Vbat.

#### Figure 26. ADC init function

```
void dadc_init(void)
//ADC D chO is used to convert the VBat and it is configured an
//interrupt at the EOC of this channel. eMIOS1 ch2 is used as counter to read VBat.
//When the counter elapses, the CTU Ch34 (connected to the ENIOS1 ch2)
// will trigger the ADCO chO to convert the Vbat.
//At the EOC an interrupt will be raisen to adapt the Duty Cycle of the
// PWM signals to the VBat
   vuint8 t i, j;
   for (i=20; i < 26; i++) //28
       SIU.PCR[i].B.APC = 1;
   for (i=48; i < 60; i++)
       SIU.PCR[i].B.APC = 1;
   3
   ADC 0.MCR.B.MODE = 0;
                             // Configure One shot conversion
   ADC_0.NCMRO.R = 0x1E;
                              // Normal Conversion Mask Register Enables bits
                              // of normal sampling for channel 1, 2, 3, 4
   ADC O.IMR.B.MSKEOCTU = 1; // Interrupt Mask Register Mask Enabled End of CTU C
   ADC O.CIMRO.B.CIMO = 1; // Channel Interrupt Mask Register Enables Interrupt
   INTC.PSR[62].B.FRI = 1; // Set priority for the ADC_EOC end of conversion
   ADC O.DMARO.B.DMA4 = \frac{0 \times 1}{2}; // DMA Channel Select Register enable channel 4 to t
   ADC O.DMAE.B.DMAEN = 1; // DMA enable register: DMA feature enabled.
   for (i=0;i<NCHANNEL; i++)</pre>
     for (j = 0; j < MD6_NUMBER; j++)</pre>
       DMA_MO6_VBAT[j][i]=(0x1<< (16+j)) +msg[i];</pre>
   3
```

Figure 27. ADC 0 CH0 EoC interrupt service routine

```
void ADCO_EOC_Isr(void)
{
    if (ADC_O.ISR.B.EOCTU && ADC_O.CEOCFRO.B.EOC_CHO)
    {
        SIU.GPDO[2].B.PDO ^= 1;
        ADC_O.ISR.B.EOCTU =1;
        ADC_O.CEOCFRO.B.EOC_CHO = 1;
        checkVoltageBattery();
        SIU.GPDO[2].B.PDO ^= 1;
}
```

## 4.5.1 Check Voltage Battery function

This function is called inside the EOC interrupt of the ADC, when the conversion is triggered by the CTU and only for the ADC0\_CH0.

It performs a reading on the Vbat value and carries out the duty cycle of the PWM signals update.

The voltage read with a nominal value of the Battery voltage (13.2 V) is equal to:

13,2\*4,7/(4,7+22) =2,32V with a resistor divider of 22KOhm and 4.7 KOhm

The resolution of the ADC is:

5V/1024=4.88mV

Reporting this resolution to the value of the Battery using the resistor divider:

```
4.88*(4.7+22)/4.7 = 28,404 \text{ mV}
```

that is the resolution of voltage of the battery (V\_BAT\_RESOLUTION)

When the value is read, following the relation  $\delta = \frac{\text{Vref}^2}{\text{Vbat}^2}$  if Vref > V/bat then the better value is  $\delta = \frac{\text{Vref}^2}{\text{Vbat}^2}$ .

if Vref ≥ Vbat then the battery voltage is under than nominal (13,2 V) value and the output channels of the M0-6 devices are configured in DC mode (100% Duty Cycle) and the trigger to read the diagnosis is given manually with the same period used to read the Vbat.

If Vref < Vbat the battery voltage is upper than the nominal value and the output channels of the M0-6 devices are configured in PWM mode with Duty Cycle based on the above relation. The trigger, in order to read the diagnosis, is given by the Sync\_Mux signal from each M0-6 device.

After that the table of PWM signals are updated and these values are sent to each M0-6 devices using the SPI connection.

Figure 28. Check Voltage Battery function part1

```
void checkVoltageBattery (void)
    uint8_t i, j;
    valore app = ADC O.CDR[0].B.CDATA;
    valore3 = V BAT NOM * 1000;
    valore4 - V BAT RESOLUTION;
    valore2 = V BAT NOW ADC;
    if (valore app > □)
        valore = ((V BiT NOM ADC * V BiT NOM ADC) * 100) / ((valore app * valore app));
         if (valore >= 100)
             valore = 100;
             EDMA.CERQ.R = 0; //Clear enable Request, clear corresponding bit in EDMA_ERQRL
             {\tt EDMA.CERQ.R} = {\tt 7;} \ //{\tt Clear \ enable \ Request, \ clear \ corresponding \ bit \ in \ {\tt EDMA\_ERQRL}
             EDMA.CERQ.R = 8; //Clear enable Request, clear corresponding bit in EDMA ERQRL
             EDMA.CERO.R = 9: //Clear enable Request, clear corresponding bit in EDMA ERORL
             for (i = 0; i < MO6 NUMBER; i++)</pre>
              txSpi(&msg_PWN_O[i]); //SPI transmission
             if (MO6 confing == 1)
                 for (i = 0; i < ND6_NUMBER*NCHANNEL; i++)</pre>
                     EDNA.TCD[2].START = 1;
                     for (j = 0; j < 100; j++);
         }else
                 msg PUM[0] = 0x00010000 + ((WRITE MODE|M06 PWMCR)<<8) | (vuint16 t) 0xf;
                 mag PUN[1] = 0x00020000 + ((WRITE MODE | MOO PWMCR) << 8) | (vuint16 t) 0xf;
                 \label{eq:mag_pum_2} \text{msg} \ \text{PUM[2]} \ = \ 0 \times 0000400000 \ + \ ( \text{(URITE MODE|M06 PWMCR}) << 8 ) \ | \ (\text{vuint16 t}) \ \text{OxF;}
                 mag PUN[3] = 0x00080000 + ((URITE MODE|MO6 PWMCR)<<8) | (vuint16 t) 0xF;
                 EDMA.SERQ.R = 0; //Set enable Request, set corresponding bit in EDMA.ERQRL
                 EDMA.SERQ.R = 7; //Set enable Request, set corresponding bit in EDMA_ERQRL
                 EDMA.SERQ.R = 8; //Set enable Request, set corresponding bit in EDMA_ERQRL
                 EDMA.SERQ.R = 9; //Set enable Request, set corresponding bit in EDMA_ERQRL
```

Figure 29. Check Voltage Battery function part2

```
valore = valore * 255 / 100;
                                msq[0] = ((@RITE_MODE|MD6_DUTYCOCR)<<8) | (vuint16_t) valore;</pre>
                                mag[1] = ((WRITE MODE|MD6 DUTYC1CR)<<8) | (vuint16 t) valore;</pre>
                                mag[2] = ((@RITE MODE|MD6 DUTYC2CR) << 8) | (vuint16 t) valore;
                                mag[3] = ((MRITE MODE|MD6 DHTYC3CR) << 8) | (vuint16 t) valore;
                                for (i=0;i<NCHANNEL; i++)</pre>
                                           for (j = 0; j < MO6_NUMBER; j++)</pre>
                                                      DMA_MO6_VBAT[j][i]=(Ox1<< (16+j)) + ((vuint16_t) msg[i]);</pre>
                                EDMA.SERQ.R = 6; //Set enable Request, set corresponding bit in EI
                                DSPI O.RSER.B.TFFFDIRS = 1; //DMA/Interrupt Request Select and ens
                                DSPI_O.RSER.B.TFFFRE - 1; //Transmit FIFO Fill Request enabled.
}else
                    valore = 100;
                     EDMA.CERQ.R = 0; //Clear enable Request, clear corresponding bit in EI
                     EDMA.CERQ.R = 7; //Clear enable Request, clear corresponding bit in EI
                     EDMA.CERO.R = 8; //Clear enable Request, clear corresponding bit in EI
                     EDMA.CERQ.R = 9; //Clear enable Request, clear corresponding bit in EI
                     initDMA \ 1 \ (); /* Configure the eDMA channels to collect the diagnosis
                    for (i = 0; i < MO6_NUMBER; i++)</pre>
                                \label{eq:txSp1(&msg_PWM_O[1]); // Transmit the PUM via SPI} $$ txSp1(&msg_PWM_O[1]); // Transmit the PUM via SPI $$ txSp1(&msg_PWM_O[1]
                     if (MO6 confing == 1)
                                for (i = 0; i < MO6 NUMBER*NCHAMNEL; i++)</pre>
                                           EDMA.TCD[2].START -1;
                                           for (j - 0; j < 100; j(1));
```

## 4.6 CTU module

The bctu\_init function configures the CTU channels as follows; CTU CH34 is connected to the eMIOS1 CH2 and it is configured to trigger the ADC conversion of the ADC0 CH0.

## Figure 30. bctu\_init function

```
void bctu_init(void)
{
   CTU.EVTCFGR[34].B.TM = 1;  // Trigger Enabled
   CTU.EVTCFGR[34].B.CHANNEL_VALUE = 0;  // Selected channel 0
}
```

## 4.7 Micro Resources summary

The Lighting Application example allocates the several resources inside the micro:

Table 1. Resources allocated on the microcontroller

| Peripheral<br>name | Resource                                                                                                                                                                                                                                                                                 | Notes                         |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| DSPI               | DSPI_0                                                                                                                                                                                                                                                                                   | 7 pins                        |
| INTC               | IRQ 62<br>IRQ 0                                                                                                                                                                                                                                                                          | ADC_EOC<br>Software interrupt |
| eDMA               | CH6-Vbat measure CH0 - Start counter M0-6-1 CH7-Start counter M0-6-2 CH8 - Start counter M0-6-3 CH9 - Start counter M0-6-4 CH1 Start ADC conversion CH4 Transfer data register of ADC in RAM CH10 Transfer value in final array CH5 Trigger SPI communication to select the M0-6 channel | 10 DMA channels used          |
| eMIOS              | eMIOS0 - 2 Channels<br>eMIOS1 - 8 Channels                                                                                                                                                                                                                                               | 10 eMIOS channels used        |
| DADC               | CH0 for Vbat<br>CH1, CH2, CH3, CH4 to convert the CS                                                                                                                                                                                                                                     | 5 ADC channels used           |
| всти               | CTU_CH34<br>eMIOS1_CH2 vs ADC0_CH0                                                                                                                                                                                                                                                       | 1 CTU channel used            |

AN4300 Conclusion

## 5 Conclusion

The SPC56EC74 lighting application example introduces MCU eMIOS, CTU, and ADC modules usage within a lighting application, which is in this case well suited for the lamp light bulbs control as well as for the lamp LEDs control with no major change required in the peripherals software.

The benefit of using the CTU module is significant as opposed to using the timer to trigger ADC at a certain point within a PWM channel cycle. The timer produces frequent interrupts that need to be processed by the MCU CPU, causing an increase in the CPU load and suspending run time processes. Using the CTU gives the application designer a powerful tool to avoid diagnostic timer-configuration challenges and makes the lighting application simpler to design and test.

The ADC module gives the designer the opportunity to use watchdog threshold interrupts to increase MCU performance, and enables fast responses in case of lamp light bulb failures. If required, the number of the ADC channels can be increased from 64 up to 95, using simple external logic circuitry fully controlled by the ADC module.

The eMIOS module offers up to 64 PWM channels suitable for a lighting application as well as for other PWM-based applications. The eMIOS module provides PWM channels with high resolution and flexibility.

The lighting application example consists of an example description and complete software demonstration based on the SPC56EC74L7 LQFP176 minimodule and EVB.

This example is easily portable to each device of the SPC56xBx/RPC56xBx/SPC56xCx family; for devices which have DMA module, no particular modifications are required. For devices where DMA module is missing, the DMA feature can be replaced with interrupt routines but with a higher CPU load.



Reference documents AN4300

## Appendix A Reference documents

## A.1 Reference documents

 SPC560B4x, SPC560B5x, SPC560C4x, SPC560C5x, 32-bit MCU family built on the embedded Power Architecture<sup>®</sup> (RM0017), available at www.st.com

 SPC564Bxx, SPC56ECxx 32-bit MCU family built on the embedded Power Architecture<sup>®</sup> (RM0070 DOC ID18196)

## A.2 Acronyms

Table 2. Acronyms

| Acronym | Name                                        |
|---------|---------------------------------------------|
| ADC     | Analog to Digital Converter                 |
| ALTCADR | eMIOS UC A2 Register                        |
| CADR    | eMIOS UC A1 Register                        |
| CBDR    | eMIOS UC B2 Register                        |
| CTU     | Cross Triggering Unit                       |
| EMC     | Electromagnetic Compatibility               |
| eMIOS   | Configurable enhanced Modular I/O Subsystem |
| EVB     | Evaluation Board                            |
| LA      | Lighting Application                        |
| MC      | eMIOS channel Modulus Counter mode          |
| MCU     | Microcontroller Unit (SPC560B50)            |
| OPWMT   | eMIOS channel Output PWM mode with Trigger  |
| PCR     | Pad Configuration Register                  |
| PWM     | Pulse Width Modulation                      |
| SIUL    | System Integration Unit Lite                |
| SAIC    | Single Action Input Capture                 |
| SAOC    | Single Action Output Compare                |
| DMA     | Direct Memory Access                        |
| UC      | eMIOS Universal Counter channel             |

AN4300 Revision history

# **Revision history**

Table 3. Document revision history

| Date        | Revision | Changes                         |
|-------------|----------|---------------------------------|
| 13-Jun-2013 | 1        | Initial release                 |
| 17-Sep-2013 | 2        | Updated Disclaimer.             |
| 08-Oct-2015 | 3        | Robust root part numbers added. |

#### **IMPORTANT NOTICE - PLEASE 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 acknowledgement.

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. 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.

© 2015 STMicroelectronics - All rights reserved