Commit 259a290e authored by Akinobu Mita's avatar Akinobu Mita Committed by Dave Airlie

gpu/drm/ttm: use copy_highpage

Use copy_highpage() to copy from one page to another.
Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
Cc: dri-devel@lists.freedesktop.org
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
parent 27796b46
...@@ -290,8 +290,6 @@ int ttm_tt_swapin(struct ttm_tt *ttm) ...@@ -290,8 +290,6 @@ int ttm_tt_swapin(struct ttm_tt *ttm)
struct file *swap_storage; struct file *swap_storage;
struct page *from_page; struct page *from_page;
struct page *to_page; struct page *to_page;
void *from_virtual;
void *to_virtual;
int i; int i;
int ret = -ENOMEM; int ret = -ENOMEM;
...@@ -311,11 +309,7 @@ int ttm_tt_swapin(struct ttm_tt *ttm) ...@@ -311,11 +309,7 @@ int ttm_tt_swapin(struct ttm_tt *ttm)
goto out_err; goto out_err;
preempt_disable(); preempt_disable();
from_virtual = kmap_atomic(from_page); copy_highpage(to_page, from_page);
to_virtual = kmap_atomic(to_page);
memcpy(to_virtual, from_virtual, PAGE_SIZE);
kunmap_atomic(to_virtual);
kunmap_atomic(from_virtual);
preempt_enable(); preempt_enable();
page_cache_release(from_page); page_cache_release(from_page);
} }
...@@ -336,8 +330,6 @@ int ttm_tt_swapout(struct ttm_tt *ttm, struct file *persistent_swap_storage) ...@@ -336,8 +330,6 @@ int ttm_tt_swapout(struct ttm_tt *ttm, struct file *persistent_swap_storage)
struct file *swap_storage; struct file *swap_storage;
struct page *from_page; struct page *from_page;
struct page *to_page; struct page *to_page;
void *from_virtual;
void *to_virtual;
int i; int i;
int ret = -ENOMEM; int ret = -ENOMEM;
...@@ -367,11 +359,7 @@ int ttm_tt_swapout(struct ttm_tt *ttm, struct file *persistent_swap_storage) ...@@ -367,11 +359,7 @@ int ttm_tt_swapout(struct ttm_tt *ttm, struct file *persistent_swap_storage)
goto out_err; goto out_err;
} }
preempt_disable(); preempt_disable();
from_virtual = kmap_atomic(from_page); copy_highpage(to_page, from_page);
to_virtual = kmap_atomic(to_page);
memcpy(to_virtual, from_virtual, PAGE_SIZE);
kunmap_atomic(to_virtual);
kunmap_atomic(from_virtual);
preempt_enable(); preempt_enable();
set_page_dirty(to_page); set_page_dirty(to_page);
mark_page_accessed(to_page); mark_page_accessed(to_page);
......
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