1. 24 5月, 2016 3 次提交
    • V
      drm/i915: Unify SKL cdclk init paths · 9f7eb31a
      Ville Syrjälä 提交于
      Currently we initialize cdclk on SKL from two different places,
      depending on whether it's during driver init or resume. Let's
      unify it to happen from the same place always, and that place will be
      the display core init function.
      
      To do this we first run through the cdclk sanitation code, which will
      first verify that the PLL is programmed correctly, after which we can
      read out the current cdclk frequency, and once the cdclk is known we
      verify that the cdclk "decimal" frequency is programmed correctly. If
      any of these fail we will force a cdclk change, and to be safe we also
      force the PLL to be turned off and on again. If the sanitation step
      didn't notice anything amiss, we'll skip the cdclk programming which
      will prevent cdclk reprogramming when the displays might be active.
      
      We can also toss in a few WARNs about the register values into
      skl_update_dpll0() since we now know that the PLL state should
      always be sane when that function is called.
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1463172100-24715-11-git-send-email-ville.syrjala@linux.intel.comReviewed-by: NImre Deak <imre.deak@intel.com>
      9f7eb31a
    • V
      drm/i915: Keep track of preferred cdclk vco frequency on SKL · b2045352
      Ville Syrjälä 提交于
      Now that skl_vco_freq tracks the actual DPLL0 vco frequency, we'll need
      something that keeps track of which vco frequency we want to use in case
      the current vco is 0. This would be important across supend/resume since
      we'll disable DPLL0 around those parts.
      
      We'll also update our idea of max cdclk/dotclock when the preferred
      vco changes. That could happen if out initial guess was wrong, and
      later eDP would force us to change it. One issue here could be that
      changing the max dotclock could cause our mode list to change during
      next time the displays get probed. But I don't see a good way to avoid
      that, except perhaps by allowing either vco frequency to be used as
      needed. But the docs suggest that such usage wasn't really inteded.
      
      Also need to make sure we don't update our max_cdclk value before we
      have a preferred vco value, which means moving that to happen after
      the cdclk sanitation.
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1463172100-24715-9-git-send-email-ville.syrjala@linux.intel.comReviewed-by: NImre Deak <imre.deak@intel.com>
      b2045352
    • C
      drm/i915/skl: SKL CDCLK change on modeset tracking VCO · c89e39f3
      Clint Taylor 提交于
      WARNING: Using ChromeOS with an eDP panel and a 4K@60 DP monitor connected
      to DDI1 the system will hard hang during a cold boot. Occurs when DDI1
      is enabled when the cdclk is less then required. DP connected to DDI2
      and HPD on either port works correctly.
      
      Set cdclk based on the max required pixel clock based on VCO
      selected. Track boot vco instead of boot cdclk.
      
      The vco is now tracked at the atomic level and all CRTCs updated if
      the required vco is changed. Not tested with eDP v1.4 panels that
      require 8640 vco due to availability.
      
      V1: initial version
      V2: add vco tracking in intel_dp_compute_config(), rename
      skl_boot_cdclk.
      V3: rebase, V2 feedback not possible as encoders are not aware of
      atomic.
      V4: track target vco is atomic state. modeset all CRTCs if vco changes
      V5: rename atomic variable, cleaner if/else logic, use existing vco if
            encoder does not return a new vco value. check_patch.pl cleanup
      V6: simplify logic in intel_modeset_checks.
      V7: reorder an IF for readability and whitespace fix.
      V8: use dev_cdclk for tracking new cdclk during atomic
      V9: correctly handle vco 8640 when crtcs==0
      V10: Clean up if else in crtcs==0
      V11: Rebase for new intel_dpll_mgr.c
      Reviewed-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Signed-off-by: NClint Taylor <clinton.a.taylor@intel.com>
      [vsyrjala: rebased due to churn]
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Reviewed-by: NImre Deak <imre.deak@intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1463172100-24715-3-git-send-email-ville.syrjala@linux.intel.com
      c89e39f3
  2. 19 5月, 2016 13 次提交
  3. 17 5月, 2016 1 次提交
  4. 13 5月, 2016 8 次提交
  5. 12 5月, 2016 1 次提交
  6. 11 5月, 2016 1 次提交
  7. 09 5月, 2016 4 次提交
    • C
      drm/i915: Store a i915 backpointer from engine, and use it · c033666a
      Chris Wilson 提交于
         text	   data	    bss	    dec	    hex	filename
      6309351	3578714	 696320	10584385	 a18141	vmlinux
      6308391	3578714	 696320	10583425	 a17d81	vmlinux
      
      Almost 1KiB of code reduction.
      
      v2: More s/INTEL_INFO()->gen/INTEL_GEN()/ and IS_GENx() conversions
      
         text	   data	    bss	    dec	    hex	filename
      6304579	3578778	 696320	10579677	 a16edd	vmlinux
      6303427	3578778	 696320	10578525	 a16a5d	vmlinux
      
      Now over 1KiB!
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      Cc: Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
      Reviewed-by: NTvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1462545621-30125-3-git-send-email-chris@chris-wilson.co.uk
      c033666a
    • T
      drm/i915: Small display interrupt handlers tidy · 91d14251
      Tvrtko Ursulin 提交于
      I have noticed some of our interrupt handlers use both dev and
      dev_priv while they could get away with only dev_priv in the
      huge majority of cases.
      
      Tidying that up had a cascading effect on changing functions
      prototypes, so relatively big churn factor, but I think it is
      for the better.
      
      For example even where changes cascade out of i915_irq.c, for
      functions prefixed with intel_, genX_ or <plat>_, it makes more
      sense to take dev_priv directly anyway.
      
      This allows us to eliminate local variables and intermixed usage
      of dev and dev_priv where only one is good enough.
      
      End result is shrinkage of both source and the resulting binary.
      
      i915.ko:
      
       - .text         000b0899
       + .text         000b0619
      
      Or if we look at the Gen8 display irq chain:
      
       -00000000000006ad t gen8_irq_handler
       +0000000000000663 t gen8_irq_handler
         -0000000000000028 T intel_opregion_asle_intr
         +0000000000000024 T intel_opregion_asle_intr
         -000000000000008c t ilk_hpd_irq_handler
         +000000000000007f t ilk_hpd_irq_handler
         -0000000000000116 T intel_check_page_flip
         +0000000000000112 T intel_check_page_flip
         -000000000000011a T intel_prepare_page_flip
         +0000000000000119 T intel_prepare_page_flip
         -0000000000000014 T intel_finish_page_flip_plane
         +0000000000000013 T intel_finish_page_flip_plane
         -0000000000000053 t hsw_pipe_crc_irq_handler
         +000000000000004c t hsw_pipe_crc_irq_handler
         -000000000000022e t cpt_irq_handler
         +0000000000000213 t cpt_irq_handler
      
      So small shrinkage but it is all fast paths so doesn't harm.
      
      Situation is similar in other interrupt handlers as well.
      
      v2: Tidy intel_queue_rps_boost_for_request as well. (Chris Wilson)
      Signed-off-by: NTvrtko Ursulin <tvrtko.ursulin@intel.com>
      Cc: Chris Wilson <chris@chris-wilson.co.uk>
      Reviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
      91d14251
    • V
      drm/i915: Enable/disable TMDS output buffers in DP++ adaptor as needed · b2ccb822
      Ville Syrjälä 提交于
      To save a bit of power, let's try to turn off the TMDS output buffers
      in DP++ adaptors when we're not driving the port.
      
      v2: Let's not forget DDI, toss in a debug message while at it
      v3: Just do the TMDS output control based on adaptor type. With the
          helper getting passed the type, we wouldn't actually have to
          check at all in the driver, but the check eliminates the debug
          output more honest
      
      Cc: stable@vger.kernel.org
      Cc: Tore Anderson <tore@fud.no>
      Cc: Paulo Zanoni <paulo.r.zanoni@intel.com>
      Cc: Shashank Sharma <shashank.sharma@intel.com>
      Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1462216105-20881-4-git-send-email-ville.syrjala@linux.intel.comReviewed-by: NShashank Sharma <shashank.sharma@intel.com>
      b2ccb822
    • V
      drm/i915: Respect DP++ adaptor TMDS clock limit · b1ba124d
      Ville Syrjälä 提交于
      Try to detect the max TMDS clock limit for the DP++ adaptor (if any)
      and take it into account when checking the port clock.
      
      Note that as with the sink (HDMI vs. DVI) TMDS clock limit we'll ignore
      the adaptor TMDS clock limit in the modeset path, in case users are
      already "overclocking" their TMDS links. One subtle change here is that
      we'll have to respect the adaptor TMDS clock limit when we decide whether
      to do 12bpc or 8bpc, otherwise we might end up picking 12bpc and
      accidentally driving the TMDS link out of spec even when the user chose
      a mode that fits wihting the limits at 8bpc. This means you can't
      "overclock" your DP++ dongle at 12bpc anymore, but you can continue to
      do so at 8bpc.
      
      Note that for simplicity we'll use the I2C access method for all dual
      mode adaptors including type 2. Otherwise we'd have to start mixing
      DP AUX and HDMI together. In the future we may need to do that if we
      come across any board designs that don't hook up the DDC pins to the
      DP++ connectors. Such boards would obviously only work with type 2
      dual mode adaptors, and not type 1.
      
      v2: Store adaptor type under indel_hdmi->dp_dual_mode
          Deal with DRM_DP_DUAL_MODE_UNKNOWN
          Pass adaptor type to drm_dp_dual_mode_max_tmds_clock(),
          and use it for type1 adaptors as well
      
      Cc: stable@vger.kernel.org
      Reported-by: NTore Anderson <tore@fud.no>
      Fixes: 7a0baa62 ("Revert "drm/i915: Disable 12bpc hdmi for now"")
      Cc: Paulo Zanoni <paulo.r.zanoni@intel.com>
      Cc: Shashank Sharma <shashank.sharma@intel.com>
      Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Link: http://patchwork.freedesktop.org/patch/msgid/1462216105-20881-3-git-send-email-ville.syrjala@linux.intel.comReviewed-by: NShashank Sharma <shashank.sharma@intel.com>
      b1ba124d
  8. 05 5月, 2016 1 次提交
  9. 04 5月, 2016 2 次提交
  10. 29 4月, 2016 1 次提交
  11. 28 4月, 2016 2 次提交
  12. 27 4月, 2016 1 次提交
  13. 26 4月, 2016 2 次提交