C
Infineon TRAVEO T2G
Note: Infineon TRAVEO T2G prebuilt libraries are built using the GHS 2017.1.4 compiler. To use a different compiler version you have to rebuild the Qt Quick Ultralite libraries. See Building Qt Quick Ultralite from sources for more information.
Board features
| Hardware board | CPU model | CPU type | VRAM | Internal flash | Internal SRAM | External flash | External RAM | 
|---|---|---|---|---|---|---|---|
| TRAVEO T2G CYT3DL | CYT3DLABHS | One 240 MHz 32-bit ARM Cortex-M7 cores and one 100 MHz ARM Cortex-M0+ core | 2048 KB (VRAM) | 4160 KB | 384 KB | Up to 256 MB of SEMPER NOR Flash | Up to 256 MB of HyperRAM | 
| TRAVEO T2G CYT3DL (4M LITE KIT) | CYT3DLBBHS | One 240 MHz 32-bit ARM Cortex-M7 cores and one 100 MHz ARM Cortex-M0+ core | 2048 KB (VRAM) | 4160 KB | 384 KB | Up to 256 MB of SEMPER NOR Flash | Up to 256 MB of HyperRAM | 
| TRAVEO T2G CYT4DN | CYT4DNJBHS | Two 320 MHz 32-bit ARM Cortex-M7 cores and one 100 MHz ARM Cortex-M0+ core | 4096 KB (VRAM) | 6336 KB | 640 KB | Up to 256 MB of HyperFlash NOR Flash | Up to 256 MB of HyperRAM | 
| TRAVEO T2G CYT4DN (6M LITE KIT) | CYT4DNJBZS | Two 320 MHz 32-bit ARM Cortex-M7 cores and one 100 MHz ARM Cortex-M0+ core | 4096 KB (VRAM) | 6336 KB | 640 KB | Up to 256 MB of HyperFlash NOR Flash | Up to 256 MB of HyperRAM | 
Supported color depths
The reference port for these boards supports 32 bits per pixel color depth.
There is also support for 16 bits per pixel and 24 bits per pixel with the ItemLayer API, but not with QUL_COLOR_DEPTH.
See Color depth for more information.
Layers support
To enable optimal VRAM usage as well as support for larger displays, the Infineon TRAVEO T2G supports the following rendering modes:
- IBO Mode - Image-based Rendering Mode, drawing commands are executed directly into the framebuffer
- LBO Mode - Line-based Rendering Mode, drawing commands are batched and performed line by line into the framebuffer
- OTF Mode - On-the-Fly Mode, drawing commands are batched and replayed each display refresh cycle via a small line buffer
Overview
With IBO mode, blitting happens directly to the target framebuffer in the same order that the drawing commands are issued. LBO performs drawing line-by-line into a line buffer, before writing the complete line buffer back into the framebuffer. The LBO mode saves bandwidth and can thus offer higher performance.
LBO can be used to write into a framebuffer (LBO to memory) or directly to the display (LBO to display). The latter method is also called OTF (on-the-fly). In the case of OTF, only a fraction of a full frame buffer is needed, in order to store the potentially much smaller line buffer in VRAM.
The IBO and LBO to memory modes need width*height*bpp*2 bytes to store a set of framebuffers (double buffered). The OTF mode needs width*lines*bpp bytes only, where lines is the height of the line buffer for a layer. By default, lines is set to 64 on TRAVEO T2G CYT3DL and 128 on TRAVEO T2G CYT4DN. See Advanced layer configuration for more information about configuring lines according to your need. Besides these, the rendering instructions and other rendering-related tasks need extra buffers that are relatively smaller.
Because of the performance and memory usage benefits of OTF mode, it is the default layer configuration in Qt Quick Ultralite.
The drawback of OTF mode is that if there are too many rendering operations, LBO might not be able to finish writing to the line buffer in time, and visual glitches could appear on the display. So when using OTF mode, the application should make sure to not have too many visual elements displayed at the same time, especially transformed image assets as they take a longer time to blit.
Choosing a rendering mode per layer
When creating an ItemLayer, the ItemLayer::renderingHints property can be used to control which rendering mode is used. The default rendering hint for a platform can be set with MCU.Config.platformDefaultLayerRenderingHints. The default for TRAVEO T2G CYT3DL and CYT4DN is OptimizeForSize, which will result in the OTF rendering mode.
In order to use IBO mode, use the rendering hint NoRenderingHint:
ItemLayer {
    renderingHints: ItemLayer.NoRenderingHint
}And in order to use LBO to memory mode, use the rendering hint OptimizeForSpeed:
ItemLayer {
    renderingHints: ItemLayer.OptimizeForSpeed
}Advanced layer configuration
In some cases, it might be necessary to override some OTF layer configuration values specific to Infineon TRAVEO T2G.
For this, the Qt Quick Ultralite configuration API for Infineon TRAVEO T2G can be used. It works by using the ItemLayer::platformId API to give a specific platform id to the layer whose configuration should be changed, and then using the provided Tvii::Configuration::setConfigForOTFLayer C++ API to set the custom layer properties before the Qt Quick Ultralite application is started.
Here's how the platform id would be set:
ItemLayer {
    platformId: 1
}Here's how to include the correct header in order to use the C++ API:
#include <tviiextras/tviiconfiguration.h>
And here's how the OTF layer would be configured:
Tvii::Configuration::setConfigForOTFLayer(1, 64, 128 * 1024, 256);
The first parameter is the platform id of the layer, as specified in the QML file.
The second parameter is the number of copses, which are used for rendering images with compression in LBO mode. If any errors appear when using a lot of compressed images in a given layer, this value could be increased from the default value of 16.
The third parameter is the size of the FIFO used to buffer instructions for the command sequencer. A large number of visual elements might require bigger FIFO buffer size. The default value is 64 * 1024.
The last parameter is the size of the line buffer used by LBO. A bigger line buffer consumes more VRAM, but also reduces the risk of visual glitches that could result if a line does not finish rendering before the time it should be displayed using OTF mode.
For more information see the Graphics Driver for TRAVEO T2G Cluster Series User Guide.
Layer and VRAM optimization guide
See Layer and VRAM optimization guide for Infineon TRAVEO T2G boards for information on how to get the best application performance when using Qt for MCUs on the Infineon TRAVEO T2G boards.
Platform limitations
There are some hardware limitations when using the Layers QML APIs:
- Changing the z-order or size of layers at runtime is not supported.
- An application can have a maximum of two OTF layers.
- The maximum size of an OTF layer is 1300x720, so on larger displays it's necessary to use multiple layers.
When using vector outlines for text rendering, the Shape API, or Qul::PlatformInterface::DrawingEngine::blendPath() APIs to draw paths, there are some limitations to take into account:
- Complicated paths might produce errors or have parts missing. It might be possible to increase the QUL_PLATFORM_TVII_DRAW_CONTEXT_ALPHA_BUFFER_WIDTH,QUL_PLATFORM_TVII_DRAW_CONTEXT_ALPHA_BUFFER_HEIGHT, andQUL_PLATFORM_TVII_DRAW_CONTEXT_PATH_BUFFER_SIZEvalues inplatform_config.hto fix this issue.
- Self intersecting paths might cause visual artifacts. This is a hardware limitation (refer to the TRAVEO T2G Graphics Driver User Guide). When using the Shape API, It's recommended to set ShapePath's strokeColor property to "transparent" to prevent generating self-intersecting paths.
- For LinearGradient, the ReflectSpreadandRepeatSpreadspread types do not work. OnlyPadSpreadis supported.
- Gradient color stops with transparency are interpolated differently from when using the desktop backend, and will appear more faint in the transparent areas.
Due to a limitation of the Graphics Driver, currently the only supported subsampling mode for source JPEG images is YUV420. See Sample application user guide for JPEG decode driver TRAVEO T2G cluster series User Manual for more information. To convert source images to the YUV420 subsampling format, you can use ImageMagick Convert tool: convert input.jpg -sampling-factor 4:2:0 output.jpg.
Using drawing engine for text rendering
If using the Monotype Spark font engine, it's possible to enable an experimental Qt Quick Ultralite feature in order to use vector outlines for text rendering. This utilizes the path drawing capabilities of the TRAVEO T2G hardware drawing engine to draw the text into a surface stored in video memory, and then blend that surface in order to display the text.
Use the MCU.Config.fontVectorOutlinesDrawing QmlProject option to enable vector outlines. Refer to Text Rendering and Fonts for more detail about how to use the Monotype Spark font engine.
Note: Due to the hardware limitation of self intersecting paths not being supported, certain fonts might have visual artifacts when drawn as vector outlines. Only fonts that do not have self intersecting outlines are supported.
Resource cache policy
By default, the application's resource data is copied to VRAM on application startup. In order to keep resources in flash, and not load them to VRAM on startup, use the ImageFiles.MCU.resourceCachePolicy QmlProject property with the value NoCaching when adding resources to the application with ImageFiles.files.
Resource storage section
By default, the application's resource data is stored on internal flash. Instead, you can choose to store the resource data in external flash. Configure the ImageFiles.MCU.resourceStorageSection QmlProject property with QulResourceDataInExternalFlash, when adding resources to the application using ImageFiles.files.
For TRAVEO T2G CYT4DN, external flash is only supported for the TVII-C-2D-6M-327-SET (REV-01) revision. Refer to Flashing to HyperFlash NOR Flash on TRAVEO T2G CYT4DN (6M and 6M LITE KIT) for flashing instructions.
On TRAVEO T2G CYT3DL, if the application uses SEMPER NOR Flash, the flashing procedure is different. Refer to Flashing to SEMPER NOR Flash on TRAVEO T2G CYT3DL for the instructions on how to flash. For the 4M LITE KIT variant, refer to to Flashing to SEMPER NOR Flash on TRAVEO T2G CYT3DL (4M LITE KIT).
Including compressed assets
The Infineon TRAVEO T2G supports some custom Run-length encoding based (RLE) compression formats, which can be decoded directly by the blit engine. Assets compressed in this way don't require additional CPU time and memory for decoding and storing a decompressed copy of the image data, as in the case of the standard PNG compressed assets that Qt Quick Ultralite supports. A limitation of the Infineon TRAVEO T2G's RLE compression is that the images compressed in this way can't be transformed. Some images will also not get a good compression ratio using RLE.
Using AutomaticCompressedLossless
The simplest way to use RLE compressed images on Infineon TRAVEO T2G is to set ImageFiles.MCU.resourceImagePixelFormat to AutomaticCompressedLossless:
ImageFiles {
    files: ["image.png"]
    MCU.resourceImagePixelFormat: "AutomaticCompressedLossless"
}Using the ResourceGenerator.cmake CMake module
See tests/manual/traveo-t2g/compressed_images for the ResourceGenerator.cmake CMake module, which can be used to configure assets specifically for the Infineon TRAVEO T2G, in order to specify color format, RLE compression flags, and asset location.
Compared to AutomaticCompressedLossless, it enables more explicit control over which compression method and pixel format to use.
Here's a snippet showing how the ResourceGenerator.cmake CMake module should be used:
set(external_resources "${CMAKE_CURRENT_BINARY_DIR}/external_resources.cpp")
start_generated_external_resources_file(${external_resources})
    compress_with_resource_generator(test_tvii_compressed_images images/cover01.png "VRAM" "R8G8B8" "" ${external_resources} 128 128 OFF)
    compress_with_resource_generator(test_tvii_compressed_images images/cover02.png "InternalFlash" "R8G8B8" "c" ${external_resources} 128 128 OFF)
end_generated_external_resources_file(${external_resources})
target_sources(test_tvii_compressed_images PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/external_resources.cpp)
qul_add_resource(test_tvii_compressed_images
    FILES
        images/cover01.png
        images/cover02.png)The first parameter to compress_with_resource_generator is the target, and the second parameter is the image location.
The third parameter is the asset location, and the value can be "InternalFlash", "VRAM" ("VRAM" is valid for TRAVEO T2G CYT3DL and CYT4DN, or "HyperRAM", corresponding to one of the following memory banks:
| Name | Size | Start address | 
|---|---|---|
| InternalFlash | 4 MB(TRAVEO T2G CYT3DL and CYT3DL LITE KIT), 6 MB (TRAVEO T2G CYT4DN and CYT4DN LITE KIT) | 0x10000000 | 
| VRAM | 2 MB VRAM (TRAVEO T2G CYT3DL and CYT3DL LITE KIT), 4 MB VRAM (TRAVEO T2G CYT4DN and CYT4DN LITE KIT) | 0x24000000 | 
| HyperRAM | 8 MB | 0x90000000 | 
Note: VRAM is also needed for IBO framebuffers and LBO line buffers, for platforms with limited amount of VRAM (TRAVEO T2G CYT3DL and CYT4DN) putting too many image assets in VRAM might mean there's not enough VRAM to create the buffers needed for the hardware layers. If so, free up VRAM by keeping assets in internal flash instead. This can be done either with the resource generator approach described above, or with the QUL_RESOURCE_CACHE_POLICY CMake property.
The fourth parameter is the color format, with possible values such as R8G8B8A8 (32 bpp RGBA), X8B8G8R8 (32 bpp BGR), R8G8B8 (24 bpp RGB), R6G6B6 (18 bpp RGB), R4G4B4A4 (16 bpp RGBA), A1R5G5B5 (16 bpp ARGB), A8 (8 bpp alpha format), and so on. For full list of possibilities see the Graphics Driver for TRAVEO T2G Cluster Series User Guide.
The fifth parameter specifies compression, and the values can be "" for no compression, "c" for RLE compression, "cRLA" for RLA compression, "cRLAD" for RLAD compression, or "cRLAD<rgba>" where the RGBA values specify the maximum average number of bits for the channels red, green, blue and alpha. For example "cRLAD4442".
The sixth parameter is the name of a source file that the compressed assets will get written to. It should be added as a source to the target in the end.
The seventh and eighth parameters are the width and height of the image asset, respectively.
The final parameter controls whether to enable object partitioning. Enabling it can improve blit engine throughput when using LBO to IBO or LBO to OTF layers, by splitting compressed assets into smaller partitions. For non-compressed assets, or direct IBO layers, it has no benefit.
Note: Image assets that have a transform applied should not be compressed, as that might cause runtime errors or visual glitches.
Display output (TRAVEO T2G CYT3DL 4M LITE KIT and CYT4DN 6M LITE KIT)
The TRAVEO T2G Cluster 4M Lite (KIT_T2G_C-2D-4M_LITE) and TRAVEO T2G Cluster 6M Lite (KIT_T2G_C-2D-6M_LITE) come with an on-board EZ-USB FX3 controller, which allows to stream graphics output directly to the host via a USB cable.
The graphics output can be displayed on the host machine with any media player application. If using VLC media player, select Media > Open Media Capture... and choose the following settings:
- Capture mode : DirectShow
- Video device name : FX3
- Audio device name : None
- Video size : 800x480
- Aspect Ratio : 5:3
The command below can be used from a Windows terminal to automatically start capturing the graphics output.
set vlc="C:\Program Files\VideoLAN\VLC\vlc.exe" %vlc% dshow:// :dshow-vdev=FX3 :dshow-adev=none :dshow-size=800x480 :dshow-aspect-ratio=5\:3 :live-caching=300
LVDS display output on TRAVEO T2G CYT3DL 4M LITE KIT
USB display output is the default mode for the reference platform. To use the LVDS display output, it is necessary to rebuild the Platform library after having enabled the pre-processor macro QUL_TVIIC2D4MLITE_USE_LVDS_DISPLAY in the platform_config.h header located in the build folder.
HDMI display output on TRAVEO T2G CYT4DN 6M LITE KIT
The HDMI display output is currently experimental and requires a custom Graphics Driver for TRAVEO T2G Cluster Series from Infineon with HDMI support enabled.
To use the HDMI display output:
- Enable the pre-processor macro QUL_T2G_ENABLE_HDMI_DISPLAY_OUTPUTin theplatform_config.hheader located in the build folder.
- Rebuild the Platform library against the custom graphics driver.
To select the HDMI video output format, enable the corresponding pre-processor macro in platform_config.h. The supported configurations are as follows:
- QUL_T2G_CY_HDMI_VIDEO_OUTPUT_FORMAT_800x480p60
- QUL_T2G_CY_HDMI_VIDEO_OUTPUT_FORMAT_1024x600w60
- QUL_T2G_CY_HDMI_VIDEO_OUTPUT_FORMAT_1280x720p60
- QUL_T2G_CY_HDMI_VIDEO_OUTPUT_FORMAT_1920x720w60
- QUL_T2G_CY_HDMI_VIDEO_OUTPUT_FORMAT_1920x1080w60(untested)
Warping
The Infineon TRAVEO T2G supports warping, enabling distorting the coordinate system of the displayed application.
A CYGFX_WARP_PARAM_S struct as well as a warping buffer needs to be provided by the application. For information about how to prepare these, refer to chapter 3.11.6 Warping Buffer of the Graphics Driver for TRAVEO T2G Cluster Series User Guide.
Using the Qt Quick Ultralite warping API for Infineon TRAVEO T2G, it's possible to set a specific layer to use warping buffers.
First include the necessary header file:
#include <tviiextras/layerwarping.h>
Then call set the warping buffer for the layer with a given platform id like this:
Tvii::Warping::setWarpingBufferForLayer(platformId, warpBuffer, &warpParameters);
Finally, you must link your application against Qul::PlatformTraveoIIExtras.
TRAVEO T2G Extras module
Qt Quick Ultralite comes with a TRAVEO T2G Extras module which includes additional APIs specific to TRAVEO T2G. To use these APIs, link Qul::PlatformTraveoIIExtras to your project.
The following APIs are available through the extras module:
| Provides convenience functions for setting up warping for TRAVEO™ T2G layers | |
| Provides extra configuration functions for TRAVEO™ T2G layer configuration | 
TRAVEO T2G custom effects
To make use of some of the custom hardware blending capabilities of the TRAVEO T2G it's possible to use the PaintedItem API.
The Qt Quick Ultralite traveo_t2g_effects Example demonstrates some effects using the PaintedItem API on TRAVEO T2G. The effects included in this example can also be used as components in a custom application.
Safety-critical applications
TRAVEO T2G series utilize CRC-32/MPEG-2 to calculate the checksum for display data output. Set crcgen to mpeg2 for the Qt Safe Layout Tool.
qtsafelayouttool.exe --crcgen mpeg2 ...
Combine CRC values from RGB channels into one to match with Qt Safe Layout Tool generated Golden CRC value.
crc = signature.sigRed ^ signature.sigGreen ^ signature.sigBlue;
Other board revisions
For TRAVEO T2G CYT4DN, by default the TVII-C-2D-6M-327-SET (REV-01) board revision is supported. To use other TRAVEO T2G CYT4DN board revisions, rebuild the platform from source with the following CMake configure options:
| Board revision | CMake configuration options | 
|---|---|
| TVII-C-2D-6M-500-CPU | -DQUL_TVIIC2D6M_BOARD_REVISION=500-BGA | 
| TVII-C-2D-6M-327-CPU REV-B | -DQUL_TVIIC2D6M_BOARD_REVISION=327-BGA-REV-B | 
| TVII-C-2D-6M-327-REF (cluster with 1920x720 display) | -DQUL_TVIIC2D6M_BOARD_REVISION=327-BGA-REF-DTVII_SCREEN_CONFIGURATION=1920x720 | 
Available under certain Qt licenses.
Find out more.
