mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
ed5455458b
* Handle Exceptions in main & Pythoninit * Have SSDPDiscover generic again * Have SSDPDiscover generic again * Change Info- to Debug logs as technical service messages * Nanoleaf - When switched on, ensure UDP mode * Include SQL Database in Cross-Compile instructions * Fix Clazy (QT code checker) and clang Warnings * Stop LedDevice:write for disabled device * Nanoleaf: Fix uint printfs * NanoLeaf: Fix indents to tabs * NanoLeaf - Add debug verbosity switches * Device switchability support, FileDevice with timestamp support * Nanoleaf Light Panels now support External Control V2 * Enhance LedDeviceFile by Timestamp + fix readyness * Stop color stream, if LedDevice disabled * Nanoleaf - remove switchability * Fix MultiColorAdjustment, if led-range is greater lednum * Fix logging * LedFileDevice/LedDevice - add testing support * New "Led Test" effect * LedDeviceFile - Add chrono include + Allow Led rewrites for testing * Stabilize Effects for LedDevices where latchtime = 0 * Update LedDeviceFile, allow latchtime = 0 * Distangle LinearColorSmoothing and LEDDevice, Fix Effect configuration updates * Updates LedDeviceFile - Initialize via Open * Updates LedDeviceNanoleaf - Initialize via Open, Remove throwing exceptions * Updates ProviderUDP - Remove throwing exceptions * Framebuffer - Use precise timer * TestSpi - Align to LedDevice updates * Pretty Print CrossCompileHowTo as markdown-file * Ensure that output is only written when LedDevice is ready * Align APA102 Device to new device staging * Logger - Remove clang warnings on extra semicolon * Devices SPI - Align to Device stages and methods * Fix cppcheck and clang findings * Add Code-Template for new Devices * Align devices to stages and methods, clean-up some code * Allow to reopen LedDevice without restart * Revert change "Remove Connect (PriorityMuxer::visiblePriorityChanged -> Hyperion::update) due to double writes" * Remove visiblePriorityChanged from LedDevice to decouple LedDevice from hyperion logic * Expose LedDevice getLedCount and align signedness
93 lines
3.3 KiB
Markdown
93 lines
3.3 KiB
Markdown
# Cross-Compile Hyperion-NG
|
|
Leverage the power of a host environment (here Ubuntu) compiling for a target platform (here Raspberry Pi).
|
|
Use a clean Raspbian Stretch Lite (on target) and Ubuntu 18/19 (on host) to execute the steps outlined below.
|
|
## On the Target system (here Raspberry Pi)
|
|
Install required additional packages.
|
|
```
|
|
sudo apt-get install qtbase5-dev libqt5serialport5-dev libusb-1.0-0-dev python3-dev libxrender-dev libavahi-core-dev libavahi-compat-libdnssd-dev libjpeg-dev libqt5sql5-sqlite aptitude show qt5-default rsync
|
|
```
|
|
## On the Host system (here Ubuntu)
|
|
Update the Ubuntu environment to the latest stage and install required additional packages.
|
|
```
|
|
sudo apt-get update
|
|
sudo apt-get upgrade
|
|
sudo apt-get -qq -y install git rsync cmake build-essential qtbase5-dev libqt5serialport5-dev libusb-1.0-0-dev python3-dev libxrender-dev libavahi-core-dev libavahi-compat-libdnssd-dev libjpeg-dev libqt5sql5-sqlite
|
|
```
|
|
|
|
Refine the target IP or hostname, plus userID as required and set-up cross-compilation environment:
|
|
```
|
|
export TARGET_IP=x.x.x.x
|
|
export TARGET_USER=pi
|
|
```
|
|
```
|
|
export CROSSROOT="$HOME/crosscompile"
|
|
export RASCROSS_DIR="$CROSSROOT/raspberrypi"
|
|
export ROOTFS_DIR="$RASCROSS_DIR/rootfs"
|
|
export TOOLCHAIN_DIR="$RASCROSS_DIR/tools"
|
|
export QT5_DIR="$CROSSROOT/Qt5"
|
|
export HYPERION_DIR="$HOME/hyperion.ng"
|
|
```
|
|
Get native files from target platform into the host-environment:
|
|
```
|
|
mkdir -p "$ROOTFS_DIR/lib"
|
|
mkdir -p "$ROOTFS_DIR/usr"
|
|
rsync -rl --delete-after --copy-unsafe-links $TARGET_USER@$TARGET_IP:/lib "$ROOTFS_DIR"
|
|
rsync -rl --delete-after --copy-unsafe-links $TARGET_USER@$TARGET_IP:/usr/include "$ROOTFS_DIR/usr"
|
|
rsync -rl --delete-after --copy-unsafe-links $TARGET_USER@$TARGET_IP:/usr/lib "$ROOTFS_DIR/usr"
|
|
```
|
|
|
|
### Raspberry Pi specific steps
|
|
Get Raspberry Pi firmware:
|
|
```
|
|
mkdir -p "$RASCROSS_DIR/firmware"
|
|
git clone --depth 1 https://github.com/raspberrypi/firmware.git "$RASCROSS_DIR/firmware"
|
|
ln -s "$RASCROSS_DIR/firmware/hardfp/opt" "$ROOTFS_DIR/opt"
|
|
```
|
|
Get toolchain files which allows to build ARM executables on x86 platforms:
|
|
```
|
|
mkdir -p "$TOOLCHAIN_DIR"
|
|
cd $TOOLCHAIN_DIR
|
|
wget -c https://releases.linaro.org/components/toolchain/binaries/latest-7/arm-linux-gnueabihf/gcc-linaro-7.4.1-2019.02-x86_64_arm-linux-gnueabihf.tar.xz --no-check-certificate
|
|
tar -xvf gcc-linaro-7.4.1-2019.02-x86_64_arm-linux-gnueabihf.tar.xz
|
|
```
|
|
### Install the Qt5 framework
|
|
```
|
|
mkdir -p "$QT5_DIR"
|
|
cd "$QT5_DIR"
|
|
wget -c http://download.qt.io/archive/qt/5.7/5.7.1/qt-opensource-linux-x64-5.7.1.run
|
|
chmod +x $QT5_DIR/*.run
|
|
```
|
|
Display absolute installation directory to be used in Qt5 installer:
|
|
```
|
|
echo $HOME/crosscompile/Qt5
|
|
```
|
|
Start the Qt5 installation.
|
|
Follow the dialogs and install in absolute directory of ```$HOME/crosscompile/Qt5``` (copy from above)
|
|
```
|
|
./qt-opensource-linux-x64-5.7.1.run
|
|
```
|
|
### Get the Hyperion-NG source files
|
|
```
|
|
git clone --recursive https://github.com/hyperion-project/hyperion.ng.git "$HYPERION_DIR"
|
|
```
|
|
### Get required submodules for Hyperion
|
|
```
|
|
cd "$HYPERION_DIR"
|
|
git fetch --recurse-submodules -j2
|
|
```
|
|
### Compile Hyperion-NG
|
|
```
|
|
cd "$HYPERION_DIR"
|
|
chmod +x "$HYPERION_DIR/bin/"*.sh
|
|
./bin/create_all_releases.sh
|
|
```
|
|
### Transfer output packages to target platform and install Hyperion-NG
|
|
Output packages for target platform (.deb, .tar.gz, .sh) can be found here:
|
|
```
|
|
$HYPERION_DIR/deploy/rpi
|
|
```
|
|
# Install Hyperion-NG on target platform
|
|
t.b.d.
|
|
|
|
|