Page MenuHomeFreeBSD

release: Use the ABI of the target release to fetch packages
ClosedPublic

Authored by jhb on Apr 11 2024, 5:44 PM.
Tags
None
Referenced Files
F107092068: D44749.diff
Thu, Jan 9, 11:51 PM
Unknown Object (File)
Mon, Jan 6, 4:18 AM
Unknown Object (File)
Mon, Dec 16, 5:40 PM
Unknown Object (File)
Dec 6 2024, 11:08 AM
Unknown Object (File)
Dec 5 2024, 7:08 PM
Unknown Object (File)
Nov 28 2024, 8:12 AM
Unknown Object (File)
Oct 24 2024, 3:00 AM
Unknown Object (File)
Oct 4 2024, 3:25 AM
Subscribers

Details

Summary
  • Point --rootdir at the installed destdir in the dvd tree. This causes pkg to determine the ABI from the installed destdir instead of the host's binaries. Previously the result was that packages for the host's ABI were always downloaded breaking cross-releases (e.g. arm64 releases built on an amd64 host included amd64 packages on the DVD ISO image rather than arm64 packages). This also handles version mismatches, and I tested this by cross-building a 15.x arm64 release on a 14.x amd64 host.
  • As a result, pkg now does a chdir(3) to the rootdir before running, so the -o argument to fetch needs to be updated to be relative to rootdir instead of the CWD as make runs.
  • Add a new ROOTDIR variable to limit references to "dvd" to one place. Ideally ROOTDIR would be an argument to this script so that it didn't really know about the dvd layout at all.
  • While here, simplify creation of symlinks by just using a longer path to the link name instead of using 'cd' in the shell before invoking ln(1). Also use ln -sf to create the pkg.pkg symlink rather than rm + ln.

PR: 278273
Reported by: gatekeeper <tiago.gasiba@gmail.com>

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 57040
Build 53928: arc lint + arc unit

Event Timeline

jhb requested review of this revision.Apr 11 2024, 5:44 PM
release/scripts/pkg-stage.sh
12

The pkg config invocations need to leave out the -d. We could choose to pass -d explicitly to the later pkg invocations instead perhaps which would allow the pkg config invocations to use PKGCMD directly limiting the places that need the explicit --rootdir.

I'm also not sure how helpful the -d messages really are in practice. They seemed quite verbose in my testing.

58

If it is helpful I could split out the changes to remove cd into a single commit prior to this current commit.

These seem reasonable, but I don't know pkg pedantically enough to know if they are completely correct or not.

This revision is now accepted and ready to land.Apr 11 2024, 7:26 PM
delphij added a subscriber: delphij.
delphij added inline comments.
release/scripts/pkg-stage.sh
88

maybe just use the variable?

release/scripts/pkg-stage.sh
88

Oh, yes.