Home
last modified time | relevance | path

Searched full:pinned (Results 1 – 25 of 568) sorted by relevance

12345678910>>...23

/linux-6.12.1/drivers/gpu/drm/xe/
Dxe_bo_evict.c18 * Evict non-pinned user BOs first (via GPU), evict pinned external BOs next
19 * (via GPU), wait for evictions, and finally evict pinned kernel BOs via CPU.
60 /* Pinned user memory in VRAM */ in xe_bo_evict_all()
62 spin_lock(&xe->pinned.lock); in xe_bo_evict_all()
64 bo = list_first_entry_or_null(&xe->pinned.external_vram, in xe_bo_evict_all()
70 spin_unlock(&xe->pinned.lock); in xe_bo_evict_all()
77 spin_lock(&xe->pinned.lock); in xe_bo_evict_all()
79 &xe->pinned.external_vram); in xe_bo_evict_all()
80 spin_unlock(&xe->pinned.lock); in xe_bo_evict_all()
84 spin_lock(&xe->pinned.lock); in xe_bo_evict_all()
[all …]
Dxe_bo_doc.h31 * are in the GGTT), are pinned (can't move or be evicted at runtime), have a
35 * More details of why kernel BOs are pinned and contiguous below.
43 * user BOs are evictable and user BOs are never pinned by XE. The allocation of
134 * A simple TTM call (ttm_resource_manager_evict_all) can move all non-pinned
135 * (user) BOs to sysmem. External BOs that are pinned need to be manually
141 * TTM memcpy (CPU) to move any kernel (pinned) BO on either suspend or resume.
145 * for simplity, we enforce that all kernel (pinned) BOs are contiguous and
148 * Pinned external BOs in VRAM are restored on resume via the GPU.
171 * Make some kernel BO evictable rather than pinned. An example of this would be
Dxe_device_types.h366 /** @pinned: pinned BO state */
368 /** @pinned.lock: protected pinned BO list state */
370 /** @pinned.kernel_bo_present: pinned kernel BO that are present */
372 /** @pinned.evicted: pinned BO that have been evicted */
374 /** @pinned.external_vram: pinned external BO in vram*/
376 } pinned; member
/linux-6.12.1/drivers/infiniband/hw/hfi1/
Dpin_system.c119 int pinned, cleared; in pin_system_pages() local
138 pinned = hfi1_acquire_user_pages(current->mm, start_address, npages, 0, in pin_system_pages()
141 if (pinned < 0) { in pin_system_pages()
143 SDMA_DBG(req, "pinned %d", pinned); in pin_system_pages()
144 return pinned; in pin_system_pages()
146 if (pinned != npages) { in pin_system_pages()
147 unpin_vector_pages(current->mm, pages, node->npages, pinned); in pin_system_pages()
148 SDMA_DBG(req, "npages %u pinned %d", npages, pinned); in pin_system_pages()
155 atomic_add(pinned, &pq->n_locked); in pin_system_pages()
156 SDMA_DBG(req, "done. pinned %d", pinned); in pin_system_pages()
[all …]
Duser_exp_rcv.c122 * Release pinned receive buffer pages.
161 int pinned; in pin_rcv_pages() local
179 * pages, accept the amount pinned so far and program only that. in pin_rcv_pages()
187 pinned = hfi1_acquire_user_pages(current->mm, vaddr, npages, true, pages); in pin_rcv_pages()
188 if (pinned <= 0) { in pin_rcv_pages()
190 return pinned; in pin_rcv_pages()
193 fd->tid_n_pinned += pinned; in pin_rcv_pages()
194 return pinned; in pin_rcv_pages()
249 int ret = 0, need_group = 0, pinned; in hfi1_user_exp_rcv_setup() local
288 pinned = pin_rcv_pages(fd, tidbuf); in hfi1_user_exp_rcv_setup()
[all …]
/linux-6.12.1/drivers/infiniband/core/
Dumem.c140 * @access: IB_ACCESS_xxx flags for memory being pinned
153 int pinned, ret; in ib_umem_get() local
213 pinned = pin_user_pages_fast(cur_base, in ib_umem_get()
218 if (pinned < 0) { in ib_umem_get()
219 ret = pinned; in ib_umem_get()
223 cur_base += pinned * PAGE_SIZE; in ib_umem_get()
224 npages -= pinned; in ib_umem_get()
226 &umem->sgt_append, page_list, pinned, 0, in ib_umem_get()
227 pinned << PAGE_SHIFT, ib_dma_max_seg_size(device), in ib_umem_get()
230 unpin_user_pages_dirty_lock(page_list, pinned, 0); in ib_umem_get()
[all …]
/linux-6.12.1/Documentation/core-api/
Dpin_user_pages.rst35 In other words, use pin_user_pages*() for DMA-pinned pages, and
89 Tracking dma-pinned pages
92 Some of the key design constraints, and solutions, for tracking dma-pinned
98 * False positives (reporting that a page is dma-pinned, when in fact it is not)
105 the upper bits in that field for a dma-pinned count. "Sort of", means that,
109 on it 1024 times, then it will appear to have a single dma-pinned count.
121 * Callers must specifically request "dma-pinned tracking of pages". In other
152 NOTE: Some pages, such as DAX pages, cannot be pinned with longterm pins. That's
202 The whole point of marking folios as "DMA-pinned" or "gup-pinned" is to be able
203 to query, "is this folio DMA-pinned?" That allows code such as folio_mkclean()
[all …]
/linux-6.12.1/rust/kernel/init/
Dmacros.rs72 //! This macro is used to specify which fields are structurally pinned and which fields are not. It
153 //! // Now we only want to implement `Unpin` for `Bar` when every structurally pinned field is
154 //! // `Unpin`. In other words, whether `Bar` is `Unpin` only depends on structurally pinned
178 //! // access to `&mut self` inside of `drop` even if the struct was pinned. This could lead to
394 //! let pinned = unsafe { ::core::pin::Pin::new_unchecked(self) };
398 //! ::kernel::init::PinnedDrop::drop(pinned, token);
526 /// This macro first parses the struct definition such that it separates pinned and not pinned
545 // identify fields marked with `#[pin]`, these fields are the 'pinned fields'. The user
546 // wants these to be structurally pinned. The rest of the fields are the
547 // 'not pinned fields'. Additionally we collect all fields, since we need them in the right
[all …]
/linux-6.12.1/Documentation/arch/powerpc/
Dpmu-ebb.rst53 existing "pinned" and "exclusive" attributes of perf_events. This means EBB
54 events will be given priority over other events, unless they are also pinned.
55 If an EBB event and a regular event are both pinned, then whichever is enabled
70 An EBB event must be created with the "pinned" and "exclusive" attributes set.
100 This behaviour occurs because the EBB event is pinned and exclusive. When the
101 EBB event is enabled it will force all other non-pinned events off the PMU. In
103 pinned on the PMU then the enable will not be successful.
/linux-6.12.1/tools/bpf/bpftool/Documentation/
Dbpftool-map.rst47 | *MAP* := { **id** *MAP_ID* | **pinned** *FILE* | **name** *MAP_NAME* }
49 | *PROG* := { **id** *PROG_ID* | **pinned** *FILE* | **tag** *PROG_TAG* | **name** *PROG_NAME* }
166 Show file names of pinned maps.
216 | **# bpftool map del pinned /sys/fs/bpf/map key 13 00 07 00**
224 processing. Note that the prog array map MUST be pinned into the BPF virtual
238 pinned /sys/fs/bpf/foo/xdp
242 pinned /sys/fs/bpf/foo/process
246 pinned /sys/fs/bpf/foo/debug
258 | **# bpftool map dump pinned /sys/fs/bpf/bar**
265 | **# bpftool map update pinned /sys/fs/bpf/bar key 0 0 0 0 value pinned /sys/fs/bpf/foo/debug**
[all …]
/linux-6.12.1/include/trace/events/
Dxen.h287 TP_PROTO(struct mm_struct *mm, unsigned long pfn, unsigned level, bool pinned),
288 TP_ARGS(mm, pfn, level, pinned),
293 __field(bool, pinned)
298 __entry->pinned = pinned),
301 __entry->pinned ? "" : "un")
305 TP_PROTO(unsigned long pfn, unsigned level, bool pinned),
306 TP_ARGS(pfn, level, pinned),
310 __field(bool, pinned)
314 __entry->pinned = pinned),
317 __entry->pinned ? "" : "un")
/linux-6.12.1/drivers/iommu/iommufd/
Diova_bitmap.c21 * subset of said IOVA space that is pinned by its parent structure (struct
44 /* page offset of the first user page pinned */
47 /* number of pages pinned */
50 /* pinned pages representing the bitmap data */
63 * The bitmap object uses one base page to store all the pinned pages
66 * 2M of bitmap data is pinned at a time. If the iova_bitmap page size is
184 * Bitmap address to be pinned is calculated via pointer arithmetic in iova_bitmap_get()
206 * offset of the page where pinned pages bit 0 is located. in iova_bitmap_get()
301 * the currently pinned bitmap pages.
328 * pinned data can cover. Afterwards, that is capped to in iova_bitmap_mapped_length()
[all …]
/linux-6.12.1/kernel/events/
Dhw_breakpoint.c54 /* Number of pinned CPU breakpoints in a CPU. */
56 /* Histogram of pinned task breakpoints in a CPU. */
67 /* Number of pinned CPU breakpoints globally. */
69 /* Number of pinned CPU-independent task breakpoints. */
300 * Return the maximum number of pinned breakpoints a task has in this CPU.
366 * Returns the max pinned breakpoint slots in a given
418 * Update the pinned CPU slots, in per-CPU bp_cpuinfo and in the in toggle_bp_slot()
439 * Update the pinned task slots, in per-CPU bp_cpuinfo and in the global in toggle_bp_slot()
485 /* Add this first CPU-pinned task breakpoint. */ in toggle_bp_slot()
488 /* Rebalance global task pinned histogram. */ in toggle_bp_slot()
[all …]
/linux-6.12.1/arch/powerpc/platforms/8xx/
DKconfig170 bool "Pinned Kernel TLBs"
174 table 4 TLBs can be pinned.
183 bool "Pinned TLB for DATA"
190 bool "Pinned TLB for IMMR"
199 bool "Pinned TLB for TEXT"
/linux-6.12.1/drivers/fpga/
Ddfl-afu-dma-region.c29 * @region: dma memory region to be pinned
39 int ret, pinned; in afu_dma_pin_pages() local
51 pinned = pin_user_pages_fast(region->user_addr, npages, FOLL_WRITE, in afu_dma_pin_pages()
53 if (pinned < 0) { in afu_dma_pin_pages()
54 ret = pinned; in afu_dma_pin_pages()
56 } else if (pinned != npages) { in afu_dma_pin_pages()
61 dev_dbg(dev, "%d pages pinned\n", pinned); in afu_dma_pin_pages()
66 unpin_user_pages(region->pages, pinned); in afu_dma_pin_pages()
/linux-6.12.1/drivers/gpu/drm/i915/gt/
Dintel_gt_buffer_pool.c107 if (node->pinned) { in pool_retire()
112 node->pinned = false; in pool_retire()
129 if (node->pinned) in intel_gt_buffer_pool_mark_used()
133 /* Hide this pinned object from the shrinker until retired */ in intel_gt_buffer_pool_mark_used()
135 node->pinned = true; in intel_gt_buffer_pool_mark_used()
153 node->pinned = false; in node_create()
Dintel_context.h73 * parent is pinned. in intel_context_to_parent()
99 * intel_context_lock_pinned - Stablises the 'pinned' status of the HW context
102 * Acquire a lock on the pinned status of the HW context, such that the context
113 * intel_context_is_pinned - Reports the 'pinned' status
117 * tables is pinned into memory and the GTT.
119 * Returns: true if the context is currently pinned for use by the GPU.
135 * intel_context_unlock_pinned - Releases the earlier locking of 'pinned' status
/linux-6.12.1/Documentation/infiniband/
Duser_verbs.rst54 amount of memory pinned in the process's pinned_vm, and checks that
57 Pages that are pinned multiple times are counted each time they are
58 pinned, so the value of pinned_vm may be an overestimate of the
59 number of pages pinned by a process.
/linux-6.12.1/drivers/s390/cio/
Dvfio_ccw_cp.c25 /* Array that receives the pinned pages. */
27 /* Number of pages pinned from @pa_iova. */
38 /* Pinned PAGEs for the original data. */
45 * @len: number of pages that should be pinned from @iova
88 * Only unpin if any pages were pinned to begin with, i.e. pa_nr > 0,
121 * Returns number of pages pinned upon success.
133 int pinned = 0, npage = 1; in page_array_pin() local
136 while (pinned < pa->pa_nr) { in page_array_pin()
137 dma_addr_t *first = &pa->pa_iova[pinned]; in page_array_pin()
140 if (pinned + npage < pa->pa_nr && in page_array_pin()
[all …]
/linux-6.12.1/mm/
Dgup.c42 * We only pin anonymous pages if they are exclusive. Once pinned, we in sanity_check_pinned_pages()
46 * We'd like to verify that our pinned anonymous pages are still mapped in sanity_check_pinned_pages()
162 * so that the page really is pinned. in try_grab_folio()
178 * unpin_user_page() - release a dma-pinned page
181 * Pages that were pinned via pin_user_pages*() must be released via either
194 * unpin_folio() - release a dma-pinned folio
197 * Folios that were pinned via memfd_pin_folios() or other similar routines
207 * folio_add_pin - Try to get an additional pin on a pinned folio
208 * @folio: The folio to be pinned
221 * pinned. in folio_add_pin()
[all …]
/linux-6.12.1/tools/testing/selftests/bpf/prog_tests/
Dpinning.c65 /* check that pinmap was pinned */ in test_pinning()
70 /* check that nopinmap was *not* pinned */ in test_pinning()
76 /* check that nopinmap2 was *not* pinned */ in test_pinning()
151 /* check that nopinmap was pinned at the custom path */ in test_pinning()
196 /* nopinmap2 should have been pinned and cleaned up again */ in test_pinning()
220 /* check that pinmap was pinned at the custom path */ in test_pinning()
265 /* check that pinmap was pinned at the custom path */ in test_pinning()
/linux-6.12.1/include/linux/
Drmap.h403 * If this folio may have been pinned by the parent process, in __folio_try_dup_anon_rmap()
406 * guarantee the pinned folio won't be randomly replaced in the in __folio_try_dup_anon_rmap()
415 * copying if the folio maybe pinned. in __folio_try_dup_anon_rmap()
465 * Duplicating the mappings can only fail if the folio may be pinned; device
466 * private folios cannot get pinned and consequently this function cannot fail
501 * Duplicating the mapping can only fail if the folio may be pinned; device
502 * private folios cannot get pinned and consequently this function cannot fail
530 /* device private folios cannot get pinned via GUP. */ in __folio_try_share_anon_rmap()
538 * the page is not pinned and that concurrent GUP-fast won't succeed in in __folio_try_share_anon_rmap()
543 * (A2) Check if the page is pinned; back off if so. in __folio_try_share_anon_rmap()
[all …]
/linux-6.12.1/drivers/gpu/drm/i915/selftests/
Di915_gem_evict.c114 /* Fill the GGTT with pinned objects and try to evict one. */ in igt_evict_something()
120 /* Everything is pinned, nothing should happen */ in igt_evict_something()
162 /* Fill the GGTT with pinned objects and then try to pin one more. in igt_overcommit()
201 /* Fill the GGTT with pinned objects and try to evict a range. */ in igt_evict_for_vma()
207 /* Everything is pinned, nothing should happen */ in igt_evict_for_vma()
309 /* Attempt to remove the first *pinned* vma, by removing the (empty) in igt_evict_for_cache_color()
340 /* Fill the GGTT with pinned objects and try to evict everything. */ in igt_evict_vm()
346 /* Everything is pinned, nothing should happen */ in igt_evict_vm()
480 /* Keep every request/ctx pinned until we are full */ in igt_evict_contexts()
/linux-6.12.1/drivers/gpu/drm/i915/gem/
Di915_gem_userptr.c239 int pinned, ret; in i915_gem_object_userptr_submit_init() local
267 pinned = 0; in i915_gem_object_userptr_submit_init()
268 while (pinned < num_pages) { in i915_gem_object_userptr_submit_init()
269 ret = pin_user_pages_fast(obj->userptr.ptr + pinned * PAGE_SIZE, in i915_gem_object_userptr_submit_init()
270 num_pages - pinned, gup_flags, in i915_gem_object_userptr_submit_init()
271 &pvec[pinned]); in i915_gem_object_userptr_submit_init()
275 pinned += ret; in i915_gem_object_userptr_submit_init()
303 unpin_user_pages(pvec, pinned); in i915_gem_object_userptr_submit_init()
452 * restriction is that we do not allow userptr surfaces to be pinned to the
/linux-6.12.1/arch/arm64/mm/
Dcontext.c175 * If it is pinned, we can keep using it. Note that reserved in new_context()
176 * takes priority, because even if it is also pinned, we need to in new_context()
179 if (refcount_read(&mm->context.pinned)) in new_context()
285 if (refcount_inc_not_zero(&mm->context.pinned)) in arm64_mm_context_get()
304 refcount_set(&mm->context.pinned, 1); in arm64_mm_context_get()
329 if (refcount_dec_and_test(&mm->context.pinned)) { in arm64_mm_context_put()
394 * are pinned, there still is at least one empty slot in the ASID map. in asids_update_limit()

12345678910>>...23