Skip to content

Make host USM resident before kernel use#585

Draft
michel2323 wants to merge 1 commit into
mainfrom
host-usm-make-resident
Draft

Make host USM resident before kernel use#585
michel2323 wants to merge 1 commit into
mainfrom
host-usm-make-resident

Conversation

@michel2323

Copy link
Copy Markdown
Member

Summary

Host USM allocations (HostBuffer) and the host pattern buffer used by fill! were never made resident on the device, unlike DeviceBuffer and SharedBuffer allocations (which already call make_resident). A GPU kernel that reads a non-resident host buffer can take a NotPresent pagefault under GC/allocation churn, even though host USM is nominally device-accessible.

This makes host USM resident at allocation time (src/pool.jl) and for fill!'s pattern buffer (src/array.jl), removing the asymmetry with device/shared USM.

Notes

Extracted as a standalone, stack-independent fix from the Aurora LTS work; the residency omission is a real asymmetry on main regardless of runtime.

🤖 Generated with Claude Code

Host USM allocations (HostBuffer) and the host pattern buffer used by
`fill!` were never made resident on the device, unlike DeviceBuffer and
SharedBuffer allocations (which already call `make_resident`). A GPU
kernel that reads a non-resident host buffer can take a NotPresent
pagefault under GC/allocation churn, even though host USM is nominally
device-accessible.

Make host USM resident at allocation time and for `fill!`'s pattern
buffer, removing the asymmetry with device/shared USM.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
@codecov

codecov Bot commented Jun 18, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 80.90%. Comparing base (e995a63) to head (aec725f).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #585      +/-   ##
==========================================
- Coverage   80.92%   80.90%   -0.02%     
==========================================
  Files          48       48              
  Lines        3234     3237       +3     
==========================================
+ Hits         2617     2619       +2     
- Misses        617      618       +1     

☔ View full report in Codecov by Harness.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant