[PATCH 02/12] drm/ttm: remove split btw highmen and lowmem page
Konrad Rzeszutek Wilk
konrad.wilk at oracle.com
Tue Nov 8 07:13:21 PST 2011
On Tue, Nov 08, 2011 at 08:56:17AM +0100, Thomas Hellstrom wrote:
> On 11/08/2011 12:40 AM, j.glisse at gmail.com wrote:
> >From: Jerome Glisse<jglisse at redhat.com>
> >
> >Split btw highmem and lowmem page was rendered useless by the
> >pool code. Remove it.
>
> Actually it was introduced so that we could call set_pages_array_xx
> when changing caching attributes of an existing TTM, since the
> set_pages_array_xx functions complained about highmem pages.
>
> That should've been fixed now in the pageattr code, though.
Yup (from __change_page_attr):
if (cpa->flags & CPA_PAGES_ARRAY) {
struct page *page = cpa->pages[cpa->curpage];
if (unlikely(PageHighMem(page)))
return 0;
>
> Reviewed-by: Thomas Hellstrom <thellstrom at vmware.com>
>
>
> > Note further cleanup would change the
> >ttm page allocation helper to actualy take an array instead
> >of relying on list this could drasticly reduce the number of
> >function call in the common case of allocation whole buffer.
> >
> >Signed-off-by: Jerome Glisse<jglisse at redhat.com>
> >Reviewed-by: Konrad Rzeszutek Wilk<konrad.wilk at oracle.com>
> >---
> > drivers/gpu/drm/ttm/ttm_tt.c | 11 ++---------
> > include/drm/ttm/ttm_bo_driver.h | 7 -------
> > 2 files changed, 2 insertions(+), 16 deletions(-)
> >
> >diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
> >index 82a1161..8b7a6d0 100644
> >--- a/drivers/gpu/drm/ttm/ttm_tt.c
> >+++ b/drivers/gpu/drm/ttm/ttm_tt.c
> >@@ -69,7 +69,7 @@ static struct page *__ttm_tt_get_page(struct ttm_tt *ttm, int index)
> > struct ttm_mem_global *mem_glob = ttm->glob->mem_glob;
> > int ret;
> >
> >- while (NULL == (p = ttm->pages[index])) {
> >+ if (NULL == (p = ttm->pages[index])) {
> >
> > INIT_LIST_HEAD(&h);
> >
> >@@ -85,10 +85,7 @@ static struct page *__ttm_tt_get_page(struct ttm_tt *ttm, int index)
> > if (unlikely(ret != 0))
> > goto out_err;
> >
> >- if (PageHighMem(p))
> >- ttm->pages[--ttm->first_himem_page] = p;
> >- else
> >- ttm->pages[++ttm->last_lomem_page] = p;
> >+ ttm->pages[index] = p;
> > }
> > return p;
> > out_err:
> >@@ -270,8 +267,6 @@ static void ttm_tt_free_alloced_pages(struct ttm_tt *ttm)
> > ttm_put_pages(&h, count, ttm->page_flags, ttm->caching_state,
> > ttm->dma_address);
> > ttm->state = tt_unpopulated;
> >- ttm->first_himem_page = ttm->num_pages;
> >- ttm->last_lomem_page = -1;
> > }
> >
> > void ttm_tt_destroy(struct ttm_tt *ttm)
> >@@ -315,8 +310,6 @@ struct ttm_tt *ttm_tt_create(struct ttm_bo_device *bdev, unsigned long size,
> >
> > ttm->glob = bdev->glob;
> > ttm->num_pages = (size + PAGE_SIZE - 1)>> PAGE_SHIFT;
> >- ttm->first_himem_page = ttm->num_pages;
> >- ttm->last_lomem_page = -1;
> > ttm->caching_state = tt_cached;
> > ttm->page_flags = page_flags;
> >
> >diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
> >index 37527d6..9da182b 100644
> >--- a/include/drm/ttm/ttm_bo_driver.h
> >+++ b/include/drm/ttm/ttm_bo_driver.h
> >@@ -136,11 +136,6 @@ enum ttm_caching_state {
> > * @dummy_read_page: Page to map where the ttm_tt page array contains a NULL
> > * pointer.
> > * @pages: Array of pages backing the data.
> >- * @first_himem_page: Himem pages are put last in the page array, which
> >- * enables us to run caching attribute changes on only the first part
> >- * of the page array containing lomem pages. This is the index of the
> >- * first himem page.
> >- * @last_lomem_page: Index of the last lomem page in the page array.
> > * @num_pages: Number of pages in the page array.
> > * @bdev: Pointer to the current struct ttm_bo_device.
> > * @be: Pointer to the ttm backend.
> >@@ -157,8 +152,6 @@ enum ttm_caching_state {
> > struct ttm_tt {
> > struct page *dummy_read_page;
> > struct page **pages;
> >- long first_himem_page;
> >- long last_lomem_page;
> > uint32_t page_flags;
> > unsigned long num_pages;
> > struct ttm_bo_global *glob;
More information about the dri-devel
mailing list