Setup Ubuntu Developer VM
This guide describes the setup of an Ubuntu VM for the complete YIO Remote development.
The development VM supports:
- Building, running and debugging the YIO Remote software on the Linux desktop.
- Creating the custom Linux image for Raspberry Pi Zero using Buildroot.
- Cross compiling the YIO Remote software for Raspberry Pi Zero.
- Using Qt Creator to cross compile and deploy directly to the device.
Since certain aspects are the same for local development on macOS and Windows, this guide focuses on Linux and cross compilation. Common tasks are documented in dedicated Wiki topics and will be referenced in this documentation.
Prerequisites
Host system:
- Dual core processor or better.
- 8 GB RAM or more recommended.
- 50 GB of free hard drive space.
 SSD is highly recommended.
- Internet access.
Software:
A virtualization software is required if the Linux system is not installed on a dedicated PC or as dual boot option.
Recommendations:
- Oracle VM VirtualBox
 A cross-platform virtualization application and free for personal use.
- VMware Fusion / Player / Workstation
 A commercial alternative with usually better desktop integration.
- Windows Hyper-V
 Included in Windows 10 Pro, but can only be used if no other virtualization software is in use!
Other virtualization software will work too of course. We just list what we are using personally.
Download Ubuntu
The minimal recommended Ubuntu version is 18.04 LTS.
Versions 19.04 and 19.10 have been tested as well. If you want long term support without the latest features and software versions, then choose the LTS version.
Windows Hyper-V
At the time of writing this guide the only fully working Ubuntu version with Windows Hyper-V was the provided 18.04.3 LTS version within Hyper-V. The newer 19.04 was not working with the advanced Windows integration features like custom screen resolution with RDP!
In Hyper-V Manager choose “Quick Create” and then select “Ubuntu 18.04.3 LTS”:

Other Virtualization Software
Download the desired Ubuntu Desktop ISO image from https://ubuntu.com/download/desktop.
This guide will use the 19.10 version with VMware Fusion.
Create new Virtual Machine
Create a new virtual machine from the downloaded ISO image.
- In VMware select “Install from disc or image” and the creation wizard starts:  - Create a new Virtual Machine 
- When using VMWare you can choose “Linux Easy Install” to automatically create a user account during installation. 
 However, for this guide we are not using it. The reason is to show the regular setup process when installing Ubuntu with other virtualization products. - Linux Easy Install 
- In the firmware type page use the default “Legacy BIOS” option:  - Choose Firmware Type 
- In the final wizard step click “Customize” and give a better name to the virtual machine like “YIO Development”:  - Customize VM Name 
The creation wizard is now complete.
Before starting the new VM some settings should be customized though:
- Processor cores: at least 2
- Memory: at least 4 GB

- Disk space: at least 50 GB

The virtual machine can now be started for the Ubuntu OS installation.
Install Ubuntu
Start the virtual machine to begin the installation process.
- Choose your preferred language and click ‘Install Ubuntu’:  
- Choose your keyboard layout and click ‘Continue’:  
- Since we like the development as small as possible select minimal installation:  
- Use the default for installation type (hard drive partitioning):  
- Select timezone. 
 With a network connection this is usually pre-selected to the correct location: 
- Set the user account information. 
 If you wish you can choose “Log in automatically” if you use the VM solely for YIO development. 
- Finish the installation with ‘Restart Now’ and press Enter when asked to eject the installation medium. Otherwise the system won’t restart!  
- After system reboot you are greeted by the login screen. 
 Select your account and enter your credentials defined in the setup process. 
- At first login a setup wizard is shown. 
 Select desired options or skip through the wizard: 
- Software updates might be available. Install the updates and restart system if asked to. 
The installation of the base Linux system is now finished! Next step is to install the required development tools.
Install Required Software
- Common tools 
 For remote access- openssh-serverand- screenare installed. This is optional.
 The- nanoeditor is a personal preference. Feel free to install your personal choice.- sudo apt install \ bzip2 \ git \ nano \ openssh-server \ rsync \ screen \ ssh \ tar \ unzip
- Build dependencies for YIO Remote software - sudo apt-get install \ libavahi-client-dev \ libgl1-mesa-dev
- Build tools - sudo apt install \ build-essential \ dos2unix \ g++ \ gdb-multiarch \ gettext \ libncurses5-dev \ libtool \ npm \ patch \ python \ texinfo
- Optional: Docker 
TODO
Checkout YIO Remote Project Repositories
See QT Creator IDE Setup: Project Organization and Checkout.
Cross Compile Toolchain for RPi Zero
This step is optional and only required if you want to cross-compile the YIO Remote software for the Raspberry Pi Zero. The crosscompile toolchain is also being used by Qt Creator to build and deploy the YIO Remote software to the RPi Zero device.
Without the cross compile toolchain you can still build and run the software on the Ubuntu Linux desktop but not on a Raspberry Pi.
The toolchain can either be downloaded or compiled from the remote-os project.
Download pre-compiled Toolchain
See remote-os releases for pre-compiled toolchains.
Not every remote-os release requires a new toolchain. Usually, major releases will require a new toolchain (v1.y.z, v2, y.z, etc.), or if the Qt version has been updated or new libraries have been introduced.
Build Toolchain with Buildroot
Start toolchain build:
cd $YIO_SRC/remote-os
make remote-sdk
The build will take at least an hour or much longer on a slower system!
The SDK will be written to: ./buildroot/output/images/arm-buildroot-linux-gnueabihf_sdk-buildroot.tar.gz
See Buildroot developer topic for more information.
Install Cross Compile Toolchain
After download or compiling the cross compile toolchain, it needs to be unpacked and relocated to be used with Qt Creator.
Copy the archive to the desired destination folder (for example ~/projects/yio) and then rename and relocate it:
tar -xf arm-buildroot-linux-gnueabihf_sdk-buildroot.tar.gz
mv arm-buildroot-linux-gnueabihf_sdk-buildroot yio-remote-toolchain-vX.Y.Z
cd yio-remote-toolchain-vX.Y.Z
./relocate-sdk.sh
Attention: do not move or rename the toolchain after calling relocate-sdk.sh. If you want to move it to another directory, then extract the original archive and execute relocate-sdk.sh again.
Install Qt Runtime and Qt Development Tools
See QT Creator IDE Setup.
Qt Creator Configuration for Raspberry Pi
After building the cross-compilation toolchain with Buildroot it can be used in Qt Creator to define a new device target. In our case the RPi Zero.
The required configuration is done through the Options dialog in Qt Creator: Tools, Options… from the main menu.

After installation there’s a default Qt kit defined for the current desktop. A kit is a platform definition for a specific device including Qt version, compiler and debugger.
First we need to add the specific Qt build, cross-compiler and debugger information before defining a new kit for RPi Zero.
Add Raspberry Pi Qt build
- Select Kits in the Options dialog list.
- Select Qt Versions tab.
- Click Add…
- Select the qmake executable in the RPi Buildroot build:/home/yio/projects/yio/yio-remote-toolchain-v1.0.0/bin/qmake
- Click Apply.

Configure Cross-Compilers
Here we have to reference the relocated Buildroot SDK. Replace /home/yio/projects/yio/yio-remote-toolchain-v1.0.0 with the location where you have extracted the external Buildroot toolchain.
Note: the screen shots still show the old Buildroot output pathes instead of the relocated SDK!
- Select Kits in the Options dialog list. 
- Select Compilers tab.  - Kits: Compilers 
- Define C compiler: click Add and select GCC -> C. - Name: RPi GCC
- Compiler path:/home/yio/projects/yio/yio-remote-toolchain-v1.0.0/bin/arm-buildroot-linux-gnueabihf-gcc
- The ABI will be set automatically: arm-linux-generic-elf-32bit.
- Click Apply.
  - RPi C Compiler 
- Name: 
- Define C++ compiler: click Add and select GCC -> C++ - Name: RPi g++
- Compiler path:/home/yio/projects/yio/yio-remote-toolchain-v1.0.0/bin/arm-buildroot-linux-gnueabihf-g++
- The ABI will be set automatically: arm-linux-generic-elf-32bit.
- Click Apply.
  - RPi C++ Compiler 
- Name: 
Configure Debugger
- Select Kits in the Options dialog list. 
- Select Debuggers tab. 
- Click Add and enter the following information: - Name: RPi debugger
- Path: /usr/bin/gdb-multiarch
- Click Apply.
  - RPi Debugger 
- Name: 
Define RPi Zero as new Device
- Select Devices in the Options dialog list.  - Qt Devices 
- Click Add… 
- In the dialog box select Generic Linux Device and click Start Wizard.  - Generic Linux Device 
- In the connection page enter the following information: - Name: YIO Remote
- Host name or IP address
- Username: root
 
- Name: 
- In the Key Deployment page create a new key pair and deploy the public key to the device.  - Create Key Pair  - Key Deployment succesful 
- Finish the wizard. 
- A device test will be run. 
 For a successful test the device needs at least a sftp service or rsync. - Device Test 
- Close the device test dialog and click Apply in the devices tab.  - YIO Remote device 
Create a Qt Kit with Cross-Compiler Toolchain
Now all the individual pieces are defined and a RPi Qt kit can be configured:
- Select Kits in the Options dialog list.
- Select Kits tab.
- Click the Add button.
- Enter the following information for the new RPi kit:- Name: RPi Crosscompile
- Device Type: Generic Linux Device
- Device: select the previously defined YIO Remotedevice.
- Sysroot: select the output target of the Buildroot build./home/yio/projects/yio/remote-os/rpi0/output/target
- Compiler: select the previously defined cross compilers.- C: RPi GCC
- C++: RPi g++
 
- C: 
- Environment: add environment variable:QT_LINGUIST_DIR=/home/yio/Qt/5.12.6/gcc_64/bin
 Reason: The cross-compiler toolchain doesn’t contain the Qt linguist tools. But we can simply use the tools from the desktop kit. See topic Qt IDE: qmake Environment Variables.
- Debugger: select the previously defined debugger: RPi debugger
- Qt version: select the previously defined version: Qt 5.12.4 (host)
- Qt mkspec is not required, leave empty.
- CMake Tool is not required, leave empty.
 
- Name: 
- Click Ok to save the new RPi kit.

Device Deployment
The required files for remote deployment are defined in the remote.pro project file and cannot be changed in the Qt Creator project settings dialog. They are only shown in Run Settings, Deployment:

For the remote console to be redirected to Qt Creator the run environment variable QT_ASSUME_STDERR_HAS_CONSOLE must be set to 1. Furthermore, the screen parameters and touch driver settings must be set:
| Variable | Value | 
|---|---|
| QT_ASSUME_STDERR_HAS_CONSOLE | 1 | 
| QT_QPA_EGLFS_FORCE888 | 1 | 
| QT_QPA_EGLFS_PHYSICAL_WIDTH | 46 | 
| QT_QPA_EGLFS_PHYSICAL_HEIGHT | 76 | 
| QT_QPA_EVDEV_TOUCHSCREEN_PARAMETERS | /dev/input/event0:rotate=90:invertx | 
Select Projects, Click on Run in the ‘RPi Crosscompile’ kit and define above variables in the Run Environment:

To deploy and run on the RPi device select the RPi cross-compile run target:

Remote Debugging
The gdb server must be available on the remote device for remote debugging.
TODO: include gdb server in remote-os build