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