



# J7AHP MCAL - SoC User Manual

Document Version : 25

Document Owner : Rohit Tiwari

**TI Confidential - NDA Restrictions**

**Copyright ©2023 Texas Instruments Incorporated**

- [1.1. Introduction](#)
- [1.2. Purpose](#)
- [1.3. SoC Architecture](#)
- [1.4. MCAL Scope and HW Peripheral Details](#)
- [1.5. MCAL Integration Details](#)
  - [1.5.1. Dependency:](#)
    - [1.5.1.1. Hardware Dependency on J784S4 EVM](#)
    - [1.5.1.2. Compiler](#)
    - [1.5.1.3. PDK](#)
- [1.6. Running Examples:](#)
  - [1.6.1. CCS](#)
    - [1.6.1.1. Load Example Binaries](#)
  - [1.6.2. SBL](#)
- [1.7. MCAL Module User Guide Info:](#)
  - [1.7.1. ADC](#)
  - [1.7.2. DIO](#)
  - [1.7.3. WDG](#)
  - [1.7.4. SPI](#)
  - [1.7.5. CAN](#)
  - [1.7.6. GPT](#)
  - [1.7.7. PWM](#)
    - [1.7.7.1. PWM\\_GPT](#)
    - [1.7.7.2. PWM\\_EPWM](#)
  - [1.7.8. CDDIPC](#)
  - [1.7.9. FLS](#)
  - [1.7.10. ICU](#)



- [1.7.11. MCU](#)
- [1.8. Build Env:](#)
- [1.9. Steps to Build in Windows:](#)
  - [1.9.1.1. Step 1 : Download the windows version of required tools](#)
  - [1.9.1.2. Step 2 : Install tools and copy the components](#)
  - [1.9.1.3. Step 4 : Disable generation of cust SBL](#)
  - [1.9.1.4. Step 3 : Build](#)
  - [1.9.1.5. Examples NOT supported in windows build](#)

#### Document Revision History

| Revision | Date                     | Author       | Description                         |
|----------|--------------------------|--------------|-------------------------------------|
| 0.1      | <span>07 Mar 2022</span> | Nikki Shah   | Initial Version                     |
| v.25     | <span>13 Feb 2023</span> | Subham Swain | Updated J784s4 SoC specific changes |



## 1 1.1. Introduction

SoC's such as J7AHP (J784S4) family of devices, integrates an MicroController Unit Subsystem (MCU SS) as an chip-in-chip. It operates using a separate voltage supply, clock sources and resets and includes the components needed for device management. This allows the MC USS to function continuously regardless of the state of the rest of the device. MCU SS has one or more DUAL core Cortex R5F.



## 2 1.2. Purpose

This document is a supplement to the CSP provided with the MCAL product.

The purpose of this document is to highlight J784S4 SoC integration details, SoC specific differences and deviations from MCAL Architecture Document, Module User Guide, Design Documents, Test Strategy Document, etc.



### 3 1.3. SoC Architecture

Reference: J784S4, TDA4AP, TDA4VP, TDA4AH, TDA4VH Processors Silicon Revision 1.0 TRM, Revision: April 2022, [TRM](#)

J7AHP device integrates MicroControllerUnit (MCU) dedicated to provide isolated processing entity. This isolated processing entity could be employed to realize an ASIL system (upto ASIL D). The block diagrams of J7ahp is as shown below, the integrated MCU is referred as MCU SS. The AUTOSAR is expected to be hosted on MCU SS (or WAKEUP/MUC of J7AHP) and other R5F in Main domain, in case of J7AHP class of devices. The MCU SS will have dual core lock-step R5F processor. The MCAL drivers provided will use peripheral within the MCU SS and shared peripherals within the SoC.

J7ahp SoCs are expected to be used in various automotive ECUs (such as front-camera ADAS, SRV, Gate Way, Head-Unit, etc...). AUTOSAR is the industry standard software architecture that allows OEM's software applications to scale to different vehicles, different SoCs, while maintaining safety and functional requirements. TDA4x SoC dedicates MCU SS to host AUTOSAR stack and provide a isolated processing entity.



## 4 1.4. MCAL Scope and HW Peripheral Details

|          | <b>MCAL Driver</b> | <b>HW Peripheral Details</b> | <b>Device Specific Recommendations</b>                                                                                                                                                                                                                                                                                                                             |
|----------|--------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>1</b> | ADC                | 2x ADC Instances             | NA                                                                                                                                                                                                                                                                                                                                                                 |
| <b>2</b> | DIO                | 7x GPIO Instances            | NA                                                                                                                                                                                                                                                                                                                                                                 |
| <b>3</b> | GPT                | 16x DM Timers                | NA                                                                                                                                                                                                                                                                                                                                                                 |
| <b>4</b> | WDG                | 11x RTI Instances            | NA                                                                                                                                                                                                                                                                                                                                                                 |
| <b>5</b> | SPI                | 11 McSPI Devices             | <p>Below SPI instances for TDA4x have limitations:</p> <ol style="list-style-type: none"> <li>1. MCSPI7 from the main domain does not support master mode.</li> <li>2. MCSPI17 from the main domain and MCU_MCSPI2 from MCU domain.</li> </ol> <p>Below SPI instances of device variants TDA4x does not support master mode and are not pinned out externally.</p> |



|           | <b>MCAL Driver</b> | <b>HW Peripheral Details</b>                | <b>Device Specific Recommendations</b> |
|-----------|--------------------|---------------------------------------------|----------------------------------------|
| <b>6</b>  | ICU                | 3x ECAP Instances                           | NA                                     |
| <b>7</b>  | FLS                | OSPI<br>External Flash Device:<br>S28HS512T | NA                                     |
| <b>8</b>  | PWM (Timer)        | 16x DM Timers                               | NA                                     |
| <b>9</b>  | EPWM               | 6x EPWM Instances                           | NA                                     |
| <b>10</b> | CDD IPC            |                                             |                                        |
| <b>11</b> | ETH                | TBD                                         |                                        |
| <b>12</b> | MCU                | TBD                                         | NA                                     |
| <b>13</b> | CAN(MCAN)          | 2x (MCU)                                    | NA                                     |



Below table outlines specific HW IP usage per module:

|   | <b>SW Modules</b> | <b>HW IP</b>                |
|---|-------------------|-----------------------------|
| 1 | ADC               | adc12_16ffc_10_rel.1.0.x    |
| 2 | DIO               | gpio_144_10_rel.1.5.x       |
| 3 | WDG               | rti_10_rel.0.0.x            |
| 4 | CAN               | mcanss_10_rel.1.1.x         |
| 5 | SPI               | spi_10_rel.2.11.x           |
| 6 | GPT               | dmtimer_dmc1ms_10_rel.1.0.x |
| 7 | PWM               | dmtimer_dmc1ms_10_rel.1.0.x |
| 8 | EPWM              | ehrpwm_10_rel.1.3.x         |



|    | <b>SW Modules</b> | <b>HW IP</b>            |
|----|-------------------|-------------------------|
| 9  | ICU               | ecap_10_rel.1.0.x       |
| 10 | FLS               | ospi_10_rel.1.0.x       |
| 11 | CDD IPC           | ksipc_mailbox_rel.1.0.x |



## 5 1.5. MCAL Integration Details

J7AHP MCAL is delivered as a component within Processor SDK and part of MCUSW.

J7AHP MCAL examples are dependent on an SDK and will require that proper dependencies are met.

### 5.1 1.5.1. Dependency:

#### 5.1.1 1.5.1.1. Hardware Dependency on J784S4 EVM

**EVM:**

Contact your FAE for documents describing the EVM



Revision: 25  
Page 13 of 60



### 5.1.2 J784S4 EVM NO Boot Mode / CCS:



TI Confidential - NDA Restrictions

Revision: 25

Page 15 of 60



### 5.1.3 J784S4 EVM MMC/SD Boot Mode:



Revision: 25

Page 17 of 60



#### 5.1.4 J784S4 EVM OSPI Boot Mode:





#### **Emulator:**

J784S4 EVM includes an on-board XDS110 USB emulator, which could be used with CCS. Please contact your FAE for documents describing the EVM.

An external emulator such as Spectrum Digital XDS560V2 could be used. While creating the target, please select the emulator that is being used. Refer to MCUSW User Guide for details.

#### **5.1.5 1.5.1.2. Compiler**

The SDK with which MCUSW is expected to be used, packages all required compiler and code generation tools required by MCUSW. The Configurator would be an exception, please refer to MCUSW User Guide for details.

MCUSW has now migrated to the TI Arm Clang compiler. Some benefits of this migration include:

- Excellent C/C++ standards support
- Improved code size over.
- Ease of use with fast compiles and expressive diagnostic messages.

#### **5.1.6 1.5.1.3. PDK**

"PDK" is a component within Processor SDK. Following section list the sub-components of PDK that are used / required by MCAL modules.

Please check release note that came with this release for the compatible version of PDK/SDK.

#### **UDMA:**

UDMA is used to move data between peripherals and memory.

- The Eth MCAL module relies on UDMA driver.



- SPI Driver relied on UDMA driver for DMA mode.

#### **MCAL Example Application**

- Applications rely on SCI Client to request interrupt number as resource.
- Applications rely on OSAL to register MCAL modules interrupts.
- Applications rely on UART driver to print on console.
- For MCU21 applications, please note that sciserver\_testapp needs to be run on mcu1\_0 core.



## 6 1.6. Running Examples:

### 6.1 1.6.1. CCS

#### IDE (CCS)

Code Composer Studio is an integrated development environment (IDE) that supports TI's Microcontroller and Embedded Processors portfolio.

- [CCS Link](#)
- [Download](#)

J721E/J7200/J721S2/J784S4

1. Supported CCS version is detailed in SDK Documents.
2. Installation and configuration of GEL files is detailed in SDK Documents.

#### 6.1.1 1.6.1.1. Load Example Binaries

1. Ensure boot mode of the EVM is configured as described in No Boot mode.
2. UART / Console for demo application logs / messages
  - J784S4 EVM had 2 UART ports
  - UART port named **MCU UART** would be used when demo applications are hosted on MCU R5F (mcu 1 0)
  - UART port named **Main UART** would be used when demo applications are hosted on MAIN R5F (mcu 2 1)
3. CCS Setup & Steps to run from CCS Refer the SDK Documents user guide for generic test setup details and steps to run the examples/demos using CCS/SBL.
4. **Reset MCU\_Cortex\_R5\_0\_0 core**
5. In core MCU\_Cortex\_R5\_0\_0, load binary **(driver name)\_app\_mcu1\_0\_(release or debug).xer5f**



- J784S4 MCAL Binaries is available at (\$PSDKRA\_INSTALL\_PATH)/mcusw/binary/(driver name)\_app/bin/j784s4\_evm/
  - Some of the example applications (ipc) would have more than 1 binaries. The name of the binaries specify the core that it's intended to host on
6. Run example
    - Expect to see prints on CCS console or UART console. See "Setup Build Environment" in MCUSW User Guide.
  7. On Core MCU 2 1
    - UART port on which prints are displayed is different, ensure to connect UART port named **UART** on the EVM
    - J784S4 MCAL Binaries is available at (\$PSDKRA\_INSTALL\_PATH)/mcusw/binary/(driver name)\_app/bin/j784s4\_evm/(driver name)\_app\_mcu2\_1\_(release or debug).xer5f
    - Connect to MAIN\_Cortex\_R5\_0\_1
    - Load binaries and run

## 6.2 1.6.2. SBL

### SD/MMC

To build the SBL binary for SD/MMC, please use the following command:

```
$cd ($PSDKRA_INSTALL_PATH)/pdk_jacinto_07_xx_xx/packages/ti/build $make sbl_mmcisd_img
```

Post compilation of SBL, the SBL binary can be found at (\$PSDKRA\_INSTALL\_PATH)/(pdk-install-folder)/packages/ti/boot/sbl/binary/j784s4\_evm/(boot-media)/bin/\*.tiimage

To be able to boot from SD card copy the following to the SD card boot partition (FAT32)

- Copy the tifs.bin form **(\$PSDKRA\_INSTALL\_PATH)/(pdk-install-folder)/packages/ti/driv/sciclient/soc/V4/tifs.bin as tifs.bin**
- Copy the application from (\$PSDKRA\_INSTALL\_PATH)/mcusw/binary/(driver name)\_app/bin/j784s4\_evm/.\*appimage to the SD card boot partition as **app**
- MMC SD: Ensure The bootmode switches are configured as described in MMC/SD Boot Mode.

### OSPI



Steps below highlight the steps required to program OSPI with binary image

#### Software Prerequisites

- Download and install the latest Uniflash version 8.2 from <https://www.ti.com/tool/UNIFLASH>

#### Board Setup for Flashing OSPI

- Configure SW3 on CP board for below values  
1-OFF, 2-X, 3-X, 4-X, 5-X, 6-X, 7-X, 8-X
- Configure Boot switches to 'UART' mode  
SW8: 1-OFF, 2-OFF, 3-OFF, 4-OFF, 5-OFF, 6-OFF, 7-OFF, 8-OFF  
SW9: 1-OFF, 2-ON, 3-ON, 4-ON, 5-OFF, 6-OFF, 7-OFF, 8-OFF
- Connect micro USB cable to MCU UART port (J43) and host PC – Configure serial console application on host PC to use MCU UART port with '115200 8N1' configuration

#### Procedure for Flashing OSPI

1. Load the uart flash writer binary `uart_j784s4_evm_flash_programmer_release.timage` @ 0th location.
  - Flash programmer is available as part of Uniflash at - (Path to Uniflash Install Directory)/processors/FlashWriter/j784s4\_evm
  - Goto Uniflash Install Directory and run the following commands from that path.  
Eg: `dslite.bat --mode processors -c COM55 -f C:\ti\uniflash_6.1.0\processors\FlashWriter\j784s4_evm\uart_j784s4_evm_flash_programmer_release.timage -i 0`
2. Make sure the character 'C' is getting displayed on the serial console. Make a note of the COM port number.
3. Close all the serial console applications on host PC, disconnect and reconnect micro USB cable connected to MCU UART port (J43)
4. Run the below command to flash the SBL to OSPI flash `dslite.bat -mode processors -c (COM Port#) -f (Boot Image) -d 3 -o 0`
  - COM port#: COM port number on which J7 MCU UART serial port is connected
  - Boot Image: SBL image (`sbl_ospi_img_mcu1_0_release.timage`) with full path.  
Eg: `dslite.bat --mode processors -c COM55 -f C:\ti\j7_evm_repo\pdk\packages\ti\boot\sbl\binary\j784s4_evm\ospi\bin\sbl_ospi_img_mcu1_0_release.timage -d 3 -o 0`
5. Run the below command to flash the system firmware to OSPI flash `dslite.bat -mode processors -c (COM Port#) -f (SYSFW Image) -d 3 -o 80000`



- COM port#: COM port number on which J7 MCU UART serial port is connected
- SYSFW Image: System firmware image with full path.

Eg: dslite.bat --mode processors -c COM55 -f C:\ti\j7\_evm\_repo\pdk\packages\ti\drv\sciclient\soc\V1\tifs.bin -d 3 -o 80000

6. Run the below command to flash the app image to OSPI flash dslite.bat -mode processors -c (COM Port#) -f (App Image) -d 3 -o 100000

- COM port#: COM port number on which J7 MCU UART serial port is connected
- App Image: Application image with full path name.

Eg: dslite.bat --mode processors -c COM55 -f C:

\ti\j7\_evm\_repo\pdk\packages\ti\binary\udma\_memcpy\_testapp\bin\j784s4\_evm\udma\_memcpy\_testapp\_mcu1\_0\_release.appimage -d 3 -o 100000

7. Run the below command to flash OSPI PHY tuning binary. In case of J7200 flash at location 3FC0000 and for J784S4 at 3FE0000 dslite.bat -mode processors -c (COM Port#) -f (nor\_spi\_patterns.bin) -d 3 -o 3FE0000

- COM port#: COM port number on which J7 MCU UART serial port is connected
- OSPI Phy Bin : nor\_spi\_patterns.bin.

Eg: dslite.bat --mode processors -c COM55 -f C:\ti\j7\_evm\_repo\pdk\packages\ti\board\src\flash\nor\ospi\nor\_spi\_patterns.bin -d 3 -o 3FE0000

#### Procedure for Verifying OSPI Boot

- After successful flashing, power OFF the board and configure it for OSPI boot.
- Connect micro USB cable to MCU UART port (J43) and host PC – Configure serial console application on host PC to use MCU UART port with '115200 8N1' configuration
- Power ON the board and confirm the boot logs on serial console

| Mode | Switch Settings                |
|------|--------------------------------|
| UART | SW8: 0000_0000, SW9: 0111_0000 |



| <b>Mode</b>   | <b>Switch Settings</b>          |
|---------------|---------------------------------|
| OSPI (J721E)  | SW8: 0000_0000, SW9: 0100_0000  |
| OSPI (J7200)  | SW8: 1000_0010, SW9: 0011_0000  |
| OSPI (J721S2) | SW8: 0000_1010, SW9: 0110_0000  |
| OSPI (J784S4) | SW11: 0000_1010, SW7: 0110_0000 |



## 7 1.7. MCAL Module User Guide Info:

### 7.1 1.7.1. ADC

#### Sample Log

J784S4

### 7.2 1.7.2. DIO

#### Pin Mapping J784S4

In case of J784S4, each Dio instance supports 9 banks of 16 DIO signals/pins or channels (2 in WKUP and 4 in Main domain). Please note in each instance there are some pins that are not pinned out and are reserved.

The mapping of pins in the different instances is shown in the following table. For this implementation the absolute numbering of channel ids starts from the Dio instance in the wakeup domain. Please refer TRM for more details.

| Instance    | Pin Number | ChannelId | Port ID | Available/Not Available |
|-------------|------------|-----------|---------|-------------------------|
| WKUP_GPIO 0 | 0          | 0         | 0       | Available               |



| Instance    | Pin Number | ChannelId | Port ID | Available/Not Available |
|-------------|------------|-----------|---------|-------------------------|
| :           | :          | :         | :       | Available               |
| WKUP_GPIO 0 | 31         | 31        | 0       | Available               |
| WKUP_GPIO 0 | 32         | 32        | 1       | Available               |
| :           | :          | :         | :       | Available               |
| WKUP_GPIO 0 | 63         | 63        | 1       | Available               |
| WKUP_GPIO 0 | 64         | 64        | 2       | Available               |
| :           | :          | :         | :       | Available               |
| WKUP_GPIO 0 | 83         | 83        | 2       | Available               |
| WKUP_GPIO 0 | 84         | x         | x       | <b>Not Available</b>    |



| Instance    | Pin Number | ChannelId | Port ID | Available/Not Available |
|-------------|------------|-----------|---------|-------------------------|
| :           | :          | :         | :       | <b>Not Available</b>    |
| WKUP_GPIO 0 | 143        | x         | x       | <b>Not Available</b>    |
| WKUP_GPIO 1 | 0          | 144       | 3       | Available               |
| :           | :          | :         | :       | Available               |
| WKUP_GPIO 1 | 31         | 175       | 3       | Available               |
| WKUP_GPIO 1 | 32         | 176       | 4       | Available               |
| :           | :          | :         | :       | Available               |
| WKUP_GPIO 1 | 63         | 207       | 4       | Available               |
| WKUP_GPIO 1 | 64         | 208       | 5       | Available               |



| Instance    | Pin Number | ChannelId | Port ID | Available/Not Available |
|-------------|------------|-----------|---------|-------------------------|
| :           | :          | :         | :       | Available               |
| WKUP_GPIO 1 | 83         | 227       | 5       | Available               |
| WKUP_GPIO 1 | 84         | x         | x       | <b>Not Available</b>    |
| :           | :          | :         | :       | <b>Not Available</b>    |
| WKUP_GPIO 1 | 143        | x         | x       | <b>Not Available</b>    |
| GPIO 0      | 0          | 288       | 6       | Available               |
| :           | :          | :         | :       | Available               |
| GPIO 0      | 31         | 319       | 6       | Available               |
| GPIO 0      | 32         | 320       | 7       | Available               |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | Available               |
| GPIO 0   | 63         | 351       | 7       | Available               |
| GPIO 0   | 64         | 352       | 8       | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 0   | 95         | 383       | 8       | Available               |
| GPIO 0   | 96         | 384       | 9       | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 0   | 127        | 415       | 9       | Available               |
| GPIO 0   | 128        | x         | x       | <b>Not Available</b>    |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | <b>Not Available</b>    |
| GPIO 0   | 143        | x         | x       | <b>Not Available</b>    |
| GPIO 2   | 0          | 576       | 12      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 2   | 31         | 607       | 12      | Available               |
| GPIO 2   | 32         | 608       | 13      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 2   | 63         | 639       | 13      | Available               |
| GPIO 2   | 64         | 640       | 14      | Available               |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | Available               |
| GPIO 2   | 95         | 671       | 14      | Available               |
| GPIO 2   | 96         | 672       | 15      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 2   | 127        | 703       | 15      | Available               |
| GPIO 2   | 128        | x         | x       | <b>Not Available</b>    |
| :        | :          | :         | :       | <b>Not Available</b>    |
| GPIO 2   | 143        | x         | x       | <b>Not Available</b>    |
| GPIO 4   | 0          | 864       | 18      | Available               |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | Available               |
| GPIO 4   | 31         | 895       | 18      | Available               |
| GPIO 4   | 32         | 896       | 19      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 4   | 63         | 927       | 19      | Available               |
| GPIO 4   | 64         | 928       | 20      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 4   | 95         | 959       | 20      | Available               |
| GPIO 4   | 96         | 960       | 21      | Available               |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | Available               |
| GPIO 4   | 127        | 991       | 21      | Available               |
| GPIO 4   | 128        | x         | x       | <b>Not Available</b>    |
| :        | :          | :         | :       | <b>Not Available</b>    |
| GPIO 4   | 143        | x         | x       | <b>Not Available</b>    |
| GPIO 6   | 0          | 1152      | 25      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 6   | 31         | 1183      | 25      | Available               |
| GPIO 6   | 32         | 1184      | 26      | Available               |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | Available               |
| GPIO 6   | 63         | 1215      | 26      | Available               |
| GPIO 6   | 64         | 1216      | 27      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 6   | 95         | 1247      | 27      | Available               |
| GPIO 6   | 96         | 1248      | 28      | Available               |
| :        | :          | :         | :       | Available               |
| GPIO 6   | 127        | 1279      | 28      | Available               |
| GPIO 6   | 128        | x         | x       | <b>Not Available</b>    |



| Instance | Pin Number | ChannelId | Port ID | Available/Not Available |
|----------|------------|-----------|---------|-------------------------|
| :        | :          | :         | :       | <b>Not Available</b>    |
| GPIO 6   | 143        | X         | X       | <b>Not Available</b>    |

**Sample Log****J784S4**



```
Sample Application - STARTS !!!
```

**DIO MCAL Version Info**

```
-----  
Vendor ID      : 44  
Module ID     : 120  
SW Major Version : 3  
SW Minor Version : 0  
SW Patch Version : 0
```

**Test A. Write and Read Channel**

```
-----  
Channels written
```

```
Channel read DIO_PinLevel[0] = 0  
Channel read DIO_PinLevel[1] = 1  
Channel read DIO_PinLevel[2] = 0  
DIO Service API Read-back Channel Succeeds !!!
```

**DIO Test A :Service API: Write/Read Channel completed**

**Test B. Write and Read Channel Group**

```
-----  
DIO Service Read/Write Channel Group Read-back Succeeds !!!
```

**DIO Test B : Service API : Write/Read Channel Group completed**

**Test C. Write and Read Port**

```
-----  
DIO Service API Read-Back Port succeeds !!!
```

**DIO Test C : Service API: Write/Read Port completed**

**Test D. Flip Channel**

```
-----  
Pin Value Before Flip: 0
```

```
Pin Value After Flip: 1
```

**DIO Test D : Service API: Flip Channel completed**

**Test E. Dio\_RegisterReadback**

```
-----
```



## 7.3 1.7.3. WDG

### Sample Log

**J784S4**

User Input : To generate an interrupt (via ESM)



```
Starting WDG test !!!
```

```
WDG MCAL Version Info
```

```
-----  
Vendor ID      : 44  
Module ID     : 102  
SW Major Version : 3  
SW Minor Version : 0  
SW Patch Version : 0
```

```
On Expiry of WDG timeout Please enter :
```

```
0 To generate an interrupt (via ESM)  
1 To drive MCU_SAFETY_ERROR Pin low (via ESM)  
0
```

```
Variant - Pre Compile being used !!!
```

```
WDG timeout is configured for 2000 millisecs
```

```
Number of times WDG will be serviced : 5
```

```
WDG ESM Interrupt will be generated after 2000 * 5 i.e 10000 millisecs
```

```
WDG Elapsed and generated an event to ESM
```

```
ESM has generated an Interrupt
```

```
WDG App Completed as expected!!!
```

```
Please refer user guide on usage details
```

```
WDG Stack Usage : 2764 bytes
```

```
WDG Test Passed!!!
```

```
WDG MCAL Version Info
```

```
-----  
Vendor ID      : 44  
Module ID     : 102  
SW Major Version : 3  
SW Minor Version : 0  
SW Patch Version : 0
```

```
On Expiry of WDG timeout Please enter :
```

```
0 To generate an interrupt (via ESM)  
1 To drive MCU_SAFETY_ERROR Pin low (via ESM)
```

## 7.4 1.7.4. SPI

Spi Instance ID mapping and ISR mapping

11 spi instances are supported by this driver implementation (8 instances in Main Domain & 3 in MCU Domain in case of J721E/J7200/J721S2/J784S4). The following table lists the mapping between instance of MCSPI and SpiChannelId of the configurator

| <b>Spi HwUnit Id</b> | <b>Spi Instance</b> | <b>Associated ISR</b>    |
|----------------------|---------------------|--------------------------|
| 0                    | MCU SPI 0           | Spi_IrqUnitMcuMcspi0TxRx |
| 1                    | MCU SPI 1           | Spi_IrqUnitMcuMcspi1TxRx |
| 2                    | MCU SPI 2           | Spi_IrqUnitMcuMcspi2TxRx |
| 3                    | SPI 0               | Spi_IrqUnitMcspi0TxRx    |
| 4                    | SPI 1               | Spi_IrqUnitMcspi1TxRx    |
| 5                    | SPI 2               | Spi_IrqUnitMcspi2TxRx    |



| Spi HwUnit Id | Spi Instance | Associated ISR        |
|---------------|--------------|-----------------------|
| 6             | SPI 3        | Spi_IrqUnitMcspi3TxRx |
| 7             | SPI 4        | Spi_IrqUnitMcspi4TxRx |
| 8             | SPI 5        | Spi_IrqUnitMcspi5TxRx |
| 9             | SPI 6        | Spi_IrqUnitMcspi6TxRx |
| 10            | SPI 7        | Spi_IrqUnitMcspi7TxRx |

#### Sample Log

J784S4



```
SPI MCAL Version Info
-----
Vendor ID      : 44
Module ID     : 83
SW Major Version : 3
SW Minor Version : 0
SW Patch Version : 0

SPI_APP: CH 1: JOBS 1: SEQ 1: Max HWUNIT 1: NUM OF WORDS 10000:!!!
SPI_APP: SPI Async transmit in progress!!
SPI_APP: SPI Hwunit 0 configuration Register Readback values
SPI_APP: MCSPI_HL_REV          : 0x40301a0b
SPI_APP: MCSPI_HL_HWINFO       : 0x9
SPI_APP: MCSPI_HL_SYSCONFIG    : 0x4
SPI_APP: MCSPI_REVISION        : 0x2b
SPI_APP: MCSPI_SYSSTATUS       : 0x1
SPI_APP: MCSPI_SYST            : 0x0
SPI_APP: MCSPI_MODULCTRL       : 0x1
SPI_APP: MCSPI_SYSCONFIG       : 0x308
SPI_APP: MCSPI_CH0CONF         : 0x20050f80
SPI_APP: MCSPI_CH1CONF         : 0x60000
SPI_APP: MCSPI_CH2CONF         : 0x60000
SPI_APP: MCSPI_CH3CONF         : 0x60000
SPI_APP: MCSPI_IRQENABLE       : 0x0
SPI_APP: SPI Stack Usage: 2844 bytes
SPI_APP: SPI Loopback Test Passed!!!
```



## 7.5 1.7.5. CAN

**Sample Log**

**J784S4**



```
CAN_APP: Sample Application - STARTS !!!  
CAN_APP: Variant - Pre Compile being used !!!  
CAN_APP: Successfully Enabled CAN Transceiver MCU MCAN0!!!  
CAN_APP: Successfully Enabled CAN Transceiver MCU MCAN1!!!  
CAN_APP: Message Id Received 400000a0 Message Length is 64  
CAN_APP: Can Controller Instance MCAN 0      Internal LoopBack Mode Test Passed  
CAN_APP: Message Id Received c00000b0 Message Length is 64  
CAN_APP: Can Controller Instance MCAN 1      Internal LoopBack Mode Test Passed  
CAN_APP: Message Id Received 400000c0 Message Length is 64  
CAN_APP: Can Controller Instance MCAN 2      Internal LoopBack Mode Test Passed  
  
CAN_APP: Safety Diagnostic API functionality test for controller MCAN 0  
CAN_APP: Can_EnableIntr() API test  
CAN_APP: Successfully Enabled TOO interrupt  
CAN_APP: Successfully Enabled PEA interrupt  
CAN_APP: Can_GetIntrStatus() API test  
CAN_APP: No error event occurred  
CAN_APP: Can_ClearIntrStatus() API test  
CAN_APP: Interrupt Status Clear Successful  
CAN_APP: Can_DisableIntr() API test  
CAN_APP: Successfully Disable TOO interrupt  
CAN_APP: Successfully Disable PEA interrupt  
CAN_APP: Can_RegisterReadback() API test  
CAN_APP: Can_RegisterReadback Successful  
  
CAN_APP: Safety Diagnostic API functionality test for controller MCAN 1  
CAN_APP: Can_EnableIntr() API test  
CAN_APP: Successfully Enabled TOO interrupt  
CAN_APP: Successfully Enabled PEA interrupt  
CAN_APP: Can_GetIntrStatus() API test  
CAN_APP: No error event occurred  
CAN_APP: Can_ClearIntrStatus() API test  
CAN_APP: Interrupt Status Clear Successful  
CAN_APP: Can_DisableIntr() API test  
CAN_APP: Successfully Disable TOO interrupt  
CAN_APP: Successfully Disable PEA interrupt  
CAN_APP: Can_RegisterReadback() API test
```



## 7.6 1.7.6. GPT

**Sample Log**

**J784S4**



**GPT\_APP: Building Interrupt List !!!**

**GPT\_APP: Variant - Post Build being used !!!**

**GPT\_APP: Interrupt List Completed !!!**

**GPT\_APP: Sample Application - STARTS !!!**

**GPT\_APP: Variant - Post Build being used !!!**

**GPT\_APP GPT MCAL Version Info**

**GPT\_APP-----**

**GPT\_APP Vendor ID : 44**

**GPT\_APP Module ID : 100**

**GPT\_APP SW Major Version : 3**

**GPT\_APP SW Minor Version : 0**

**GPT\_APP SW Patch Version : 0**

**GPT\_APP-----**

**GPT\_APP: GPT Channel 11 configuration register values**

**GPT\_APP TIMER\_TIDR : 0x50003900**

**GPT\_APP TIMER\_TTGR : 0xffffffff**

**GPT\_APP TIMER\_TSICR : 0x0**

**GPT\_APP TIMER\_TIOCP\_CFG : 0xa**

**GPT\_APP TIMER\_TCLR : 0x0**



## 7.7 1.7.7. PWM

### Example Application

#### PwmApp\_Gpt

J784S4 EVM

The timer Test Point TP93 can be probed to check the output PWM signals,

#### PwmApp\_Epwm

J784S4 EVM

The ePWM Test Point TP126 can be probed to check the output PWM signals.

## 7.8 Limitations:

1. AEP will not support EHRPWM feature because of hardware limitation.

### 7.8.1 1.7.7.1. PWM\_GPT

#### Sample Log

J784S4



**PWM\_APP\_GPT: Sample Application - STARTS !!!**

**PWM\_APP\_GPT: PWM MCAL Version Info**

-----  
**PWM\_APP\_GPT: Vendor ID : 44**

**PWM\_APP\_GPT: Module ID : 121**

**PWM\_APP\_GPT: SW Major Version : 3**

**PWM\_APP\_GPT: SW Minor Version : 0**

**PWM\_APP\_GPT: SW Patch Version : 0**

**PWM\_APP\_GPT: Variant - Pre Compile being used !!!**

**PWM\_APP\_GPT: PWM CHANNEL 10 configuration Register Readback values**

**PWM\_APP\_GPT: PWM\_REV : 0x50003900**

**PWM\_APP\_GPT: PWM\_TTGR : 0xffffffff**

**PWM\_APP\_GPT: PWM\_TMSYNCTRL : 0x0**

**PWM\_APP\_GPT: PWM Channel Initialized**

**PWM\_APP\_GPT: PWM Duty cycle: 50 Percent, PWM Period: 1 sec**

**PWM\_APP\_GPT: Probe TIMER in Main domain(Test Pin TP93)in J784S4 EVM**

**PWM\_APP\_GPT: This example waits for 10 seconds please probe**

**PWM\_APP\_GPT: Changing the Duty cycle from 50 Percent to 80 Percent**

**PWM\_APP\_GPT: This example waits for 10 seconds Please probe**



## 7.8.2 1.7.7.2. PWM\_EPWM

**Sample Log**

**J784S4**



**PWM\_APP\_EPWM: Sample Application - STARTS !!!**

**PWM\_APP\_EPWM: EPWM being used with Channel # 1!!!**

**Copy the tifs.bin form (\$PSDKRA\_INSTALL\_PATH)/(pdk-install-folder)/packages/ti/drv/sciclient/soc/V1/tifs.bin as tifs.bin in case of J721E**

**Copy the tifs.bin form (\$PSDKRA\_INSTALL\_PATH)/(pdk-install-folder)/packages/ti/drv/sciclient/soc/V2/tifs.bin as tifs.bin in case of J7200**

**PWM\_APP\_EPWM: PWM MCAL Version Info**

---

**PWM\_APP\_EPWM: Vendor ID : 44**

**PWM\_APP\_EPWM: Module ID : 121**

**PWM\_APP\_EPWM: SW Major Version : 3**

**PWM\_APP\_EPWM: SW Minor Version : 0**

**PWM\_APP\_EPWM: SW Patch Version : 0**

**PWM\_APP\_EPWM: Variant - Pre Compile being used !!!**

**PWM\_APP\_EPWM: PWM Channel Initialized**

**PWM\_APP\_EPWM: PWM Duty cycle: 60 Percent, 1000Hz**

**PWM\_APP\_EPWM: PWM CHANNEL 1 configuration Register Readback values**

**PWM\_APP\_EPWM: EPWM\_TBCTL : 0x84b2**

**PWM\_APP\_EPWM: EPWM\_TBPHS : 0x0**

**PWM\_APP\_EPWM: EPWM\_TBCNT : 0x11c3**

**PWM\_APP\_EPWM: EPWM\_AQCTLA : 0xf2**

**PWM\_APP\_EPWM: EPWM\_AQCTLB : 0xf02**



## 7.9 1.7.8. CDDIPC

### Interrupt to ISR mapping

The following table lists the interrupt details, required for applications to register ISR to receive interrupt on the core that hosts MCAL/IPC

J784S4:

J784S4: CDD IPC Example on MCU 21

| Host Core | Remote Core | Cluster | User | Int No on MCU 10 | Comments                           |
|-----------|-------------|---------|------|------------------|------------------------------------|
| MCU 2 1   | MCU 2 0     | 7       | 0    | 377              | ISR <b>Cdd_IpcIRQMbxFromMcu_20</b> |

### Running the example application via CCS

#### Steps to run

**J784S4 - MCU 2 1**



```
CDD_IPC_APP : CDD IPC MCAL Version Info
CDD_IPC_APP :-----
CDD_IPC_APP : Vendor ID      : 44
CDD_IPC_APP : Module ID     : 255
CDD_IPC_APP : SW Major Version : 3
CDD_IPC_APP : SW Minor Version : 0
CDD_IPC_APP : SW Patch Version : 0

CDD_IPC_APP :
CDD_IPC_APP : Sample Application - STARTS !!!
CDD_IPC_APP : Received ti.ipc4.ping-pong as ctrl MSG from MCU 2 0
CDD_IPC_APP : Received ping 0 Iteration 10 from MCU 2 0
CDD_IPC_APP : Received ping 1 Iteration 9 from MCU 2 0
CDD_IPC_APP : Received ping 2 Iteration 8 from MCU 2 0
CDD_IPC_APP : Received ping 3 Iteration 7 from MCU 2 0
CDD_IPC_APP : Received ping 4 Iteration 6 from MCU 2 0
CDD_IPC_APP : Received ping 5 Iteration 5 from MCU 2 0
CDD_IPC_APP : Received ping 6 Iteration 4 from MCU 2 0
CDD_IPC_APP : Received ping 7 Iteration 3 from MCU 2 0
CDD_IPC_APP : Received ping 8 Iteration 2 from MCU 2 0
CDD_IPC_APP : Received ping 9 Iteration 1 from MCU 2 0

CDD_IPC_APP :-----
CDD_IPC_APP :: IPC Channel 3 configuration register values
CDD_IPC_APP : MAILBOX_REVISION      : 0x66fca100
CDD_IPC_APP : MAILBOX_SYSCONFIG    : 0x0
CDD_IPC_APP : MAILBOX_IRQ_EOI      : 0x0
CDD_IPC_APP : MAILBOX_MESSAGE     : 0x0
CDD_IPC_APP : MAILBOX_FIFOSTATUS   : 0x0
CDD_IPC_APP : MAILBOX_MSGSTATUS    : 0x0
CDD_IPC_APP : MAILBOX_IRQSTATUS_RAW : 0aaaaaaaaa
CDD_IPC_APP : MAILBOX_IRQSTATUS_CLR : 0x0
CDD_IPC_APP : MAILBOX_IRQENABLE_CLR : 0x400
CDD_IPC_APP : MAILBOX_IRQENABLE_SET : 0x400

CDD_IPC_APP :-----
```



## 7.10 1.7.9. FLS

### **Sample Log**

**J784S4**

FLS\_app\_dac

FLS\_app\_indac

1.7.10. ICU

### **Functional Description:**

The Icu driver uses ECAP module to capture events. There are three ECAP instances available to work with (ECAP0 - ECAP2) on J721E, J7200 , J721S2 & J784S4.

### **Icu Channel ID , Instance mapping and ISR mapping:**

4The Icu module is implemented using the ECAP instances on the device.

Three ECAP instances are supported by this driver implementation (three instances present in MAIN domain on J721E, J7200, J721S2 & J784S4). The following table lists the mapping between instance of ECAP and IcuChannelId of the configurator.



| IcuChannelId | ECAP Instance | Associated ISR (if notification is enabled) |
|--------------|---------------|---------------------------------------------|
| 0            | ECAP0         | Icu_ch0Notify                               |
| 1            | ECAP1         | Icu_ch1Notify                               |
| 2            | ECAP2         | Icu_ch2Notify                               |

### **Build and Running the Example Application:**

#### **Example Application:**

To run the icu\_app:

1. J784S4: Uses instance ECAP2 instance and EPWM1 instance

User need to connect EPWM output (TP126) to ECAP input (TP93 on base Board).

#### **Example Log**

##### **J784S4**



## 7.11 1.7.11. MCU

### **Example Log**

**J784S4**



## 8 1.8. Build Env:

<TO-DO>

Add info on how to build example with SDK integration

## 9 1.9. Steps to Build in Windows:

By default CORE SDK RTOS JACINTO support to be built in Linux environment. All the required tools (compilers, OS, etc...) are packaged in CORE SDK RTOS, which enables MCUSW to built without any modifications.

The components MCUSW and PDK can be built in windows environment, with right version of tools.

List below details the steps required to build MCAL (MCUSW) examples in windows environment

### 9.1 1.9.1.1. Step 1 : Download the windows version of required tools

- CORE SDK RTOS J784S4 source is installed and accessible from windows machine, which would be used to build
- Download the windows version of the tools
  - XDC download [TI Website](#)
  - ARM Compiler [TI Website](#)
  - DSP Compiler [TI Website](#)
  - **Please ensure to download the versions used in CORE SDK RTOS JACINTO**
- Create a folder "CORE\_SDK\_RTOS\_J784S4\_XXYYZZ" where XXYYZZ is release number

### 9.2 1.9.1.2. Step 2 : Install tools and copy the components

- Install the downloaded tools in \${Path}/CORE\_SDK\_RTOS\_J784S4\_XXYYZZ/
  - Ensure the version of downloaded tools match the versions used in CORE SDK RTOS
- Copy the components mcusw and pdk
  - Ensure that the mcusw & pdk naming conventions is same as in CORE SDK RTOS

### 9.3 1.9.1.3. Step 4 : Disable generation of cust SBL

- Custom SBL is part of PDK package and relies on Linux based tools
- This requires to be excluded
- In file CORE\_SDK\_RTOS\_J784S4\_XXYYZZ\pdk\packages\ti\boot\sbl\sbl\_component.mk
- Comment out / delete
  - **sbl\_lib\_cust** from sbl\_LIB\_LIST
  - All statements under # **SBL Custom LIB**
- Without these steps the PDK library compilation would fail

### 9.4 1.9.1.4. Step 3 : Build

- Follow the steps listed in [Build](#) to build MCAL examples

### 9.5 1.9.1.5. Examples NOT supported in windows build

| Core   | Examples Not Supported        | Comments                                   |
|--------|-------------------------------|--------------------------------------------|
| MCU 10 | Multi-Core Boot Application   | As demo requires Linux/QNX, C7x & C66 apps |
| MPU 10 | IPC Remote Client Application | Not Yet supported                          |



| Core   | Examples Not Supported | Comments                                |
|--------|------------------------|-----------------------------------------|
| MCU 10 | can_profile_xip_app    | Creation of .bin image is not supported |
| MCU 10 | fls_xip                | Creation of .bin image is not supported |