[PATCH 02/12] drm/ttm: remove split btw highmen and lowmem page
Thomas Hellstrom
thellstrom at vmware.com
Mon Nov 7 23:56:17 PST 2011
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.
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