mirror of
https://git.yoctoproject.org/meta-arm
synced 2026-06-01 13:10:04 +00:00
arm-autonomy/xenguest: Generate xenguest.env containing variable values
Added task "do_deploy_xenguestenv" to xenguest_image.bbclass which creates intermediary files for each recipe that inherits xenguest_image. These files are merged into the main xenguest.env file in DEPLOY_DIR_IMAGE by the task "do_merge_xenguestenv" in image_types_xenguest.bbclass, which has a dependency on all do_deploy_xenguestenv in recipes it depends on. Variables to write to the file are listed in XENGUEST_IMAGE_VARS, and any extra variables in child recipes should be added to XENGUEST_IMAGE_VARS_EXTRA xenguest-image had to be renamed xenguest_image to use EXPORT, since dash is illegal in bash function names. Issue-Id: SCM-2035 Signed-off-by: Nathan Dunne <Nathan.Dunne@arm.com> Change-Id: I6fe45b8a5db6eb7a757c6150515da0b4de8a7205 Signed-off-by: Jon Mason <jon.mason@arm.com>
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
# Create a xenguest image with kernel and filesystem produced by Yocto
|
||||
# This will create a .xenguest file that the xenguest-manager can use.
|
||||
|
||||
inherit xenguest-image
|
||||
inherit xenguest_image
|
||||
|
||||
# We are creating our guest in a local subdirectory
|
||||
# force the value so that we are not impacted if the user is changing it
|
||||
@@ -63,6 +63,67 @@ IMAGE_TYPEDEP_xenguest ?= "tar"
|
||||
IMAGE_TYPES_MASKED += "xenguest"
|
||||
IMAGE_TYPES += "xenguest"
|
||||
|
||||
XENGUEST_IMAGE_RECIPE = "${PN}"
|
||||
XENGUEST_IMAGE_VARS += "XENGUEST_IMAGE_RECIPE"
|
||||
|
||||
# Merge intermediate env files from all recipes into a single file
|
||||
python do_merge_xenguestenv () {
|
||||
|
||||
import re
|
||||
|
||||
# Open final merged file in DEPLOY_DIR_IMAGE for writing, or create
|
||||
outdir = d.getVar('DEPLOY_DIR_IMAGE')
|
||||
with open(os.path.join(outdir,'xenguest.env'), 'w') as merged_file:
|
||||
|
||||
# Adds vars from xenguest_image to list
|
||||
merged_env = []
|
||||
xenguest_vars = d.getVar('XENGUEST_IMAGE_VARS')
|
||||
for var in xenguest_vars.split():
|
||||
value = d.getVar(var)
|
||||
if value:
|
||||
merged_env.append(var + "=" + " ".join(value.split()) + "\n")
|
||||
|
||||
# Resolve dependencies for this task to find names of intermediate
|
||||
# .xenguestenv files
|
||||
taskdepdata = d.getVar('BB_TASKDEPDATA')
|
||||
task_mc = d.getVar('BB_CURRENT_MC')
|
||||
task_file = d.getVar('FILE')
|
||||
|
||||
# See runqueue.py function build_taskdepdata
|
||||
DEPS_INDEX = 3
|
||||
|
||||
depdata_key = task_file + ":do_merge_xenguestenv"
|
||||
|
||||
# If in a multiconfig, need to add that to the key
|
||||
if task_mc != "default":
|
||||
depdata_key = "mc:" + task_mc + ":" + depdata_key
|
||||
|
||||
# Retrieve filename using regex
|
||||
get_filename = re.compile(r'/([^/]+\.bb):do_deploy_xenguestenv$')
|
||||
env_dir = d.getVar('XENGUEST_ENV_STAGING_DIR')
|
||||
|
||||
for task_dep in taskdepdata[depdata_key][DEPS_INDEX]:
|
||||
if task_dep.endswith(":do_deploy_xenguestenv"):
|
||||
filename = re.search(get_filename, task_dep).group(1) + ".xenguestenv"
|
||||
bb.note("Merging: " + filename)
|
||||
try:
|
||||
with open(env_dir + "/" + filename, 'r') as f:
|
||||
# Eliminate duplicates
|
||||
merged_env = list(set(merged_env + f.readlines()))
|
||||
except (FileNotFoundError, IOError):
|
||||
bb.note(" " + filename + " has no extra vars")
|
||||
|
||||
# Sort Alphabetically and write
|
||||
merged_env.sort()
|
||||
merged_file.write("".join(merged_env))
|
||||
}
|
||||
do_merge_xenguestenv[dirs] = "${DEPLOY_DIR_IMAGE}"
|
||||
do_merge_xenguestenv[vardeps] += "${XENGUEST_IMAGE_VARS}"
|
||||
do_merge_xenguestenv[vardepsexclude] += "BB_TASKDEPDATA"
|
||||
do_merge_xenguestenv[recrdeptask] += "do_deploy_xenguestenv"
|
||||
|
||||
addtask merge_xenguestenv before do_populate_lic_deploy after do_image_complete
|
||||
|
||||
python __anonymous() {
|
||||
# Do not do anything if we are not in the want FSTYPES
|
||||
if bb.utils.contains_any('IMAGE_FSTYPES', 'xenguest', '1', '0', d):
|
||||
|
||||
@@ -3,7 +3,10 @@
|
||||
# This is done using kernel-fitimage as model
|
||||
# To activate this, kernel-xenguest must be added to KERNEL_CLASSES
|
||||
|
||||
inherit xenguest-image
|
||||
# Add a variable name to XENGUEST_IMAGE_VARS_EXTRA if you want it to
|
||||
# appear in xenguest.env when the image is deployed
|
||||
|
||||
inherit xenguest_image
|
||||
|
||||
# use a local copy to pack all together
|
||||
XENGUEST_IMAGE_DEPLOY_DIR = "${WORKDIR}/tmp-xenguest"
|
||||
@@ -24,7 +27,7 @@ do_assemble_xenguest_initramfs() {
|
||||
rm -f ${B}/${KERNEL_OUTPUT_DIR}/Image-initramfs.xenguest
|
||||
call_xenguest_mkimage pack ${B}/${KERNEL_OUTPUT_DIR}/Image-initramfs.xenguest
|
||||
}
|
||||
do_assemble_xenguest_initramfs[depends] += "${INITRAMFS_IMAGE}:do_image_complete"
|
||||
do_assemble_xenguest_initramfs[depends] += "${INITRAMFS_IMAGE}:do_merge_xenguestenv"
|
||||
|
||||
kernel_do_deploy_append() {
|
||||
if [ -f "${B}/${KERNEL_OUTPUT_DIR}/Image-initramfs.xenguest" ]; then
|
||||
|
||||
+46
-3
@@ -30,7 +30,7 @@ XENGUEST_IMAGE_ROOT ??= "/dev/xvda1"
|
||||
# Guest kernel command line arguments
|
||||
XENGUEST_IMAGE_CMDLINE ??= "earlyprintk=xenboot console=hvc0 rw"
|
||||
|
||||
# Extra commands to add to xenguest-image when creating the image
|
||||
# Extra commands to add to xenguest_image when creating the image
|
||||
XENGUEST_IMAGE_EXTRA_CMD ??= ""
|
||||
|
||||
# Kernel binary
|
||||
@@ -83,6 +83,18 @@ XENGUEST_IMAGE_DEPLOY_SUBDIR ?= "xenguest"
|
||||
# - something in ${WORKDIR} if you need to clone and manipulate an image
|
||||
XENGUEST_IMAGE_DEPLOY_DIR ??= "${DEPLOYDIR}"
|
||||
|
||||
# These vars are used by image_types_xenguest.bbclass to generate the
|
||||
# xenguest.env file. In a recipe that inherits this class and extra variables
|
||||
# that should be included in xenguest.env need to be added to
|
||||
# XENGUEST_IMAGE_VARS_EXTRA
|
||||
XENGUEST_IMAGE_VARS ?= "\
|
||||
MACHINE DISTRO DISTRO_VERSION DISTRO_FEATURES TUNE_FEATURES TARGET_FPU \
|
||||
IMAGE_FEATURES INITRAMFS_IMAGE_BUNDLE INITRAMFS_IMAGE \
|
||||
XENGUEST_IMAGE_MEMORY_SIZE XENGUEST_IMAGE_NUM_VCPUS XENGUEST_IMAGE_AUTOBOOT \
|
||||
XENGUEST_IMAGE_ROOT XENGUEST_IMAGE_CMDLINE XENGUEST_IMAGE_EXTRA_CMD \
|
||||
XENGUEST_IMAGE_KERNEL XENGUEST_IMAGE_DISK_SIZE XENGUEST_IMAGE_DISK_DEVICE \
|
||||
XENGUEST_IMAGE_DISK_PARTITIONS XENGUEST_IMAGE_NETWORK_TYPE"
|
||||
|
||||
#
|
||||
# Wrapper to call xenguest-mkimage
|
||||
# It is using XENGUEST_IMAGE_DEPLOY_DIR and XENGUEST_IMAGE_DEPLOY_SUBDIR
|
||||
@@ -167,7 +179,38 @@ xenguest_image_create() {
|
||||
fi
|
||||
}
|
||||
|
||||
#
|
||||
XENGUEST_ENV_STAGING_DIR ??= "${STAGING_DIR}/${MACHINE}/xenguestenv"
|
||||
|
||||
# Create an intermediary file containing all variables used to by a
|
||||
# particular recipe that inherits this class
|
||||
|
||||
# File will contain the values of all variables listed in:
|
||||
# XENGUEST_IMAGE_VARS_EXTRA
|
||||
python do_deploy_xenguestenv () {
|
||||
xenguest_vars = d.getVar('XENGUEST_IMAGE_VARS_EXTRA')
|
||||
if not xenguest_vars:
|
||||
return
|
||||
|
||||
outdir = d.getVar('XENGUEST_ENV_STAGING_DIR')
|
||||
|
||||
# Writes file to tmp/sysroots/${MACHINE}/xenguestenv/ by default
|
||||
filename = os.path.basename(d.getVar('FILE')) + '.xenguestenv'
|
||||
with open(os.path.join(outdir, filename), 'w') as envf:
|
||||
for var in xenguest_vars.split():
|
||||
value = d.getVar(var)
|
||||
if value:
|
||||
# Write value only if set
|
||||
envf.write('%s="%s"\n' % (var, " ".join(value.split())))
|
||||
envf.close()
|
||||
}
|
||||
|
||||
# Since the intermediary file is deleted by do_merge_xenguestenv it
|
||||
# must be re-created every time
|
||||
do_deploy_xenguestenv[vardeps] += "${XENGUEST_IMAGE_VARS_EXTRA}"
|
||||
do_deploy_xenguestenv[dirs] = "${XENGUEST_ENV_STAGING_DIR}"
|
||||
|
||||
addtask deploy_xenguestenv before do_populate_sysroot
|
||||
|
||||
# Clone the current xenguest from deploy to manipulate it locally
|
||||
# This is required if you need to change things before packing an image
|
||||
# To set the local directory where to clone you must set
|
||||
@@ -181,7 +224,7 @@ xenguest_image_clone() {
|
||||
fi
|
||||
|
||||
if [ ! -f ${DEPLOY_DIR_IMAGE}/${XENGUEST_IMAGE_DEPLOY_SUBDIR}/guest.cfg ]; then
|
||||
die "xenguest-image: ${DEPLOY_DIR_IMAGE}/${XENGUEST_IMAGE_DEPLOY_SUBDIR} does not contain a valid guest"
|
||||
die "xenguest_image: ${DEPLOY_DIR_IMAGE}/${XENGUEST_IMAGE_DEPLOY_SUBDIR} does not contain a valid guest"
|
||||
fi
|
||||
|
||||
rm -rf ${XENGUEST_IMAGE_DEPLOY_DIR}/${XENGUEST_IMAGE_DEPLOY_SUBDIR}
|
||||
+20
-11
@@ -4,8 +4,11 @@
|
||||
# The class is extending deploy function so you recipe must inherit deploy and
|
||||
# have a do_deploy function (even if it is empty)
|
||||
|
||||
# Use standard xenguest-image
|
||||
inherit xenguest-image
|
||||
# Add a variable name to XENGUEST_IMAGE_VARS_EXTRA if you want it to
|
||||
# appear in xenguest.env when the image is deployed
|
||||
|
||||
# Use standard xenguest_image
|
||||
inherit xenguest_image
|
||||
|
||||
# Add a DTB file for the guest
|
||||
# Only one file should be added, if this is set multiple times or in several
|
||||
@@ -39,6 +42,12 @@ XENGUEST_EXTRA_FILES ??= ""
|
||||
# dir1/file1 file in the disk content parameters).
|
||||
XENGUEST_EXTRA_DISK_FILES ??= ""
|
||||
|
||||
# Extra vars to be written to xenguest.env
|
||||
XENGUEST_IMAGE_VARS_EXTRA += "\
|
||||
XENGUEST_EXTRA_DTB XENGUEST_EXTRA_RAMDISK XENGUEST_EXTRA_XENCONFIG \
|
||||
XENGUEST_EXTRA_INIT_PRE XENGUEST_EXTRA_INIT XENGUEST_EXTRA_INIT_POST \
|
||||
XENGUEST_EXTRA_FILES XENGUEST_EXTRA_DISK_FILES"
|
||||
|
||||
do_deploy_append() {
|
||||
if [ -z "${XENGUEST_IMAGE_DEPLOY_DIR}" -o \
|
||||
-z "${XENGUEST_IMAGE_DEPLOY_SUBDIR}" ]; then
|
||||
@@ -49,14 +58,14 @@ do_deploy_append() {
|
||||
|
||||
if [ -n "${XENGUEST_EXTRA_DTB}" ]; then
|
||||
if [ ! -f ${XENGUEST_EXTRA_DTB} ]; then
|
||||
die "xenguest-image: DTB file ${XENGUEST_EXTRA_DTB} does not exist"
|
||||
die "xenguest_image: DTB file ${XENGUEST_EXTRA_DTB} does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --xen-device-tree=${XENGUEST_EXTRA_DTB}
|
||||
fi
|
||||
|
||||
if [ -n "${XENGUEST_EXTRA_RAMDISK}" ]; then
|
||||
if [ ! -f ${XENGUEST_EXTRA_RAMDISK} ]; then
|
||||
die "xenguest-image: DTB file ${XENGUEST_EXTRA_RAMDISK} does not exist"
|
||||
die "xenguest_image: DTB file ${XENGUEST_EXTRA_RAMDISK} does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --xen-ramdisk=${XENGUEST_EXTRA_RAMDISK}
|
||||
fi
|
||||
@@ -64,7 +73,7 @@ do_deploy_append() {
|
||||
if [ -n "${XENGUEST_EXTRA_XENCONFIG}" ]; then
|
||||
for f in ${XENGUEST_EXTRA_XENCONFIG}; do
|
||||
if [ ! -f $f ]; then
|
||||
die "xenguest-image: Xen config $f does not exist"
|
||||
die "xenguest_image: Xen config $f does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --xen-append=$f
|
||||
done
|
||||
@@ -72,21 +81,21 @@ do_deploy_append() {
|
||||
|
||||
if [ -n "${XENGUEST_EXTRA_INIT_PRE}" ]; then
|
||||
if [ ! -f ${XENGUEST_EXTRA_INIT_PRE} ]; then
|
||||
die "xenguest-image: Init script ${XENGUEST_EXTRA_INIT_PRE} does not exist"
|
||||
die "xenguest_image: Init script ${XENGUEST_EXTRA_INIT_PRE} does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --init-pre=${XENGUEST_EXTRA_INIT_PRE}
|
||||
fi
|
||||
|
||||
if [ -n "${XENGUEST_EXTRA_INIT}" ]; then
|
||||
if [ ! -f ${XENGUEST_EXTRA_INIT} ]; then
|
||||
die "xenguest-image: Init script ${XENGUEST_EXTRA_INIT} does not exist"
|
||||
die "xenguest_image: Init script ${XENGUEST_EXTRA_INIT} does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --init-script=${XENGUEST_EXTRA_INIT}
|
||||
fi
|
||||
|
||||
if [ -n "${XENGUEST_EXTRA_INIT_POST}" ]; then
|
||||
if [ ! -f ${XENGUEST_EXTRA_INIT_POST} ]; then
|
||||
die "xenguest-image: Init script ${XENGUEST_EXTRA_INIT_POST} does not exist"
|
||||
die "xenguest_image: Init script ${XENGUEST_EXTRA_INIT_POST} does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --init-post=${XENGUEST_EXTRA_INIT_POST}
|
||||
fi
|
||||
@@ -94,7 +103,7 @@ do_deploy_append() {
|
||||
if [ -n "${XENGUEST_EXTRA_FILES}" ]; then
|
||||
for f in ${XENGUEST_EXTRA_FILES}; do
|
||||
if [ ! -f $f ]; then
|
||||
die "xenguest-image: Xen file $f does not exist"
|
||||
die "xenguest_image: Xen file $f does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --xen-add-file=$f
|
||||
done
|
||||
@@ -103,12 +112,12 @@ do_deploy_append() {
|
||||
if [ -n "${XENGUEST_EXTRA_DISK_FILES}" ]; then
|
||||
for f in ${XENGUEST_EXTRA_DISK_FILES}; do
|
||||
if [ ! -f $f ]; then
|
||||
die "xenguest-image: Disk file $f does not exist"
|
||||
die "xenguest_image: Disk file $f does not exist"
|
||||
fi
|
||||
call_xenguest_mkimage partial --disk-add-file=$f
|
||||
done
|
||||
fi
|
||||
}
|
||||
# Need to have xenguest-image tool
|
||||
# Need to have xenguest_image tool
|
||||
do_deploy[depends] += "xenguest-base-image:do_deploy"
|
||||
|
||||
Reference in New Issue
Block a user