Commit 11f20322 authored by Ville Syrjälä's avatar Ville Syrjälä

drm/i915: Move the NULL sg handling out from rotate_pages()

rotate_pages() checks to see if it got called with a NULL sg, and then
goes to extract it from sg->sgl. It always gets called with a NULL sg
for the first plane, so moving the initial 'sg=st->sgl' assignment out
into intel_rotate_fb_obj_pages() seems less special-casey.
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/1455569699-27905-9-git-send-email-ville.syrjala@linux.intel.com
parent 1663b9d6
...@@ -3377,11 +3377,6 @@ rotate_pages(const dma_addr_t *in, unsigned int offset, ...@@ -3377,11 +3377,6 @@ rotate_pages(const dma_addr_t *in, unsigned int offset,
unsigned int column, row; unsigned int column, row;
unsigned int src_idx; unsigned int src_idx;
if (!sg) {
st->nents = 0;
sg = st->sgl;
}
for (column = 0; column < width; column++) { for (column = 0; column < width; column++) {
src_idx = stride * (height - 1) + column; src_idx = stride * (height - 1) + column;
for (row = 0; row < height; row++) { for (row = 0; row < height; row++) {
...@@ -3443,11 +3438,14 @@ intel_rotate_fb_obj_pages(struct intel_rotation_info *rot_info, ...@@ -3443,11 +3438,14 @@ intel_rotate_fb_obj_pages(struct intel_rotation_info *rot_info,
i++; i++;
} }
st->nents = 0;
sg = st->sgl;
/* Rotate the pages. */ /* Rotate the pages. */
sg = rotate_pages(page_addr_list, 0, sg = rotate_pages(page_addr_list, 0,
rot_info->plane[0].width, rot_info->plane[0].height, rot_info->plane[0].width, rot_info->plane[0].height,
rot_info->plane[0].width, rot_info->plane[0].width,
st, NULL); st, sg);
/* Append the UV plane if NV12. */ /* Append the UV plane if NV12. */
if (rot_info->pixel_format == DRM_FORMAT_NV12) { if (rot_info->pixel_format == DRM_FORMAT_NV12) {
...@@ -3459,10 +3457,10 @@ intel_rotate_fb_obj_pages(struct intel_rotation_info *rot_info, ...@@ -3459,10 +3457,10 @@ intel_rotate_fb_obj_pages(struct intel_rotation_info *rot_info,
rot_info->uv_start_page = uv_start_page; rot_info->uv_start_page = uv_start_page;
rotate_pages(page_addr_list, rot_info->uv_start_page, sg = rotate_pages(page_addr_list, rot_info->uv_start_page,
rot_info->plane[1].width, rot_info->plane[1].height, rot_info->plane[1].width, rot_info->plane[1].height,
rot_info->plane[1].width, rot_info->plane[1].width,
st, sg); st, sg);
} }
DRM_DEBUG_KMS("Created rotated page mapping for object size %zu (%ux%u tiles, %u pages (%u plane 0)).\n", DRM_DEBUG_KMS("Created rotated page mapping for object size %zu (%ux%u tiles, %u pages (%u plane 0)).\n",
......
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