Page MenuHomeFreeBSD

net/wifi-firmware-*kmod: improve build logic, add flavors, update version
ClosedPublic

Authored by bz on Apr 25 2024, 2:39 PM.
Tags
None
Referenced Files
F108433376: D44945.id137804.diff
Fri, Jan 24, 5:48 PM
F108432930: D44945.id139016.diff
Fri, Jan 24, 5:45 PM
Unknown Object (File)
Mon, Jan 20, 9:44 PM
Unknown Object (File)
Sun, Jan 19, 1:09 PM
Unknown Object (File)
Nov 28 2024, 2:46 AM
Unknown Object (File)
Nov 24 2024, 10:14 PM
Unknown Object (File)
Nov 24 2024, 2:19 PM
Unknown Object (File)
Nov 22 2024, 9:59 PM

Details

Summary
  • update framework to no longer depend on local distfiles for firmware(9) but generate the Makefile hierarchy in post-extract. Keep a Makefile.inc.in in files for simplicity.
  • update extracting WHENCE parts using a local WHENCE.awk.in in files and a pattern to match the section(s).
  • use the already prepared FWSUBS sections for flavors and add the FWDRV as "default". Generate the CONFLICTS_INSTALL conflict and PKGNAMESUFFIX entries. Adjust paths and logic for flavors. Depend on the flavors rather the combined ("default flavor") packages by default if someone installs wifi-firmware-kmod. The wifi-firmware-${name}-kmod packages are still built for older versions of fwget shipping in releases.
  • add support for iwlwifi and ath12k firmware
  • update firmware to linux-firmware.git tag: 20240410 for all drivers.

TODOs for the next iteration (to ease review for the current changes):

  • use plain firmware files and no longer .ko where supported (currently in main)
  • add the logic to deal with different versions and sets of files in different branches; currently this is still the old "one size fits all" logic which currently likely works for all but iwlwifi but for that stable branches still have firmware in src so we should be good.

Sponsored by: The FreeBSD Foundation

Diff Detail

Repository
R11 FreeBSD ports repository
Lint
No Lint Coverage
Unit
No Test Coverage
Build Status
Buildable 57435
Build 54323: arc lint + arc unit

Event Timeline

bz requested review of this revision.Apr 25 2024, 2:39 PM
bz created this revision.
net/wifi-firmware-ath10k-kmod/Makefile
12–20

Flavors must be [a-z0-9_].

net/wifi-firmware-ath11k-kmod/Makefile
10–12

Flavors must be [a-z0-9_].

net/wifi-firmware-ath12k-kmod/Makefile
15

Flavors must be [a-z0-9_].

bz planned changes to this revision.Apr 25 2024, 8:37 PM
bz added inline comments.
net/wifi-firmware-ath10k-kmod/Makefile
12–20

Hmm I saw the comment somewhere (but probably did not think about that anymore).
Why does nothing in ports barf on this enforcing it but it "just work"?
I am probably asking the wrong questions.
Hmm show-dev-errors should barf.

DEV_ERROR+=             "FLAVORS contains flavors that are not all [a-z0-9_]: ${_BAD_FLAVOR_NAMES}"

I wonder which target I should have run and did not?

I'll go and fix...

net/wifi-firmware-kmod/Makefile
10–45

FLAVOR names MUSt be lower case here too then.

net/wifi-firmware-ath10k-kmod/Makefile
12–20

It does barf.

jrm@ser /usr/ports/net/wifi-firmware-ath12k-kmod [arcpatch-D44945|✔] % make
/!\ wifi-firmware-ath12k-kmod-20240410: Makefile errors /!\

FLAVORS contains flavors that are not all [a-z0-9_]: WCN7850_hw20

*** Error code 1

Stop.
make: stopped in /usr/ports/net/wifi-firmware-ath12k-kmod

Rebuild all the wifi-firmware flavors from scripts, this time hopefully with lower case names.

bz marked 4 inline comments as done.Apr 28 2024, 9:14 PM
bz added inline comments.
net/wifi-firmware-ath10k-kmod/Makefile
12–20

I did not get that error; and my shell script rebuilding things has set -e set so would also have stopped (and didn't).
I did check that I have work directories everywhere and things were built, but I indeed did not have packages for all of them.

Hope the update solves this.

The build now looks good to me. I asked a few minor questions below.

net/wifi-firmware-kmod/Makefile.inc
35

I'm unclear why this is necessary. bsd.port.mk includes

.    if !empty(FLAVORS) && empty(FLAVOR)
FLAVOR=	${FLAVORS:[1]}
.    endif
62–64

Can this simply be @${MKDIR} ${WRKSRC}/${FLAVOR}/fw?

bz marked 2 inline comments as done.Apr 30 2024, 6:36 PM
bz added inline comments.
net/wifi-firmware-kmod/Makefile.inc
35

Otherweise it wasn't properly set in the .for loop in post-extract. That was the case with or without the intermediate variable. Given the ports handbook suggests it and I saw the same in some Uses/ (?) file and it helped, it's there. If there is a better solution I am all for it but it needs someone understanding the internals, which I am not and I do not want to spend 3 hours on figuring it out if avoidable.

62–64

Is MKDIR in ports guaranteed to always do -p ? Hmm looks like ../Mk/bsd.commands.mk:MKDIR?= /bin/mkdir -p; I'll fold this into one line in a minute and update the review.

bz marked an inline comment as done.

fold the three $MKDIR into one as suggested by @jrm.

This revision is now accepted and ready to land.May 1 2024, 1:02 PM

Update firmware to 20240513 (I have locally updated the commit message).
Also sort out some iwlwifi bits (we try to find the best supported
firmware version if the latest does not exist; may not have made a difference
to the lastet review version?)

This revision now requires review to proceed.May 16 2024, 9:44 PM
bz marked an inline comment as done.May 16 2024, 9:44 PM

Looks good to me. Thanks.

This revision is now accepted and ready to land.May 21 2024, 6:58 PM

@jrm given I am not a ports committer how do I proceed? I assume I need an Approved by: line from someone?

In D44945#1033260, @bz wrote:

@jrm given I am not a ports committer how do I proceed? I assume I need an Approved by: line from someone?

As a src committer, you no longer need explicit approval to commit to the ports tree [1], so you can commit with Reviewed by: jrm. If you don't have things set up for ports, I can commit (as you) if that's helpful.

[1] In January 2023, Sergio (with core-secretary@ hat on) emailed a developers list with the subject 'RFC: Simplifying cross-repository commits' that essentially says core was considering doing away with the requirement for committers of one repo to require explicit permission to commit to another repo. @bsdimp just confirmed on IRC that this is in effect now.

Broken make index.
Add to net/Makefile wifi-firmware-ath12k-kmod and wifi-firmware-iwlwifi-kmod.