1. 19 1月, 2011 3 次提交
  2. 14 1月, 2011 1 次提交
  3. 12 1月, 2011 10 次提交
  4. 23 12月, 2010 2 次提交
  5. 18 12月, 2010 1 次提交
  6. 17 12月, 2010 3 次提交
    • C
      drm/i915: Enable EI mode for RCx decision making on Sandybridge · 9c3d2f7f
      Chris Wilson 提交于
      And no I have no idea what the difference is either, just that is the
      recommendation.
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      9c3d2f7f
    • M
      drm/i915: Add Guess-o-matic for pageflip timestamping. · 49b14a5c
      Mario Kleiner 提交于
      This patch changes the strategy for pageflip completion
      timestamping. It detects if the pageflip completion
      routine gets executed before or after drm_handle_vblank,
      and thereby decides if the returned vblank count and
      timestamp must be incremented by 1 frame(duration) or
      not. It compares the current system time at invocation
      against the current vblank timestamp. If the difference
      is more than 0.9 video refresh interval durations then
      it assumes the vblank timestamp and count are outdated
      and need to be incremented and does so. Otherwise it
      assumes a delayed pageflip irq and doesn't correct
      the timestamp and count.
      
      Advantage of this patch: Pageflip timestamping becomes
      more robust against implementation errors and is
      maintenance free for future GPU's.
      
      Disadvantage: A few dozen (hundred?) nsecs extra
      time spent in pageflip irq handler for each flip,
      compared to hard-coded per-gpu settings?
      Signed-off-by: NMario Kleiner <mario.kleiner@tuebingen.mpg.de>
      Acked-by: NJesse Barnes <jbarnes@virtuousgeek.org>
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      49b14a5c
    • M
      drm/i915: Add support for precise vblank timestamping (v2) · 0af7e4df
      Mario Kleiner 提交于
      v2: Change IS_IRONLAKE to IS_GEN5 to adapt to 2.6.37
      
      This patch adds new functions for use by the drm core:
      
      .get_vblank_timestamp() provides a precise timestamp
      for the end of the most recent (or current) vblank
      interval of a given crtc, as needed for the DRI2
      implementation of the OML_sync_control extension.
      It is a thin wrapper around the drm function
      drm_calc_vbltimestamp_from_scanoutpos() which does
      almost all the work.
      
      .get_scanout_position() provides the current horizontal
      and vertical video scanout position and "in vblank"
      status of a given crtc, as needed by the drm for use by
      drm_calc_vbltimestamp_from_scanoutpos().
      
      The patch modifies the pageflip completion routine
      to use these precise vblank timestamps as the timestamps
      for pageflip completion events.
      
      This code has been only tested on a HP-Mini Netbook with
      Atom processor and Intel 945GME gpu. The codepath for
      (IS_G4X(dev) || IS_GEN5(dev) || IS_GEN6(dev)) gpu's
      has not been tested so far due to lack of hardware.
      Signed-off-by: NMario Kleiner <mario.kleiner@tuebingen.mpg.de>
      Acked-by: NJesse Barnes <jbarnes@virtuousgeek.org>
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      0af7e4df
  7. 15 12月, 2010 4 次提交
  8. 10 12月, 2010 2 次提交
  9. 08 12月, 2010 1 次提交
  10. 06 12月, 2010 2 次提交
  11. 05 12月, 2010 5 次提交
  12. 04 12月, 2010 3 次提交
  13. 03 12月, 2010 1 次提交
  14. 02 12月, 2010 1 次提交
    • C
      drm/i915: Pipelined fencing [infrastructure] · d9e86c0e
      Chris Wilson 提交于
      With this change, every batchbuffer can use all available fences (save
      pinned and scanout, of course) without ever stalling the gpu!
      
      In theory. Currently the actual pipelined update of the register is
      disabled due to some stability issues. However, just the deferred update
      is a significant win.
      
      Based on a series of patches by Daniel Vetter.
      
      The premise is that before every access to a buffer through the GTT we
      have to declare whether we need a register or not. If the access is by
      the GPU, a pipelined update to the register is made via the ringbuffer,
      and we track the last seqno of the batches that access it. If by the
      CPU we wait for the last GPU access and update the register (either
      to clear or to set it for the current buffer).
      
      One advantage of being able to pipeline changes is that we can defer the
      actual updating of the fence register until we first need to access the
      object through the GTT, i.e. we can eliminate the stall on set_tiling.
      This is important as the userspace bo cache does not track the tiling
      status of active buffers which generate frequent stalls on gen3 when
      enabling tiling for an already bound buffer.
      Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
      Reviewed-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
      d9e86c0e
  15. 30 11月, 2010 1 次提交