From mboxrd@z Thu Jan 1 00:00:00 1970 X-GM-THRID: 6808879013169201152 X-Received: by 2002:adf:ed42:: with SMTP id u2mr899137wro.175.1585335012548; Fri, 27 Mar 2020 11:50:12 -0700 (PDT) X-BeenThere: isar-users@googlegroups.com Received: by 2002:a1c:6402:: with SMTP id y2ls915160wmb.1.canary-gmail; Fri, 27 Mar 2020 11:50:12 -0700 (PDT) X-Google-Smtp-Source: ADFU+vvvHhn/KKOjFhqtSWwP17BTJNYbAFXhn1w951VMGiYY8VjhcENtWTnMgzhOL9MCmPAkMslj X-Received: by 2002:a1c:2b06:: with SMTP id r6mr121509wmr.25.1585335011916; Fri, 27 Mar 2020 11:50:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585335011; cv=none; d=google.com; s=arc-20160816; b=qADuugb3Ej2/F2hxMJjHsOpnQJLRomsKy+yRxrc+dJ/AAxfALSxMhIX2nWLfQduEpu tq+1rEwiddLb+j0zNcCtztgx0i3Rz7fyWlkL827FPEpWmR0yQJ9JHwz+F3EpRzbeaU0M d3QL4NUKArvVhnKe2ND0YDk539BIcw9jpCdCp1LmzOovza1YtL8/FiGJmsYVhF1I5p77 MnShVGG7uZU5Mn7nBB1qtcD7IHr41T9pozUidu4KopzRdWUIYCp4hyyuwo/VOzmC82Mt ZM7s3uLThuEpiu0m9Ob06wEcYte1K6EZLC2vo6eDuJi0CMFE1OgkLhL5epHxurHORep2 62Aw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:subject:cc:to:from:date; bh=xRyssD4R3396OqYoN4PWVetZT49jQxjaKnp6zrCmVFU=; b=sUHxJ+HobVGrljURWUzfdxUqkpvtb7wu0l2qjxP/DOozeyMcZ2gj4D/AIcQ7ZTuxWw Ktisu0CNe6RcRHdEiph/RtytmMMZu/dysLXHDz2eG2/hajdkgECjB8vdGh4stimhYZVj gQnlU6uRvFwH5dRRMdXFDupLCrjhuxoIZ3/FK5NgvkPgCd902q2nFx40B3Rpkl6pnqAa 6FI+RiQSTupmMd8nqgrSMvZPv3/j3LFC61XRVv576DSCUGenpDfcNiNnpTIok/NP5HzJ NiZNoFI597fgDP6oRV82p4lZMeSHTkf9SVJUva8yurOZN8fZkdepp4nJDIO3IMyGFyvt Wttg== ARC-Authentication-Results: i=1; gmr-mx.google.com; spf=pass (google.com: domain of henning.schild@siemens.com designates 194.138.37.40 as permitted sender) smtp.mailfrom=henning.schild@siemens.com; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=siemens.com Return-Path: Received: from gecko.sbs.de (gecko.sbs.de. [194.138.37.40]) by gmr-mx.google.com with ESMTPS id g78si267659wmg.0.2020.03.27.11.50.11 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 27 Mar 2020 11:50:11 -0700 (PDT) Received-SPF: pass (google.com: domain of henning.schild@siemens.com designates 194.138.37.40 as permitted sender) client-ip=194.138.37.40; Authentication-Results: gmr-mx.google.com; spf=pass (google.com: domain of henning.schild@siemens.com designates 194.138.37.40 as permitted sender) smtp.mailfrom=henning.schild@siemens.com; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=siemens.com Received: from mail1.sbs.de (mail1.sbs.de [192.129.41.35]) by gecko.sbs.de (8.15.2/8.15.2) with ESMTPS id 02RIoBF7016438 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK) for ; Fri, 27 Mar 2020 19:50:11 +0100 Received: from md1za8fc.ad001.siemens.net ([167.87.0.5]) by mail1.sbs.de (8.15.2/8.15.2) with ESMTP id 02RIoB3o024306; Fri, 27 Mar 2020 19:50:11 +0100 Date: Fri, 27 Mar 2020 19:50:08 +0100 From: Henning Schild To: "[ext] Q. Gylstorff" Cc: Subject: Re: [PATCH 2/3] meta/classes: Generate ova image for vmware or virtualbox Message-ID: <20200327195008.7e72c2b1@md1za8fc.ad001.siemens.net> In-Reply-To: <20200327132801.19835-3-Quirin.Gylstorff@siemens.com> References: <20200327132801.19835-1-Quirin.Gylstorff@siemens.com> <20200327132801.19835-3-Quirin.Gylstorff@siemens.com> X-Mailer: Claws Mail 3.17.4 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-TUID: 4M/ITLyW9/QQ Hi Quirin, i recently used that in a layer. In fact it does two things that maybe deserve two classes ... or the name of the class should change. 1. it converts a raw image into another format ... something that could even eventually support qcow2, vdi ... 2. it creates an ova as a follow-up step of a vmdk conversion That said, i think it can stay in one class. But the name of that class should change. "virtual-machine-image.bbclass" ? And the ova step should be done only if VIRTUAL_MACHINE_IMAGE_TYPE="vmdk". I think going with vmdk-only in a first round is good, but its important to hopefully find an interface that we do not need to change with the next sub-feature. On Fri, 27 Mar 2020 14:28:00 +0100 "[ext] Q. Gylstorff" wrote: > From: Quirin Gylstorff > > Signed-off-by: Quirin Gylstorff > --- > meta/classes/ova-wic-img.bbclass | 236 > +++++++++++++++++++++++++++++++ 1 file changed, 236 insertions(+) > create mode 100644 meta/classes/ova-wic-img.bbclass > > diff --git a/meta/classes/ova-wic-img.bbclass > b/meta/classes/ova-wic-img.bbclass new file mode 100644 > index 0000000..a03ec1b > --- /dev/null > +++ b/meta/classes/ova-wic-img.bbclass > @@ -0,0 +1,236 @@ > +# This software is a part of ISAR. > +# Copyright (C) 2019-2020 Siemens AG > +# > +# This class allows to generate images for vmware and virtualbox > +# > + > +inherit buildchroot > +inherit wic-img > +IMAGER_INSTALL += "qemu-utils gawk uuid-runtime" > +OVA_NAME ?= "${IMAGE_FULLNAME}" > +OVA_MEMORY ?= "8192" > +OVA_NUMBER_OF_CPU ?= "4" > +OVA_VRAM ?= "64" > +OVA_FIRMWARE ?= "efi" > +OVA_ACPI ?= "true" > +OVA_3D_ACCEL ?= "true" > +OVA_CLIPBOARD ?= "bidirectional" > +VMDK_DISK ?= "${PP_DEPLOY}/${VMDK_IMAGE_FILE}" > +RAW_INPUT_IMAGE_FILE ?= "${IMAGE_FULLNAME}.wic.img" > +VMDK_IMAGE_FILE = "${IMAGE_FULLNAME}.vmdk" > +VMDK_SUBFORMAT ?= "monolithicSparse" > +do_convert_wic_to_vmdk() { > + rm -f '${DEPLOY_DIR_IMAGE}/${VMDK_IMAGE_FILE}' indent is off > + image_do_mounts > + bbnote "Creating ${VMDK_IMAGE_FILE} from ${RAW_INPUT_IMAGE_FILE}" > + sudo -E chroot --userspec=$( id -u ):$( id -g ) > ${BUILDCHROOT_DIR} \ > + /usr/bin/qemu-img convert -f raw -O vmdk -o > subformat=${VMDK_SUBFORMAT} \ > + '${PP_DEPLOY}/${RAW_INPUT_IMAGE_FILE}' > '${PP_DEPLOY}/${VMDK_IMAGE_FILE}' +} the command under sudo should be indented deeper > +addtask convert_wic_to_vmdk before do_build after do_wic_image > do_copy_boot_files do_install_imager_deps do_transform_template + > +# Generate random MAC addresses just as VirtualBox does, the format > is +# their assigned prefix for the first 3 bytes followed by 3 > random bytes. +VBOX_MAC_PREFIX = "080027" > +macgen() { > + hexdump -n3 -e "\"${VBOX_MAC_PREFIX}%06X\n\"" /dev/urandom > +} > +get_disksize() { > + image_do_mounts > + sudo -E chroot --userspec=$( id -u ):$( id -g ) ${BUILDCHROOT_DIR} > \ > + qemu-img info -f vmdk "${VMDK_DISK}" | gawk 'match($0, /^virtual > size:.*\(([0-9]+) bytes\)/, a) {print a[1]}' +} > +do_create_ova() { > + rm -f '${DEPLOY_DIR_IMAGE}/${OVA_NAME}.ova' > + rm -f '${DEPLOY_DIR_IMAGE}/${OVA_NAME}.ovf' > + export PRIMARY_MAC=$(macgen) > + export SECONDARY_MAC=$(macgen) I am not sure, but maybe people would want to control that. But i guess default random is a good starting point. > + export DISK_NAME=$(basename -s .vmdk ${VMDK_DISK}) > + export DISK_SIZE_BYTES=$(get_disksize) > + export LAST_CHANGE=$(date -u "+%Y-%m-%dT%H:%M:%SZ") > + export OVA_FIRMWARE_VIRTUALBOX=$(echo ${OVA_FIRMWARE} | tr '[a-z]' > '[A-Z]') > + image_do_mounts > + sudo -Es chroot --userspec=$( id -u ):$( id -g ) > ${BUILDCHROOT_DIR} <<'EOSUDO' indentation again > + export DISK_UUID=$(uuidgen) > + export VM_UUID=$(uuidgen) > + # create ovf > + cat > "${PP_DEPLOY}/${DISK_NAME}.ovf" << EOF > + > + xmlns="http://schemas.dmtf.org/ovf/envelope/1" > xmlns:ovf="http://schemas.dmtf.org/ovf/envelope/1" > xmlns:rasd="http://schemas.dmtf.org/wbem/wscim/1/cim-schema/2/CIM_ResourceAllocationSettingData" > xmlns:vssd="http://schemas.dmtf.org/wbem/wscim/1/cim-schema/2/CIM_VirtualSystemSettingData" > xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" > xmlns:vbox="http://www.virtualbox.org/ovf/machine"> > + > + > + > + > + List of the virtual disks used in the package > + ovf:capacityAllocationUnits="byte" ovf:diskId="vmdisk1" > ovf:fileRef="file1" > ovf:format="http://www.vmware.com/interfaces/specifications/vmdk.html#streamOptimized" > vbox:uuid="${DISK_UUID}"/> > + > + > + Logical networks used in the package > + > + Logical network used by this > appliance. > + > + > + > + A virtual machine > + > + The kind of installed guest operating system > + Debian_64 > + Debian_64 > + > + > + Virtual hardware requirements for a virtual > machine > + > + Virtual Hardware Family > + 0 > + > ${OVA_NAME} > + > virtualbox-2.2 > + > + > + hertz * 10^6 > + ${OVA_NUMBER_OF_CPU} virtual CPU > + Number of virtual CPUs > + ${OVA_NUMBER_OF_CPU} virtual > CPU > + 1 > + 3 > + > ${OVA_NUMBER_OF_CPU} > + > + > + MegaBytes > + ${OVA_MEMORY} MB of memory > + Memory Size > + ${OVA_MEMORY} MB of > memory > + 2 > + 4 > + ${OVA_MEMORY} > + > + > + 0 > + ideController0 > + IDE Controller > + ideController0 > + 3 > + PIIX4 > + 5 > + > + > + 1 > + ideController1 > + IDE Controller > + ideController1 > + 4 > + PIIX4 > + 5 > + > + > + true > + Ethernet adapter on 'NAT' > + NAT > + Ethernet adapter on > 'NAT' > + 5 > + E1000 > + 10 > + > + > + 0 > + disk1 > + Disk Image > + disk1 > + /disk/vmdisk1 > + 6 > + 3 > + 17 > + > + vmw:value="${OVA_FIRMWARE}"/> > + vmw:key="tools.syncTimeWithHost" vmw:value="false"/> > + vmw:value="true"/> > + vmw:value="true"/> > + vmw:key="tools.beforeGuestShutdown" vmw:value="true"/> > + vmw:key="tools.beforeGuestStandby" vmw:value="true"/> > + vmw:key="virtualHW.productCompatibility" vmw:value="hosted"/> > + > + uuid="${VM_UUID}" name="${OVA_NAME}" OSType="Debian_64" > snapshotFolder="Snapshots" lastStateChange="${LAST_CHANGE}"> > + Complete VirtualBox machine configuration in > VirtualBox format > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + accelerate3D="${OVA_3D_ACCEL}" accelerate2DVideo="false"/> > + horzRes="640" vertRes="480"/> > + > + > + > + > + > + > + > + > + > + > + > + MACAddress="${PRIMARY_MAC}" cable="true" speed="0" type="virtio"> > + > + > + use-host-resolver="false"/> > + use-same-ports="false"/> > + > + > + > + > + hostMode="Disconnected"/> > + hostMode="Disconnected"/> > + > + > + > + > + > + enabled="false"/> > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + > + PortCount="2" useHostIOCache="true" Bootable="true"> > + > + > + > + > + > + > + > + > +EOF > +tar -c -f ${PP_DEPLOY}/${OVA_NAME}.ova -C ${PP_DEPLOY} > ${OVA_NAME}.ovf ${VMDK_IMAGE_FILE} +EOSUDO > +} > + > +addtask do_create_ova after do_convert_wic_to_vmdk before do_deploy > \ No newline at end of file