Commit d843310d authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Use intel_tile_{size,width,height}() in intel_gen4_compute_page_offset()

Make intel_gen4_compute_page_offset() ready for other tiling formats
besied X-tile by getting the tile dimensions through
intel_tile_{size,width,height}().
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Link: http://patchwork.freedesktop.org/patch/msgid/1452625717-9713-6-git-send-email-ville.syrjala@linux.intel.com
parent d9b3288e
...@@ -2464,15 +2464,20 @@ unsigned long intel_gen4_compute_page_offset(struct drm_i915_private *dev_priv, ...@@ -2464,15 +2464,20 @@ unsigned long intel_gen4_compute_page_offset(struct drm_i915_private *dev_priv,
unsigned int pitch) unsigned int pitch)
{ {
if (fb_modifier != DRM_FORMAT_MOD_NONE) { if (fb_modifier != DRM_FORMAT_MOD_NONE) {
unsigned int tile_size, tile_width, tile_height;
unsigned int tile_rows, tiles; unsigned int tile_rows, tiles;
tile_rows = *y / 8; tile_size = intel_tile_size(dev_priv);
*y %= 8; tile_width = intel_tile_width(dev_priv, fb_modifier, cpp);
tile_height = tile_size / tile_width;
tile_rows = *y / tile_height;
*y %= tile_height;
tiles = *x / (512/cpp); tiles = *x / (tile_width/cpp);
*x %= 512/cpp; *x %= tile_width/cpp;
return tile_rows * pitch * 8 + tiles * 4096; return tile_rows * pitch * tile_height + tiles * tile_size;
} else { } else {
unsigned int alignment = intel_linear_alignment(dev_priv) - 1; unsigned int alignment = intel_linear_alignment(dev_priv) - 1;
unsigned int offset; unsigned int offset;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment