Difference between revisions of "Template:Luneos build"

From WebOS-Ports
Jump to navigation Jump to search
 
(36 intermediate revisions by 6 users not shown)
Line 7: Line 7:
 
     $ sudo dpkg-reconfigure dash
 
     $ sudo dpkg-reconfigure dash
 
            
 
            
The essential and graphical support packages you need for a supported Ubuntu or Debian distribution are shown in the following command:
+
The essential and graphical support packages you need for a supported Ubuntu or Debian distribution are shown in the following commands:
 
      
 
      
 +
    $ curl -sL https://deb.nodesource.com/setup_4.x | sudo bash -
 
     $ sudo apt-get install gawk wget git-core diffstat unzip texinfo \
 
     $ sudo apt-get install gawk wget git-core diffstat unzip texinfo \
     build-essential chrpath libsdl1.2-dev xterm
+
     build-essential chrpath libsdl1.2-dev xterm nodejs bzr
 +
 
 +
(Recently, building on 64-bit Ubuntu 16.04 also required apt-get install gcc-multilib g++-multilib.)
  
 
For other Linux distributions please have a look at [https://www.yoctoproject.org/docs/1.5/yocto-project-qs/yocto-project-qs.html the Yocto Project Quick Start guide].
 
For other Linux distributions please have a look at [https://www.yoctoproject.org/docs/1.5/yocto-project-qs/yocto-project-qs.html the Yocto Project Quick Start guide].
  
 +
{{note|note=The steps below will setup your build environment for a development build. If you want to build the latest release use ENV_NAME=stable instead but keep in mind that all new developed features need to go into testing first before they are submitted to stable.}}
 
<code>
 
<code>
 
   $ cd into-your-build-directory
 
   $ cd into-your-build-directory
 
   $ mkdir webos-ports-env && cd webos-ports-env
 
   $ mkdir webos-ports-env && cd webos-ports-env
   $ wget https://raw.github.com/webOS-ports/webos-ports-setup/dora/Makefile
+
  $ export ENV_NAME=testing
 +
   $ wget https://raw.github.com/webOS-ports/webos-ports-setup/$ENV_NAME/Makefile
 
   $ make setup-webos-ports
 
   $ make setup-webos-ports
 
</code>
 
</code>
  
This has been tested on Gentoo (shr-chroot) and Ubuntu-12.04 amd64 and should work almost everywhere where valid toolchain is provided.
+
This has been tested on Gentoo (shr-chroot) and Ubuntu-20.04/22.04/22.10/23.04/23.10 amd64/x64 and should work almost everywhere where valid toolchain is provided.
 
 
You need a lot of RAM to link qtwebkit, make sure you have at least 6GB (it's OK when some of that is swap, because it's used only for short part of build). Webkit needs so much ram to link because it's linking with debug symbols (huge files) which are stripped later in do_package after creating -dbg packages.
 
 
 
You can add extra 2GB of swap file like this:
 
 
 
<code>
 
  $ dd if=/dev/zero of=swap_2gb.img bs=1024k count=2048
 
  $ mkswap swap_2gb.img
 
  $ sudo swapon swap_2gb.img
 
</code>
 
  
If you want it permanently add it to your /etc/fstab.
+
You need a lot of RAM to link Chromium, make sure you have at least 16GB (it's OK when some of that is swap, because it's used only for short part of build). Chromium needs so much ram to link because it's linking with debug symbols (huge files) which are stripped later in do_package after creating -dbg packages.
  
 
== Building ==
 
== Building ==
Line 61: Line 56:
 
</code>
 
</code>
  
To build the webos-ports-dev-image for a device (please pick one of maguro, grouper and <machine name> with it):
+
{{#ifeq: {{{device_codename}}}|qemux86| To build the VirtualBox Appliance Image: |To build the luneos-dev-image for a device ({{lc:{{{device_codename}}}}}):}}
 +
 
 +
<code>
 +
  $ MACHINE={{lc:{{{device_codename}}}}} {{#switch: {{{device_codename}}}|qemux86 = bitbake -k luneos-dev-emulator-appliance | Tenderloin = bb luneos-dev-image | PinePhone = bb luneos-dev-image | PinePhonePro = bb luneos-dev-image | PineTab2 = bb luneos-dev-image | RaspberryPi2 = bb luneos-dev-image | RaspberryPi3 = bb luneos-dev-image | bb luneos-dev-package }}
 +
</code>
 +
 
 +
After the build completes, you will find your image in <build env>/tmp-glibc/deploy/images/{{lc:{{{device_codename}}}}}/
 +
 
 +
== Clean up the work directory  ==
 +
If you run out of disk space during a build, run the following command from the <tt>webos-ports</tt> directory, then build again:
 +
<code>
 +
  $ rm -rf tmp-glibc
 +
</code>
 +
This removes all build things but OE luckily has a copy of every build result in a cache folder called ''sstate-cache'' which you should keep to let OE quickly rebuild everything from the cache instead to do it from scratch (next build will be quite faster).
 +
 
 +
If you run out of space because of a too large sstate-cache folder you can clean it up to contain only the results for the latest component versions with the following command:
 +
<code>
 +
  $ openembedded-core/scripts/sstate-cache-management.sh -L --cache-dir=sstate-cache -d -y
 +
</code>
 +
 
 +
==Adding Swap Space==
 +
To speed up the build, you can add extra 2GB of swap file like this:
  
 
<code>
 
<code>
   $ MACHINE={{#lowercase:{{{device_codename}}}}} bb webos-ports-dev-image
+
   $ dd if=/dev/zero of=swap_2gb.img bs=1024k count=2048
 +
  $ mkswap swap_2gb.img
 +
  $ sudo swapon swap_2gb.img
 
</code>
 
</code>
  
After the build completes, you will find your image in <build env>/tmp-eglibc/deploy/images/{{#lowercase:{{{device_codename}}}}}/
+
If you want it permanently add it to your /etc/fstab.  If the swap file is /var/swap_2gb.img, add the following lines to /etc/fstab:
 +
<pre>
 +
# additional swap
 +
/var/swap_2gb.img swap          swap    sw              0      0
 +
</pre>
  
 
==Speeding up the build==
 
==Speeding up the build==
 +
Bitbake automatically uses all of the processors assigned to your virtual machine and gives good result on a variety of systems.
 +
You can tune bitbake for modest improvements in build speed, but the correct parameters depend on whether builds are limited by processors, disk I/O, or network I/O.
 +
Edit webos-ports/conf/local.conf and uncomment the PARALLEL_MAKE and BB_NUMBER_THREADS lines.
  
You can tune bitbake to use more of your processor.  Edit webos-ports/conf/local.conf and uncomment the PARALLEL_MAKE and BB_NUMBER_THREADS lines.  PARALLEL_MAKE should be set to the number of processor cores you have (or the number you have made available to the VM in the case of a VM) and BB_NUMBER_THREADS can be set from one to two times that, depending upon RAM, processor speed, other tasks running and Hyper-threading support.  Example values:
+
Example values:
 
 
 
<code>
 
<code>
 
   PARALLEL_MAKE = "-j 4"
 
   PARALLEL_MAKE = "-j 4"
 
   BB_NUMBER_THREADS = "4"
 
   BB_NUMBER_THREADS = "4"
 
</code>
 
</code>

Latest revision as of 09:22, 16 February 2024

Setup the build environment

Before you can build, you will need some tools. If you try to build without them, bitbake will fail a sanity check and tell you about what's missing, but not really how to get the missing pieces.

If your distribution is Ubuntu, you need to be running the bash shell. You can be sure you are running this shell by entering the following command and selecting "No" at the prompt:

    $ sudo dpkg-reconfigure dash
          

The essential and graphical support packages you need for a supported Ubuntu or Debian distribution are shown in the following commands:

    $ curl -sL https://deb.nodesource.com/setup_4.x | sudo bash -
    $ sudo apt-get install gawk wget git-core diffstat unzip texinfo \
    build-essential chrpath libsdl1.2-dev xterm nodejs bzr

(Recently, building on 64-bit Ubuntu 16.04 also required apt-get install gcc-multilib g++-multilib.)

For other Linux distributions please have a look at the Yocto Project Quick Start guide.

Note:

The steps below will setup your build environment for a development build. If you want to build the latest release use ENV_NAME=stable instead but keep in mind that all new developed features need to go into testing first before they are submitted to stable.

 $ cd into-your-build-directory
 $ mkdir webos-ports-env && cd webos-ports-env
 $ export ENV_NAME=testing
 $ wget https://raw.github.com/webOS-ports/webos-ports-setup/$ENV_NAME/Makefile
 $ make setup-webos-ports

This has been tested on Gentoo (shr-chroot) and Ubuntu-20.04/22.04/22.10/23.04/23.10 amd64/x64 and should work almost everywhere where valid toolchain is provided.

You need a lot of RAM to link Chromium, make sure you have at least 16GB (it's OK when some of that is swap, because it's used only for short part of build). Chromium needs so much ram to link because it's linking with debug symbols (huge files) which are stripped later in do_package after creating -dbg packages.

Building

Make sure you're _not_ root, as the build will fail. If you SU in the middle, don't forget to set up env afresh (. setup-env)

To configure to build (notice '.' which is actually bash 'source' command):

 $ cd into-your-build-directory/webos-ports-env/webos-ports
 $ . setup-env

To update metadata

 # go one level up to the webos-ports-env dir
 $ cd ..
 $ make update
 # or if it shows warning about different bblayers.conf or layers.txt
 $ make update-conffiles && make update
 # you can also add UPDATE_CONFFILES_ENABLED = 1 to config.mk
 # if you never want to have any uncommited changes in your checkouts RESET_ENABLED = 1 in config.mk
 # go back to the webos-ports dir to continue with the build process
 $ cd webos-ports

To build the luneos-dev-image for a device ({{{device_codename}}}):

 $ MACHINE={{{device_codename}}} bb luneos-dev-package

After the build completes, you will find your image in <build env>/tmp-glibc/deploy/images/{{{device_codename}}}/

Clean up the work directory

If you run out of disk space during a build, run the following command from the webos-ports directory, then build again:

 $ rm -rf tmp-glibc 

This removes all build things but OE luckily has a copy of every build result in a cache folder called sstate-cache which you should keep to let OE quickly rebuild everything from the cache instead to do it from scratch (next build will be quite faster).

If you run out of space because of a too large sstate-cache folder you can clean it up to contain only the results for the latest component versions with the following command:

 $ openembedded-core/scripts/sstate-cache-management.sh -L --cache-dir=sstate-cache -d -y

Adding Swap Space

To speed up the build, you can add extra 2GB of swap file like this:

 $ dd if=/dev/zero of=swap_2gb.img bs=1024k count=2048
 $ mkswap swap_2gb.img
 $ sudo swapon swap_2gb.img

If you want it permanently add it to your /etc/fstab. If the swap file is /var/swap_2gb.img, add the following lines to /etc/fstab:

# additional swap
/var/swap_2gb.img swap          swap    sw              0       0

Speeding up the build

Bitbake automatically uses all of the processors assigned to your virtual machine and gives good result on a variety of systems. You can tune bitbake for modest improvements in build speed, but the correct parameters depend on whether builds are limited by processors, disk I/O, or network I/O. Edit webos-ports/conf/local.conf and uncomment the PARALLEL_MAKE and BB_NUMBER_THREADS lines.

Example values:

 PARALLEL_MAKE = "-j 4"
 BB_NUMBER_THREADS = "4"