xref: /f-stack/lib/include/vm/uma_int.h (revision 2317ada5)
1a9643ea8Slogwang /*
2a9643ea8Slogwang  * Copyright (c) 2010 Kip Macy All rights reserved.
3*2317ada5Sfengbojiang  * Copyright (C) 2017-2021 THL A29 Limited, a Tencent company.
4a9643ea8Slogwang  * All rights reserved.
5a9643ea8Slogwang  *
6a9643ea8Slogwang  * Redistribution and use in source and binary forms, with or without
7a9643ea8Slogwang  * modification, are permitted provided that the following conditions are met:
8a9643ea8Slogwang  *
9a9643ea8Slogwang  * 1. Redistributions of source code must retain the above copyright notice, this
10a9643ea8Slogwang  *   list of conditions and the following disclaimer.
11a9643ea8Slogwang  * 2. Redistributions in binary form must reproduce the above copyright notice,
12a9643ea8Slogwang  *   this list of conditions and the following disclaimer in the documentation
13a9643ea8Slogwang  *   and/or other materials provided with the distribution.
14a9643ea8Slogwang  *
15a9643ea8Slogwang  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16a9643ea8Slogwang  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17a9643ea8Slogwang  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18a9643ea8Slogwang  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
19a9643ea8Slogwang  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20a9643ea8Slogwang  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21a9643ea8Slogwang  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22a9643ea8Slogwang  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23a9643ea8Slogwang  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24a9643ea8Slogwang  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25a9643ea8Slogwang  *
26a9643ea8Slogwang  */
27a9643ea8Slogwang 
28a9643ea8Slogwang 
29a9643ea8Slogwang #ifndef _FSTACK_VM_UMA_INT_H_
30a9643ea8Slogwang #define _FSTACK_VM_UMA_INT_H_
31a9643ea8Slogwang 
32a9643ea8Slogwang #include <sys/mutex.h>
3322ce4affSfengbojiang #include <sys/sx.h>
34a9643ea8Slogwang 
35a9643ea8Slogwang #define vtoslab   vtoslab_native
3622ce4affSfengbojiang #define vtozoneslab vtozoneslab_native
3722ce4affSfengbojiang #define vsetzoneslab  vsetzoneslab_native
38a9643ea8Slogwang #include_next <vm/uma_int.h>
39a9643ea8Slogwang #undef vtoslab
4022ce4affSfengbojiang #undef vtozoneslab
4122ce4affSfengbojiang #undef vsetzoneslab
42a9643ea8Slogwang 
43a9643ea8Slogwang #undef UMA_MD_SMALL_ALLOC
44a9643ea8Slogwang 
45a9643ea8Slogwang #define critical_enter() do {} while(0)
46a9643ea8Slogwang #define critical_exit()  do {} while(0)
47a9643ea8Slogwang 
4822ce4affSfengbojiang #define sleepq_lock(w) do {} while(0)
4922ce4affSfengbojiang #define sleepq_release(w) do {} while(0)
5022ce4affSfengbojiang #define sleepq_add(a, b, c, d, e) do {} while(0)
5122ce4affSfengbojiang #define sleepq_wait(w, p) do {} while(0)
5222ce4affSfengbojiang 
5322ce4affSfengbojiang #define _vm_map_unlock(sx, arg) do {} while(0)
5422ce4affSfengbojiang 
55a9643ea8Slogwang extern int uma_page_mask;
56a9643ea8Slogwang 
5722ce4affSfengbojiang extern int __read_mostly vm_ndomains;
5822ce4affSfengbojiang 
59a9643ea8Slogwang #define UMA_PAGE_HASH(va) (((va) >> PAGE_SHIFT) & uma_page_mask)
60a9643ea8Slogwang 
61a9643ea8Slogwang typedef struct uma_page {
62a9643ea8Slogwang     LIST_ENTRY(uma_page) list_entry;
63a9643ea8Slogwang     vm_offset_t up_va;
64a9643ea8Slogwang     uma_slab_t up_slab;
6522ce4affSfengbojiang     uma_zone_t up_zone;
66a9643ea8Slogwang } *uma_page_t;
67a9643ea8Slogwang 
68a9643ea8Slogwang LIST_HEAD(uma_page_head, uma_page);
69a9643ea8Slogwang extern struct uma_page_head *uma_page_slab_hash;
70a9643ea8Slogwang 
71a9643ea8Slogwang static __inline uma_slab_t
vtoslab(vm_offset_t va)72a9643ea8Slogwang vtoslab(vm_offset_t va)
73a9643ea8Slogwang {
74a9643ea8Slogwang     struct uma_page_head *hash_list;
75a9643ea8Slogwang     uma_page_t up;
76a9643ea8Slogwang 
77a9643ea8Slogwang     hash_list = &uma_page_slab_hash[UMA_PAGE_HASH(va)];
78a9643ea8Slogwang     LIST_FOREACH(up, hash_list, list_entry)
79a9643ea8Slogwang         if (up->up_va == va)
80a9643ea8Slogwang             return (up->up_slab);
81a9643ea8Slogwang     return (NULL);
82a9643ea8Slogwang }
83a9643ea8Slogwang 
84a9643ea8Slogwang static __inline void
vtozoneslab(vm_offset_t va,uma_zone_t * zone,uma_slab_t * slab)8522ce4affSfengbojiang vtozoneslab(vm_offset_t va, uma_zone_t *zone, uma_slab_t *slab)
8622ce4affSfengbojiang {
8722ce4affSfengbojiang     struct uma_page_head *hash_list;
8822ce4affSfengbojiang     uma_page_t up;
8922ce4affSfengbojiang 
9022ce4affSfengbojiang     hash_list = &uma_page_slab_hash[UMA_PAGE_HASH(va)];
9122ce4affSfengbojiang     LIST_FOREACH(up, hash_list, list_entry)
9222ce4affSfengbojiang         if (up->up_va == va)
9322ce4affSfengbojiang             break;
9422ce4affSfengbojiang 
9522ce4affSfengbojiang     *slab = up->up_slab;
9622ce4affSfengbojiang     *zone = up->up_zone;
9722ce4affSfengbojiang }
9822ce4affSfengbojiang 
9922ce4affSfengbojiang static __inline void
vsetzoneslab(vm_offset_t va,uma_zone_t zone,uma_slab_t slab)10022ce4affSfengbojiang vsetzoneslab(vm_offset_t va, uma_zone_t zone, uma_slab_t slab)
101a9643ea8Slogwang {
102a9643ea8Slogwang     struct uma_page_head *hash_list;
103a9643ea8Slogwang     uma_page_t up;
104a9643ea8Slogwang     hash_list = &uma_page_slab_hash[UMA_PAGE_HASH(va)];
105a9643ea8Slogwang     LIST_FOREACH(up, hash_list, list_entry)
106a9643ea8Slogwang         if (up->up_va == va)
107a9643ea8Slogwang             break;
108a9643ea8Slogwang 
109a9643ea8Slogwang     if (up != NULL) {
110a9643ea8Slogwang         up->up_slab = slab;
11122ce4affSfengbojiang         up->up_zone = zone;
112a9643ea8Slogwang         return;
113a9643ea8Slogwang     }
114a9643ea8Slogwang 
115a9643ea8Slogwang     up = malloc(sizeof(*up), M_DEVBUF, M_WAITOK);
116a9643ea8Slogwang     up->up_va = va;
117a9643ea8Slogwang     up->up_slab = slab;
11822ce4affSfengbojiang     up->up_zone = zone;
119a9643ea8Slogwang     LIST_INSERT_HEAD(hash_list, up, list_entry);
120a9643ea8Slogwang }
121a9643ea8Slogwang 
122a9643ea8Slogwang #endif    /* _FSTACK_VM_UMA_INT_H_ */
123