init
This commit is contained in:
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
.cache
|
||||
.vscode
|
||||
build/tmp/
|
||||
4
.gitmodules
vendored
Normal file
4
.gitmodules
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
[submodule "poky"]
|
||||
path = poky
|
||||
url = https://git.yoctoproject.org/poky
|
||||
branch = scarthgap
|
||||
39
README.md
Normal file
39
README.md
Normal file
@@ -0,0 +1,39 @@
|
||||
# Yocto template
|
||||
|
||||
Template for a yocto workspace to use with docker.
|
||||
|
||||
## Requirements
|
||||
|
||||
### docker
|
||||
|
||||
This template requires docker to work.
|
||||
See the [official manual](https://docs.docker.com/engine/install/) to set it up.
|
||||
|
||||
### custom yocto docker image
|
||||
|
||||
The custom image is available on hub.anxietyprime.de/yocto:latest, but requires login.
|
||||
It can be build locally following the instructions in https://git.anxietyprime.de/timoschneider/docker-yocto.
|
||||
|
||||
## Workspace layout
|
||||
|
||||
```bash
|
||||
yocto (origin)
|
||||
├── build
|
||||
│ └── conf
|
||||
├── .cache
|
||||
│ ├── docker
|
||||
│ └── yocto
|
||||
├── docker-compose.yaml
|
||||
├── .git
|
||||
├── .gitignore
|
||||
├── .gitmodules
|
||||
├── layers
|
||||
├── poky
|
||||
├── README.md
|
||||
└── scripts
|
||||
├── docker-entrypoint.sh
|
||||
├── setup-env.sh
|
||||
├── setup-paths.sh
|
||||
└── start-docker.sh
|
||||
```
|
||||
The cache and download folders are auto generated.
|
||||
12
build/conf/bblayers.conf
Normal file
12
build/conf/bblayers.conf
Normal file
@@ -0,0 +1,12 @@
|
||||
# POKY_BBLAYERS_CONF_VERSION is increased each time build/conf/bblayers.conf
|
||||
# changes incompatibly
|
||||
POKY_BBLAYERS_CONF_VERSION = "2"
|
||||
|
||||
BBPATH = "${TOPDIR}"
|
||||
BBFILES ?= ""
|
||||
|
||||
BBLAYERS ?= " \
|
||||
/home/yocto/ws/poky/meta \
|
||||
/home/yocto/ws/poky/meta-poky \
|
||||
/home/yocto/ws/poky/meta-yocto-bsp \
|
||||
"
|
||||
19
build/conf/conf-notes.txt
Normal file
19
build/conf/conf-notes.txt
Normal file
@@ -0,0 +1,19 @@
|
||||
|
||||
### Shell environment set up for builds. ###
|
||||
|
||||
You can now run 'bitbake <target>'
|
||||
|
||||
Common targets are:
|
||||
core-image-minimal
|
||||
core-image-full-cmdline
|
||||
core-image-sato
|
||||
core-image-weston
|
||||
meta-toolchain
|
||||
meta-ide-support
|
||||
|
||||
You can also run generated qemu images with a command like 'runqemu qemux86-64'.
|
||||
|
||||
Other commonly useful commands are:
|
||||
- 'devtool' and 'recipetool' handle common recipe tasks
|
||||
- 'bitbake-layers' handles common layer tasks
|
||||
- 'oe-pkgdata-util' handles common target package tasks
|
||||
1
build/conf/conf-summary.txt
Normal file
1
build/conf/conf-summary.txt
Normal file
@@ -0,0 +1 @@
|
||||
This is the default build configuration for the Poky reference distribution.
|
||||
310
build/conf/local.conf
Normal file
310
build/conf/local.conf
Normal file
@@ -0,0 +1,310 @@
|
||||
#
|
||||
# This file is your local configuration file and is where all local user settings
|
||||
# are placed. The comments in this file give some guide to the options a new user
|
||||
# to the system might want to change but pretty much any configuration option can
|
||||
# be set in this file. More adventurous users can look at
|
||||
# local.conf.sample.extended which contains other examples of configuration which
|
||||
# can be placed in this file but new users likely won't need any of them
|
||||
# initially. There's also site.conf.sample which contains examples of site specific
|
||||
# information such as proxy server addresses.
|
||||
#
|
||||
# Lines starting with the '#' character are commented out and in some cases the
|
||||
# default values are provided as comments to show people example syntax. Enabling
|
||||
# the option is a question of removing the # character and making any change to the
|
||||
# variable as required.
|
||||
|
||||
#
|
||||
# Machine Selection
|
||||
#
|
||||
# You need to select a specific machine to target the build with. There are a selection
|
||||
# of emulated machines available which can boot and run in the QEMU emulator:
|
||||
#
|
||||
#MACHINE ?= "qemuarm"
|
||||
#MACHINE ?= "qemuarm64"
|
||||
#MACHINE ?= "qemumips"
|
||||
#MACHINE ?= "qemumips64"
|
||||
#MACHINE ?= "qemuppc"
|
||||
#MACHINE ?= "qemux86"
|
||||
#MACHINE ?= "qemux86-64"
|
||||
#
|
||||
# There are also the following hardware board target machines included for
|
||||
# demonstration purposes:
|
||||
#
|
||||
#MACHINE ?= "beaglebone-yocto"
|
||||
#MACHINE ?= "genericarm64"
|
||||
#MACHINE ?= "genericx86"
|
||||
#MACHINE ?= "genericx86-64"
|
||||
#
|
||||
# This sets the default machine to be qemux86-64 if no other machine is selected:
|
||||
MACHINE ??= "qemux86-64"
|
||||
|
||||
# These are some of the more commonly used values. Looking at the files in the
|
||||
# meta/conf/machine directory, or the conf/machine directory of any additional layers
|
||||
# you add in will show all the available machines.
|
||||
|
||||
#
|
||||
# Where to place downloads
|
||||
#
|
||||
# During a first build the system will download many different source code tarballs
|
||||
# from various upstream projects. This can take a while, particularly if your network
|
||||
# connection is slow. These are all stored in DL_DIR. When wiping and rebuilding you
|
||||
# can preserve this directory to speed up this part of subsequent builds. This directory
|
||||
# is safe to share between multiple builds on the same machine too.
|
||||
#
|
||||
# The default is a downloads directory under TOPDIR which is the build directory.
|
||||
#
|
||||
#DL_DIR ?= "${TOPDIR}/downloads"
|
||||
|
||||
#
|
||||
# Where to place shared-state files
|
||||
#
|
||||
# BitBake has the capability to accelerate builds based on previously built output.
|
||||
# This is done using "shared state" files which can be thought of as cache objects
|
||||
# and this option determines where those files are placed.
|
||||
#
|
||||
# You can wipe out TMPDIR leaving this directory intact and the build would regenerate
|
||||
# from these files if no changes were made to the configuration. If changes were made
|
||||
# to the configuration, only shared state files where the state was still valid would
|
||||
# be used (done using checksums).
|
||||
#
|
||||
# The default is a sstate-cache directory under TOPDIR.
|
||||
#
|
||||
#SSTATE_DIR ?= "${TOPDIR}/sstate-cache"
|
||||
|
||||
#
|
||||
# Where to place the build output
|
||||
#
|
||||
# This option specifies where the bulk of the building work should be done and
|
||||
# where BitBake should place its temporary files and output. Keep in mind that
|
||||
# this includes the extraction and compilation of many applications and the toolchain
|
||||
# which can use Gigabytes of hard disk space.
|
||||
#
|
||||
# The default is a tmp directory under TOPDIR.
|
||||
#
|
||||
#TMPDIR = "${TOPDIR}/tmp"
|
||||
|
||||
#
|
||||
# Default policy config
|
||||
#
|
||||
# The distribution setting controls which policy settings are used as defaults.
|
||||
# The default value is fine for general Yocto project use, at least initially.
|
||||
# Ultimately when creating custom policy, people will likely end up subclassing
|
||||
# these defaults.
|
||||
#
|
||||
DISTRO ?= "poky"
|
||||
# As an example of a subclass there is a "bleeding" edge policy configuration
|
||||
# where many versions are set to the absolute latest code from the upstream
|
||||
# source control systems. This is just mentioned here as an example, its not
|
||||
# useful to most new users.
|
||||
# DISTRO ?= "poky-bleeding"
|
||||
|
||||
#
|
||||
# Package Management configuration
|
||||
#
|
||||
# This variable lists which packaging formats to enable. Multiple package backends
|
||||
# can be enabled at once and the first item listed in the variable will be used
|
||||
# to generate the root filesystems.
|
||||
# Options are:
|
||||
# - 'package_deb' for debian style deb files
|
||||
# - 'package_ipk' for ipk files are used by opkg (a debian style embedded package manager)
|
||||
# - 'package_rpm' for rpm style packages
|
||||
# E.g.: PACKAGE_CLASSES ?= "package_rpm package_deb package_ipk"
|
||||
# OE-Core defaults to ipkg, whilst Poky defaults to rpm:
|
||||
# PACKAGE_CLASSES ?= "package_rpm"
|
||||
|
||||
#
|
||||
# SDK target architecture
|
||||
#
|
||||
# This variable specifies the architecture to build SDK items for and means
|
||||
# you can build the SDK packages for architectures other than the machine you are
|
||||
# running the build on (i.e. building i686 packages on an x86_64 host).
|
||||
# Supported values are i686, x86_64, aarch64
|
||||
#SDKMACHINE ?= "i686"
|
||||
|
||||
#
|
||||
# Extra image configuration defaults
|
||||
#
|
||||
# The EXTRA_IMAGE_FEATURES variable allows extra packages to be added to the generated
|
||||
# images. Some of these options are added to certain image types automatically. The
|
||||
# variable can contain the following options:
|
||||
# "dbg-pkgs" - add -dbg packages for all installed packages
|
||||
# (adds symbol information for debugging/profiling)
|
||||
# "src-pkgs" - add -src packages for all installed packages
|
||||
# (adds source code for debugging)
|
||||
# "dev-pkgs" - add -dev packages for all installed packages
|
||||
# (useful if you want to develop against libs in the image)
|
||||
# "ptest-pkgs" - add -ptest packages for all ptest-enabled packages
|
||||
# (useful if you want to run the package test suites)
|
||||
# "tools-sdk" - add development tools (gcc, make, pkgconfig etc.)
|
||||
# "tools-debug" - add debugging tools (gdb, strace)
|
||||
# "eclipse-debug" - add Eclipse remote debugging support
|
||||
# "tools-profile" - add profiling tools (oprofile, lttng, valgrind)
|
||||
# "tools-testapps" - add useful testing tools (ts_print, aplay, arecord etc.)
|
||||
# "debug-tweaks" - make an image suitable for development
|
||||
# e.g. ssh root access has a blank password
|
||||
# There are other application targets that can be used here too, see
|
||||
# meta/classes-recipe/image.bbclass and
|
||||
# meta/classes-recipe/core-image.bbclass for more details.
|
||||
# We default to enabling the debugging tweaks.
|
||||
EXTRA_IMAGE_FEATURES ?= "debug-tweaks"
|
||||
|
||||
#
|
||||
# Additional image features
|
||||
#
|
||||
# The following is a list of additional classes to use when building images which
|
||||
# enable extra features. Some available options which can be included in this variable
|
||||
# are:
|
||||
# - 'buildstats' collect build statistics
|
||||
USER_CLASSES ?= "buildstats"
|
||||
|
||||
#
|
||||
# Runtime testing of images
|
||||
#
|
||||
# The build system can test booting virtual machine images under qemu (an emulator)
|
||||
# after any root filesystems are created and run tests against those images. It can also
|
||||
# run tests against any SDK that are built. To enable this uncomment these lines.
|
||||
# See meta/classes-recipe/test{image,sdk}.bbclass for further details.
|
||||
#IMAGE_CLASSES += "testimage testsdk"
|
||||
#TESTIMAGE_AUTO:qemuall = "1"
|
||||
|
||||
#
|
||||
# Interactive shell configuration
|
||||
#
|
||||
# Under certain circumstances the system may need input from you and to do this it
|
||||
# can launch an interactive shell. It needs to do this since the build is
|
||||
# multithreaded and needs to be able to handle the case where more than one parallel
|
||||
# process may require the user's attention. The default is iterate over the available
|
||||
# terminal types to find one that works.
|
||||
#
|
||||
# Examples of the occasions this may happen are when resolving patches which cannot
|
||||
# be applied, to use the devshell or the kernel menuconfig
|
||||
#
|
||||
# Supported values are auto, gnome, xfce, rxvt, screen, konsole (KDE 3.x only), none
|
||||
# Note: currently, Konsole support only works for KDE 3.x due to the way
|
||||
# newer Konsole versions behave
|
||||
#OE_TERMINAL = "auto"
|
||||
# By default disable interactive patch resolution (tasks will just fail instead):
|
||||
PATCHRESOLVE = "noop"
|
||||
|
||||
#
|
||||
# Disk Space Monitoring during the build
|
||||
#
|
||||
# Monitor the disk space during the build. If there is less that 1GB of space or less
|
||||
# than 100K inodes in any key build location (TMPDIR, DL_DIR, SSTATE_DIR), gracefully
|
||||
# shutdown the build. If there is less than 100MB or 1K inodes, perform a hard halt
|
||||
# of the build. The reason for this is that running completely out of space can corrupt
|
||||
# files and damages the build in ways which may not be easily recoverable.
|
||||
# It's necessary to monitor /tmp, if there is no space left the build will fail
|
||||
# with very exotic errors.
|
||||
BB_DISKMON_DIRS ??= "\
|
||||
STOPTASKS,${TMPDIR},1G,100K \
|
||||
STOPTASKS,${DL_DIR},1G,100K \
|
||||
STOPTASKS,${SSTATE_DIR},1G,100K \
|
||||
STOPTASKS,/tmp,100M,100K \
|
||||
HALT,${TMPDIR},100M,1K \
|
||||
HALT,${DL_DIR},100M,1K \
|
||||
HALT,${SSTATE_DIR},100M,1K \
|
||||
HALT,/tmp,10M,1K"
|
||||
|
||||
#
|
||||
# Shared-state files from other locations
|
||||
#
|
||||
# As mentioned above, shared state files are prebuilt cache data objects which can be
|
||||
# used to accelerate build time. This variable can be used to configure the system
|
||||
# to search other mirror locations for these objects before it builds the data itself.
|
||||
#
|
||||
# This can be a filesystem directory, or a remote url such as https or ftp. These
|
||||
# would contain the sstate-cache results from previous builds (possibly from other
|
||||
# machines). This variable works like fetcher MIRRORS/PREMIRRORS and points to the
|
||||
# cache locations to check for the shared objects.
|
||||
# NOTE: if the mirror uses the same structure as SSTATE_DIR, you need to add PATH
|
||||
# at the end as shown in the examples below. This will be substituted with the
|
||||
# correct path within the directory structure.
|
||||
#SSTATE_MIRRORS ?= "\
|
||||
#file://.* https://someserver.tld/share/sstate/PATH;downloadfilename=PATH \
|
||||
#file://.* file:///some/local/dir/sstate/PATH"
|
||||
|
||||
#
|
||||
# Yocto Project SState Mirror
|
||||
#
|
||||
# The Yocto Project has prebuilt artefacts available for its releases, you can enable
|
||||
# use of these by uncommenting some of the following lines. This will mean the build uses
|
||||
# the network to check for artefacts at the start of builds, which does slow it down
|
||||
# initially but it will then speed up the builds by not having to build things if they are
|
||||
# present in the cache. It assumes you can download something faster than you can build it
|
||||
# which will depend on your network.
|
||||
# Note: For this to work you also need hash-equivalence passthrough to the matching server
|
||||
# There is a choice between our sstate server directly and a faster content delivery network
|
||||
# (CDN) kindly provided by JSDelivr, uncomment one of the SSTATE_MIRRORS lines, not both.
|
||||
# Using the CDN rather than the yoctoproject.org address is suggested/preferred.
|
||||
#
|
||||
#BB_HASHSERVE_UPSTREAM = 'wss://hashserv.yoctoproject.org/ws'
|
||||
#SSTATE_MIRRORS ?= "file://.* http://sstate.yoctoproject.org/all/PATH;downloadfilename=PATH"
|
||||
|
||||
#
|
||||
# Qemu configuration
|
||||
#
|
||||
# By default native qemu will build with a builtin VNC server where graphical output can be
|
||||
# seen. The line below enables the SDL UI frontend too.
|
||||
PACKAGECONFIG:append:pn-qemu-system-native = " sdl"
|
||||
# By default libsdl2-native will be built, if you want to use your host's libSDL instead of
|
||||
# the minimal libsdl built by libsdl2-native then uncomment the ASSUME_PROVIDED line below.
|
||||
#ASSUME_PROVIDED += "libsdl2-native"
|
||||
|
||||
# You can also enable the Gtk UI frontend, which takes somewhat longer to build, but adds
|
||||
# a handy set of menus for controlling the emulator.
|
||||
#PACKAGECONFIG:append:pn-qemu-system-native = " gtk+"
|
||||
|
||||
#
|
||||
# Hash Equivalence
|
||||
#
|
||||
# Enable support for automatically running a local hash equivalence server and
|
||||
# instruct bitbake to use a hash equivalence aware signature generator. Hash
|
||||
# equivalence improves reuse of sstate by detecting when a given sstate
|
||||
# artifact can be reused as equivalent, even if the current task hash doesn't
|
||||
# match the one that generated the artifact.
|
||||
#
|
||||
# A shared hash equivalent server can be set with "<HOSTNAME>:<PORT>" format
|
||||
#
|
||||
#BB_HASHSERVE = "auto"
|
||||
#BB_SIGNATURE_HANDLER = "OEEquivHash"
|
||||
|
||||
#
|
||||
# Memory Resident Bitbake
|
||||
#
|
||||
# Bitbake's server component can stay in memory after the UI for the current command
|
||||
# has completed. This means subsequent commands can run faster since there is no need
|
||||
# for bitbake to reload cache files and so on. Number is in seconds, after which the
|
||||
# server will shut down.
|
||||
#
|
||||
#BB_SERVER_TIMEOUT = "60"
|
||||
|
||||
# CONF_VERSION is increased each time build/conf/ changes incompatibly and is used to
|
||||
# track the version of this file when it was generated. This can safely be ignored if
|
||||
# this doesn't mean anything to you.
|
||||
CONF_VERSION = "2"
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
# >>> yocto cache (managed) >>>
|
||||
DL_DIR = "/home/yocto/ws/.cache/yocto/downloads"
|
||||
SSTATE_DIR = "/home/yocto/ws/.cache/yocto/sstate"
|
||||
# <<< yocto cache (managed) <<<
|
||||
1
build/conf/templateconf.cfg
Normal file
1
build/conf/templateconf.cfg
Normal file
@@ -0,0 +1 @@
|
||||
meta-poky/conf/templates/default
|
||||
42
docker-compose.yaml
Normal file
42
docker-compose.yaml
Normal file
@@ -0,0 +1,42 @@
|
||||
services:
|
||||
yocto:
|
||||
image: hub.anxietyprime.de/yocto:latest
|
||||
container_name: yocto
|
||||
runtime: nvidia # Enable GPU support
|
||||
network_mode: host
|
||||
devices:
|
||||
- /dev/dri
|
||||
- /dev/kvm:/dev/kvm
|
||||
- /dev/net/tun:/dev/net/tun
|
||||
privileged: true
|
||||
cap_add:
|
||||
- SYS_ADMIN
|
||||
- NET_ADMIN
|
||||
environment:
|
||||
- DISPLAY=${DISPLAY}
|
||||
- XDG_RUNTIME_DIR=${XDG_RUNTIME_DIR}
|
||||
- NVIDIA_VISIBLE_DEVICES=all
|
||||
- NVIDIA_DRIVER_CAPABILITIES=all
|
||||
- LIBGL_ALWAYS_INDIRECT=1
|
||||
- __GLX_VENDOR_LIBRARY_NAME=nvidia
|
||||
volumes:
|
||||
# display (if needed)
|
||||
- /tmp/.X11-unix:/tmp/.X11-unix
|
||||
- ${XDG_RUNTIME_DIR}:${XDG_RUNTIME_DIR}
|
||||
|
||||
# devices
|
||||
- /dev:/dev
|
||||
|
||||
# cache
|
||||
- ./.cache/:/home/yocto/ws/.cache
|
||||
- ./.cache/docker/zsh_history:/home/yocto/.zsh_history
|
||||
|
||||
# ws
|
||||
- ./build/:/home/yocto/ws/build
|
||||
- ./layers/:/home/yocto/ws/layers
|
||||
- ./poky/:/home/yocto/ws/poky
|
||||
- ./scripts/:/home/yocto/ws/scripts
|
||||
entrypoint: /home/yocto/ws/scripts/docker-entrypoint.sh
|
||||
stdin_open: true # equivalent to -it
|
||||
tty: true # equivalent to -it
|
||||
restart: always
|
||||
1
layers/README.md
Normal file
1
layers/README.md
Normal file
@@ -0,0 +1 @@
|
||||
Place layers here
|
||||
1
poky
Submodule
1
poky
Submodule
Submodule poky added at 553530a8ac
13
scripts/docker-entrypoint.sh
Executable file
13
scripts/docker-entrypoint.sh
Executable file
@@ -0,0 +1,13 @@
|
||||
#!/bin/bash
|
||||
trap "echo 'Stopping...'; exit 0" SIGTERM
|
||||
|
||||
# source yocto
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
source "${SCRIPT_DIR}/setup-env.sh"
|
||||
|
||||
# add add source to all zsh instances
|
||||
#echo "souce \"${YOCTO_ROOT}(scripts/setup-env.sh\"" >> ~/.zshrc
|
||||
|
||||
# trap to keep container open in background
|
||||
/bin/zsh
|
||||
#while true; do sleep 1; done
|
||||
47
scripts/setup-env.sh
Executable file
47
scripts/setup-env.sh
Executable file
@@ -0,0 +1,47 @@
|
||||
#!/usr/bin/env bash
|
||||
set -e
|
||||
# -------------------------------------------------------------------
|
||||
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
source "${SCRIPT_DIR}/setup-paths.sh"
|
||||
|
||||
# -------------------------------------------------------------------
|
||||
|
||||
# Sanity checks
|
||||
if [ ! -d "${POKY_DIR}" ]; then
|
||||
echo "ERROR: poky not found at ${POKY_DIR}"
|
||||
return 1 2>/dev/null || exit 1
|
||||
fi
|
||||
|
||||
# Create cache directories
|
||||
mkdir -p "${DL_DIR}"
|
||||
mkdir -p "${SSTATE_DIR}"
|
||||
|
||||
# Initialize Yocto build environment
|
||||
source "${POKY_DIR}/oe-init-build-env" "${YOCTO_ROOT}/${BUILD_DIR}"
|
||||
|
||||
# Inject cache paths into local.conf (idempotent)
|
||||
CONF_FILE="${BUILDDIR}/conf/local.conf"
|
||||
|
||||
START_MARKER="# >>> yocto cache (managed) >>>"
|
||||
END_MARKER="# <<< yocto cache (managed) <<<"
|
||||
|
||||
# Remove old managed block if present
|
||||
sed -i "/${START_MARKER}/,/${END_MARKER}/d" "${CONF_FILE}"
|
||||
|
||||
# Append managed block
|
||||
cat <<EOF >> "${CONF_FILE}"
|
||||
|
||||
${START_MARKER}
|
||||
DL_DIR = "${DL_DIR}"
|
||||
SSTATE_DIR = "${SSTATE_DIR}"
|
||||
${END_MARKER}
|
||||
EOF
|
||||
|
||||
|
||||
echo
|
||||
echo "Yocto environment ready:"
|
||||
echo " BUILD_DIR = ${BUILDDIR}"
|
||||
echo " DL_DIR = ${DL_DIR}"
|
||||
echo " SSTATE_DIR = ${SSTATE_DIR}"
|
||||
echo
|
||||
12
scripts/setup-paths.sh
Normal file
12
scripts/setup-paths.sh
Normal file
@@ -0,0 +1,12 @@
|
||||
#!/bin/bash
|
||||
|
||||
# ---- Configuration -------------------------------------------------
|
||||
YOCTO_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)"
|
||||
BUILD_DIR="${1:-build}"
|
||||
|
||||
CACHE_BASE="${YOCTO_ROOT}/.cache/yocto"
|
||||
DL_DIR="${CACHE_BASE}/downloads"
|
||||
SSTATE_DIR="${CACHE_BASE}/sstate"
|
||||
|
||||
POKY_DIR="${YOCTO_ROOT}/poky"
|
||||
# -------------------------------------------------------------------
|
||||
17
scripts/start-docker.sh
Executable file
17
scripts/start-docker.sh
Executable file
@@ -0,0 +1,17 @@
|
||||
#!/bin/bash
|
||||
set -e
|
||||
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
source "${SCRIPT_DIR}/setup-paths.sh"
|
||||
|
||||
# -------------------------------------------------------------------
|
||||
|
||||
mkdir -p "${YOCTO_ROOT}/.cache/docker/"
|
||||
touch "${YOCTO_ROOT}/.cache/docker/zsh_history"
|
||||
mkdir -p "${BUILD_DIR}"
|
||||
mkdir -p "${DL_DIR}"
|
||||
mkdir -p "${SSTATE_DIR}"
|
||||
|
||||
# -------------------------------------------------------------------
|
||||
|
||||
docker compose -f $YOCTO_ROOT/docker-compose.yaml up -d
|
||||
Reference in New Issue
Block a user