From mboxrd@z Thu Jan 1 00:00:00 1970 X-GM-THRID: 7172560304523444224 X-Received: by 2002:a17:903:240b:b0:186:9fc5:6c2c with SMTP id e11-20020a170903240b00b001869fc56c2cmr79484900plo.174.1670936003733; Tue, 13 Dec 2022 04:53:23 -0800 (PST) X-BeenThere: isar-users@googlegroups.com Received: by 2002:a17:90a:8a94:b0:218:a5af:5c43 with SMTP id x20-20020a17090a8a9400b00218a5af5c43ls20500586pjn.3.-pod-control-gmail; Tue, 13 Dec 2022 04:53:22 -0800 (PST) X-Google-Smtp-Source: AA0mqf4DeXdfSXKuLw2B1LCpFbn9+q/Dqam2xuM8rsck8vraY5hd92ttcl1uR9ARg3oZ/bKMDxOY X-Received: by 2002:a17:902:7598:b0:188:92d6:49c8 with SMTP id j24-20020a170902759800b0018892d649c8mr20858246pll.48.1670936002854; Tue, 13 Dec 2022 04:53:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1670936002; cv=none; d=google.com; s=arc-20160816; b=f8oHV6cziycIJc7Bfic3R3GqUt0CAzyO7njAqvlRJNdrgR2ycQONK2CXzTKjZmtGEg hvKe7qTr+fWPrm/UskqsYomx/7uoPiq/ZMUozSRYnBLjPEQJRPNkgS1ADd8HdWs9Q6DQ RkS66GEzHVgVVP58dlBSfBaT2F5tEbLDPg+nXvamXS2v097i/95EnNeNYiEJ3AxYmyr9 ytUk+krDuWWJv4CnEHzDh5uv6KgL79ke4DU1uQXoSFSCVsrrbqQBs00WiXxMvNNbxdpQ NaZgREAPYCxf2zGQAQMUmMIYaHtCcbXMwmrFvYoyqAQE4O9ct6Pvak66A4SksfKf1uzz 8x0g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=message-id:date:subject:cc:to:from; bh=JVYbsoUeehQdEdl0G0QQgiuzvFh4MRjRZwYqD4ystps=; b=PQJTygqPx1DtN7MNCSw5evd+d5/g9QXhU/1TVnO3BvKidKtDkiknVymVXv/RRyZMHO 26cZ0nEL8aR2LGB8yIxsdezYqbJmwYrNokjQALJ7T1WlNDIxgBV/Uqi/VgYU4KJeblC+ EoGNTONLnEfrFn3G60zd9/z0/8tvuuV/X/IviqCzy5YzXdZkb3anHHVdcsahOhuW1ufA 2APJGFq1lBsqHcNEibnyeIX/Dsv+T5q+2Zj9vAVpklWRnnfZL8NC4WG9appA1cPrCVGg GmoG+6mwGjpFUb7yZfrHbEO2oyiXRqtPhO/o1PqDzrW0Y78n8PALdvnWUGZxF/fnYvhl dnqA== ARC-Authentication-Results: i=1; gmr-mx.google.com; spf=pass (google.com: domain of amikan@ilbers.de designates 85.214.156.166 as permitted sender) smtp.mailfrom=amikan@ilbers.de Return-Path: Received: from shymkent.ilbers.de (shymkent.ilbers.de. [85.214.156.166]) by gmr-mx.google.com with ESMTPS id l18-20020a170902d35200b0018941ac5cc9si763620plk.3.2022.12.13.04.53.22 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 13 Dec 2022 04:53:22 -0800 (PST) Received-SPF: pass (google.com: domain of amikan@ilbers.de designates 85.214.156.166 as permitted sender) client-ip=85.214.156.166; Authentication-Results: gmr-mx.google.com; spf=pass (google.com: domain of amikan@ilbers.de designates 85.214.156.166 as permitted sender) smtp.mailfrom=amikan@ilbers.de Received: from alena-nb.promwad.com ([194.49.52.147]) (authenticated bits=0) by shymkent.ilbers.de (8.15.2/8.15.2/Debian-8+deb9u1) with ESMTPSA id 2BDCrDuS001200 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 13 Dec 2022 13:53:17 +0100 From: Anton Mikanovich To: isar-users@googlegroups.com Cc: Anton Mikanovich Subject: [PATCH v6 00/21] Migrate to Bitbake 2.0 Date: Tue, 13 Dec 2022 15:52:44 +0300 Message-Id: <20221213125305.10984-1-amikan@ilbers.de> X-Mailer: git-send-email 2.17.1 X-Spam-Status: No, score=-0.5 required=5.0 tests=ALL_TRUSTED,URI_NOVOWEL autolearn=unavailable autolearn_force=no version=3.4.2 X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on shymkent.ilbers.de X-TUID: 1wxWmD9hAd/C This patchset moves Isar to use Bitbake 2.0 branch. scripts/contrib/convert-overrides.py is the script for overrides update and it needs some testing on downstream layers. Usage: $ ./scripts/contrib/convert-overrides.py meta-customlayer Changes since v5: - Rebase on next - Document sstate migration to zstd Changes since v4: - Rebase on next - Use Bitbake 2.0.5 / Yocto 4.0.5 - Fix hash exclude variables - Add try/catch into sstate maintenance script - Fix overrides conversion script chmod - Fix clean task - Some commits reorder and rewording Changes since v3: - Rebase on next - Add network flag for do_containerize - Update imagetypes variables in override script - Update RECIPE-API-CHANGELOG Changes since v2: - Fixed building of stretch targets Changes since v1: - Rebased on top of sbuild - Resolved 'metadata is not deterministic' issues - Update sstate class and maintenance script - Update OE classes - Adopt CI configuration Anton Mikanovich (21): meta: change deprecated parse calls scripts/contrib: Add override conversion script scripts/contrib: configure override conversion script meta-isar: set default branch names meta: remove non recommended syntax bitbake: Update to Bitbake 2.0.5 doc: require zstd tool meta: update bitbake variables bitbake.conf: align hash vars with openembedded meta: mark network and sudo tasks meta: update overrides syntax sstate: update bbclass bitbake.conf: declare default XZ and ZSTD options Revert "devshell: Use different termination test to avoid warnings" meta: align with OE-core libraries update Revert "Revert "devshell: Use different termination test to avoid warnings"" CI: Adopt tests to syntax change isar-sstate: adopt sstate maintenance script RECIPE-API-CHANGELOG: Add tips after bitbake version update Revert "bitbake: Make 3.6.0 the minimum python version" Revert "utils/ply: Change md5 usages to work on FIPS enabled hosts" RECIPE-API-CHANGELOG.md | 22 + bitbake/README | 21 +- bitbake/bin/bitbake | 4 +- bitbake/bin/bitbake-diffsigs | 5 +- bitbake/bin/bitbake-getvar | 50 ++ bitbake/bin/bitbake-hashclient | 2 + bitbake/bin/bitbake-hashserv | 2 + bitbake/bin/bitbake-layers | 2 + bitbake/bin/bitbake-prserv | 8 +- bitbake/bin/bitbake-selftest | 3 + bitbake/bin/bitbake-server | 3 +- bitbake/bin/bitbake-worker | 23 +- bitbake/bin/git-make-shallow | 4 + bitbake/bin/toaster | 6 +- bitbake/bin/toaster-eventreplay | 2 + bitbake/conf/bitbake.conf | 6 +- bitbake/contrib/hashserv/Dockerfile | 6 +- bitbake/contrib/prserv/Dockerfile | 62 ++ bitbake/contrib/vim/plugin/newbbappend.vim | 2 +- bitbake/contrib/vim/syntax/bitbake.vim | 11 +- bitbake/doc/Makefile | 2 +- bitbake/doc/README | 6 +- .../bitbake-user-manual-execution.rst | 112 ++-- .../bitbake-user-manual-fetching.rst | 229 +++++-- .../bitbake-user-manual-hello.rst | 60 +- .../bitbake-user-manual-intro.rst | 64 +- .../bitbake-user-manual-metadata.rst | 493 +++++++-------- .../bitbake-user-manual-ref-variables.rst | 583 ++++++++++-------- bitbake/doc/releases.rst | 84 ++- bitbake/lib/bb/COW.py | 2 + bitbake/lib/bb/__init__.py | 15 +- bitbake/lib/bb/asyncrpc/__init__.py | 33 + bitbake/lib/bb/asyncrpc/client.py | 178 ++++++ bitbake/lib/bb/asyncrpc/serv.py | 288 +++++++++ bitbake/lib/bb/build.py | 104 ++-- bitbake/lib/bb/cache.py | 35 +- bitbake/lib/bb/checksum.py | 22 +- bitbake/lib/bb/codeparser.py | 22 +- bitbake/lib/bb/command.py | 36 +- bitbake/lib/bb/compress/_pipecompress.py | 196 ++++++ bitbake/lib/bb/compress/lz4.py | 19 + bitbake/lib/bb/compress/zstd.py | 30 + bitbake/lib/bb/cooker.py | 298 +++++---- bitbake/lib/bb/cookerdata.py | 47 +- bitbake/lib/bb/daemonize.py | 44 +- bitbake/lib/bb/data.py | 59 +- bitbake/lib/bb/data_smart.py | 213 ++++--- bitbake/lib/bb/event.py | 16 +- bitbake/lib/bb/exceptions.py | 2 + bitbake/lib/bb/fetch2/README | 57 ++ bitbake/lib/bb/fetch2/__init__.py | 138 +++-- bitbake/lib/bb/fetch2/crate.py | 136 ++++ bitbake/lib/bb/fetch2/git.py | 54 +- bitbake/lib/bb/fetch2/gitsm.py | 25 +- bitbake/lib/bb/fetch2/npm.py | 52 +- bitbake/lib/bb/fetch2/npmsw.py | 33 +- bitbake/lib/bb/fetch2/osc.py | 20 +- bitbake/lib/bb/fetch2/s3.py | 41 +- bitbake/lib/bb/fetch2/ssh.py | 49 +- bitbake/lib/bb/fetch2/svn.py | 10 +- bitbake/lib/bb/fetch2/wget.py | 161 +++-- bitbake/lib/bb/main.py | 9 +- bitbake/lib/bb/monitordisk.py | 17 +- bitbake/lib/bb/msg.py | 32 +- bitbake/lib/bb/parse/__init__.py | 2 + bitbake/lib/bb/parse/ast.py | 14 +- bitbake/lib/bb/parse/parse_py/BBHandler.py | 7 +- bitbake/lib/bb/parse/parse_py/ConfHandler.py | 16 +- bitbake/lib/bb/persist_data.py | 54 +- bitbake/lib/bb/process.py | 4 +- bitbake/lib/bb/progress.py | 9 +- bitbake/lib/bb/providers.py | 14 +- bitbake/lib/bb/runqueue.py | 284 +++++---- bitbake/lib/bb/server/process.py | 47 +- bitbake/lib/bb/server/xmlrpcserver.py | 1 + bitbake/lib/bb/siggen.py | 186 ++++-- bitbake/lib/bb/taskdata.py | 14 +- bitbake/lib/bb/tests/codeparser.py | 28 +- bitbake/lib/bb/tests/compression.py | 100 +++ bitbake/lib/bb/tests/cooker.py | 2 + bitbake/lib/bb/tests/data.py | 95 +-- .../debian/pool/main/m/minicom/index.html | 59 ++ bitbake/lib/bb/tests/fetch.py | 533 ++++++++++------ bitbake/lib/bb/tests/parse.py | 43 +- .../bb/tests/runqueue-tests/conf/bitbake.conf | 2 +- bitbake/lib/bb/tests/runqueue.py | 52 +- bitbake/lib/bb/tests/utils.py | 20 +- bitbake/lib/bb/tinfoil.py | 12 +- bitbake/lib/bb/ui/buildinfohelper.py | 83 +-- bitbake/lib/bb/ui/knotty.py | 100 +-- bitbake/lib/bb/ui/taskexp.py | 5 + bitbake/lib/bb/ui/uievent.py | 6 +- bitbake/lib/bb/ui/uihelper.py | 4 +- bitbake/lib/bb/utils.py | 159 ++++- bitbake/lib/bblayers/__init__.py | 2 + bitbake/lib/bblayers/action.py | 4 +- bitbake/lib/bblayers/common.py | 2 + bitbake/lib/bblayers/layerindex.py | 18 +- bitbake/lib/bblayers/query.py | 10 +- bitbake/lib/codegen.py | 6 + bitbake/lib/hashserv/__init__.py | 66 +- bitbake/lib/hashserv/client.py | 152 +---- bitbake/lib/hashserv/server.py | 549 ++++++++--------- bitbake/lib/hashserv/tests.py | 161 ++++- bitbake/lib/layerindexlib/__init__.py | 9 +- bitbake/lib/layerindexlib/cooker.py | 2 +- bitbake/lib/layerindexlib/restapi.py | 4 +- bitbake/lib/layerindexlib/tests/restapi.py | 2 +- bitbake/lib/prserv/__init__.py | 2 + bitbake/lib/prserv/client.py | 50 ++ bitbake/lib/prserv/db.py | 67 +- bitbake/lib/prserv/serv.py | 542 ++++++---------- bitbake/lib/pyinotify.py | 44 +- .../bldcontrol/localhostbecontroller.py | 4 +- .../management/commands/runbuilds.py | 83 ++- .../migrations/0008_models_bigautofield.py | 48 ++ bitbake/lib/toaster/manage.py | 2 + .../lib/toaster/orm/fixtures/gen_fixtures.py | 445 +++++++++++++ bitbake/lib/toaster/orm/fixtures/oe-core.xml | 48 +- bitbake/lib/toaster/orm/fixtures/poky.xml | 118 ++-- bitbake/lib/toaster/orm/fixtures/settings.xml | 2 +- .../orm/management/commands/lsupdates.py | 14 +- .../migrations/0020_models_bigautofield.py | 173 ++++++ bitbake/lib/toaster/orm/models.py | 5 +- .../toaster/toastergui/templates/base.html | 2 +- .../toastergui/templates/configvars.html | 2 +- .../toaster/toastergui/templates/landing.html | 6 +- .../templates/landing_not_managed.html | 34 - .../toastergui/templates/layerdetails.html | 2 +- .../templates/package_detail_base.html | 2 +- .../toaster/toastergui/templates/project.html | 2 +- .../templates/project_specific.html | 2 +- .../toastergui/templates/projectconf.html | 34 +- bitbake/lib/toaster/toastergui/views.py | 22 +- .../management/commands/buildimport.py | 2 +- bitbake/lib/toaster/toastermain/settings.py | 3 + bitbake/toaster-requirements.txt | 2 +- doc/user_manual.md | 3 +- meta-isar/classes/rpi-sdimg.bbclass | 4 +- meta-isar/classes/ubi-ubifs-img.bbclass | 6 +- meta-isar/conf/distro/raspios-bullseye.conf | 8 +- meta-isar/conf/distro/ubuntu-focal.conf | 4 +- meta-isar/conf/local.conf.sample | 8 +- meta-isar/conf/machine/de0-nano-soc.conf | 4 +- meta-isar/conf/machine/hikey.conf | 2 +- meta-isar/conf/machine/phyboard-mira.conf | 2 +- meta-isar/conf/machine/qemuamd64.conf | 6 +- meta-isar/conf/machine/qemuarm64.conf | 2 +- meta-isar/conf/machine/qemuriscv64.conf | 2 +- meta-isar/conf/machine/stm32mp15x.conf | 4 +- .../conf/multiconfig/qemuamd64-bullseye.conf | 2 +- .../conf/multiconfig/qemuarm-bookworm.conf | 2 +- meta-isar/recipes-app/cowsay/cowsay_git.bb | 2 +- .../recipes-app/hello-isar/hello-isar.bb | 4 +- meta-isar/recipes-app/libhello/libhello.bb | 4 +- .../bootconfig-rpi/bootconfig-rpi.bb | 6 +- .../optee-os/optee-os-stm32mp15x_3.11.0.bb | 2 +- .../linux/linux-cip_4.4.166-cip29.bb | 2 +- .../linux/linux-mainline_5.4.203.bb | 4 +- .../linux/linux-phy_5.10.76-phy4.bb | 2 +- meta/classes/base.bbclass | 1 + meta/classes/dpkg-base.bbclass | 10 +- meta/classes/dpkg-gbp.bbclass | 2 +- meta/classes/dpkg-prebuilt.bbclass | 2 +- meta/classes/dpkg.bbclass | 2 +- meta/classes/image-locales-extension.bbclass | 2 + meta/classes/image-tools-extension.bbclass | 1 + meta/classes/image.bbclass | 38 +- meta/classes/imagetypes.bbclass | 59 +- meta/classes/imagetypes_container.bbclass | 5 +- meta/classes/imagetypes_vm.bbclass | 10 +- meta/classes/imagetypes_wic.bbclass | 5 +- meta/classes/rootfs.bbclass | 7 +- meta/classes/sdk.bbclass | 30 +- meta/classes/sstate.bbclass | 249 ++++---- meta/conf/bitbake.conf | 69 ++- meta/conf/distro/debian-common.conf | 16 +- meta/conf/distro/debian-stretch.conf | 4 +- meta/lib/oe/gpg_sign.py | 35 +- meta/lib/oe/maketype.py | 7 +- meta/lib/oe/patch.py | 52 +- meta/lib/oe/path.py | 79 +++ meta/lib/oe/sstatesig.py | 131 ++-- meta/lib/oe/terminal.py | 33 +- meta/lib/oe/utils.py | 67 +- meta/recipes-bsp/barebox/barebox.inc | 2 +- .../libubootenv/libubootenv_0.3-3.bb | 2 +- meta/recipes-bsp/optee-os/optee-os-custom.inc | 2 +- .../trusted-firmware-a-custom.inc | 2 +- meta/recipes-bsp/u-boot/u-boot-custom.inc | 2 +- .../isar-bootstrap/isar-bootstrap.inc | 14 +- .../buildchroot/buildchroot-host.bb | 2 +- .../buildchroot/buildchroot.inc | 6 +- .../sbuild-chroot/sbuild-chroot.inc | 2 +- meta/recipes-kernel/kselftest/kselftest.inc | 6 +- meta/recipes-kernel/linux-module/module.inc | 2 +- meta/recipes-kernel/linux/linux-custom.inc | 12 +- scripts/contrib/convert-overrides.py | 145 +++++ scripts/isar-buildenv-internal | 4 +- scripts/isar-sstate | 70 +-- testsuite/cibuilder.py | 8 +- testsuite/citest.py | 2 +- 202 files changed, 6993 insertions(+), 3365 deletions(-) create mode 100755 bitbake/bin/bitbake-getvar create mode 100644 bitbake/contrib/prserv/Dockerfile create mode 100644 bitbake/lib/bb/asyncrpc/__init__.py create mode 100644 bitbake/lib/bb/asyncrpc/client.py create mode 100644 bitbake/lib/bb/asyncrpc/serv.py create mode 100644 bitbake/lib/bb/compress/_pipecompress.py create mode 100644 bitbake/lib/bb/compress/lz4.py create mode 100644 bitbake/lib/bb/compress/zstd.py create mode 100644 bitbake/lib/bb/fetch2/README create mode 100644 bitbake/lib/bb/fetch2/crate.py create mode 100644 bitbake/lib/bb/tests/compression.py create mode 100644 bitbake/lib/bb/tests/fetch-testdata/debian/pool/main/m/minicom/index.html create mode 100644 bitbake/lib/prserv/client.py create mode 100644 bitbake/lib/toaster/bldcontrol/migrations/0008_models_bigautofield.py create mode 100755 bitbake/lib/toaster/orm/fixtures/gen_fixtures.py create mode 100644 bitbake/lib/toaster/orm/migrations/0020_models_bigautofield.py delete mode 100644 bitbake/lib/toaster/toastergui/templates/landing_not_managed.html create mode 100755 scripts/contrib/convert-overrides.py -- 2.17.1