NOTICE: The Processors Wiki will End-of-Life on January 15, 2021. It is recommended to download any files or other content you may need that are hosted on processors.wiki.ti.com. The site is now set to read only.
MCSDK VIDEO AUDIO 2.0 CODEC TEST FW User Guide
Multicore Video on BIOS MCSDK
Version 2.0.0 
Codec Integration and Test Framework User Guide 
Last updated: 12/23/2011
Contents
Introduction[edit]
Codec integration & test framework is one major application provided by the MCSDK Video/Audio. It has been developed to facilitate the development and testing of stand-alone Codecs (including video, audio, and image codecs). It provides TFTP support over Ethernet for data I/O instead of slow freads and fwrites over JTAG. Standardized XDM compliant wrappers are provided to exercise codec APIs, with several pre-integrated video codecs as the example. It supports batch process regression test suite of codecs for multiple test vectors in a row. It supports codecs running on single core and multiple cores.
Specifically, this Codec Integration and Test Framework User Guide provides information about the call flow of Codec Test Framework, how to build the Codec Test Framework release (named as sv04 in the MCSDK Video/Audio), how to use the Codec Test Framework on TI C66x multi-core DSPs, and how to plug-in a new XDM 1.0 or XDM 0.9 compliant codec into the framework.
Recommended Hardware Emulator:
- Blackhawk XDS 560 or
- Spectrum Digital XDS 560 or
- Shannon XDS100 on board
Call Flow of Codec Integration and Test Framework[edit]
The call flow of Codec Test Framework is as follows:
- Platform initialization
- Network interface initialization
- Read network configuration file via JTAG file I/O
- Configure network channel for streaming, and local/remote network endpoints;
- Read test cases configuration file via JTAG file I/O
- Loop through all test cases
- Parse test case configuration file, and set static and dynamic parameters
- Codec initialization
- Loop through all frames until end of file reached
- TFTP Get input file into DDR2
- Process frames (decode or encode)
- TFTP Put generated bytes to TFTP server
 
 
In the above call flow, only codec initialization and frame processing are specific for individual codecs. The rest is common for all codecs.
Framework Folders and Make Instructions[edit]
Framework Folders[edit]
The following table lists the folders required for building Codec Codec Framework. It also highlights the folders which users expect to change when plugging in a new XDM compliant codec in the framework.
| Top Level Folder | Brief Description | Users Expected to Change? | 
| \dsp | ||
| Build related perl files | NO | |
| Bootloader shared information with the application | NO | |
| Build framework files (ggcfg) | YES | |
| Hardware Abstraction Layer | NO | |
| Memory management and utilities | NO | |
| Main Makefile (mkrel) | YES for setupenvMsys.sh | |
| Network Driver Interface | NO | |
| Codec integration framework (siu) | YES | |
| Build files (ggcfg\build\sv04) | YES | |
| \components | Video components | NO | 
| \inc | Include files to talk to various components | NO | 
Make Instructions[edit]
Before making the Codec Test Framework, please refer to Getting Started Guide for details on installing MCSDK Video Audio and its required tools.
When it is desired to change one (or more) of the codec algorithms or add a new codec algorithm, the following steps are needed in order to change and rebuild the Codec Test Framework.
- Make a copy of dsp directory and modify desired files in their home directories and save.
- Configure environment: the build directory is dsp\mkrel. Run the batch file "\dsp\mkrel\setupenvMsys.bat bypass" to configure the environment. The batch file calls "\dsp\mkrel\setupenvMsys.sh" which will check if all the required components and tools are available at the specified locations.
- Run dsp/mkrel/makefile to build DSP code: make sv04.
- The build procedure will produce directory: \dsp\mkrel\sv04 with the following files: sv04.out, sv04.map, readme_sv04.txt
| Useful Tip 1. If a source debugger requires all source files to be combined into a single directory, "FLAT=YES" may be added in the make command line, which will create the directory mkrel\sv04\flat containing all source and header files used for the build. 
 | 
Test Instructions[edit]
After sv04.out file is built, the following steps can be used in order to run sv04 on TI C66x multi-core DSPs.
TFTP server installation on PC[edit]
Download and install TFTP server v3.35 from TFTP Download Link.
Codec Test Instructions[edit]
1. Prepare EVM[edit]
- Connect TI C6678 EVM to the PC via switch.
- Compare the layout of EVM with the following two pictures, and then use the corresponding DIP switch settings.
2. Take DSP out of Reset[edit]
This can be done by unplugging the EVM power and plugging it in again.
3. Prepare CCS[edit]
- Open CCS
- Launch the target configuration
- On Core 0: load the GEL file "<CCS_INSTALL_LOCATION>\ccsv5\ccs_base_5.0.3.00028\emulation\boards\evmc6678l\gel\evmc6678l.gel" into CCS by selecting GEL Files under the Tools menu, and then select Load GEL… as shown below
- Connect Core 0 (via selecting Connect Target under the Target menu)
- Connect other cores when needed for multi-core codecs
4. Prepare PC[edit]
- Start TFTP Server on the PC. Click on the settings button and increase the timeout duration in the Settings window. A timeout of 20 seconds should be sufficient.
- Enable ARP entry on the PC so that it can send packets to EVM. This is done by opening the command prompt and entering the command: arp –s <dsp_ip_addr> <dsp_mac_addr>. Note that dsp_ip_addr and dsp_mac_addr are the same as the localIpAddress and localMacAddress, respectively, which are both found in the configuration file dsp\siu\vct\tftp.cfg.
5. Run the Codec Test Application[edit]
- Do system reset for Core 0 (via selecting Reset -> System Reset under the Target menu)
- For multi-core codecs, do CPU reset for the other cores (via selecting Reset -> CPU Reset under the Target menu)
- On Core 0, run the GEL file from the Scripts menu by selecting EVMTCI6608 Init Functions -> Global_Default_Setup. Wait until the following message is displayed: “C66xx_0: GEL Output: Global Default Setup... Done.”
- Load the DSP image to Core 0 by selecting Load Program... under the Target menu. Find the image sv04.out in the mkrel/sv04/flat directory.
- For multi-core codecs, load the same image to the other cores.
- Make sure the path in the function siuVctRun() (siuVctRun.c) is correct for the config file. The path can be relative to the location of the DSP image sv04.out, and is by default “../../../siu/vct/tftp.cfg”. If the path is incorrect, the file must be placed at that location, or the path can be changed which would require the image to be rebuilt.
- For automated testing of multiple clips, multiclip.cfg is added. The input file, output file, and number of frames are specified in this file. Any number of clips may be specified.
- TFTP transfer is running while the codec is processing the data.
- Make sure that the configuration file is correct. The configuration file contains the PC’s IP address and MAC address, the DSP’s IP address and MAC address, codec name, codec is for encoding or decoding, xdm version (0.9 or 1.0), codec type (image, video, or audio), resolution for high definition encoding (720p or 1080p, for H264BP encoder only) and core configuration. Changes to the configuration file do not require anything to be rebuilt.
- On Core 0: run the codec test by selecting Target -> Run. For multi-core codecs, then run the other cores. The application will obtain the input file via TFTP. Once the file transfer has been started, the user’s codec will process the data and output frames will be sent to the file specified on the TFTP server.
Integrating new Codec into the build[edit]
Currently MPEG4 Decoder, H.264HP Decoder, and H.264BP Encoder are pre-integrated into sv04 build to demonstrate how an XDM 1.0 or XDM 0.9 compliant Decoder/Encoder can be integrated into build. Please follow the following steps to add a new codec.
Codec Algorithm[edit]
New Codec must be XDM 1.0 or XDM 0.9 compliant in order to plug and play in the existing sv04 infrastructure. Codec algorithm source code can be compiled either via make or CCS to make a library. Once the Codec library with public API files is ready, need to add its environment to "\dsp\mkrel\setupenvMsys.sh" following the example below.
# MPEG4 decoder
- VIDEO_MPEG4_DEC_VERSION="C66x_m4h3dec_02_03_00_01_ELF"
- VIDEO_MPEG4_DEC_RUNPATH="$VIDEOBASE/$VIDEO_MPEG4_DEC_VERSION"
- make_shortname "VIDEO_MPEG4_DEC_RUNPATH"
- VIDEO_MPEG4_DEC_SRCPATH="$VIDEO_MPEG4_DEC_RUNPATH"
- check_exist "VIDEO_MPEG4_DEC_SRCPATH" "/packages/ti/sdo/codecs/m4h3dec/im4h3dec.h"
- COPY_TOOLS_LIST="$COPY_TOOLS_LIST VIDEO_MPEG4_DEC"
- ...
- export VIDEO_MPEG4_DEC_DOS="`echo $VIDEO_MPEG4_DEC_RUNPATH | $make_dos_sed_cmd`/packages"
 
Codec Client Glue Code[edit]
In order to glue a new codec to the framework, the following files must be written and placed as indicated:
- Decoder: vct<codec>DecClient.c and vct<codec>DecClient.h files in siu\vct\codec\decoder\codec folder
- Encoder: vct<codec>EncClient.c and vct<codec>EncClient.h files in siu\vct\codec\encoder\codec folder
MPEG4 decoder and H.264BP encoder client code can be referred to as example. <codec>encAPI and <codec>decAPI for the new codec must be defined according to the corresponding data structures defined in siuVctCodecAPI.h.
Update siuVctSupportedCodecs.c[edit]
Edit the file siuVctSupportedCodecs.c. Include the Client Glue code header file vct<codec>EncClient.h or vct<codec>DecClient.h and update the data structure encoderAPI_t or decoderAPI_t with the new API definition.
Edit makefile[edit]
siu\c64x\make\makefile must be edited to include the new header files and also compile the client glue code. Search for “h264hp” in this makefile and make similar changes
Update Linker Command File[edit]
ggcfg\build\hdg\sv04\ggvf0.becmd must be updated to include the new Codec library
Update cfg File[edit]
Update the codecName in the tftp.cfg file in siu\vct folder with the string name that is used in the Glue Code
Cache[edit]
The following describes the Cache configuration in sv04 build and the APIs available to perform cache operations such as wirteback and invalidate.
Cacheability of DDR[edit]
Sections of DDR can be made cacheable or non-cacheable, prefetchable or non- prefetchable using the MAR registers and the granularity is 16MB. For the entire DDR of 512 MB on Shannon (0x80000000 – 0x9FFFFFFF), One 16MB DDR section (0x90000000 – 0x90FFFFFF) is configured as non-cacheable and non- prefetchable while all the other DDR sections are cacheable and prefetchable. The only non-cacheable and non-prefetchable DDR section is used for multi-core synchronization buffers for multi-core codecs and QM/CPPI/PA buffers. The MAR definition can be found from “TMS320C66x DSP CorePac User Guide” (Literature Number: SPRUGW0A). The DDR Cache setting can be changed by editing the file ggcfg\build\hdg\sv04\ggmemdef.bec in the structure vigdkMemoryContext_t.
Cacheability of L1P, L1D and L2[edit]
Cache configuration for L1P, L1D and L2 is done in the file ggcfg\build\hdg\sv04\ gghwcfg.h. Recommended configuration is to use HAL_L1P_CACHE_32K, HAL_L1D_CACHE_32K and HAL_L2_CACHE_64K.
Cache Control APIs[edit]
The following functions (defined in dsp\siu\osal\bios6\siuOsalBios6.c) are available to perform various cache operations. They are wrappers calling BIOS 6 Cache APIs.
- void siu_osal_wbinv_cache_all(void);
- void siu_osal_wbinv_cache(void *base, tulong length, bool wait);
- void siu_osal_inv_cache(void *base, tulong length, bool wait);
- void siu_osal_wb_cache(void *base, tulong length, bool wait);
Multi Core Codec APIs[edit]
The API file ‘ividmc.h’ is located in dsp\siu\ividmc folder. Please refer to the source code for more details.
Related Links[edit]
- MCSDK Video Audio Getting Started Guide: http://processors.wiki.ti.com/index.php/MCSDK_VIDEO_AUDIO_2.0_Getting_Started_Guide
- Real-time Video Demonstrations of MCSDK Video Audio: http://processors.wiki.ti.com/index.php/MCSDK_VIDEO_AUDIO_Demonstration_Guide






