Thread (14 messages) 14 messages, 4 authors, 2018-06-07

[PATCH v3 2/5] efi: Add embedded peripheral firmware support

From: Bjorn Andersson <hidden>
Date: 2018-06-07 16:48:06
Also in: linux-arm-msm, linux-efi, lkml, platform-driver-x86

On Tue 08 May 09:10 PDT 2018, Luis R. Rodriguez wrote:
On Tue, May 08, 2018 at 03:38:05PM +0000, Luis R. Rodriguez wrote:
quoted
On Fri, May 04, 2018 at 12:44:37PM -0700, Martijn Coenen wrote:
quoted
On Wed, Apr 25, 2018 at 10:55 AM, Luis R. Rodriguez [off-list ref] wrote:
[..]
quoted
quoted
2) Most of those paths are not mounted by the time the corresponding
drivers are loaded, because pretty much all Android kernels today are
built without module support, and therefore drivers are loaded well
before the firmware partition is mounted
I've given this some more thought and you can address this with initramfs,
this is how other Linux distributions are addressing this. One way to
address this automatically is to scrape the drivers built-in or needed early on
boot in initamfs and if the driver has a MODULE_FIRMWARE() its respective
firmware is added to initramfs as well.
That could be done, but it would not change the fact that the
/sys/class/firmware is ABI and you may not break it.


And it doesn't change the fact that the ramdisk would have to be over
100mb to facilitate this.
If you *don't* use initramfs, then yes you can obviously run into issues
where your firmware may not be accessible if the driver is somehow loaded
early.
This is still a problem that lacks a solution.
quoted
quoted
3) I think we use _FALLBACK because doing this with uevents is just
the easiest thing to do; our init code has a firmware helper that
deals with this and searches the paths that we care about

2) will change at some point, because Android is moving towards a
model where device-specific peripheral drivers will be loaded as
modules, and since those modules would likely come from the same
partition as the firmware, it's possible that the direct load would
succeed (depending on whether the custom path is configured there or
not). But I don't think we can rely on the direct loader even in those
cases, unless we could configure it with multiple custom paths.
Using initramfs will help, but because of the custom path needs -- you're
right, we don't have anything for that yet, its also a bit unclear if
something nice and clean can be drawn up for it. So perhaps dealing with
the fallback mechanism is the way to go for this for sure, since we already
have support for it.

Just keep in mind that the fallback mechanism costs you about ~13436 bytes.
Remember that putting the firmware in the ramdisk would cost about
10000x (yes, ten thousand times) more ram.
So, if someone comes up with a clean interface for custom paths I'd love
to consider it to avoid those 13436 bytes.
Combined with a way of synchronizing this with the availability of the
firmware, this would be a nice thing!

Regards,
Bjorn
--
To unsubscribe from this list: send the line "unsubscribe linux-security-module" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help