Page MenuHomeFreeBSD

linuxkpi: add firmware loading support
ClosedPublic

Authored by bz on Nov 29 2020, 10:16 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 24, 9:42 AM
Unknown Object (File)
Fri, Jan 24, 9:26 AM
Unknown Object (File)
Sat, Jan 18, 12:04 AM
Unknown Object (File)
Thu, Jan 16, 12:31 PM
Unknown Object (File)
Wed, Jan 15, 11:00 PM
Unknown Object (File)
Wed, Jan 15, 10:48 PM
Unknown Object (File)
Wed, Jan 15, 7:57 PM
Unknown Object (File)
Wed, Jan 8, 5:31 AM

Details

Summary

Implement linux firmware KPI compat code.
This includes: request_firmware() request_firmware_nowait(),
firmware_request_nowarn(), and release_firmware().
We do not currently defer loading in the "nowait" case.

Given we will try to map requested names from natively ported
or full-linuxkpi using drivers to a firmware(9) auto-loading
format in which we can handle the .ko file and image name
we quieten firmware(9) and print success or failure (unless
the _nowarn() version was called) on the linuxkpi implementation.
At the moment we try up-to 4 different naming combinations,
with path stripped, original name, and requested name with '/'
or '.' replaced.

Sponsored by: The FreeBSD Foundation
Sponsored by: Rubicon Communications, LLC (d/b/a "Netgate") (firmware(9) update)

Changes since the last version ( D26277, D26598 ): addressed kib's comments, fixed a bug when returning fw pointer in error case not being initialized to zero [as some drivers will use any results], implement the _nowarn() version needed by iwlwifi now, and ath10k(athp once switched), make use of firmware(9) NOWARN flag to quieten attempts possibly confusing users and add our own printfs (respecting the linux _nowarn() version).

Let me know in case I need to bump __FreeBSD_version.

Test Plan

Tested with 4 WiFi drivers; and DRM in an earlier version.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 35110

Event Timeline

manu added inline comments.
sys/compat/linuxkpi/common/src/linux_firmware.c
112

Using the bsddev and device_printf would be better.

117

Same here.

137

Is it something that Linux does ? (Running the callback defered).
If yes is it something that you plan to add support to ?

Pass dev in to the common function so we can use device_printf() as suggested by manu.
Update the comment about running the "_nowait()" context deferred.

bz marked 3 inline comments as done.Nov 30 2020, 2:32 PM
bz added inline comments.
sys/compat/linuxkpi/common/src/linux_firmware.c
112

Done. Thanks. Good idea!

137

I currently do not plan to implement it.
None of the drivers I have seen so far and tested do require it.
I updated the comment to be more clear.

The comment is merely left that in case in 10 years someone works on a driver which needs the deferred context they can find the problem more easily. Should I come across a driver needing it, I will of course implement it.

bz marked 2 inline comments as done.

@manu, did we come to the conclusion last year that currently doing this all natively was not always working and we are going with this one as the next (first) step? I'd love to commit this as soon as firmware(9) changes are in and D26598 is updated and accepted, so that we don't have to update DRM ports too often.

In D27414#629460, @bz wrote:

@manu, did we come to the conclusion last year that currently doing this all natively was not always working and we are going with this one as the next (first) step? I'd love to commit this as soon as firmware(9) changes are in and D26598 is updated and accepted, so that we don't have to update DRM ports too often.

I don't remember.
I suggest just trying main + those two reviews and drm-devel-kmod, if that works that's good, otherwise just tell me the problem.

Changes since last:

  • add request_firmware_direct() needed by DRM.

@manu works for Intel.

I have a diff for FreeBSD_version checks for this and D26598 that can be applied to drm-kmod as well (once the FreeBSD_version is known) so that the conflicts are gone here: https://people.freebsd.org/~bz/tmp/2021-01-15-02-drm-kmod-FreeBSD_version-checks-firmware-linuxkpi-conflicts.diff

Current dummy version from testing: 000001 was for firmware and 2 was for D26598.

Anyone any last comments; I'd love to commit this before Monday.

This revision was not accepted when it landed; it landed in state Needs Review.Jan 28 2021, 4:47 PM
This revision was automatically updated to reflect the committed changes.