1. 03 5月, 2012 2 次提交
  2. 17 4月, 2012 1 次提交
  3. 13 4月, 2012 1 次提交
  4. 11 4月, 2012 1 次提交
    • D
      drm/i915: properly compute dp dithering for user-created modes · c4867936
      Daniel Vetter 提交于
      We've only computed whether we need to fall back to 6bpc due to dp
      link bandwidth constrains in mode_valid, but not mode_fixup. Under
      various circumstances X likes to create new modes which then lack
      proper 6bpc flags (if required), resulting in mode_fixup failures and
      ultimately black screens.
      
      Chris Wilson pointed out that we still get things wrong for bpp > 24,
      but that should be fixed in another patch (and it'll be easier because
      this patch consolidates the logic).
      
      The likely culprit for this regression is
      
      commit 3d794f87238f74d80e78a7611c7fbde8a54c85c2
      Author: Keith Packard <keithp@keithp.com>
      Date:   Wed Jan 25 08:16:25 2012 -0800
      
          drm/i915: Force explicit bpp selection for intel_dp_link_required
      
      v2: Fix indentation and tune down the too bold claim that this should
      fix the world. Both noticed by Chris Wilson.
      
      v3: Try to really git add things.
      Reported-and-tested-by: NBrice Goglin <Brice.Goglin@ens-lyon.org>
      Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=48170
      Cc: stable@kernel.org
      Reviewed-by: NAdam Jackson <ajax@redhat.com>
      Signed-Off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      c4867936
  5. 28 2月, 2012 1 次提交
  6. 07 2月, 2012 1 次提交
  7. 17 1月, 2012 3 次提交
  8. 20 12月, 2011 1 次提交
  9. 17 12月, 2011 1 次提交
  10. 24 11月, 2011 1 次提交
  11. 17 11月, 2011 9 次提交
  12. 02 11月, 2011 1 次提交
  13. 01 11月, 2011 1 次提交
  14. 21 10月, 2011 8 次提交
  15. 13 10月, 2011 2 次提交
  16. 06 10月, 2011 6 次提交
    • K
      drm/i915: Disable eDP VDD in a delayed work proc instead of synchronously · bd943159
      Keith Packard 提交于
      There's no good reason to turn off the eDP force VDD bit synchronously
      while probing devices; that just sticks a huge delay into all mode
      setting paths. Instead, queue a delayed work proc to disable the VDD
      force bit and then remember when that fires to ensure that the
      appropriate delay is respected before trying to turn it back on.
      Signed-off-by: NKeith Packard <keithp@keithp.com>
      bd943159
    • K
      drm/i915: Create helper functions to determine eDP power state · ebf33b18
      Keith Packard 提交于
      We need to check eDP VDD force and panel on in several places, so
      create some simple helper functions to avoid duplicating code.
      Signed-off-by: NKeith Packard <keithp@keithp.com>
      ebf33b18
    • K
      drm/i915: edp_panel_on does not need to return a bool · 7d639f35
      Keith Packard 提交于
      The return value was unused, so just stop doing that.
      Signed-off-by: NKeith Packard <keithp@keithp.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      7d639f35
    • K
      drm/i915: Move eDP panel fixed mode from dev_priv to intel_dp · d15456de
      Keith Packard 提交于
      This value doesn't come directly from the VBT, and so is rather
      specific to the particular DP output.
      Signed-off-by: NKeith Packard <keithp@keithp.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      d15456de
    • K
      drm/i915: Correct eDP panel power sequencing delay computations · f01eca2e
      Keith Packard 提交于
      Store the panel power sequencing delays in the dp private structure,
      rather than the global device structure. Who knows, maybe we'll get
      more than one eDP device in the future.
      
      From the eDP spec, we need the following numbers:
      
       T1 + T3	Power on to Aux Channel operation (panel_power_up_delay)
      
      		This marks how long it takes the panel to boot up and
      		get ready to receive aux channel communications.
      
       T8		Video signal to backlight on (backlight_on_delay)
      
      		Once a valid video signal is being sent to the device,
      		it can take a while before the panel is actuall
      		showing useful data. This delay allows the panel
      		to get something reasonable up before the backlight
      		is turned on.
      
       T9		Backlight off to video off (backlight_off_delay)
      
      		Turning the backlight off can take a moment, so
      		this delay makes sure there is still valid video
      		data on the screen.
      
       T10		Video off to power off (panel_power_down_delay)
      
      		Presumably this delay allows the panel to perform
      		an orderly shutdown of the display.
      
       T11 + T12	Power off to power on (panel_power_cycle_delay)
      
      		So, once you turn the panel off, you have to wait a
      		while before you can turn it back on. This delay is
      		usually the longest in the entire sequence.
      
      Neither the VBIOS source code nor the hardware documentation has a
      clear mapping between the delay values they provide and those required
      by the eDP spec. The VBIOS code actually uses two different labels for
      the delay values in the five words of the relevant VBT table.
      
      **** MORE LATER ***
      
      Look at both the current hardware register settings and the VBT
      specified panel power sequencing timings. Use the maximum of the two
      delays, to make sure things work reliably. If there is no VBT data,
      then those values will be initialized to zero, so we'll just use the
      values as programmed in the hardware. Note that the BIOS just fetches
      delays from the VBT table to place in the hardware registers, so we
      should get the same values from both places, except for rounding.
      
      VBT doesn't provide any values for T1 or T2, so we'll always just use
      the hardware value for that.
      
      The panel power up delay is thus T1 + T2 + T3, which should be
      sufficient in all cases.
      
      The panel power down delay is T1 + T2 + T12, using T1+T2 as a proxy
      for T11, which isn't available anywhere.
      
      For the backlight delays, the eDP spec says T6 + T8 is the delay from the
      end of link training to backlight on and T9 is the delay from
      backlight off until video off. The hardware provides a 'backlight on'
      delay, which I'm taking to be T6 + T8 while the VBT provides something
      called 'T7', which I'm assuming is s
      
      On the macbook air I'm testing with, this yields a power-up delay of
      over 200ms and a power-down delay of over 600ms. It all works now, but
      we're frobbing these power controls several times during mode setting,
      making the whole process take an awfully long time.
      Signed-off-by: NKeith Packard <keithp@keithp.com>
      f01eca2e
    • K
      drm/i915: Ensure eDP powered up during DP_SET_POWER operation in dp_prepare · f58ff854
      Keith Packard 提交于
      Any call to intel_dp_sink_dpms must ensure that the panel has power so
      that the DP_SET_POWER operation will be correctly received. The only
      one missing this was in intel_dp_prepare.
      Signed-off-by: NKeith Packard <keithp@keithp.com>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      f58ff854