Difference between revisions of "OpenWRT: Build Firmware"
Onnowpurbo (talk | contribs) |
Onnowpurbo (talk | contribs) |
||
Line 12: | Line 12: | ||
* Lakukan pada komputer yang mempunya harddisk free 30Gbyte | * Lakukan pada komputer yang mempunya harddisk free 30Gbyte | ||
+ | * Yang aman menggunakan Sistem Opersi Ubuntu 10.10, Ubuntu 12.04 entah kenapa sering gagal compile. | ||
* Lakukan sebagai non-root user | * Lakukan sebagai non-root user | ||
* Lakukan semua perintah di <buildroot dir> misalnya ~/openwrt/trunk/ | * Lakukan semua perintah di <buildroot dir> misalnya ~/openwrt/trunk/ |
Revision as of 08:08, 4 September 2012
WARNING: ini akan membutuhkan banyak akses ke Internet untuk download, termasuk waktu proses make. Termasuk download kernel linux, waktu compile toolchain :( ... Tampaknya tidak bisa OFFLINE :(
Sumber:
- https://forum.openwrt.org/viewtopic.php?id=15201
- http://wiki.openwrt.org/doc/howto/build
- http://downloads.openwrt.org/docs/buildroot-documentation.html
Prosedur
- Lakukan pada komputer yang mempunya harddisk free 30Gbyte
- Yang aman menggunakan Sistem Opersi Ubuntu 10.10, Ubuntu 12.04 entah kenapa sering gagal compile.
- Lakukan sebagai non-root user
- Lakukan semua perintah di <buildroot dir> misalnya ~/openwrt/trunk/
- Sebaiknya lakukan dari fresh source code. Jadi buang terlebih dahulu <buildroot dir>, kemudian refresh dari sumber di Internet.
- Update OpenWrt source
- Update & install package feeds.
- Configure build.
- Start build. Ini akan secara automatis compile Ttoolchain, cross-compile sources, package packages, dan generate image siap untuk di flashed.
- Lakukan instalasi OpenWrt
Persiapan
Lakukan
sudo su apt-get update apt-get install subversion gawk flex sharutils bison libz-dev patch fakeroot lzma git-core build-essential
Menggunakan SVN
Sebagai user biasa lakukan
svn co svn://svn.openwrt.org/openwrt/branches/backfire ~/openwrt/trunk/ cd ~/openwrt/trunk/ ./scripts/feeds update ./scripts/feeds install <pkg_name_1> <pkg_name_2> ... <pkg_name_N> make defconfig make menuconfig make world
Update SVN
cd ~/openwrt/trunk/ svn update ./scripts/feeds update
Menggunakan GIT
git clone git://nbd.name/openwrt.git ~/openwrt/trunk/ cd ~/openwrt/trunk/ ./scripts/feeds update # You have to change feeds.conf to use the git packages repo. See the patch below. ./scripts/feeds install <pkg_name_1> <pkg_name_2> ... <pkg_name_N> # After installing the package (creates the symlink for you, you can select it in menuconfig) make menuconfig # Choose your Target System/Subtarget/Target Profile and select packages/features make world
Update GIT
cd ~/openwrt/trunk/ git pull ./scripts/feeds update
Download Source Code
Yang akan membuat lama & frustasi adalah download source yang akan di compile dari nol. Terutama
80MB http://launchpad.net/gcc-linaro 60MB ftp://ftp.all.kernel.org/pub/linux/kernel/v3.x/
Tips
Kita dapat menentukan / menset chipset mana yang akan kita gunakan. Di target/linux/chipname/, ada makefile yang mengatakan kernel mana yang akan dibuat, contoh di Kamikaze tepatnya kamikaze/target/linux/atheros/Makefile.
LINUX_VERSION:=2.6.23.17
Ubah ini sesuai dengan subversion yang anda inginkan.
Build di multi-core CPU
Proses build dapat di percepat dengan menjalankan beberapa concurrent job process mengunakan option -j seperti
make -j 3
Gunakan standard formula <jumlah CPU + 1>. Jika cara ini menyebabkan error saat build, coba compile tanpa option -j.
Build di background
Jika anda ingin menggunakan sistem / mesin anda waktu anda build, kita dapat membuat proses build hanya menggunakan I/O dan kapasitas CPU yang ide, contoh untuk CPU dualcore:
ionice -c 3 nice -n 20 make -j 2
Build single Packages
Saat kita melakukan developing atau packaging software untuk OpenWrt, akan lebih memudahkan jika kita dapat membuat untuk package yang kita inginkan saja (misalnya untuk package cups):
make package/cups/compile V=99
Untuk package mc (midnight commander), yang kebetulan berada feed packages perintahnya akan seperti
make package/feeds/packages/mc/compile v=99
Melihat build errors
Jika build gagal, cara yang paling gampang untuk melihat error adalah melalui perintah
make V=99 2>&1 | tee build.log | grep -i error
Perintah di atas akan menyimpan copy full verbose dari output build (dengan stdout di pipe ke stderr) di /openwrt/trunk/build.log dan hanya memperlihatkan error saja ke screen
Contoh lain
ionice -c 3 nice -n 20 make -j 2 V=99 CONFIG_DEBUG_SECTION_MISMATCH=y 2>&1 | tee build.log | egrep -i '(warn|error)'
Cara di atas menyimpan copy full verbose dari output build (dengan stdout di pipe ke stderr) di build.log dan akan mengeluarkan hanya warning dan error saat building menggunakan resource background di dual core CPU.
Notifikasi Beep
Tergantung pada CPU yang kita gunakan, proses build akan memakan waktu sebentar, atau lama. Jika kita menginginkan notifikasi suara, kita dapat menggunakan echo -e '\a':
make V=99 ; echo -e '\a'
Locating Images
Jika berhasil image yang kita buat akan berada di bawah directory
<buildroot dir>/bin
Jika kita buat firmware untuk ar71xx maka ada di bawah
<buildroot dir>/bin/ar71xx directory.
Jika <buildroot dir> adalah /openwrt/trunk, maka binary ada di
/openwrt/trunk/bin/ar71xx.
Cleaning Up
Kadang kita ingin membersihkan lingkungan build. Contoh berikut akan sangat berguna,
Clean
Delete isi bin dan directory build_dir
make clean
Dirclean
make dirclean
Delete isi /bin dan /build_dir directory juga /staging_dir dan /toolchain (=cross-compile tool). 'Dirclean' adalah untuk memperoleh "Full clean".
atau dipaksa banget dengan
make FORCE=1 dirclean
Distclean
make distclean
Hancurkan semua yang pernah kita compile atau configure dan delete semua content feed dan package source yang pernah kita download.
PERHATIAN: Perintah ini akan menghapus build configuration (.config).
Referensi
- https://forum.openwrt.org/viewtopic.php?id=15201
- http://wiki.openwrt.org/doc/howto/build
- http://downloads.openwrt.org/docs/buildroot-documentation.html