Table of Contents
|Date||Version||Author||Description of Releases|
|4/10/2016||1.0||Rajesh Gugulothu||Initial Release|
|24/2/2017||2.0||Rajesh Gugulothu||Updated with 2016.4 tools Release and Added design|
files to support zcu102 Rev-B/Rev-D ,Rev-1.0 boards
- Zynq® UltraScale+™ MPSoC delivers unprecedented levels of heterogeneous multi-processing and combines seven user programmable processors including Quad-core ARM® Cortex™-A53 Application Processing Unit (APU), Dual-core 32-bit ARM® Cortex™-R5 Real Time Processing Unit (RPU), and ARM® Mali™-400 MP2 Graphics Processing Unit (GPU). It is Industry’s First Multi-Processor SoC delivering 5x system level performance-per-watt and any-to-any connectivity.
- The main aim of this tech tip is to provide the step by step procedure to compile and build the OpenSceneGraph high performance 3D graphics toolkit for Zynq® UltraScale+™ MPSoC target, on Linux host machine and also walks through the steps to run a opensource OSG based 3D car model on the ZCU102 board.
|Design Type||PS only|
|CPUs||Quad-core ARM® Cortex™-A53 Application Processing Unit,ARM® Mali-400 MP2 Graphics Processing Unit.|
|PS Features||DDR controller,UART,SD/eMMC interface, USB 3.0,DisplayPort|
|Xilinx Tools Version||SDK 2016.4|
|Other Details||1080p /4K display.|
|Host Type||Ubuntu Linux 16.04 LTS|
The OpenSceneGraph is an OpenSource, cross-platform graphics toolkit for the development of high-performance graphics applications such as flight simulators, games, virtual reality and scientific visualization. It is based around the concept of a SceneGraph, providing an object-oriented framework on top of OpenGL. This frees the developer from implementing and optimizing low-level graphics calls and provides many additional utilities for rapid development of graphics applications.
This Tech tip showcases 3D graphics rendering capabilities of ARM® Mali™-400 MP2 GPU integrated in Zynq® UltraScale+™ MPSoC. It executes OpenSceneGraph (OSG) based 3D graphics application on GPU. Executing OSG based graphics application requires OSG middleware layer which runs on top of the GPU software stack. OSG middle-ware layer is configured to support OpenGL ES 2.0 in order with communicate with GPU software stack. At the application side, it provides the open source 3D graphics application programming interface to develop and execute graphics application.
Highlights of the demo Execution:
Boots SMP Linux on APU subsystem.
Executes 3D graphics application (OSG format) using OSG middle-ware which executes on top of the GPU software stack.
X-server windowing system is used to display the rendered graphics application on to Sink device (Monitor) using Processing System DisplayPort controller
GPU offloads the APU for the OpenGL ES2 API based applications, rendering a 3D vehicle graphics model written in OSG format.
Linux Host machine
Xilinx ZCU102 evaluation kit with power supply.
Class 10 SD card (4GB or more).
Micro USB to Standard USB cable
1080p Monitor or Full HD Monitor and DisplayPort Cable.
USB 3.0 connector or USB 2.0 micro cable to standard USB female adapter, USB Hub to connect USB mouse and USB keyboard or connect USB keyboard with mouse integrated etc.
Fig: OSG graphics application execution software flow diagram
This Tech Tip covers below sections as follows
Running a 3D vehicle model using prebuilt images:
The fastest way to execute the demo is using prebuild images supplied with this tech tip. This section explains step by step procedure to execute the demo with prebuilt images.
Note: If you want to build the complete software from the sources , skip this section and follow from the next section on wards.
Download the supplied ZynqMPSoC_3D_Graphics_Model.zip file and extract it to the windows machine local directory.It will get extracted as
Rev_1_0_Design_Files -It has boot-able images for Rev-1.0 board.
Rev_D_Design_Files-It has boot-able images for Rev-B/Rev-C/Rev-D boards.
OSG_Files-It has OSG prebuilt binaries and card model executable.
Copy the boot-able images ( According to the board ) and OSG prebuilt binaries on to a SD card.
Make sure that , SD card has below listed images before going to execute on the target.
Boot the images by following the "ZCU102 board setup" section.
Once the board boots up, login username and password as "root".
mount the SD card boot partition and copy the OSG prebuilt images to /home/ directory.
change the directory to /home and extract the OSG libraries and binaries
$ tar -xvf lib.tar.gz
$ tar -xvf bin.tar.gz
and below command to run a OSG based 3D card model.
Observe the car model appears on the monitor like as shown in the figure "Fig: OSG based 3D card model" at the end of the document.Try to rotate the model with the mouse connected to the board.
Compiling and building complete software for Running a 3D vehicle model:
7.save the above created configuration file and give the appropriate execution permissions.
8.Now run the configuration file to by below command.
9.Once the configuration is done , run the make command to build the OSG source.
10.Make command will take some time to build the OSG . Once the build is done 100%, you can find the generated bin and lib directories under OSG source.These two directories need to copy to the SD in coming steps.
11. Compressing the OSG lib directory is required before copying to SD card, to preserve the soft links. Follow below command to compress OSG lib directory.
$tar -cvzf lib.tar.gz lib/
12. Now create the Linux boot images by following below section "Procedure to build Linux Images".
Note:For quick reference , use the prebuilt Linux boot images released with this tech tip under Design_files/BOOT directory.
13.In case of using prebuilt Linux boot images ,skip the "Procedure to build Linux Images" section.
Procedure to build Linux Images
This section describes how to build the Linux boot images for Zynq® UltraScale+™ MPSoC. This section covers the following topics
ZCU102 Board Setup
Below steps explains about ZCU102 board setup.
1. Connect the Micro USB cable into the ZCU102 Board Micro USB port J83, and the other end into an open USB port on the windows PC. This cable will be used for UART over USB communication.
2. Insert SD card into the SD card slot J100.
3. Set the SW6 switches as shown for the different boards. This configures board boot mode as SD boot mode.
4. Connect 12V Power to the ZCU102 6-Pin Molex connector.
5. Connect the Display monitor using DisplayPort cable to U50 connector of the board.
6. Connect a USB hub to the j96 connector on the board and connect a mouse to the USB hub.
6. The following figure shows the ZCU102 board with all the required connections
1.Switch on the ZCU102 Board at SW1 (red switch).
Note: Make sure that any one of the serial console utility ( Example: Tera term , putty ) is installed on the the windows machine to which UART cable is connected.This Tech tip exercises with Tera Term.
2.connect the Tera Term with the interface 0 of the UART bridge like as shown in the below figure
Fig: Serial communication port selection
3.After the Linux is boots up ,Login prompt appears.enter the login with the username as "root".
4.Copy the lib.tar.gz ,bin directory ,run_osg.sh, F612_mod.osg files to the /home directory.
5.Extrac the lib.tar.gz file in the same directory.
6.Now run the script run_osg.sh present at the same directory and observe a 3D car model is running on the monitor.
Fig: OSG based 3D car model
Appendix A:Modification in OSG source
Follow the below steps to make few required changes in OSG source to support current target.
1.Change the directory to extracted OSG source.
2.change the color format to RGB565 In the file <extracted OSG source directory>/src/osg/GraphicsContext.cpp like as follows
Replace the below lines a,b,c
3.comment the below line in <extracted OSG source directory>/examples/osgframerenderer/osgframerenderer.cpp file.
4.Replace the line " #ifndef HAVE_BOOLEAN " with #ifdef HAVE_BOOLEAN in the <extracted OSG source directory>/src/osgPlugins/jpeg/ReaderWriterJPEG.cpp
Appendix B:File Description in Design directory
lib.tar.gz: osg libraries
bin.tar.gz: osg binaries
F612_mod.osg:osg card model
configuration.sh:osg configuration file