From patchwork Tue Jan 16 21:54:45 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Masahiro Yamada X-Patchwork-Id: 1887217 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@legolas.ozlabs.org Authentication-Results: legolas.ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.ubuntu.com (client-ip=185.125.189.65; helo=lists.ubuntu.com; envelope-from=kernel-team-bounces@lists.ubuntu.com; receiver=patchwork.ozlabs.org) Received: from lists.ubuntu.com (lists.ubuntu.com [185.125.189.65]) (using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by legolas.ozlabs.org (Postfix) with ESMTPS id 4TF2rr28PNz23f0 for ; Wed, 17 Jan 2024 08:56:11 +1100 (AEDT) Received: from localhost ([127.0.0.1] helo=lists.ubuntu.com) by lists.ubuntu.com with esmtp (Exim 4.86_2) (envelope-from ) id 1rPrPf-00083W-4b; Tue, 16 Jan 2024 21:56:03 +0000 Received: from smtp-relay-internal-0.internal ([10.131.114.225] helo=smtp-relay-internal-0.canonical.com) by lists.ubuntu.com with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1rPrPc-00082u-Sv for kernel-team@lists.ubuntu.com; Tue, 16 Jan 2024 21:56:00 +0000 Received: from mail-pl1-f197.google.com (mail-pl1-f197.google.com [209.85.214.197]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by smtp-relay-internal-0.canonical.com (Postfix) with ESMTPS id A6DB43F15B for ; Tue, 16 Jan 2024 21:56:00 +0000 (UTC) Received: by mail-pl1-f197.google.com with SMTP id d9443c01a7336-1d5c39464abso13142685ad.2 for ; Tue, 16 Jan 2024 13:56:00 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1705442159; x=1706046959; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=zAMM9/cyNw/Y3OaTqigT5VOcToss5XxRMlNx+6y5srY=; b=aR9/K2iR/pENPpDK2jB7vO2AKzZDfAjZ1R1+6OmigSwr+SmBgpGsCh0vN6W2Edh6UO E91CHM455YDu0BgzlmHBCCh1qvzO9/hi3EvHz2xLDII3H7V7CUs9QYVMsa6aevRz5oFe LXpV3h9XPdOzEARH7V6MbUZvMA5YtPo1F2W5Hrc78IoMWPTAHcHeiNUlhSQti2Oa2Mru RQYZ8Nnaz7V8a2SNQf49JJXWXCYRomBeI9KT1J/MdfWKmkBa2RNeYq4Z44EUp+Nl/k4y y0CmDBt9ekOzV5q38cmQu1SYNWXqpg/vsuBRi8iI1jeZOhoWPAEc7hl/mE2QK0rf3C9s hHeA== X-Gm-Message-State: AOJu0YwoMQbpD5jWKz5Nyy0dSu8cUIfHEOoB/1nN1bEo6rNzI239hQQ9 t5/qUpp3hNjVUf0q+2FyisDerRgWP8Cg0yyyUQCS11o4EV96NXwPthB64UUUX6GI4HqT/f6SZDS k8bsCPLtbmmBEWnSttujMwDy2t8caqPZp5FyN1d+KzO3XDP2XWhq8SRff08o= X-Received: by 2002:a17:903:604:b0:1d3:f056:3f57 with SMTP id kg4-20020a170903060400b001d3f0563f57mr4310825plb.13.1705442159221; Tue, 16 Jan 2024 13:55:59 -0800 (PST) X-Google-Smtp-Source: AGHT+IGu7XTMlOxHgeoRvQzLgUjiHLfDrxXmDqXb/roJNhmACJHfvLkGPXbIZIUHRc72NZtgXSflgg== X-Received: by 2002:a17:903:604:b0:1d3:f056:3f57 with SMTP id kg4-20020a170903060400b001d3f0563f57mr4310818plb.13.1705442158756; Tue, 16 Jan 2024 13:55:58 -0800 (PST) Received: from zoe.localdomain ([2001:f74:8f00:c00:6aff::1001]) by smtp.gmail.com with ESMTPSA id y12-20020a170903010c00b001d5e7afe974sm1690598plc.279.2024.01.16.13.55.58 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 16 Jan 2024 13:55:58 -0800 (PST) From: Masahiro Yamada To: kernel-team@lists.ubuntu.com Subject: [V2 j/linux-raspi 1/2] UBUNTU: [Packaging] Remove old snapcraft.yaml Date: Wed, 17 Jan 2024 06:54:45 +0900 Message-Id: <20240116215446.1260660-1-masahiro.yamada@canonical.com> X-Mailer: git-send-email 2.40.1 MIME-Version: 1.0 X-BeenThere: kernel-team@lists.ubuntu.com X-Mailman-Version: 2.1.20 Precedence: list List-Id: Kernel team discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: kernel-team-bounces@lists.ubuntu.com Sender: "kernel-team" This file was added more than a decade ago, and is no longer working. Signed-off-by: Masahiro Yamada --- snapcraft.yaml | 36 ------------------------------------ 1 file changed, 36 deletions(-) delete mode 100644 snapcraft.yaml diff --git a/snapcraft.yaml b/snapcraft.yaml deleted file mode 100644 index 2452c4031066..000000000000 --- a/snapcraft.yaml +++ /dev/null @@ -1,36 +0,0 @@ -name: pc-kernel -version: null -version-script: | - . debian/debian.env - dpkg-parsechangelog -l $DEBIAN/changelog -S version -summary: The Ubuntu generic Linux kernel -description: This Ubuntu generic Linux kernel -grade: stable -confinement: strict -type: kernel - -parts: - kernel: - plugin: kernel - source: . - source-type: git - kconfigflavour: generic - kconfigs: - - CONFIG_DEBUG_INFO=n - override-build: | - cp debian/scripts/retpoline-extract-one \ - $SNAPCRAFT_PART_BUILD/scripts/ubuntu-retpoline-extract-one - snapcraftctl build - kernel-with-firmware: false - firmware: - plugin: nil - stage-packages: - - linux-firmware - organize: - lib/firmware: firmware - prime: - - -usr - - -lib - build-packages: - - cpio - - libssl-dev From patchwork Tue Jan 16 21:54:46 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Masahiro Yamada X-Patchwork-Id: 1887216 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@legolas.ozlabs.org Authentication-Results: legolas.ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.ubuntu.com (client-ip=185.125.189.65; helo=lists.ubuntu.com; envelope-from=kernel-team-bounces@lists.ubuntu.com; receiver=patchwork.ozlabs.org) Received: from lists.ubuntu.com (lists.ubuntu.com [185.125.189.65]) (using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by legolas.ozlabs.org (Postfix) with ESMTPS id 4TF2rr28HGz23ds for ; Wed, 17 Jan 2024 08:56:11 +1100 (AEDT) Received: from localhost ([127.0.0.1] helo=lists.ubuntu.com) by lists.ubuntu.com with esmtp (Exim 4.86_2) (envelope-from ) id 1rPrPg-00083o-NE; Tue, 16 Jan 2024 21:56:04 +0000 Received: from smtp-relay-internal-0.internal ([10.131.114.225] helo=smtp-relay-internal-0.canonical.com) by lists.ubuntu.com with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1rPrPe-00083N-44 for kernel-team@lists.ubuntu.com; Tue, 16 Jan 2024 21:56:02 +0000 Received: from mail-pl1-f200.google.com (mail-pl1-f200.google.com [209.85.214.200]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by smtp-relay-internal-0.canonical.com (Postfix) with ESMTPS id B2BD23F15B for ; Tue, 16 Jan 2024 21:56:01 +0000 (UTC) Received: by mail-pl1-f200.google.com with SMTP id d9443c01a7336-1d4c36e9507so60083235ad.0 for ; Tue, 16 Jan 2024 13:56:01 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1705442160; x=1706046960; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=GhG4kTjzKyKP51ukf9nspHweUTuw0ELzLT5CLyar8nY=; b=GsVTDJyKxq2cIS3N8T7QS6P5gfROY5rsFHB8RC+FpL4ZLvGP8oYpx7IVy7onJGW709 j8J2TjpEUaWson1jNQwuetitqL8Tnc52THVKeV1KmZSe+AvX7WLTRACBAFdzepbg+9D+ goKxluK8MG2k0kQPsywRwjh30EzPhEX9PpUch37+nKtlph2kvSx6eg6R5OwHsX5j/Qwu PRbl9AVWbCsnOV8eVPUBaIYnbaPDg/kZQUBSQquQxzB422xVA2HRPLCm6H0miOyi4loM JNfiikg4ipT/ZL4/REXtdakf7MFkwTi9FZsdo4+r3mTAHbUCJkZgvJuN2EDpmaxIxNML a5qg== X-Gm-Message-State: AOJu0Yztq0PZocAxaAgtSdoK01oIKdxio5IWgZb6OJn67A4IpE6IfRAz 9I0N7TpOY0aBtHdX3IMdPypzJ22pX9AWv8rvtHLICpacOaG1B9JYKXhaUWxmSS1TLwc+uWdbvEb MLngxcq0iN2rHKaJ/7JzoUsxO1a27SBkKCvr/Hdtb5me+IhHAvnOXgDC/aTw= X-Received: by 2002:a17:902:ed15:b0:1d5:f243:2e2d with SMTP id b21-20020a170902ed1500b001d5f2432e2dmr929735pld.138.1705442160194; Tue, 16 Jan 2024 13:56:00 -0800 (PST) X-Google-Smtp-Source: AGHT+IH+GKMW27r04VTQG8BfcAo8i3Y/PF19N2YFfSiT0vSSKTIzXazHcLJ1ivRIGkJTX5h/TfjaQQ== X-Received: by 2002:a17:902:ed15:b0:1d5:f243:2e2d with SMTP id b21-20020a170902ed1500b001d5f2432e2dmr929731pld.138.1705442159824; Tue, 16 Jan 2024 13:55:59 -0800 (PST) Received: from zoe.localdomain ([2001:f74:8f00:c00:6aff::1001]) by smtp.gmail.com with ESMTPSA id y12-20020a170903010c00b001d5e7afe974sm1690598plc.279.2024.01.16.13.55.59 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 16 Jan 2024 13:55:59 -0800 (PST) From: Masahiro Yamada To: kernel-team@lists.ubuntu.com Subject: [V2 j/linux-raspi 2/2] UBUNTU: [Packaging] Add snapcraft.yaml for building uc22 pi-kernel snap Date: Wed, 17 Jan 2024 06:54:46 +0900 Message-Id: <20240116215446.1260660-2-masahiro.yamada@canonical.com> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20240116215446.1260660-1-masahiro.yamada@canonical.com> References: <20240116215446.1260660-1-masahiro.yamada@canonical.com> MIME-Version: 1.0 X-BeenThere: kernel-team@lists.ubuntu.com X-Mailman-Version: 2.1.20 Precedence: list List-Id: Kernel team discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: kernel-team-bounces@lists.ubuntu.com Sender: "kernel-team" Add snapcraft.yaml to support the local building for the pi-kernel snap. This supports cross-building, making it possible to build the snap on your x86 machine, and useful for development purposes. Build for arm64: $ snapcraft --use-lxd --build-for=arm64 Build for armhf: $ snapcraft --use-lxd --build-for=armhf Both arm64 and armhf snaps were tested on Raspberry PI 4. Signed-off-by: Masahiro Yamada --- Changes in v2: - Remove unneeded CONFIG_MODULE_SIG_FORCE orverride - Split the last treak to 'finalize' snapcraft.yaml | 151 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 151 insertions(+) create mode 100644 snapcraft.yaml diff --git a/snapcraft.yaml b/snapcraft.yaml new file mode 100644 index 000000000000..9274305e156b --- /dev/null +++ b/snapcraft.yaml @@ -0,0 +1,151 @@ +# SPDX-License-Identifier: GPL-2.0-only +# Copyright (C) 2023 Canonical Ltd +# +# Build for arm64: +# +# $ snapcraft --use-lxd --build-for=arm64 +# +# Build for armhf: +# +# $ snapcraft --use-lxd --build-for=armhf + +name: pi-kernel +summary: The Canonical Raspberry Pi kernel +description: The Canonical Raspberry Pi kernel +type: kernel +confinement: strict +build-base: core22 +# Take the version from debian/changelog +adopt-info: kernel + +architectures: + - build-on: [amd64, arm64] + build-for: arm64 + - build-on: [amd64, armhf] + build-for: armhf + +package-repositories: + - type: apt + architectures: [arm64, armhf] + components: [main] + suites: [jammy] + key-id: 78E1918602959B9C59103100F1831DDAFC42E99D + url: https://ppa.launchpadcontent.net/snappy-dev/image/ubuntu + - type: apt + architectures: [arm64, armhf] + components: [main, restricted] + suites: [jammy, jammy-updates] + key-id: F6ECB3762474EDA9D21B7022871920D1991BC93C + url: http://ports.ubuntu.com/ubuntu-ports + +parts: + kernel: + build-packages: + - bc + - bison + - debhelper + - fakeroot + - flex + - gawk + - kmod + - libssl-dev + - pahole + - rsync + - on amd64 to arm64: + - gcc-aarch64-linux-gnu + - libc6-dev-arm64-cross + - on amd64 to armhf: + - gcc-arm-linux-gnueabihf + - libc6-dev-armhf-cross + plugin: nil + source-type: local + source: . + override-build: | + FLAVOUR=raspi + deb_arch=${SNAPCRAFT_TARGET_ARCH} + + # Include 'DEBIAN' definition + . debian/debian.env + deb_ver=$(dpkg-parsechangelog -l "${DEBIAN}/changelog" -S version) + kernelrelease=$(echo "${deb_ver}" | cut -d. -f1-3)-${FLAVOUR} + craftctl set "version=local-${deb_ver}" + + dpkg-architecture -a "${deb_arch}" -c fakeroot debian/rules clean + dpkg-architecture -a "${deb_arch}" -c debian/rules "build-${FLAVOUR}" + dpkg-architecture -a "${deb_arch}" -c fakeroot debian/rules "binary-${FLAVOUR}" + + for pkg in linux-image linux-modules linux-buildinfo; do + dpkg-deb -x "../${pkg}-${kernelrelease}_${deb_ver}_${deb_arch}.deb" tmpdir + done + + depmod -b tmpdir "${kernelrelease}" + mv tmpdir/boot/vmlinuz-* "${SNAPCRAFT_PART_INSTALL}/kernel.img" + mv tmpdir/boot/config-* tmpdir/boot/System.map-* "${SNAPCRAFT_PART_INSTALL}/" + mv tmpdir/lib/modules "${SNAPCRAFT_PART_INSTALL}" + mv "tmpdir/lib/firmware/${kernelrelease}/device-tree" "${SNAPCRAFT_PART_INSTALL}/dtbs" + + firmware: + build-packages: + - bluez-firmware + - linux-firmware + plugin: nil + override-build: | + mkdir -p tmpdir/lib + cp -r /lib/firmware tmpdir/lib + + # linux-firmware and linux-firmware-raspi provides the same firmware + # files with different contents. Copy linux-firmware-raspi last. + apt-get download "linux-firmware-raspi:${SNAPCRAFT_TARGET_ARCH}" + dpkg-deb -x linux-firmware-raspi_*.deb tmpdir + mv tmpdir/lib/firmware "${SNAPCRAFT_PART_INSTALL}" + + # 'kernel-snap-uc22' runs 'trim-firmware' as the last step. Skip it here + # to simplify the build step. The resulting kernel snap will contain more + # firmware files than needed for raspberry pi, but it is not a big deal. + + initrd: + after: + - firmware + - kernel + build-packages: + - dracut + - zstd + plugin: nil + override-build: | + apt-get download "ubuntu-core-initramfs:${SNAPCRAFT_TARGET_ARCH}" + dpkg-deb -x ubuntu-core-initramfs_*.deb tmpdir + apt-get download "snapd:${SNAPCRAFT_TARGET_ARCH}" + dpkg-deb -x snapd_*.deb tmpdir + + mkdir tmpdir/lib/modules + + kernelrelease=$(ls "${SNAPCRAFT_STAGE}/modules") + + ln -s "${SNAPCRAFT_STAGE}/modules/${kernelrelease}" "tmpdir/lib/modules/${kernelrelease}" + ln -s "${SNAPCRAFT_STAGE}/firmware" tmpdir/lib/firmware + + # Run usr/bin/ubuntu-core-initramfs inside 'tmpdir'. + # Otherwise, tmpdir would be included in initrd.img. Odd... + ( cd tmpdir; usr/bin/ubuntu-core-initramfs create-initrd \ + --root . --output initrd.img --kernelver "${kernelrelease}" ) + cp "tmpdir/initrd.img-${kernelrelease}" "${SNAPCRAFT_PART_INSTALL}"/initrd.img + + finalize: + after: + - initrd + plugin: nil + override-build: | + # Mimic what 'kernel-snaps-uc22' does + cp /usr/share/common-licenses/GPL-2 "${SNAPCRAFT_PART_INSTALL}" + mkdir "${SNAPCRAFT_PART_INSTALL}/lib" + ln -s ../firmware "${SNAPCRAFT_PART_INSTALL}/lib" + ln -s ../modules "${SNAPCRAFT_PART_INSTALL}/lib" + + mkdir -p "${SNAPCRAFT_PART_INSTALL}/meta" + { + echo "assets:" + echo " dtbs:" + echo " update: true" + echo " content:" + echo " - dtbs/" + } > "${SNAPCRAFT_PART_INSTALL}/meta/kernel.yaml"