Skip to content

Latest commit

 

History

History
121 lines (82 loc) · 4.81 KB

README.md

File metadata and controls

121 lines (82 loc) · 4.81 KB

UVDL Yocto Install Guide

Fully Automatic Method

This option takes advantage of Makefile automation.

Important environment variables are:

  • USER = jsmith - can be used to control where archive and ephemeral are built
  • ARCHIVE := /opt - controls the folder where the output files are written
  • EPHEMERAL := $(HOME) - controls the folder where the yocto builds are made
  • HOST := 10.223.0.1 - controls the default eth0 address of the processor
  • NETMASK := 16 - controls the netmask to be used
  • YOCTO_PROD := dev - controls which yocto image to build {dev, prod, min}

Ensure the environment variables are set:

export ARCHIVE=
export EPHEMERAL=
export MACHINE=
export YOCTO_PROD=
export USER=
export S3=

If you do not wish to import there are variable examples in the Makefile that you can uncomment. Once these variables are set, you can build:

make environment
make build
make archive

This will produce a set of files (with instructions) that can be transported to another machine to create the recover SD card with. The files will be in the folder:

/opt/var-YYYY-MM-DD_HHMM/ or /opt/rasp-YYYY-MM-DD_HHMM/ or /opt/tegra-YYYY-MM-DD_HHMM/

With the time based on when the make archive command is called. If an s3 bucket location is specified make archive will also upload to that bucket

Builder Server / Shared Folders

If building on a remote server (or if you just want to save time/space) I typically do the following (after make dependencies is done once):

/data/share/${MACHINE}/downloads/
/data/share/${MACHINE}/sstate/

Go into the local.conf file in yocto-ornl and uncomment them. They are defaulted to use for this organization but can be modified to anything.

EPHEMERAL

The EPHEMERAL variable controls where the yocto build directory will be placed. This is an important folder because:

a) it cannot be moved because all the yocto files reference it by full pathname b) it holds alot of cached files that if present will speed up future builds c) it is strictly tied to the yocto base system (sumo, thud, dunfell, etc.) d) it rises to about 76GB after a build completes (can be reduced if using the Shared Folders approach)

So, where this goes on your system makes a big difference. The Makefile uses a folder located on the root directory as the default, but you may want this to exist on something else (such as /dev/shm if your system has alot of memory, or a mount point to a fast storage drive).
If you wish to be able to restart your system and keep the build state you have, then ensure EPHEMERAL points to a persistent storage volume. This is set as an exported bash environment variable OR adding it to the top of the Makefile itself. There are examples that you can uncomment.

Use the Makefile target

The makefile has an environment making target, which some prefer to use.

This will create the build environment and give you additional instructions that you will need to run to configure your shell:

make environment

This will also synchronize an existing environment with any changes in this repo that have been updated. (Since this configuration is itself a repository, the standard workflows apply - this helps updated a working, evolved build environment so as to take advantage of Yocto's dependency and partial compilation system to save time.)

Using Toaster

You may wish to use 'Toaster', a dashboard for Yocto builds. To prepare for using it, do:

make toaster

Then after setting up your environment do this once before issuing bitbake commands:

$YOCTO_DIR/$YOCTO_ENV> source toaster stop ; source toaster start

Then, open a browser to http://localhost:8000 to get the UI.

Remote Servers and Toaster

When using the AWS instance to build, you will need to create an SSH tunnel to forward TCP/IP port 8000 to your local machine:

ssh -i some-cert.pem -L 8000:localhost:8000 [email protected]

The .pem file is the private key to enable login. You will have your own if you made a VM or an AWS instance. You can always start up another SSH if you forgot to do this when you initially logged in. Then you can open your browser as described above.

Clean a specific recipe

At times, a build will fail during development and you will need to clean out what was previously built. It can be painful to go to the build directory start a bitbake server then type out what you want to clean. To make things easier the Makefile has the ability to clean the recipe for you. Just run the command below:

make clean-recipe RECIPE=

Whatever RECIPE is given, bitbake will attempt a bitbake -c cleanall RECIPE. This will save you the hassle of having to go start a new bitbake server and do it manually.