mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2026-05-05 12:46:14 +02:00
The devm alloc functions that we have may follow the Linux kernel model
where allocations are (almost always) automatically free()'d. However,
quite often we don't enable, in full U-Boot, the tracking and free()'ing
functionality. This in turn leads to memory leaks because the driver
author expects that since the functions have the same name as in the
Linux Kernel they have the same behavior. In turn we then get
functionally correct commits such as commit 00e1fed93c8c ("firmware:
ti_sci: Fix memory leaks in devm_ti_sci_get_of_resource") that manually
add these calls. Rather than manually tracking allocations and
implementing free()s, rework things so that we follow expectations by
enabling the DEVRES functionality (outside of xPL phases).
This turns DEVRES from a prompted symbol to a symbol that must be
select'd, and we now remove our non-managed alloc/free functions from
outside of xPL builds.
Reviewed-by: Michael Trimarchi <michael@amarulasolutions.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
37 lines
1.0 KiB
Plaintext
37 lines
1.0 KiB
Plaintext
menu "Multiplexer drivers"
|
|
|
|
config MULTIPLEXER
|
|
bool "Multiplexer Support"
|
|
depends on DM
|
|
select DEVRES
|
|
help
|
|
The mux framework is a minimalistic subsystem that handles multiplexer
|
|
controllers. It provides the same API as Linux and mux drivers should
|
|
be portable with a minimum effort.
|
|
|
|
if MULTIPLEXER
|
|
|
|
config SPL_MUX_MMIO
|
|
bool "MMIO register bitfield-controlled Multiplexer"
|
|
depends on MULTIPLEXER && SYSCON
|
|
help
|
|
MMIO register bitfield-controlled Multiplexer controller.
|
|
|
|
The driver builds multiplexer controllers for bitfields in a syscon
|
|
register. For N bit wide bitfields, there will be 2^N possible
|
|
multiplexer states.
|
|
|
|
config MUX_MMIO
|
|
bool "MMIO register bitfield-controlled Multiplexer"
|
|
depends on MULTIPLEXER && SYSCON
|
|
help
|
|
MMIO register bitfield-controlled Multiplexer controller.
|
|
|
|
The driver builds multiplexer controllers for bitfields in a syscon
|
|
register. For N bit wide bitfields, there will be 2^N possible
|
|
multiplexer states.
|
|
|
|
endif
|
|
|
|
endmenu
|