Message ID | 20251016111628.3050999-1-ecordonnier@snap.com |
---|---|
State | New |
Headers | show |
Series | [v2] opkg: upgrade 0.7.0 -> 0.9.0 | expand |
On Thu Oct 16, 2025 at 1:16 PM CEST, Etienne Cordonnier via lists.openembedded.org wrote: > From: Etienne Cordonnier <ecordonnier@snap.com> > > See release notes at > - http://downloads.yoctoproject.org/releases/opkg/opkg-0.9.0.release-notes > - http://downloads.yoctoproject.org/releases/opkg/opkg-0.8.0.release-notes > > [0.9.0] - 2025-06-27 > > Semiannual opkg release. > Bumping the minor version as a result of the project build tooling changing from autotools to cmake. > > - Added a Dockerfile container definition (`:docker/`) for a valid developer build environment for opkg. > - It's recommended that project contributors use this container to build and test their changes. > - The AutoTools-based build framework has [been replaced](https://git.yoctoproject.org/opkg/commit/?id=3f6040e321634471ec442fb0e80f140f1437e90b) with a more modern, CMake framework. > - Refer to the `docs/CONTRIBUTING.md` documentation for updated build instructions. > > [0.8.0] - 2025-01-10 > > The minor version bump in this release is due to the changes to cURL error output line format. > > - [Changed](https://git.yoctoproject.org/opkg/commit/?id=ab03377868256427279b36c4b2a298edae4260b8) the error output for the curl download backend, to now report the HTTP error code for failed requests. > - e.g. `error: log_curl_download_error: Failed to download headers of https://foo.bar/all/Packages.gz: The requested URL returned error: 401` > - Enabling debug-verbosity, while using the cURL backend, [will now](https://git.yoctoproject.org/opkg/commit/?id=ce6fede3db931bb0da70d1334cdc4101d0aec702) print cURL's verbose error log to stderr when there is a download failure. > - The verbose output may contain confidential information about your cURL transactions. So this is your reminder that debug-verbosity should not be enabled in production systems or sensitive security environments. > - The commandline configuration file option (`-f`) [can now](https://git.yoctoproject.org/opkg/commit/?id=36d08b93d2859992b624a4ba2f412cfa5c766050) be specified multiple times, and each configuration file will be loaded and their settings merged. > - [Fixed](https://git.yoctoproject.org/opkg/commit/?id=c87188d7535684fddb8cf80993c147b215602b63) a bug in control field parsing where custom fields whose keys are similar to other fields could be confused by the parser. > > Signed-off-by: Etienne Cordonnier <ecordonnier@snap.com> > --- Hi Etienne, Thanks for the new version. However we now have another issue: ERROR: core-image-sato-1.0-r0 do_rootfs: Unable to install packages. Command '/srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/recipe-sysroot-native/usr/bin/opkg --volatile-cache -f /srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/opkg.conf -t /srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/temp/ipktemp/ -o /srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/rootfs --force-postinstall --prefer-arch-to-version install locale-base-c locale-base-en-gb locale-base-en-us' returned 255: error: pkg_extract_data_file_names_to_stream: Failed to extract data.tar.* from package '/srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/rootfs//var/cache/opkg/volatile.121547/938adf05ba43d7b754c8c03468af836d_glibc-binary-localedata-c_2.42+git-r0_cortexa57.ipk'. error: pkg_get_installed_files: Error extracting file list from /srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/rootfs//var/cache/opkg/volatile.121547/938adf05ba43d7b754c8c03468af836d_glibc-binary-localedata-c_2.42+git-r0_cortexa57.ipk. Installing glibc-binary-localedata-c (2.42+git) on root Downloading file:/srv/pokybuild/yocto-worker/qemuarm64-alt/build/build/tmp/work/qemuarm64-poky-linux/core-image-sato/1.0/oe-rootfs-repo/cortexa57/glibc-binary-localedata-c_2.42+git-r0_cortexa57.ipk. https://autobuilder.yoctoproject.org/valkyrie/#/builders/9/builds/2584 https://autobuilder.yoctoproject.org/valkyrie/#/builders/20/builds/2576 https://autobuilder.yoctoproject.org/valkyrie/#/builders/22/builds/2629 https://autobuilder.yoctoproject.org/valkyrie/#/builders/65/builds/2594 https://autobuilder.yoctoproject.org/valkyrie/#/builders/74/builds/2582 https://autobuilder.yoctoproject.org/valkyrie/#/builders/93/builds/2600 Can you have a look at what is the issue here? Thanks, Mathieu
Hi Etienne Can you split the patch in two commits for each version. Etienne Cordonnier via lists.openembedded.org <ecordonnier= snap.com@lists.openembedded.org> escreveu (quinta, 16/10/2025 à(s) 12:18): > From: Etienne Cordonnier <ecordonnier@snap.com> > > See release notes at > - http://downloads.yoctoproject.org/releases/opkg/opkg-0.9.0.release-notes > - http://downloads.yoctoproject.org/releases/opkg/opkg-0.8.0.release-notes > > [0.9.0] - 2025-06-27 > > Semiannual opkg release. > Bumping the minor version as a result of the project build tooling > changing from autotools to cmake. > > - Added a Dockerfile container definition (`:docker/`) for a valid > developer build environment for opkg. > - It's recommended that project contributors use this container to build > and test their changes. > - The AutoTools-based build framework has [been replaced]( > https://git.yoctoproject.org/opkg/commit/?id=3f6040e321634471ec442fb0e80f140f1437e90b) > with a more modern, CMake framework. > - Refer to the `docs/CONTRIBUTING.md` documentation for updated build > instructions. > > [0.8.0] - 2025-01-10 > > The minor version bump in this release is due to the changes to cURL error > output line format. > > - [Changed]( > https://git.yoctoproject.org/opkg/commit/?id=ab03377868256427279b36c4b2a298edae4260b8) > the error output for the curl download backend, to now report the HTTP > error code for failed requests. > - e.g. `error: log_curl_download_error: Failed to download headers of > https://foo.bar/all/Packages.gz: The requested URL returned error: 401` > - Enabling debug-verbosity, while using the cURL backend, [will now]( > https://git.yoctoproject.org/opkg/commit/?id=ce6fede3db931bb0da70d1334cdc4101d0aec702) > print cURL's verbose error log to stderr when there is a download failure. > - The verbose output may contain confidential information about your > cURL transactions. So this is your reminder that debug-verbosity should not > be enabled in production systems or sensitive security environments. > - The commandline configuration file option (`-f`) [can now]( > https://git.yoctoproject.org/opkg/commit/?id=36d08b93d2859992b624a4ba2f412cfa5c766050) > be specified multiple times, and each configuration file will be loaded and > their settings merged. > - [Fixed]( > https://git.yoctoproject.org/opkg/commit/?id=c87188d7535684fddb8cf80993c147b215602b63) > a bug in control field parsing where custom fields whose keys are similar > to other fields could be confused by the parser. > > Signed-off-by: Etienne Cordonnier <ecordonnier@snap.com> > --- > meta/recipes-devtools/opkg/opkg/run-ptest | 3 +-- > .../opkg/{opkg_0.7.0.bb => opkg_0.9.0.bb} | 21 +++++++++++-------- > 2 files changed, 13 insertions(+), 11 deletions(-) > rename meta/recipes-devtools/opkg/{opkg_0.7.0.bb => opkg_0.9.0.bb} (77%) > > diff --git a/meta/recipes-devtools/opkg/opkg/run-ptest > b/meta/recipes-devtools/opkg/opkg/run-ptest > index 5fb7077eec9..8cf09adba57 100644 > --- a/meta/recipes-devtools/opkg/opkg/run-ptest > +++ b/meta/recipes-devtools/opkg/opkg/run-ptest > @@ -1,5 +1,4 @@ > #!/bin/sh > > OPKG_PATH=$(which opkg) > - > -make OPKG_PATH=$OPKG_PATH run-tests > +make -C tests DATADIR=/share SYSCONFDIR=/etc VARDIR=/var > OPKG_PATH=$OPKG_PATH > diff --git a/meta/recipes-devtools/opkg/opkg_0.7.0.bb > b/meta/recipes-devtools/opkg/opkg_0.9.0.bb > similarity index 77% > rename from meta/recipes-devtools/opkg/opkg_0.7.0.bb > rename to meta/recipes-devtools/opkg/opkg_0.9.0.bb > index 95480b47164..9fa32268541 100644 > --- a/meta/recipes-devtools/opkg/opkg_0.7.0.bb > +++ b/meta/recipes-devtools/opkg/opkg_0.9.0.bb > @@ -18,31 +18,31 @@ SRC_URI = " > http://downloads.yoctoproject.org/releases/${BPN}/${BPN}-${PV}.tar.gz > file://run-ptest \ > " > > -SRC_URI[sha256sum] = > "d973fd0f1568f58f87d6aecd9aa95e3e1f60214a45cee26704bf8fe757c54567" > +SRC_URI[sha256sum] = > "440ef321862e01f83da4d02884a0cbb4d9d7b32f82faa81a6a85493f0c89d0f5" > > # This needs to be before ptest inherit, otherwise all ptest files end > packaged > # in libopkg package if OPKGLIBDIR == libdir, because default > # PTEST_PATH ?= "${libdir}/${BPN}/ptest" > PACKAGES =+ "libopkg" > > -inherit autotools pkgconfig ptest > +inherit cmake pkgconfig ptest > > target_localstatedir := "${localstatedir}" > OPKGLIBDIR ??= "${target_localstatedir}/lib" > > PACKAGECONFIG ??= "libsolv" > > -PACKAGECONFIG[gpg] = "--enable-gpg,--disable-gpg,\ > +PACKAGECONFIG[gpg] = "-DWITH_GPGME=ON,-DWITH_GPGME=OFF,\ > gnupg gpgme libgpg-error,\ > ${@ "gnupg" if ("native" in d.getVar("PN")) else "gnupg-gpg"}\ > " > -PACKAGECONFIG[curl] = "--enable-curl,--disable-curl,curl" > -PACKAGECONFIG[ssl-curl] = "--enable-ssl-curl,--disable-ssl-curl,curl > openssl" > -PACKAGECONFIG[sha256] = "--enable-sha256,--disable-sha256" > -PACKAGECONFIG[libsolv] = "--with-libsolv,--without-libsolv,libsolv" > +PACKAGECONFIG[curl] = "-DWITH_CURL=0N,-DWITH_CURL=OFF,curl" > +PACKAGECONFIG[ssl-curl] = "-DWITH_SSLCURL=ON,-DWITH_SSLCURL=OFF,curl > openssl" > +PACKAGECONFIG[sha256] = "-DWITH_SHA256=ON,-DWITH_SHA256=OFF" > +PACKAGECONFIG[libsolv] = > "-DUSE_SOLVER_LIBSOLV=ON,-DUSE_SOLVER_LIBSOLV=OFF,libsolv" > > -EXTRA_OECONF = "--enable-zstd" -EXTRA_OECONF:append:class-native = " > --localstatedir=/${@os.path.relpath('${localstatedir}', > '${STAGING_DIR_NATIVE}')} --sysconfdir=/${@os.path.relpath('${sysconfdir}', > '${STAGING_DIR_NATIVE}')}" > +EXTRA_OECMAKE = "-DWITH_ZSTD=ON" > I wonder if we shouldn't also disable the XZ which is enabled by default and we don't use it. Jose > +EXTRA_OECMAKE:append:class-native = " > -DVARDIR=/${@os.path.relpath('${localstatedir}', '${STAGING_DIR_NATIVE}')} > -DSYSCONFDIR=/${@os.path.relpath('${sysconfdir}', '${STAGING_DIR_NATIVE}')}" > > do_install:append () { > install -d ${D}${sysconfdir}/opkg > @@ -56,6 +56,9 @@ do_install:append () { > } > > do_install_ptest () { > + # the ptest class uses a Makefile for installation, but cmake uses > Ninja per default so we need to install ptests manually: > + cp -r ${S}/tests ${D}${PTEST_PATH} > + > sed -i -e '/@echo $^/d' ${D}${PTEST_PATH}/tests/Makefile > sed -i -e '/@PYTHONPATH=. $(PYTHON) $^/a\\t@if [ "$$?" != "0" > ];then echo "FAIL:"$^;else echo "PASS:"$^;fi' > ${D}${PTEST_PATH}/tests/Makefile > } > -- > 2.43.0 > > > -=-=-=-=-=-=-=-=-=-=-=- > Links: You receive all messages sent to this group. > View/Reply Online (#224962): > https://lists.openembedded.org/g/openembedded-core/message/224962 > Mute This Topic: https://lists.openembedded.org/mt/115787032/5052612 > Group Owner: openembedded-core+owner@lists.openembedded.org > Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [ > quaresma.jose@gmail.com] > -=-=-=-=-=-=-=-=-=-=-=- > >
diff --git a/meta/recipes-devtools/opkg/opkg/run-ptest b/meta/recipes-devtools/opkg/opkg/run-ptest index 5fb7077eec9..8cf09adba57 100644 --- a/meta/recipes-devtools/opkg/opkg/run-ptest +++ b/meta/recipes-devtools/opkg/opkg/run-ptest @@ -1,5 +1,4 @@ #!/bin/sh OPKG_PATH=$(which opkg) - -make OPKG_PATH=$OPKG_PATH run-tests +make -C tests DATADIR=/share SYSCONFDIR=/etc VARDIR=/var OPKG_PATH=$OPKG_PATH diff --git a/meta/recipes-devtools/opkg/opkg_0.7.0.bb b/meta/recipes-devtools/opkg/opkg_0.9.0.bb similarity index 77% rename from meta/recipes-devtools/opkg/opkg_0.7.0.bb rename to meta/recipes-devtools/opkg/opkg_0.9.0.bb index 95480b47164..9fa32268541 100644 --- a/meta/recipes-devtools/opkg/opkg_0.7.0.bb +++ b/meta/recipes-devtools/opkg/opkg_0.9.0.bb @@ -18,31 +18,31 @@ SRC_URI = "http://downloads.yoctoproject.org/releases/${BPN}/${BPN}-${PV}.tar.gz file://run-ptest \ " -SRC_URI[sha256sum] = "d973fd0f1568f58f87d6aecd9aa95e3e1f60214a45cee26704bf8fe757c54567" +SRC_URI[sha256sum] = "440ef321862e01f83da4d02884a0cbb4d9d7b32f82faa81a6a85493f0c89d0f5" # This needs to be before ptest inherit, otherwise all ptest files end packaged # in libopkg package if OPKGLIBDIR == libdir, because default # PTEST_PATH ?= "${libdir}/${BPN}/ptest" PACKAGES =+ "libopkg" -inherit autotools pkgconfig ptest +inherit cmake pkgconfig ptest target_localstatedir := "${localstatedir}" OPKGLIBDIR ??= "${target_localstatedir}/lib" PACKAGECONFIG ??= "libsolv" -PACKAGECONFIG[gpg] = "--enable-gpg,--disable-gpg,\ +PACKAGECONFIG[gpg] = "-DWITH_GPGME=ON,-DWITH_GPGME=OFF,\ gnupg gpgme libgpg-error,\ ${@ "gnupg" if ("native" in d.getVar("PN")) else "gnupg-gpg"}\ " -PACKAGECONFIG[curl] = "--enable-curl,--disable-curl,curl" -PACKAGECONFIG[ssl-curl] = "--enable-ssl-curl,--disable-ssl-curl,curl openssl" -PACKAGECONFIG[sha256] = "--enable-sha256,--disable-sha256" -PACKAGECONFIG[libsolv] = "--with-libsolv,--without-libsolv,libsolv" +PACKAGECONFIG[curl] = "-DWITH_CURL=0N,-DWITH_CURL=OFF,curl" +PACKAGECONFIG[ssl-curl] = "-DWITH_SSLCURL=ON,-DWITH_SSLCURL=OFF,curl openssl" +PACKAGECONFIG[sha256] = "-DWITH_SHA256=ON,-DWITH_SHA256=OFF" +PACKAGECONFIG[libsolv] = "-DUSE_SOLVER_LIBSOLV=ON,-DUSE_SOLVER_LIBSOLV=OFF,libsolv" -EXTRA_OECONF = "--enable-zstd" -EXTRA_OECONF:append:class-native = " --localstatedir=/${@os.path.relpath('${localstatedir}', '${STAGING_DIR_NATIVE}')} --sysconfdir=/${@os.path.relpath('${sysconfdir}', '${STAGING_DIR_NATIVE}')}" +EXTRA_OECMAKE = "-DWITH_ZSTD=ON" +EXTRA_OECMAKE:append:class-native = " -DVARDIR=/${@os.path.relpath('${localstatedir}', '${STAGING_DIR_NATIVE}')} -DSYSCONFDIR=/${@os.path.relpath('${sysconfdir}', '${STAGING_DIR_NATIVE}')}" do_install:append () { install -d ${D}${sysconfdir}/opkg @@ -56,6 +56,9 @@ do_install:append () { } do_install_ptest () { + # the ptest class uses a Makefile for installation, but cmake uses Ninja per default so we need to install ptests manually: + cp -r ${S}/tests ${D}${PTEST_PATH} + sed -i -e '/@echo $^/d' ${D}${PTEST_PATH}/tests/Makefile sed -i -e '/@PYTHONPATH=. $(PYTHON) $^/a\\t@if [ "$$?" != "0" ];then echo "FAIL:"$^;else echo "PASS:"$^;fi' ${D}${PTEST_PATH}/tests/Makefile }