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#if IS_ENABLED(CONFIG_INFINIBAND_USER_ACCESS)
41extern const struct uverbs_object_def uverbs_object_comp_channel;
42extern const struct uverbs_object_def uverbs_object_cq;
43extern const struct uverbs_object_def uverbs_object_qp;
44extern const struct uverbs_object_def uverbs_object_rwq_ind_table;
45extern const struct uverbs_object_def uverbs_object_wq;
46extern const struct uverbs_object_def uverbs_object_srq;
47extern const struct uverbs_object_def uverbs_object_ah;
48extern const struct uverbs_object_def uverbs_object_flow;
49extern const struct uverbs_object_def uverbs_object_mr;
50extern const struct uverbs_object_def uverbs_object_mw;
51extern const struct uverbs_object_def uverbs_object_pd;
52extern const struct uverbs_object_def uverbs_object_xrcd;
53extern const struct uverbs_object_def uverbs_object_device;
54
55extern const struct uverbs_object_tree_def uverbs_default_objects;
56static inline const struct uverbs_object_tree_def *uverbs_default_get_objects(void)
57{
58 return &uverbs_default_objects;
59}
60#else
61static inline const struct uverbs_object_tree_def *uverbs_default_get_objects(void)
62{
63 return NULL;
64}
65#endif
66
67static inline struct ib_uobject *__uobj_get(const struct uverbs_obj_type *type,
68 bool write,
69 struct ib_ucontext *ucontext,
70 int id)
71{
72 return rdma_lookup_get_uobject(type, ucontext, id, write);
73}
74
75#define uobj_get_type(_object) uverbs_object_##_object.type_attrs
76
77#define uobj_get_read(_type, _id, _ucontext) \
78 __uobj_get(_type, false, _ucontext, _id)
79
80#define uobj_get_obj_read(_object, _id, _ucontext) \
81({ \
82 struct ib_uobject *__uobj = \
83 __uobj_get(uverbs_object_##_object.type_attrs, \
84 false, _ucontext, _id); \
85 \
86 (struct ib_##_object *)(IS_ERR(__uobj) ? NULL : __uobj->object);\
87})
88
89#define uobj_get_write(_type, _id, _ucontext) \
90 __uobj_get(_type, true, _ucontext, _id)
91
92static inline void uobj_put_read(struct ib_uobject *uobj)
93{
94 rdma_lookup_put_uobject(uobj, false);
95}
96
97#define uobj_put_obj_read(_obj) \
98 uobj_put_read((_obj)->uobject)
99
100static inline void uobj_put_write(struct ib_uobject *uobj)
101{
102 rdma_lookup_put_uobject(uobj, true);
103}
104
105static inline int __must_check uobj_remove_commit(struct ib_uobject *uobj)
106{
107 return rdma_remove_commit_uobject(uobj);
108}
109
110static inline void uobj_alloc_commit(struct ib_uobject *uobj)
111{
112 rdma_alloc_commit_uobject(uobj);
113}
114
115static inline void uobj_alloc_abort(struct ib_uobject *uobj)
116{
117 rdma_alloc_abort_uobject(uobj);
118}
119
120static inline struct ib_uobject *__uobj_alloc(const struct uverbs_obj_type *type,
121 struct ib_ucontext *ucontext)
122{
123 return rdma_alloc_begin_uobject(type, ucontext);
124}
125
126#define uobj_alloc(_type, ucontext) \
127 __uobj_alloc(_type, ucontext)
128
129#endif
130
131