.. | .. |
---|
1 | 1 | /* |
---|
| 2 | + * Copyright(c) 2020 Cornelis Networks, Inc. |
---|
2 | 3 | * Copyright(c) 2016 Intel Corporation. |
---|
3 | 4 | * |
---|
4 | 5 | * This file is provided under a dual BSD/GPLv2 license. When using or |
---|
.. | .. |
---|
54 | 55 | unsigned long len; |
---|
55 | 56 | unsigned long __last; |
---|
56 | 57 | struct rb_node node; |
---|
| 58 | + struct mmu_rb_handler *handler; |
---|
57 | 59 | struct list_head list; |
---|
| 60 | + struct kref refcount; |
---|
58 | 61 | }; |
---|
59 | 62 | |
---|
60 | 63 | /* |
---|
.. | .. |
---|
71 | 74 | void *evict_arg, bool *stop); |
---|
72 | 75 | }; |
---|
73 | 76 | |
---|
74 | | -int hfi1_mmu_rb_register(void *ops_arg, struct mm_struct *mm, |
---|
| 77 | +struct mmu_rb_handler { |
---|
| 78 | + struct mmu_notifier mn; |
---|
| 79 | + struct rb_root_cached root; |
---|
| 80 | + void *ops_arg; |
---|
| 81 | + spinlock_t lock; /* protect the RB tree */ |
---|
| 82 | + struct mmu_rb_ops *ops; |
---|
| 83 | + struct list_head lru_list; |
---|
| 84 | + struct work_struct del_work; |
---|
| 85 | + struct list_head del_list; |
---|
| 86 | + struct workqueue_struct *wq; |
---|
| 87 | +}; |
---|
| 88 | + |
---|
| 89 | +int hfi1_mmu_rb_register(void *ops_arg, |
---|
75 | 90 | struct mmu_rb_ops *ops, |
---|
76 | 91 | struct workqueue_struct *wq, |
---|
77 | 92 | struct mmu_rb_handler **handler); |
---|
78 | 93 | void hfi1_mmu_rb_unregister(struct mmu_rb_handler *handler); |
---|
79 | 94 | int hfi1_mmu_rb_insert(struct mmu_rb_handler *handler, |
---|
80 | 95 | struct mmu_rb_node *mnode); |
---|
| 96 | +void hfi1_mmu_rb_release(struct kref *refcount); |
---|
| 97 | + |
---|
81 | 98 | void hfi1_mmu_rb_evict(struct mmu_rb_handler *handler, void *evict_arg); |
---|
82 | | -void hfi1_mmu_rb_remove(struct mmu_rb_handler *handler, |
---|
83 | | - struct mmu_rb_node *mnode); |
---|
84 | | -bool hfi1_mmu_rb_remove_unless_exact(struct mmu_rb_handler *handler, |
---|
85 | | - unsigned long addr, unsigned long len, |
---|
86 | | - struct mmu_rb_node **rb_node); |
---|
| 99 | +struct mmu_rb_node *hfi1_mmu_rb_get_first(struct mmu_rb_handler *handler, |
---|
| 100 | + unsigned long addr, |
---|
| 101 | + unsigned long len); |
---|
87 | 102 | |
---|
88 | 103 | #endif /* _HFI1_MMU_RB_H */ |
---|