mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 05:44:45 +01:00
drm/xe: Adjust page count tracepoints in shrinker
Page accounting can change via the shrinker without calling
xe_ttm_tt_unpopulate(), which normally updates page count tracepoints
through update_global_total_pages. Add a call to
update_global_total_pages when the shrinker successfully shrinks a BO.
v2:
- Don't adjust global accounting when pinning (Stuart)
Cc: stable@vger.kernel.org
Fixes: ce3d39fae3 ("drm/xe/bo: add GPU memory trace points")
Signed-off-by: Matthew Brost <matthew.brost@intel.com>
Reviewed-by: Stuart Summers <stuart.summers@intel.com>
Link: https://patch.msgid.link/20260107205732.2267541-1-matthew.brost@intel.com
This commit is contained in:
parent
3f0e3af468
commit
cc54eabdfb
1 changed files with 7 additions and 2 deletions
|
|
@ -1054,6 +1054,7 @@ static long xe_bo_shrink_purge(struct ttm_operation_ctx *ctx,
|
|||
unsigned long *scanned)
|
||||
{
|
||||
struct xe_device *xe = ttm_to_xe_device(bo->bdev);
|
||||
struct ttm_tt *tt = bo->ttm;
|
||||
long lret;
|
||||
|
||||
/* Fake move to system, without copying data. */
|
||||
|
|
@ -1078,8 +1079,10 @@ static long xe_bo_shrink_purge(struct ttm_operation_ctx *ctx,
|
|||
.writeback = false,
|
||||
.allow_move = false});
|
||||
|
||||
if (lret > 0)
|
||||
if (lret > 0) {
|
||||
xe_ttm_tt_account_subtract(xe, bo->ttm);
|
||||
update_global_total_pages(bo->bdev, -(long)tt->num_pages);
|
||||
}
|
||||
|
||||
return lret;
|
||||
}
|
||||
|
|
@ -1165,8 +1168,10 @@ long xe_bo_shrink(struct ttm_operation_ctx *ctx, struct ttm_buffer_object *bo,
|
|||
if (needs_rpm)
|
||||
xe_pm_runtime_put(xe);
|
||||
|
||||
if (lret > 0)
|
||||
if (lret > 0) {
|
||||
xe_ttm_tt_account_subtract(xe, tt);
|
||||
update_global_total_pages(bo->bdev, -(long)tt->num_pages);
|
||||
}
|
||||
|
||||
out_unref:
|
||||
xe_bo_put(xe_bo);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue