1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33#ifndef _UVERBS_STD_TYPES__
34#define _UVERBS_STD_TYPES__
35
36#include <rdma/uverbs_types.h>
37#include <rdma/uverbs_ioctl.h>
38#include <rdma/ib_user_ioctl_verbs.h>
39
40#define UVERBS_OBJECT(id) uverbs_object_##id
41
42#if IS_ENABLED(CONFIG_INFINIBAND_USER_ACCESS)
43const struct uverbs_object_tree_def *uverbs_default_get_objects(void);
44#else
45static inline const struct uverbs_object_tree_def *uverbs_default_get_objects(void)
46{
47 return NULL;
48}
49#endif
50
51static inline struct ib_uobject *__uobj_get(const struct uverbs_obj_type *type,
52 bool write,
53 struct ib_ucontext *ucontext,
54 int id)
55{
56 return rdma_lookup_get_uobject(type, ucontext, id, write);
57}
58
59#define uobj_get_type(_object) UVERBS_OBJECT(_object).type_attrs
60
61#define uobj_get_read(_type, _id, _ucontext) \
62 __uobj_get(uobj_get_type(_type), false, _ucontext, _id)
63
64#define uobj_get_obj_read(_object, _type, _id, _ucontext) \
65({ \
66 struct ib_uobject *__uobj = \
67 __uobj_get(uobj_get_type(_type), \
68 false, _ucontext, _id); \
69 \
70 (struct ib_##_object *)(IS_ERR(__uobj) ? NULL : __uobj->object);\
71})
72
73#define uobj_get_write(_type, _id, _ucontext) \
74 __uobj_get(uobj_get_type(_type), true, _ucontext, _id)
75
76static inline void uobj_put_read(struct ib_uobject *uobj)
77{
78 rdma_lookup_put_uobject(uobj, false);
79}
80
81#define uobj_put_obj_read(_obj) \
82 uobj_put_read((_obj)->uobject)
83
84static inline void uobj_put_write(struct ib_uobject *uobj)
85{
86 rdma_lookup_put_uobject(uobj, true);
87}
88
89static inline int __must_check uobj_remove_commit(struct ib_uobject *uobj)
90{
91 return rdma_remove_commit_uobject(uobj);
92}
93
94static inline void uobj_alloc_commit(struct ib_uobject *uobj)
95{
96 rdma_alloc_commit_uobject(uobj);
97}
98
99static inline void uobj_alloc_abort(struct ib_uobject *uobj)
100{
101 rdma_alloc_abort_uobject(uobj);
102}
103
104static inline struct ib_uobject *__uobj_alloc(const struct uverbs_obj_type *type,
105 struct ib_ucontext *ucontext)
106{
107 return rdma_alloc_begin_uobject(type, ucontext);
108}
109
110#define uobj_alloc(_type, ucontext) \
111 __uobj_alloc(uobj_get_type(_type), ucontext)
112
113#endif
114
115