diff options
| author | Grant Likely <grant.likely@secretlab.ca> | 2010-02-02 03:05:22 -0500 |
|---|---|---|
| committer | Grant Likely <grant.likely@secretlab.ca> | 2010-02-02 03:05:22 -0500 |
| commit | fb7899b1f0b748ef966071f5dc23c59ebd57d08f (patch) | |
| tree | 2f13f9d8607871a60334608524e8b4e9447f5309 /drivers/gpu/drm/ttm/ttm_bo.c | |
| parent | 212b3c8b8ab94d983c2e0ee1821f17dd5b4e0859 (diff) | |
| parent | abe94c756c08d50566c09a65b9c7fe72f83071c5 (diff) | |
Merge commit 'v2.6.33-rc6' into secretlab/next-spi
Diffstat (limited to 'drivers/gpu/drm/ttm/ttm_bo.c')
| -rw-r--r-- | drivers/gpu/drm/ttm/ttm_bo.c | 69 |
1 files changed, 37 insertions, 32 deletions
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c index 2920f9a279e1..1a3e909b7bba 100644 --- a/drivers/gpu/drm/ttm/ttm_bo.c +++ b/drivers/gpu/drm/ttm/ttm_bo.c | |||
| @@ -426,7 +426,8 @@ moved: | |||
| 426 | bdev->man[bo->mem.mem_type].gpu_offset; | 426 | bdev->man[bo->mem.mem_type].gpu_offset; |
| 427 | bo->cur_placement = bo->mem.placement; | 427 | bo->cur_placement = bo->mem.placement; |
| 428 | spin_unlock(&bo->lock); | 428 | spin_unlock(&bo->lock); |
| 429 | } | 429 | } else |
| 430 | bo->offset = 0; | ||
| 430 | 431 | ||
| 431 | return 0; | 432 | return 0; |
| 432 | 433 | ||
| @@ -523,52 +524,44 @@ static int ttm_bo_cleanup_refs(struct ttm_buffer_object *bo, bool remove_all) | |||
| 523 | static int ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all) | 524 | static int ttm_bo_delayed_delete(struct ttm_bo_device *bdev, bool remove_all) |
| 524 | { | 525 | { |
| 525 | struct ttm_bo_global *glob = bdev->glob; | 526 | struct ttm_bo_global *glob = bdev->glob; |
| 526 | struct ttm_buffer_object *entry, *nentry; | 527 | struct ttm_buffer_object *entry = NULL; |
| 527 | struct list_head *list, *next; | 528 | int ret = 0; |
| 528 | int ret; | ||
| 529 | 529 | ||
| 530 | spin_lock(&glob->lru_lock); | 530 | spin_lock(&glob->lru_lock); |
| 531 | list_for_each_safe(list, next, &bdev->ddestroy) { | 531 | if (list_empty(&bdev->ddestroy)) |
| 532 | entry = list_entry(list, struct ttm_buffer_object, ddestroy); | 532 | goto out_unlock; |
| 533 | nentry = NULL; | ||
| 534 | 533 | ||
| 535 | /* | 534 | entry = list_first_entry(&bdev->ddestroy, |
| 536 | * Protect the next list entry from destruction while we | 535 | struct ttm_buffer_object, ddestroy); |
| 537 | * unlock the lru_lock. | 536 | kref_get(&entry->list_kref); |
| 538 | */ | ||
| 539 | 537 | ||
| 540 | if (next != &bdev->ddestroy) { | 538 | for (;;) { |
| 541 | nentry = list_entry(next, struct ttm_buffer_object, | 539 | struct ttm_buffer_object *nentry = NULL; |
| 542 | ddestroy); | 540 | |
| 541 | if (entry->ddestroy.next != &bdev->ddestroy) { | ||
| 542 | nentry = list_first_entry(&entry->ddestroy, | ||
| 543 | struct ttm_buffer_object, ddestroy); | ||
| 543 | kref_get(&nentry->list_kref); | 544 | kref_get(&nentry->list_kref); |
| 544 | } | 545 | } |
| 545 | kref_get(&entry->list_kref); | ||
| 546 | 546 | ||
| 547 | spin_unlock(&glob->lru_lock); | 547 | spin_unlock(&glob->lru_lock); |
| 548 | ret = ttm_bo_cleanup_refs(entry, remove_all); | 548 | ret = ttm_bo_cleanup_refs(entry, remove_all); |
| 549 | kref_put(&entry->list_kref, ttm_bo_release_list); | 549 | kref_put(&entry->list_kref, ttm_bo_release_list); |
| 550 | entry = nentry; | ||
| 551 | |||
| 552 | if (ret || !entry) | ||
| 553 | goto out; | ||
| 550 | 554 | ||
| 551 | spin_lock(&glob->lru_lock); | 555 | spin_lock(&glob->lru_lock); |
| 552 | if (nentry) { | 556 | if (list_empty(&entry->ddestroy)) |
| 553 | bool next_onlist = !list_empty(next); | ||
| 554 | spin_unlock(&glob->lru_lock); | ||
| 555 | kref_put(&nentry->list_kref, ttm_bo_release_list); | ||
| 556 | spin_lock(&glob->lru_lock); | ||
| 557 | /* | ||
| 558 | * Someone might have raced us and removed the | ||
| 559 | * next entry from the list. We don't bother restarting | ||
| 560 | * list traversal. | ||
| 561 | */ | ||
| 562 | |||
| 563 | if (!next_onlist) | ||
| 564 | break; | ||
| 565 | } | ||
| 566 | if (ret) | ||
| 567 | break; | 557 | break; |
| 568 | } | 558 | } |
| 569 | ret = !list_empty(&bdev->ddestroy); | ||
| 570 | spin_unlock(&glob->lru_lock); | ||
| 571 | 559 | ||
| 560 | out_unlock: | ||
| 561 | spin_unlock(&glob->lru_lock); | ||
| 562 | out: | ||
| 563 | if (entry) | ||
| 564 | kref_put(&entry->list_kref, ttm_bo_release_list); | ||
| 572 | return ret; | 565 | return ret; |
| 573 | } | 566 | } |
| 574 | 567 | ||
| @@ -950,6 +943,14 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo, | |||
| 950 | ttm_flag_masked(&cur_flags, placement->busy_placement[i], | 943 | ttm_flag_masked(&cur_flags, placement->busy_placement[i], |
| 951 | ~TTM_PL_MASK_MEMTYPE); | 944 | ~TTM_PL_MASK_MEMTYPE); |
| 952 | 945 | ||
| 946 | |||
| 947 | if (mem_type == TTM_PL_SYSTEM) { | ||
| 948 | mem->mem_type = mem_type; | ||
| 949 | mem->placement = cur_flags; | ||
| 950 | mem->mm_node = NULL; | ||
| 951 | return 0; | ||
| 952 | } | ||
| 953 | |||
| 953 | ret = ttm_bo_mem_force_space(bo, mem_type, placement, mem, | 954 | ret = ttm_bo_mem_force_space(bo, mem_type, placement, mem, |
| 954 | interruptible, no_wait); | 955 | interruptible, no_wait); |
| 955 | if (ret == 0 && mem->mm_node) { | 956 | if (ret == 0 && mem->mm_node) { |
| @@ -1844,6 +1845,9 @@ static int ttm_bo_swapout(struct ttm_mem_shrink *shrink) | |||
| 1844 | * anyone tries to access a ttm page. | 1845 | * anyone tries to access a ttm page. |
| 1845 | */ | 1846 | */ |
| 1846 | 1847 | ||
| 1848 | if (bo->bdev->driver->swap_notify) | ||
| 1849 | bo->bdev->driver->swap_notify(bo); | ||
| 1850 | |||
| 1847 | ret = ttm_tt_swapout(bo->ttm, bo->persistant_swap_storage); | 1851 | ret = ttm_tt_swapout(bo->ttm, bo->persistant_swap_storage); |
| 1848 | out: | 1852 | out: |
| 1849 | 1853 | ||
| @@ -1864,3 +1868,4 @@ void ttm_bo_swapout_all(struct ttm_bo_device *bdev) | |||
| 1864 | while (ttm_bo_swapout(&bdev->glob->shrink) == 0) | 1868 | while (ttm_bo_swapout(&bdev->glob->shrink) == 0) |
| 1865 | ; | 1869 | ; |
| 1866 | } | 1870 | } |
| 1871 | EXPORT_SYMBOL(ttm_bo_swapout_all); | ||
