1. 10 4月, 2015 1 次提交
    • M
      drm/i915: Switch to full atomic helpers for plane updates/disable, take two · 70a101f8
      Matt Roper 提交于
      Switch from our plane update/disable entrypoints to use the full atomic
      helpers (which generate a top-level atomic transaction) rather than the
      transitional helpers (which only create/manipulate orphaned plane states
      independent of a top-level transaction).  Various upcoming work (SKL
      scalers, atomic watermarks, etc.) requires a full atomic transaction to
      behave properly/cleanly.
      
      Last time we tried this, we had to back out the change because we still
      call the drm_plane vfuncs directly from within our legacy modesetting
      code.  This potentially results in nested atomic transactions, locking
      collisions, and other failures.  To avoid that problem again, we
      sidestep the issue by calling the transitional helpers directly (rather
      than through a vfunc) when we're nested inside of other legacy
      modesetting code.  However this does allow legacy SetPlane() ioctl's to
      process an entire drm_atomic_state transaction, which is important for
      upcoming patches.
      
      Cc: Chandra Konduru <chandra.konduru@intel.com>
      Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      70a101f8
  2. 27 3月, 2015 1 次提交
  3. 23 3月, 2015 2 次提交
  4. 20 3月, 2015 5 次提交
  5. 18 3月, 2015 1 次提交
  6. 28 2月, 2015 3 次提交
  7. 23 2月, 2015 1 次提交
  8. 14 2月, 2015 2 次提交
    • T
      drm/i915/skl: Use fb modifiers for sprites · 66ebf567
      Tvrtko Ursulin 提交于
      While at it just outright remove the tiling check in
      intel_check_sprite_plane because it's impossible: We only allow
      untiled and X-tiled. This essentially reverts
      
      commit 94c6419e
      Author: Damien Lespiau <damien.lespiau@intel.com>
      Date:   Mon Oct 29 15:14:51 2012 +0000
      
          drm/i915: Error out when trying to set a y-tiled as a sprite
      Signed-off-by: NTvrtko Ursulin <tvrtko.ursulin@intel.com>
      [danvet: Drop the hunk in check_sprite, it's impossible.]
      Cc: Damien Lespiau <damien.lespiau@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      66ebf567
    • P
      drm/i915: change dev_priv->fbc.plane to dev_priv->fbc.crtc · e35fef21
      Paulo Zanoni 提交于
      Since the mapping from CRTCs to planes is fixed, looking at the CRTC
      is essentially the same as looking at the plane. Also, the next
      patches wil start using the frontbuffer_bits macros, and they take the
      pipe as the parameter instead of the plane, and this could differ on
      gens 2 and 3.
      
      Another nice thing is that we don't risk accidentally initializing
      things to PLANE_A if we don't set the value before it is used for the
      first time. But this shouldn't be a problem with the current code.
      
      V2: Rebase.
      
      Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com> (v1)
      Signed-off-by: NPaulo Zanoni <paulo.r.zanoni@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      e35fef21
  9. 27 1月, 2015 5 次提交
  10. 13 1月, 2015 5 次提交
    • M
      drm/i915: Drop unused position fields (v2) · 53a366b9
      Matt Roper 提交于
      The userspace-requested plane coordinates are now always available via
      plane->state.base (and the i915-adjusted values are stored in
      plane->state), so we no longer use the coordinate fields in intel_plane
      and can drop them.
      
      Also, note that the error case for pageflip calls update_plane() to
      program the values from plane->state; it's simpler to just call
      intel_plane_restore() which does the same thing.
      
      v2: Replace manual update_plane() with intel_plane_restore() in pageflip
          error handler.
      
      Reviewed-by(v1): Bob Paauwe <bob.j.paauwe@intel.com>
      Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
      Reviewed-by: NAnder Conselvan de Oliveira <ander.conselvan.de.oliveira@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      53a366b9
    • M
      drm/i915: Move to atomic plane helpers (v9) · ea2c67bb
      Matt Roper 提交于
      Switch plane handling to use the atomic plane helpers.  This means that
      rather than provide our own implementations of .update_plane() and
      .disable_plane(), we expose the lower-level check/prepare/commit/cleanup
      entrypoints and let the DRM core implement update/disable for us using
      those entrypoints.
      
      The other main change that falls out of this patch is that our
      drm_plane's will now always have a valid plane->state that contains the
      relevant plane state (initial state is allocated at plane creation).
      The base drm_plane_state pointed to holds the requested source/dest
      coordinates, and the subclassed intel_plane_state holds the adjusted
      values that our driver actually uses.
      
      v2:
       - Renamed file from intel_atomic.c to intel_atomic_plane.c (Daniel)
       - Fix a copy/paste comment mistake (Bob)
      
      v3:
       - Use prepare/cleanup functions that we've already factored out
       - Use newly refactored pre_commit/commit/post_commit to avoid sleeping
         during vblank evasion
      
      v4:
       - Rebase to latest di-nightly requires adding an 'old_state' parameter
         to atomic_update;
      
      v5:
       - Must have botched a rebase somewhere and lost some work.  Restore
         state 'dirty' flag to let begin/end code know which planes to
         run the pre_commit/post_commit hooks for.  This would have actually
         shown up as broken in the next commit rather than this one.
      
      v6:
       - Squash kerneldoc patch into this one.
       - Previous patches have now already taken care of most of the
         infrastructure that used to be in this patch.  All we're adding here
         now is some thin wrappers.
      
      v7:
       - Check return of intel_plane_duplicate_state() for allocation
         failures.
      
      v8:
       - Drop unused drm_plane_state -> intel_plane_state cast.  (Ander)
       - Squash in actual transition to plane helpers.  Significant
         refactoring earlier in the patchset has made the combined
         prep+transition much easier to swallow than it was in earlier
         iterations. (Ander)
      
      v9:
       - s/track_fbs/disabled_planes/ in the atomic crtc flags.  The only fb's
         we need to update frontbuffer tracking for are those on a plane about
         to be disabled (since the atomic helpers never call prepare_fb() when
         disabling a plane), so the new name more accurately describes what
         we're actually tracking.
      
      Testcase: igt/kms_plane
      Testcase: igt/kms_universal_plane
      Testcase: igt/kms_cursor_crc
      Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
      Reviewed-by: NAnder Conselvan de Oliveira <conselvan2@gmail.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      ea2c67bb
    • M
      drm/i915: Clarify sprite plane function names (v4) · 4a3b8769
      Matt Roper 提交于
      A few of the sprite-related function names in i915 are very similar
      (e.g., intel_enable_planes() vs intel_crtc_enable_planes()) and don't
      make it clear whether they only operate on sprite planes, or whether
      they also apply to all universal plane types.  Rename a few functions to
      be more consistent with our function naming for primary/cursor planes or
      to clarify that they apply specifically to sprite planes:
      
       - s/intel_disable_planes/intel_disable_sprite_planes/
       - s/intel_enable_planes/intel_enable_sprite_planes/
      
      Also, drop the sprite-specific intel_destroy_plane() and just use
      the type-agnostic intel_plane_destroy() function.  The extra 'disable'
      call that intel_destroy_plane() did is unnecessary since the plane will
      already be disabled due to framebuffer destruction by the point it gets
      called.
      
      v2: Earlier consolidation patches have reduced the number of functions
          we need to rename here.
      
      v3: Also rename intel_plane_funcs vtable to intel_sprite_plane_funcs
          for consistency with primary/cursor.  (Ander)
      
      v4: Convert comment for intel_plane_destroy() to kerneldoc now that it
          is no longer a static function.  (Ander)
      
      Reviewed-by(v1): Bob Paauwe <bob.j.paauwe@intel.com>
      Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
      Reviewed-by: NAnder Conselvan de Oliveira <conselvan2@gmail.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      4a3b8769
    • M
      drm/i915: Move vblank evasion to commit (v4) · c34c9ee4
      Matt Roper 提交于
      Move the vblank evasion up from the low-level, hw-specific
      update_plane() handlers to the general plane commit operation.
      Everything inside commit should now be non-sleeping, so this brings us
      closer to how vblank evasion will behave once we move over to atomic.
      
      v2:
       - Restore lost intel_crtc->active check on vblank evasion
      
      v3:
       - Replace assert_pipe_enabled() in intel_disable_primary_hw_plane()
         with an intel_crtc->active test; it turns out assert_pipe_enabled()
         grabs some mutexes and can sleep, which we can't do with interrupts
         disabled.
      
      v4:
       - Equivalent to v2; v3 change is now squashed into an earlier patch
         of the series.  (Ander).
      Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
      Reviewed-by: NAnder Conselvan de Oliveira <conselvan2@gmail.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      c34c9ee4
    • M
      drm/i915: Refactor work that can sleep out of commit (v7) · 32b7eeec
      Matt Roper 提交于
      Once we integrate our work into the atomic pipeline, plane commit
      operations will need to happen with interrupts disabled, due to vblank
      evasion.  Our commit functions today include sleepable work, so those
      operations need to be split out and run either before or after the
      atomic register programming.
      
      The solution here calculates which of those operations will need to be
      performed during the 'check' phase and sets flags in an intel_crtc
      sub-struct.  New intel_begin_crtc_commit() and
      intel_finish_crtc_commit() functions are added before and after the
      actual register programming; these will eventually be called from the
      atomic plane helper's .atomic_begin() and .atomic_end() entrypoints.
      
      v2: Fix broken sprite code split
      
      v3: Make the pre/post commit work crtc-based to match how we eventually
          want this to be called from the atomic plane helpers.
      
      v4: Some platforms that haven't had their watermark code reworked were
          waiting for vblank, then calling update_sprite_watermarks in their
          platform-specific disable code.  These also need to be flagged out
          of the critical section.
      
      v5: Sprite plane test for primary show/hide should just set the flag to
          wait for pending flips, not actually perform the wait.  (Ander)
      
      v6:
       - Rebase onto latest di-nightly; picks up an important runtime PM fix.
       - Handle 'wait_for_flips' flag in intel_begin_crtc_commit(). (Ander)
       - Use wait_for_flips flag for primary plane update rather than
         performing the wait in the check routine.
       - Added kerneldoc to pre_disable/post_enable functions that are no
         longer static.  (Ander)
       - Replace assert_pipe_enabled() in intel_disable_primary_hw_plane()
         with an intel_crtc->active test; it turns out assert_pipe_enabled()
         grabs some mutexes and can sleep, which we can't do with interrupts
         disabled.
      
      v7:
       - Check for fb != NULL when deciding whether the sprite plane hides the
         primary plane during a sprite update.  (PRTS)
      Signed-off-by: NMatt Roper <matthew.d.roper@intel.com>
      Reviewed-by: NAnder Conselvan de Oliveira <conselvan2@gmail.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      32b7eeec
  11. 11 12月, 2014 1 次提交
  12. 06 12月, 2014 5 次提交
  13. 14 11月, 2014 1 次提交
    • P
      drm/i915: use the correct obj when preparing the sprite plane · b8bbac1d
      Paulo Zanoni 提交于
      Commit "drm/i915: create a prepare phase for sprite plane updates"
      changed the old_obj pointer we use when committing sprite planes,
      which caused a WARN() and a BUG() to be triggered. Later, commit
      "drm/i915: use intel_fb_obj() macros to assign gem objects" introduced
      the same problem to function intel_commit_sprite_plane().
      
      Regression introduced by:
          commit ec82cb793c9224e0692eed904f43490cf70e8258
          Author: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
          Date:   Fri Oct 24 14:51:32 2014 +0100
              drm/i915: create a prepare phase for sprite plane updates
      and:
          commit 77cde952
          Author: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
          Date:   Fri Oct 24 14:51:33 2014 +0100
              drm/i915: use intel_fb_obj() macros to assign gem objects
      
      Credits to Imre Deak for pointing out the exact lines that were wrong.
      
      v2: Also fix intel_commit_sprite_plane() (Ville)
      
      Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=85634
      Testcase: igt/pm_rpm/legacy-planes
      Testcase: igt/pm_rpm/legacy-planes-dpms
      Testcase: igt/pm_rpm/universal-planes
      Testcase: igt/pm_rpm/universal-planes-dpms
      Credits-to: Imre Deak <imre.deak@intel.com>
      Cc: Gustavo Padovan <gustavo.padovan@collabora.co.uk>
      Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
      Signed-off-by: NPaulo Zanoni <paulo.r.zanoni@intel.com>
      Reviewed-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      b8bbac1d
  14. 08 11月, 2014 4 次提交
  15. 05 11月, 2014 3 次提交
    • V
      drm/i915: Add support for CHV pipe B sprite CSC · 6ca2aeb2
      Ville Syrjälä 提交于
      CHV has a programmable CSC unit on the pipe B sprites. Program the unit
      appropriately for BT.601 limited range YCbCr to full range RGB color
      conversion. This matches the programming we currently do for sprites
      on the other pipes and on other platforms.
      
      It seems the CSC only works when the input data is YCbCr. For RGB
      pixel formats it doesn't matter what we program into the CSC registers.
      Doesn't make much sense to me especially since the register names give
      the impression that RGB input data would also work. But that's how
      it behaves here.
      
      In the review discussions there's been some nice math to explain the
      values obtained here. First about the YCbCr->RGB matrix:
      
      "I had the RGB->YCbCr matrix, inverted it and the values came out. But they
      should match the wikipedia article. Also keep in mind that the coefficients
      are in .12 in fixed point format, hence we need a 1<<12 factor. So let's
      try it:
      
      Kb=.114
      Kr=.299
      (1<<12) * 255/219 ~= 4769
      -(1<<12) * 255/112*(1-Kb)*Kb/(1-Kb-Kr) ~= -1605
      -(1<<12) * 255/112*(1-Kr)*Kr/(1-Kb-Kr) ~= -3330
      (1<<12) * 255/112*(1-Kr) ~= 6537
      (1<<12) * 255/112*(1-Kb) ~= 8263
      
      "Looks like the same values to me."
      
      And then about the limits used for clamping:
      
      "> where did you get these min/max?
      
      "The hardware apparently deals in 10bit values, so we need to multiply everything
      by 4 when we start with the 8bit min/max values.
      
      Y = [16:235] * 4 = [64:940]
      CbCr = ([16:240] - 128) * 4 = [-112:112] * 4 = [-448:448]
      
      "The -128 being the -0.5 bias that the hardware already applied before
      the data entered the CSC unit."
      
      Raw data is also supplied in 10bpc in the registers.
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Reviewed-by Rodrigo Vivi <rodrigo.vivi@intel.com>
      [danvet: Copypaste explanations&math from the review discussion.]
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      6ca2aeb2
    • V
      drm/i915: Initialize new chv primary plane and pipe blender registers · c14b0485
      Ville Syrjälä 提交于
      CHV adds a bunch of new registers for primary plane size/position and
      pipe blender setup. Initialize all those registers to avoid nasty
      surprises. PRIMSIZE is especially important as without programming it
      the outout will be garbled whenever the primary plane size would not
      match what the BIOS set up.
      
      Also program the sprite constant alpha register to disable the constant
      alpha blending factor. This applies to vlv as well as chv.
      Signed-off-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Reviewed-by: NRodrigo Vivi <rodrigo.vivi@intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      c14b0485
    • G
      drm/i915: use intel_fb_obj() macros to assign gem objects · 77cde952
      Gustavo Padovan 提交于
      Use the macros makes the code cleaner and it also checks for a NULL fb.
      Signed-off-by: NGustavo Padovan <gustavo.padovan@collabora.co.uk>
      Reviewed-by: NVille Syrjälä <ville.syrjala@linux.intel.com>
      Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      77cde952