diff options
author | Furquan Shaikh <furquan@google.com> | 2021-05-20 22:47:02 -0700 |
---|---|---|
committer | Tim Wawrzynczak <twawrzynczak@chromium.org> | 2021-05-24 16:55:39 +0000 |
commit | 7f6ae79280eabce22f1df3c858617c6e890e3594 (patch) | |
tree | 7b15e6c75896b9c6f8b987db890bf232d5d6dd66 /src/include/device | |
parent | 665891e3a8daafe04494fd4ac2dba49a99840a3a (diff) |
device: Consider fw_config probing in `is_dev_enabled()`
With the introduction of fw_config support in coreboot, it is possible
for mainboards to control the state of a device (on/off) in ramstage
using fw_config probe conditions. However, the device tree in
immutable in all other stages and hence `is_dev_enabled()` does not
really reflect the true state as in ramstage.
This change adds a call to `fw_config_probe_dev()` in
`is_dev_enabled()` when device tree is immutable (by checking
DEVTREE_EARLY) to first check if device is disabled because of device
probe conditions. If so, then it reports device as being
disabled. Else, dev->enabled is used to report the device state.
This allows early stages (bootblock, romstage) to use
`is_dev_enabled()` to get the true state of the device by taking probe
conditions into account and eliminates the need for each caller to
perform their own separate probing.
Change-Id: Ifede6775bda245cba199d3419aebd782dc690f2c
Signed-off-by: Furquan Shaikh <furquan@google.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/54752
Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
Reviewed-by: Karthik Ramasubramanian <kramasub@google.com>
Reviewed-by: EricR Lai <ericr_lai@compal.corp-partner.google.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Diffstat (limited to 'src/include/device')
-rw-r--r-- | src/include/device/device.h | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/src/include/device/device.h b/src/include/device/device.h index 88b5310055..623d337601 100644 --- a/src/include/device/device.h +++ b/src/include/device/device.h @@ -191,11 +191,7 @@ void dev_set_enabled(struct device *dev, int enable); void disable_children(struct bus *bus); bool dev_is_active_bridge(struct device *dev); void add_more_links(struct device *dev, unsigned int total_links); - -static inline bool is_dev_enabled(const struct device *const dev) -{ - return dev && dev->enabled; -} +bool is_dev_enabled(const struct device *const dev); /* Option ROM helper functions */ void run_bios(struct device *dev, unsigned long addr); |