Lines Matching full:slots
3 * Manage cache of swap slots to be used for and returned from
10 * We allocate the swap slots from the global pool and put
17 * lock. We do not reuse the returned slots directly but
19 * allows the slots to coalesce and reduce fragmentation.
25 * The swap slots cache is protected by a mutex instead of
26 * a spin lock as when we search for slots with scan_swap_map,
42 /* Serialize swap slots cache enable/disable operations */
115 swp_entry_t *slots, *slots_ret; in alloc_swap_slot_cache() local
122 slots = kvcalloc(SWAP_SLOTS_CACHE_SIZE, sizeof(swp_entry_t), in alloc_swap_slot_cache()
124 if (!slots) in alloc_swap_slot_cache()
130 kvfree(slots); in alloc_swap_slot_cache()
136 if (cache->slots || cache->slots_ret) { in alloc_swap_slot_cache()
140 kvfree(slots); in alloc_swap_slot_cache()
156 * !cache->slots or !cache->slots_ret to know if it is safe to acquire in alloc_swap_slot_cache()
161 cache->slots = slots; in alloc_swap_slot_cache()
171 swp_entry_t *slots = NULL; in drain_slots_cache_cpu() local
174 if ((type & SLOTS_CACHE) && cache->slots) { in drain_slots_cache_cpu()
176 swapcache_free_entries(cache->slots + cache->cur, cache->nr); in drain_slots_cache_cpu()
179 if (free_slots && cache->slots) { in drain_slots_cache_cpu()
180 kvfree(cache->slots); in drain_slots_cache_cpu()
181 cache->slots = NULL; in drain_slots_cache_cpu()
190 slots = cache->slots_ret; in drain_slots_cache_cpu()
194 kvfree(slots); in drain_slots_cache_cpu()
205 * left over slots are in cache when we remove in __drain_swap_slots_cache()
208 * on swap slots when allocating memory and need in __drain_swap_slots_cache()
209 * to return swap slots to global pool. in __drain_swap_slots_cache()
222 * fill any swap slots in slots cache of such cpu. in __drain_swap_slots_cache()
223 * There are no slots on such cpu that need to be drained. in __drain_swap_slots_cache()
246 "without swap slots cache.\n", __func__)) in enable_swap_slots_cache()
266 cache->slots, 1); in refill_swap_slots_cache()
278 /* Swap slots cache may be deactivated before acquiring lock */ in free_swap_slot()
285 * Return slots to global pool. in free_swap_slot()
327 if (likely(check_cache_active() && cache->slots)) { in get_swap_page()
329 if (cache->slots) { in get_swap_page()
332 entry = cache->slots[cache->cur]; in get_swap_page()
333 cache->slots[cache->cur++].val = 0; in get_swap_page()