SDK Development flow

Processor SDK Linux for Edge AI comprises of 3 parts,

  • Edge AI Applications

  • Processor SDK - Linux

  • Processor SDK - RTOS

If you wish to work with just the Edge AI Applications, you can edit-build-run directly on the target by flashing the etcher image as specified in Preparing SD card image. No need to build the RTOS binaries as described below!

If you are modifying any RTOS components such as vision_apps, tiovx, tidl, tiadalg etc. you will need to rebuilt the RTOS binaries and update the SD card filesystem with the latest. This requires the Processor SDK RTOS source package and Processor SDK Linux filesystem packages.

Getting PSDK LINUX and RTOS

You can download the latest Processor SDK Linux and Processor SDK RTOS for TDA4VM from the below links

The Processor SDK RTOS source package:

https://software-dl.ti.com/jacinto7/esd/processor-sdk-rtos-jacinto7/08_00_01_10/exports/ti-processor-sdk-rtos-j721e-evm-08_00_01_10.tar.gz

The Processor SDK Linux filesystem and BOOT partition files:

https://software-dl.ti.com/jacinto7/esd/processor-sdk-linux-jacinto7/08_00_01_13/exports/tisdk-default-image-j7-evm.tar.xz https://software-dl.ti.com/jacinto7/esd/processor-sdk-linux-jacinto7/08_00_01_13/exports/boot-j7-evm.tar.gz

Building the SDK from source

Untar the ti-processor-sdk-rtos-j721e-evm-08_00_01_xx.tar.gz to some location on PC and copy the tisdk-default-image-j7-evm.tar.xz and boot-j7-evm.tar.gz into the RTOS SDK folder. Execute the setup_psdk_rtos.sh script from below folder. This will untar the linux filesystem, download GCC cross compile toolchain and dependencies all in preparation to build the SDK

#Run the setup script as shown
<PSDK-RTOS path>#./psdk_rtos/scripts/setup_psdk_rtos.sh

Ensure that you are building only for the target and the profile is set to release mode. In the file <PSDK-RTOS path>/tiovx/build_flags.mak check for,

# Build for SoC
BUILD_TARGET_MODE?=yes
# Build for x86 PC
BUILD_EMULATION_MODE?=no
# valid values: release debug all
PROFILE?=release

Navigate to vision_apps folder and build the RTOS components

<PSDK-RTOS path>/vision_apps#BUILD_EDGEAI=yes make sdk -j8

Once the build is complete with no errors install the Linux filesystem to an SD card. A minimum of 16GB is highly recommended. Insert an SD card and unmount its partitions. If you had previously installed using the same SD card, you might have to unmount the BOOT and rootfs partitions

Note

/dev/sda1 and /dev/sda2 are just examples here, and the SD card might be mounted differently on your system. Ensure that you are unmounting the correct partitions before reformatting the SD card!

umount /dev/sda1
umount /dev/sda2

Use the script to create required partitions and filesystem format. This will create two partitions namely BOOT and rootfs

<PSDK-RTOS path>#sudo ./psdk_rtos/scripts/mk-linux-card.sh /dev/sda

Note

Follow the interactive menu (mostly press Y and Y) to correctly format the SD card for Linux boot. Once successfully complete, PLEASE EJECT THE SD CARD AND INSERT AGAIN. This ensures that files are not installed under root permissions and the follwing steps do not require sudo permissions

Use another script to install the filesystem to the rootfs partition

<PSDK-RTOS path>#./psdk_rtos/scripts/install_to_sd_card.sh

Next transfer the RTOS component libraries, header files and remote core binaries to the SD card.

<PSDK-RTOS path>/vision_apps# BUILD_EDGEAI=yes make linux_fs_install_sd
  • Installs the vision_apps.so library under /usr/lib

  • Copies the vision_apps headers under /usr/include/processor_sdk folder

  • Copies the RTOS binaries under /usr/lib/firmware

** This completes the PSDK Linux and RTOS setup **

Applications setup

At this point the SD card is ready with Linux image and RTOS components. Next we need to clone the target side components under SD card /opt If the provided steps are not executing you might have to provide permissions for the scripts to make directory under SD card /opt.

Note

You need to change permissions on SD card /opt folder NOT your Linux PC /opt folder. Change permissions of SD card /opt directory /media/<user-name>/rootfs# sudo chmod -R ugo+w opt

First clone the edge_ai_apps repo into the SD card under /opt

/media/<user-name>/rootfs/opt#git clone --single-branch --branch master git://git.ti.com/edgeai/edge_ai_apps.git

Once edge_ai_apps is cloned, on the PC itself run the setup_script.sh. This will clone and install DL dependencies, clone the edgeai-gst-plugins and edgeai-tiovx-modules repo on the SD card /opt. It will also build the edgeai-tiovx-modules, edgeai-gst-plugins and apps_cpp demos.

/media/<user-name>/rootfs/opt/edge_ai_apps#./setup_script.sh

Also download the recommended set of models or any model that you would like to test by running the download_models.sh script.

/media/<user-name>/rootfs/opt/edge_ai_apps#./download_models.sh

** This completes the setup required on PC side **

Note

Before ejecting the SD card issue a ‘sync’ on the terminal to commit all changes.

Target side steps

Boot the SK or EVM with the prepared SD card. Make sure you have connected the camera and display. After boot, login as ‘root’ with no password. If you have flashed the SD card using Balena etcher tool, then upon login you will notice the wallpaper displayed on the screen disappears and you will notice “Please wait…” message. The prompt will also change to /opt/edge_ai_apps#. This is done by automatically calling the init_script.sh

If you are building from scratch, upon login you will notice that the wallpaper is still displayed on the screen. The init_script.sh is not automatically called during login. You will have to manually navigate to edge_ai_apps repo and execute every time it boots or call it under .profile

root@j7-evm:/opt/edge_ai_apps#./init_script.sh

Only for first time, you will have run the setup_script.sh once again. This time it will not download the dependencies but compile and install the edgeai-gst-plugins, edgeai-tiovx-modules and apps_cpp demos

Now you are ready to run the Python and C++ demos!

Note

IMPORTANT: Due to differences in GLIB version between Yocto and Docker you will have to rebuild the GST plugins and C++ apps when you make the switch. So always call the setup_script.sh to rebuild the plugins for Yocto/Docker while switching. Clean build the C++ apps as well.