Contenu principal

Create UART Transmit Block to Transmit Serial Data Using IO Device Builder App

Since R2025a

This example shows how to use the IO Device Builder app to create a UART Transmit block and transmit data to a serial port.

Prerequisites

Ensure that iLLD for TC3x family is downloaded as recommended by hardware setup screens for Infineon Support Package

Note: No circuit connections are required for this example.

Open the IO Device Builder App

To open the IO Device Builder app, perform these steps.

1. Start MATLAB® and then open / create a Simulink® model.

2. In the Simulink model, navigate to Modeling > Model Settings to open Configuration Parameters dialog box.

3. In the Configuration Parameters dialog box, click Hardware Implementation and then select Infineon AURIX TC3x as the hardware board and select TC39x as Device series.

4. On the Hardware tab of the Simulink toolstrip, in Prepare section, under Design, choose IO Device Builder.

Select Working Directory and Add Third-Party Source Files

Once the Source files location page loads, select the working directory and add third-party source files.

On the Source files location page:

  1. Click Select and select the working directory. This app saves generated System Object™ along with the corresponding C and H files, and the model in the working directory.

  2. Click Add folder and add the folders you downloaded. This app includes only the files present directly within the selected folder and exludes any files present within subfolders.

  3. Click Next to continue.

Select Source Files

On the Source files page, select the required source files and then click Next to continue.

Specify Block Parameters

On the Block parameters page:

1. Specify the block name and add block description.

2. Add the following mask parameters of non tunable type for the block.

  • Baudrate with uint32 as Data type, intial value of 115200

  • StopBits with uint8 as Data type, initial value of 1

  • ParityType with uint8 as Data type, inital value of 0

  • DataLength with uint8 as Data type, inital value of 7

  • DataByteOrder with uint8 as Data type, inital value of 0

3. Click Next to continue.

Define Outputs for the Block

On the Outputs page:

  1. Remove outputs for the block, if any already added.

  2. Click Next to continue.

Define Inputs for the Block

On the Inputs page:

  1. Add Input parameter with int8 as Datatype.

  2. Click Next to continue.

Preview Block

On the Block image page, view the preview of the block with the inputs and outputs you added. Click Next to continue.

Generate System Object Files

On the Generate page, the file generation location is displayed. Click Generate to generate the system object files.

Note: Clear the Select to generate a CPP driver option, as C++ is not supported for Infineon AURIX TC3x boards.

Next Steps

On the Next Steps page, the files generated are shown and the next steps to be performed are displayed. The generate files are created in a directory. This directory also includes a Dependencies folder that contains selected third-party source files. Simply copy these files and the folder to your desired location and integrate them into your Simulink project.

Click Finish.

Perform these steps.

1. The generated .c file opens automatically. Modify it to include the necessary headers and setup functions by referring to the driver file as required.

A sample modified .c file is shown below.

#include "uart_transmit.h"

#include "Ifx_Types.h"
#include "IfxAsclin_Asc.h"

#define ISR_PRIORITY_ASCLIN_TX      8
#define ISR_PRIORITY_ASCLIN_RX      4
#define ISR_PRIORITY_ASCLIN_ER      12
#define ASC_TX_BUFFER_SIZE          256
#define ASC_RX_BUFFER_SIZE          256
#define ASC_BAUDRATE                115200

IfxAsclin_Asc   g_asclin;


uint8 g_uartTxBuffer[ASC_TX_BUFFER_SIZE + sizeof(Ifx_Fifo) + 8];

IFX_INTERRUPT(asc0TxISR, 0, ISR_PRIORITY_ASCLIN_TX);

void asc0TxISR(void)
{
    IfxAsclin_Asc_isrTransmit(&g_asclin);
}

// Baudrate uint32 [1,1] Non tunable
// StopBits uint8 [1,1] Non tunable
// ParityType uint8 [1,1] Non tunable
// DataLength uint8 [1,1] Non tunable
// DataByteOrder uint8 [1,1] Non tunable

void setupFunctionuart_transmit(uint32_T  Baudrate,int size_vector__1,uint8_T  StopBits,int size_vector__2,uint8_T  ParityType,int size_vector__3,uint8_T  DataLength,int size_vector__4,uint8_T  DataByteOrder,int size_vector__5){
  IfxAsclin_Asc_Config ascConf;
    /* Initialize an instance of IfxAsclin_Asc_Config with default values */
    IfxAsclin_Asc_initModuleConfig(&ascConf, &MODULE_ASCLIN0); /* Initialize the structure with default values      */


    /* Set the desired baud rate */
    ascConf.baudrate.baudrate = Baudrate;
    ascConf.baudrate.oversampling = IfxAsclin_OversamplingFactor_16;            /* Set the oversampling factor      */

    ascConf.frame.stopBit = StopBits;
    ascConf.frame.shiftDir = DataByteOrder;
    ascConf.frame.dataLength = DataLength;
    ascConf.frame.parityType = ParityType;
    

    /* Configure the sampling mode */
      ascConf.bitTiming.medianFilter = IfxAsclin_SamplesPerBit_three;             /* Set the number of samples per bit*/
      ascConf.bitTiming.samplePointPosition = IfxAsclin_SamplePointPosition_8;    /* Set the first sample position    */

      /* ISR priorities and interrupt target */
      ascConf.interrupt.txPriority = ISR_PRIORITY_ASCLIN_TX;  /* Set the interrupt priority for TX events             */
      ascConf.interrupt.rxPriority = ISR_PRIORITY_ASCLIN_RX;  /* Set the interrupt priority for RX events             */
      // ascConf.interrupt.erPriority = ISR_PRIORITY_ASCLIN_ER;  /* Set the interrupt priority for Error events          */
      ascConf.interrupt.typeOfService = IfxSrc_Tos_cpu0;

      /* Pin configuration */
      const IfxAsclin_Asc_Pins pins = {
          .cts        = NULL_PTR,                         /* CTS pin not used                                     */
              .ctsMode    = IfxPort_InputMode_pullUp,
          .rx         = &IfxAsclin0_RXA_P14_1_IN,         /* Select the pin for RX connected to the USB port      */
              .rxMode     = IfxPort_InputMode_pullUp,         /* RX pin                                               */
              .rts        = NULL_PTR,                         /* RTS pin not used                                     */
              .rtsMode    = IfxPort_OutputMode_pushPull,
          .tx         = &IfxAsclin0_TX_P14_0_OUT,         /* Select the pin for TX connected to the USB port      */
              .txMode     = IfxPort_OutputMode_pushPull,      /* TX pin                                               */
              .pinDriver  = IfxPort_PadDriver_cmosAutomotiveSpeed1
      };
      ascConf.pins = &pins;

      /* FIFO buffers configuration */
      ascConf.txBuffer = g_uartTxBuffer;                      /* Set the transmission buffer                          */
      ascConf.txBufferSize = ASC_TX_BUFFER_SIZE;              /* Set the transmission buffer size                     */

      /* Init ASCLIN module */
      IfxAsclin_Asc_initModule(&g_asclin, &ascConf);          /* Initialize the module with the given configuration   */
}


// Input int8 [1,1]

void stepFunctionuart_transmit(int8_T Input,int size_vector_a){
  IfxAsclin_Asc_write(&g_asclin, &Input, &size_vector_a, TIME_INFINITE);   /* Transmit data via TX */
}

2. In the already opened Simulink model, add a MATLAB System block and assign the generated system object file without .m extension to the block.

3. Add a MATLAB Function block and connect it to the input of the MATLAB System block. In this example, the MATLAB Function block outputs characters A to Z, which are given as input to the uart_transmit block.

A sample code for the MATLAB Function block is shown here.

function out = SendCharacters()
    persistent currentIndex;
    if isempty(currentIndex)
        currentIndex = 1;
    end
    alphabet = int8('A'):int8('Z');
    out = alphabet(currentIndex);

    currentIndex = currentIndex + 1;
    if currentIndex > length(alphabet)
        currentIndex = 1;
    end
end

A sample Simulink model is shown here.

Deploy the Model on Infineon hardware board

When you perform Build, Deploy & Start action for the model, the host computer communicates with the target, on which the generated executable runs. To perform Build, Deploy & Start:

1. In the Simulink model, press Ctrl+E. The Configuration Parameters dialog box appears.

2. Navigate to Code Generation > Optimization and ensure that Tunable is selected for Default parameter behavior.

3. Click Apply and OK.

4. In the Simulink model, click Hardware and click Build, Deploy & Start.

The code will be generated and the same will be automatically deployed to the Infineon AURIX TC3x board.

5. From the MATLAB command window, open the serial port and read the data. A sample code to read the serial data is shown here.

s = serialport('COM9',115200)
while true
    if s.NumBytesAvailable > 0
        data = s.read(s.NumBytesAvailable,"int8");
        fprintf('%s ', data);
    end
end

Other Things to Try

Create complex device driver blocks such as LIN, analog subsystem and other blocks.