AM263x MCU+ SDK  09.02.00
SENT Decoder Example

Introduction

The Single Edge Nibble Transmission protocol is a unidirectional communications method that connects the sensor/transmitting device and the controller/receiving device without the use of a coordination signal from the controller/receiving device. It is intended for usage in situations where high-resolution data must be transferred from a sensor to an engine control unit (ECU). It serves as a simpler, less expensive alternative to CAN, LIN, or PSI5 as well as a replacement for lesser resolution techniques such as traditional sensors that provide analog output voltage and PWM. Automotive applications for SENT-compatible sensor devices include applications for pedal sensing, mass airflow sensing, pressure sensing, temperature sensing, humidity sensing, and many others.

SENT Signal

The SENT decoder Example is a reference for software based implementation of SAE J2716. PRU ICSS firmware enables SENT decoder interface on TI Sitara AM263x processor. This example does following: configures pin mux, sets soc mux to enable gpio mode for ICSS, initializes PRU, DMEM and PRU INTC module, downloads crc look up table in PRU Data RAM, and extracts sent decoded signal to UART terminal.

SENT Signal

The sensor sends out a signal that is made up of a string of pulses with data encoded as falling to falling edge periods. It happens independently of any receiver module activity and takes place without the receiver module sending a synchronization signal. The modulated signal with a constant amplitude voltage and an evaluation of the time interval between two falling edges (a single edge) is delivered in units of 4 bits (1 nibble), which can represent values ranging from 0 to 15. According to the SAE J2716 specification, a transmitter-specific nominal clock period that is used to quantify the pulse period (tick time) can be between 3-90 ms. The sensor device can use low-cost RC oscillators because the maximum permitted clock deviation is 20% from the normal tick time. The specified tick time, the sent data value, and the message time of a SENT message determine its duration. The following pulses (all with nominal timings) make up the transmitting sequence:

  1. Synchronization/calibration pulse, first (56 clock ticks)
  2. A single pulse with a 4 bit Status and Serial Communication header (12 to 27 clock ticks)
  3. A series of one to six data nibble pulses, each reflecting the values of the signal(s) to be conveyed and lasting 12 to 27 clock ticks. Since the trailing falling edge of the SENT transmission CRC nibble also serves as the leading falling edge of the subsequent SENT transmission synchronization/calibration pulse, the number of nibbles will be fixed for each application of the encoding scheme (such as throttle position sensors, mass air flow, etc.).
  4. One 4-bit checksum(CRC) nibble pulse (12 to 27 clock ticks)
  5. One optional pause pulse

SENT Signal

Supported Combinations

Parameter Value
ICSSM ICSSM
Toolchain pru-cgt
Board am263x-cc
Example folder examples/pru_io/sent/decoder/decoder_example

HW Setup

Encoder setup

Decoder setup

Encoder+Decoder Setup

Connect the following pins of HSECDOCK as shown in the below image

PR0_PRU0_GPIO0 -> PR0_PRU0_GPIO0 (Pin no. 125)
PR0_PRU0_GPIO1 -> PR0_PRU0_GPIO1 (Pin no. 126)
PR0_PRU0_GPIO2 -> PR0_PRU0_GPIO2 (Pin no. 127)
PR0_PRU0_GPIO3 -> PR0_PRU0_GPIO3 (Pin no. 128)
PR0_PRU0_GPIO4 -> PR0_PRU0_GPIO4 (Pin no. 124)
PR0_PRU0_GPIO5 -> PR0_PRU0_GPIO5 (Pin no. 108)
PR0_PRU0_GPIO6 -> PR0_PRU0_GPIO6 (Pin no. 123)
PR0_PRU0_GPIO8 -> PR0_PRU0_GPIO8 (Pin no. 122)
Ground Pin(Any) -> Ground Pin(Any) [To Make sure both boards are having common ground]

HW setup

Steps to Run the Example

  • When using CCS projects to build, Import sent_decoder_r5f project from the above mentioned Example folder path.
  • Build the  projects.
  • Load R5F project, run it. Decoder setup is now ready.
  • We will be validating decoder demo using SENT encoder example. Next step is to setup sent encoder follow the steps mentioned in SENT Encoder Example.
Note
Prerequisite: PRU-CGT-2-3 (ti-pru-cgt) should be installed at: C:/ti/

Sample Output

******************SENT DECODER Application**********************
SENT PRU-ICSS firmware loaded and running
******************CHANNEL0 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL1 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL2 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL3 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL4 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL5 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL6 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
******************CHANNEL7 SENT DATA**********************
Number of Frames received: 9
Channel0 calculated tick period: 538 ns
channel0 StatusComm Data: 08
Channel0: Data0 Data1 Data2 Data3 Data4 Data5 CRC
Value: 07 04 08 07 04 08 03
**********************************************************
Note
  • See list supported firmware design and list of supported feature : SENT

Steps to modify SENT decoder PRU Firmware

Modification supported: Change hardcoded tick period in firmware. Current release supports only 1us tick period support in firmware. In order to modify it:

  • When using CCS projects to build, Import decoder_pru1_fw project from the above mentioned Example folder path.
  • In main.asm file modify ch0_ticktime to desired value(1000 to 3000) and accordingly modify ch0_syncpulse_min_dur = (0.8*ch0_ticktime)*56 and ch0_syncpulse_max_dur = (1.2*ch0_ticktime)*56. For example for 500ns tick period.
  • Rebuild examples\pru_io\sent\decoder\decoder_pru1_fw project
  • Rebuild examples\pru_io\sent\decoder\decoder_example
  • Load R5F updated binary, run it.
ch0_ticktime .set 500
ch0_syncpulse_min_dur .set 400*56
ch0_syncpulse_max_dur .set 600*56