drm/i915/bios: limit default outputs to ports A through F
authorJani Nikula <jani.nikula@intel.com>
Wed, 17 Mar 2021 16:36:45 +0000 (18:36 +0200)
committerJani Nikula <jani.nikula@intel.com>
Thu, 18 Mar 2021 12:43:39 +0000 (14:43 +0200)
There are two main cases where the default outputs are useful when the
VBT is missing:

- There are some DDI-platform Chromebooks out there that do not have a
  VBT, which worked by coincidence because of the default outputs. The
  machines need to continue to work.

- Early platform enabling when the VBT might not be available. (This
  could be circumvented by using the i915.vbt_firmware parameter.)

Prepare for generating fake child devices for the default outputs by
limiting the number of outputs. We don't want to generate excessive
amounts of fake child devices. This could be perhaps be limited even
more in the future, but match what's possible on all DDI platforms.

Note that limiting the defaults to non-TypeC ports in commit
828ccb31cf41 ("drm/i915/icl: Add TypeC ports only if VBT is present") is
a more strict limit, and makes this a no-op on recent platforms.

v2: Rewrote commit message

Cc: Lucas De Marchi <lucas.demarchi@intel.com>
Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/5c9c9743af1c7265a2c976d582b7a6685ec0c414.1615998927.git.jani.nikula@intel.com
drivers/gpu/drm/i915/display/intel_bios.c

index be3dc3363444e0a7d50de2192eb39ec5a8a284a7..218e0dae3ece572e0190a242b63db33af9ed14c3 100644 (file)
@@ -2081,11 +2081,12 @@ static void
 init_vbt_missing_defaults(struct drm_i915_private *i915)
 {
        enum port port;
+       int ports = PORT_A | PORT_B | PORT_C | PORT_D | PORT_E | PORT_F;
 
        if (!HAS_DDI(i915) && !IS_CHERRYVIEW(i915))
                return;
 
-       for_each_port(port) {
+       for_each_port_masked(port, ports) {
                struct ddi_vbt_port_info *info =
                        &i915->vbt.ddi_port_info[port];
                enum phy phy = intel_port_to_phy(i915, port);