@@ -34,6 +34,7 @@
#include "intel_display.h"
#include "intel_display_types.h"
#include "intel_gmbus.h"
+#include "intel_opregion.h"
#define _INTEL_BIOS_PRIVATE
#include "intel_vbt_defs.h"
@@ -3082,6 +3083,7 @@ static struct vbt_header *oprom_get_vbt(struct drm_i915_private *i915)
void intel_bios_init(struct drm_i915_private *i915)
{
struct intel_vbt *vbt = &i915->display.vbt;
+ struct intel_opregion *opregion = &i915->display.opregion;
struct vbt_header *oprom_vbt = NULL;
struct vbt_header *header = NULL;
const struct bdb_header *bdb;
@@ -3104,6 +3106,8 @@ void intel_bios_init(struct drm_i915_private *i915)
init_vbt_defaults(i915);
+ if (opregion->asls)
+ intel_load_opregion_vbt(i915, opregion, vbt);
/*
* If the OpRegion does not have VBT, look in SPI flash through MMIO or
* PCI mapping
@@ -878,19 +878,19 @@ static int intel_load_vbt_firmware(struct drm_i915_private *dev_priv)
return ret;
}
-static int intel_load_opregion_vbt(struct drm_i915_private *i915,
- struct intel_opregion *opregion,
- struct intel_vbt *vbt)
+void intel_load_opregion_vbt(struct drm_i915_private *i915,
+ struct intel_opregion *opregion,
+ struct intel_vbt *vbt)
{
const void *vbt_data;
u32 vbt_size;
void *base = opregion->header;
if (intel_load_vbt_firmware(i915) == 0)
- goto out;
+ return;
if (dmi_check_system(intel_no_opregion_vbt))
- goto out;
+ return;
if (opregion->header->over.major >= 2 && opregion->asle &&
opregion->asle->rvda && opregion->asle->rvds) {
@@ -920,7 +920,7 @@ static int intel_load_opregion_vbt(struct drm_i915_private *i915,
vbt->vbt = vbt_data;
vbt->vbt_size = vbt_size;
vbt->type = I915_VBT_OPREGION;
- goto out;
+ return;
} else {
drm_dbg_kms(&i915->drm,
"Invalid VBT in ACPI OpRegion (RVDA)\n");
@@ -950,15 +950,11 @@ static int intel_load_opregion_vbt(struct drm_i915_private *i915,
drm_dbg_kms(&i915->drm,
"Invalid VBT in ACPI OpRegion (Mailbox #4)\n");
}
-
-out:
- return 0;
}
int intel_opregion_setup(struct drm_i915_private *dev_priv)
{
struct intel_opregion *opregion = &dev_priv->display.opregion;
- struct intel_vbt *vbt = &dev_priv->display.vbt;
struct pci_dev *pdev = to_pci_dev(dev_priv->drm.dev);
u32 asls, mboxes;
char buf[sizeof(OPREGION_SIGNATURE)];
@@ -1044,7 +1040,7 @@ int intel_opregion_setup(struct drm_i915_private *dev_priv)
drm_dbg(&dev_priv->drm, "Mailbox #2 for backlight present\n");
}
- return intel_load_opregion_vbt(dev_priv, opregion, vbt);
+ return 0;
err_out:
memunmap(base);
@@ -31,6 +31,7 @@
struct drm_i915_private;
struct intel_connector;
struct intel_encoder;
+struct intel_vbt;
struct opregion_header;
struct opregion_acpi;
@@ -77,6 +78,9 @@ const struct drm_edid *intel_opregion_get_edid(struct intel_connector *connector
bool intel_opregion_headless_sku(struct drm_i915_private *i915);
+void intel_load_opregion_vbt(struct drm_i915_private *i915,
+ struct intel_opregion *opregion,
+ struct intel_vbt *vbt);
#else /* CONFIG_ACPI*/
static inline int intel_opregion_setup(struct drm_i915_private *dev_priv)
@@ -137,6 +141,11 @@ static inline bool intel_opregion_headless_sku(struct drm_i915_private *i915)
return false;
}
+static inline void intel_load_opregion_vbt(struct drm_i915_private *i915,
+ struct intel_opregion *opregion,
+ struct intel_vbt *vbt)
+{
+}
#endif /* CONFIG_ACPI */
#endif
Opregion is probed early during the driver bring up and if present, vbt is extracted. Move vbt loading to a more appropriate place during bios init where the vbt is parsed. While at it remove the empty return. Signed-off-by: Radhakrishna Sripada <radhakrishna.sripada@intel.com> --- drivers/gpu/drm/i915/display/intel_bios.c | 4 ++++ drivers/gpu/drm/i915/display/intel_opregion.c | 18 +++++++----------- drivers/gpu/drm/i915/display/intel_opregion.h | 9 +++++++++ 3 files changed, 20 insertions(+), 11 deletions(-)