AM64x MCU+ SDK  08.04.00
ADS85x8

Introduction

This example uses ADC ICs from the below list to convert analog input signal on adc channels to samples and store the results in a shared memory which can be configured by the user (using PRU IPC module). The read samples are finally printed to the R5F console, or can also be visualized using CCS Graph plotter. GUI Composer app available on TI Gallery can also be used to evaluate the ADC using a GUI based interface.

The example does the below

  • PRU controls the ADC and reads the samples
  • PRU program implements ADC samples transfer interface
  • PRU then writes the samples to a shared memory and creates an interrupt after writing 1 block of data
  • On interrupt R5F then reads the data and prints it on console

Supported Combinations

Parameter Value
CPU + OS r5fss0-0 freertos
ICSSG ICSSG0 - PRU0
Toolchain ti-arm-clang, pru-cgt
Board am64x-evm
Example folder examples/pru_io/adc/ads85x8/

Steps to Run the Example

  • Setup: The ADC EVM is connected to AM64x/AM243x GP EVM using an Adapter Board inbetween. When using "T&M SEM Adapter Board", refer to Important Usage Guidelines for additional details.

  • When using CCS projects to build, import the CCS project from the above mentioned Example folder path for R5F (It will automatically import PRU project) for the required combination.
  • On importing the project, SysConfig will contain an ADC Config instance with default configurations which are compatible with the T&M SEM Adapter Board. Use SysConfig to configure the required settings for the ADC IC.

ADC SysConfig Options
You will need to edit linker file whenever changes are made to the configuration for PRU IPC module, refer Update linker command file
  • Build only the R5F project using the CCS project menu (see Using SDK with CCS Projects).

    • Build Flow: Once you click on build in R5F project, first, SysConfig files are generated, then the PRU project is compiled according to the configurations set in SysConfig. Finally the R5F project will be generated using both the generated SysConfig and PRU project binaries.
    • Note: The PRU project won't build independently as it is dependent on SysConfig files generated by the R5F project.
    Note
    Prerequisite: PRU-CGT-2-3 (ti-pru-cgt) should be installed at: C:/ti/
  • Launch a CCS debug session and run the executable, see CCS Launch, Load and Run

Features

Supported:

  • Parallel 8 Bit Interface
  • Parallel 16 Bit Interface
  • Interrupt on receiving a block of data
  • ADC, Pinmux and other configurations through SysConfig interface

Not Supported:

  • Serial Interface

Important Usage Guidelines

To evaluate ADS8598H use the ADS8588SEVM-PDK but solder the ADS8598H part in place of ADS8588S. To connect the boards use T&M SEM Adapter Board, and connect it with ADC EVM and AM64x/AM243x GP EVM

  • When interfacing with T&M SEM Adapter Board (deprecated), AM64x/AM243x GP EVM requires some hardware changes as mentioned:

AM64x/AM243x GP EVM Changes
  • Make sure the J9 jumper on the adapter board is in "Parallel" mode for ADS85xx adcs for all modes of interface (serial, parallel or byte-parallel).
  • From now on, T&M SEM Adapter Board won't be available for purchase, and Schematics and other details about this board can be found at: T&M SEM Adapter Board files
  • ADC-PHI-PRU-EVM Adapter Board is supported from now on [orderable from May 2022]. Use of T&M SEM Adapter Board is deprecated.

Important files and directory structure

Folder/Files Description
${SDK_INSTALL_PATH}/source/pru_io/
firmware/ PRU source files providing macros for interfaces, pru_ipc, etc.
driver/ PRU IPC source files for sending ADC samples from PRU to R5F

Sample Output

Shown below is a sample output when the application is run:

--------------------------------------------------
Initializing ADC
--------------------------------------------------
Powering up ADC
--------------------------------------------------
Resetting ADC
--------------------------------------------------
Starting ADC Conversion
Started
----- Channel: 1 -----
Sample 1: 50308
Sample 2: 50304
Sample 3: 50304
Sample 4: 50304
----- Channel: 2 -----
Sample 1: 50308
Sample 2: 50304
Sample 3: 50304
Sample 4: 50304

Implementation Details

Refer here for complete implementation explanation: ADS85x8 Implementation Details