本記事は JUCE Advent Calendar 2017 の12月7日向けに投稿した記事です。
JUCEライブラリをRaspberryPi(Raspbian)でビルドする方法については私のブログに投稿しておりますが、同様にTinkerBoard(TinkerOS)でもビルドすることができたので、その手順について紹介します。
TinkerBoardとは?
公式サイト: https://www.asus.com/jp/Single-Board-Computer/Tinker-Board/
ASUSからリリースされた、Rasberry Piと同サイズのシングルボードコンピューターです。
RasberryPi3よりも強力なCPU,GPUを搭載していることから、より快適なIoTデバイスの実装が期待されています。
なお、基本スペックが高いぶんCPUの発熱量も凄いため、ヒートシンクが同梱されています。
その反面、コミュニティも歴史が浅く、Raspberry Piと比較するとOSや各種ドライバの安定性は発展途上という印象もあります。
開発環境
◆ハードウェア
TinkerBoard
◆OS
TinkerOS ver2.0.3(beta)
最新版のOSはこちらのフォーラムからDLすることができます。
https://tinkerboarding.co.uk/forum/thread-69.html
0.OSインストール
こちらの記事が参考になります。
[[メモ] ASUS Tinker Board: 初期設定 (TinkerOS 2.0.1 betaベース) 2017年8月版]
(https://qiita.com/mt08/items/9094cc624953360c120b)
1.準備
まず、JUCEをダウンロードしましょう。公式ダウンロードサイト
Windows/macOS/Linuxから選択することができますが、Linux向けを選択すれば良いです。
※Linux用のProjucerが同梱されていますがx86をターゲットにしているため、CPUアーキテクチャが異なるRaspberry Pi (ARM)上では動作しません。TinkerBoard用のProjucerは以下の手順にてビルドすることができます。
また、GitHubリポジトリからDLする場合は、ターミナルで次のコマンドを打ちましょう。
$ sudo git clone https://github.com/WeAreROLI/JUCE.git
2.依存パッケージのインストール
$ sudo apt-get install clang freeglut3-dev g++ libasound2-dev libcurl4-openssl-dev libfreetype6-dev libjack-jackd2-dev libx11-dev libxcomposite-dev libxcursor-dev libxinerama-dev libxrandr-dev mesa-common-dev webkit2gtk-4.0
JUCEライブラリのビルドに必要な依存パッケージをインストールします。ついでにLLVM-Clangコンパイラをインストールします。
GCCでもコンパイルできることを確認しています。
3.Wayland-EGLの環境を構築する
RaspberryPi(Raspbian)では、2.の依存パッケージのインストールでビルド環境構築は完了ですが。
TinkerBoard(TinkerOS)でビルドしようとすると、makeから以下の警告が返ってきます。
Package wayland-egl was not found in the pkg-config search path.
Perhaps you should add the directory containing `wayland-egl.pc'
to the PKG_CONFIG_PATH environment variable
Package 'wayland-egl', required by 'gdk-3.0', not found
Package wayland-egl was not found in the pkg-config search path.
Perhaps you should add the directory containing `wayland-egl.pc'
to the PKG_CONFIG_PATH environment variable
Package 'wayland-egl', required by 'gdk-3.0', not found
Makefile:418: recipe for target 'check-pkg-config' failed
make: *** [check-pkg-config] Error 1
どうやら、GTK3がWayland-EGLに依存しているため、ビルド依存関係を解決する必要があります。
それを解決するために、apt-get build-depを実行します。
$ sudo apt-get build-dep wayland weston
4.作業ディレクトリへの移動
$ cd JUCE/extras/Projucer/Builds/LinuxMakefile
LinuxMakefileが置かれたディレクトリに移動します。
※ディレクトリは各自の環境に合わせて入力してください。
※サンプルプロジェクトの一部に”LinuxMakefile”用プロジェクトが同梱されています。
5.コンパイル
5-1.GCCでコンパイルする場合
$ sudo make CXX=g++
LinuxMakefileからビルドを実行します。
ビルドモードは”Debug”がデフォルトです。
各種オプションについては以下の通りです。
・CXX=g++
… LinuxMakefileオプションです。C++コンパイラにg++を使用します
5-2.LLVM-Clangでコンパイルする場合
$ sudo make CXX=clang++ "TARGET_ARCH=-march=armv7-a"
LinuxMakefileからビルドを実行します。
ビルドモードは”Debug”がデフォルトです。
各種オプションについては以下の通りです。
・CXX=clang++
… LinuxMakefileオプションです。C++コンパイラにclang++を使用します
・“TARGET_ARCH=-march=armv7-a”
… LinuxMakefileオプションです。ターゲットアーキテクチャを明示的に指定します
6.起動用のランチャーを作成する
ビルドしたプログラムを実行するには、ターミナルから以下のコマンドを実行することで実行することができます。
$ ./Projucer ※./(プログラム名)
ただし、TinkerOSでは、ビルドしたプログラムは"共有ライブラリ(Shared Library)"として扱われるようですので、ファイラーからダブルクリックで実行することはできないようです。
一方Raspbianの場合、ビルドしたプログラムは"実行ファイル"として扱われ、ファイラーからダブルクリックで実行することが出来るという違いがあります。
そこで、こちらの記事: Linuxでアイコンを作成する方法を参考に、ダブルクリックで実行することが出来るランチャーをデスクトップに追加しましょう。
まず、デスクトップにEmpty Fileを追加します。
Empty Fileをエディタで開き、次の文字を書いて保存します。
[Desktop Entry]
Type=Application
すると、そのファイルの属性がデスクトップエントリーファイルに変更されます。
このファイルを[右クリック]→[Properties]→[Desktop Entry]を開きます。
[Desktop Entry]メニュー、"Command"項目の[Browse]ボタンを押すと、ファイラーが立ち上がるので、ビルドしたプログラムを探して選択、[Open]して関連付けます。
プログラムと関連付けたら、当デスクトップエントリーファイルをダブルクリックすると、ビルドしたプログラムが実行されます。
7.補足:Releaseビルド時のコマンド
// GCCでコンパイルする場合
$ sudo make CXX=g++ CONFIG=Release
// LLVM-Clangでコンパイルする場合
$ sudo make CXX=clang++ "TARGET_ARCH=-march=armv7-a" CONFIG=Release
・CONFIG=Release
… LinuxMakefileオプションです。”Release”モードでビルドします。