Merge tag 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost
[firefly-linux-kernel-4.4.55.git] / drivers / staging / lustre / lustre / osc / osc_dev.c
1 /*
2  * GPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 only,
8  * as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License version 2 for more details (a copy is included
14  * in the LICENSE file that accompanied this code).
15  *
16  * You should have received a copy of the GNU General Public License
17  * version 2 along with this program; If not, see
18  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
19  *
20  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21  * CA 95054 USA or visit www.sun.com if you need additional information or
22  * have any questions.
23  *
24  * GPL HEADER END
25  */
26 /*
27  * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
28  * Use is subject to license terms.
29  *
30  * Copyright (c) 2012, Intel Corporation.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  *
36  * Implementation of cl_device, cl_req for OSC layer.
37  *
38  *   Author: Nikita Danilov <nikita.danilov@sun.com>
39  */
40
41 #define DEBUG_SUBSYSTEM S_OSC
42
43 /* class_name2obd() */
44 #include <obd_class.h>
45
46 #include "osc_cl_internal.h"
47
48 /** \addtogroup osc
49  * @{
50  */
51
52 struct kmem_cache *osc_lock_kmem;
53 struct kmem_cache *osc_object_kmem;
54 struct kmem_cache *osc_thread_kmem;
55 struct kmem_cache *osc_session_kmem;
56 struct kmem_cache *osc_req_kmem;
57 struct kmem_cache *osc_extent_kmem;
58 struct kmem_cache *osc_quota_kmem;
59
60 struct lu_kmem_descr osc_caches[] = {
61         {
62                 .ckd_cache = &osc_lock_kmem,
63                 .ckd_name  = "osc_lock_kmem",
64                 .ckd_size  = sizeof (struct osc_lock)
65         },
66         {
67                 .ckd_cache = &osc_object_kmem,
68                 .ckd_name  = "osc_object_kmem",
69                 .ckd_size  = sizeof (struct osc_object)
70         },
71         {
72                 .ckd_cache = &osc_thread_kmem,
73                 .ckd_name  = "osc_thread_kmem",
74                 .ckd_size  = sizeof (struct osc_thread_info)
75         },
76         {
77                 .ckd_cache = &osc_session_kmem,
78                 .ckd_name  = "osc_session_kmem",
79                 .ckd_size  = sizeof (struct osc_session)
80         },
81         {
82                 .ckd_cache = &osc_req_kmem,
83                 .ckd_name  = "osc_req_kmem",
84                 .ckd_size  = sizeof (struct osc_req)
85         },
86         {
87                 .ckd_cache = &osc_extent_kmem,
88                 .ckd_name  = "osc_extent_kmem",
89                 .ckd_size  = sizeof (struct osc_extent)
90         },
91         {
92                 .ckd_cache = &osc_quota_kmem,
93                 .ckd_name  = "osc_quota_kmem",
94                 .ckd_size  = sizeof(struct osc_quota_info)
95         },
96         {
97                 .ckd_cache = NULL
98         }
99 };
100
101 struct lock_class_key osc_ast_guard_class;
102
103 /*****************************************************************************
104  *
105  * Type conversions.
106  *
107  */
108
109 static struct lu_device *osc2lu_dev(struct osc_device *osc)
110 {
111         return &osc->od_cl.cd_lu_dev;
112 }
113
114 /*****************************************************************************
115  *
116  * Osc device and device type functions.
117  *
118  */
119
120 static void *osc_key_init(const struct lu_context *ctx,
121                          struct lu_context_key *key)
122 {
123         struct osc_thread_info *info;
124
125         OBD_SLAB_ALLOC_PTR_GFP(info, osc_thread_kmem, GFP_NOFS);
126         if (info == NULL)
127                 info = ERR_PTR(-ENOMEM);
128         return info;
129 }
130
131 static void osc_key_fini(const struct lu_context *ctx,
132                          struct lu_context_key *key, void *data)
133 {
134         struct osc_thread_info *info = data;
135         OBD_SLAB_FREE_PTR(info, osc_thread_kmem);
136 }
137
138 struct lu_context_key osc_key = {
139         .lct_tags = LCT_CL_THREAD,
140         .lct_init = osc_key_init,
141         .lct_fini = osc_key_fini
142 };
143
144 static void *osc_session_init(const struct lu_context *ctx,
145                               struct lu_context_key *key)
146 {
147         struct osc_session *info;
148
149         OBD_SLAB_ALLOC_PTR_GFP(info, osc_session_kmem, GFP_NOFS);
150         if (info == NULL)
151                 info = ERR_PTR(-ENOMEM);
152         return info;
153 }
154
155 static void osc_session_fini(const struct lu_context *ctx,
156                              struct lu_context_key *key, void *data)
157 {
158         struct osc_session *info = data;
159         OBD_SLAB_FREE_PTR(info, osc_session_kmem);
160 }
161
162 struct lu_context_key osc_session_key = {
163         .lct_tags = LCT_SESSION,
164         .lct_init = osc_session_init,
165         .lct_fini = osc_session_fini
166 };
167
168 /* type constructor/destructor: osc_type_{init,fini,start,stop}(). */
169 LU_TYPE_INIT_FINI(osc, &osc_key, &osc_session_key);
170
171 static int osc_cl_process_config(const struct lu_env *env,
172                                  struct lu_device *d, struct lustre_cfg *cfg)
173 {
174         return osc_process_config_base(d->ld_obd, cfg);
175 }
176
177 static const struct lu_device_operations osc_lu_ops = {
178         .ldo_object_alloc      = osc_object_alloc,
179         .ldo_process_config    = osc_cl_process_config,
180         .ldo_recovery_complete = NULL
181 };
182
183 static const struct cl_device_operations osc_cl_ops = {
184         .cdo_req_init = osc_req_init
185 };
186
187 static int osc_device_init(const struct lu_env *env, struct lu_device *d,
188                            const char *name, struct lu_device *next)
189 {
190         return 0;
191 }
192
193 static struct lu_device *osc_device_fini(const struct lu_env *env,
194                                          struct lu_device *d)
195 {
196         return NULL;
197 }
198
199 static struct lu_device *osc_device_free(const struct lu_env *env,
200                                          struct lu_device *d)
201 {
202         struct osc_device *od = lu2osc_dev(d);
203
204         cl_device_fini(lu2cl_dev(d));
205         OBD_FREE_PTR(od);
206         return NULL;
207 }
208
209 static struct lu_device *osc_device_alloc(const struct lu_env *env,
210                                           struct lu_device_type *t,
211                                           struct lustre_cfg *cfg)
212 {
213         struct lu_device *d;
214         struct osc_device *od;
215         struct obd_device *obd;
216         int rc;
217
218         OBD_ALLOC_PTR(od);
219         if (od == NULL)
220                 return ERR_PTR(-ENOMEM);
221
222         cl_device_init(&od->od_cl, t);
223         d = osc2lu_dev(od);
224         d->ld_ops = &osc_lu_ops;
225         od->od_cl.cd_ops = &osc_cl_ops;
226
227         /* Setup OSC OBD */
228         obd = class_name2obd(lustre_cfg_string(cfg, 0));
229         LASSERT(obd != NULL);
230         rc = osc_setup(obd, cfg);
231         if (rc) {
232                 osc_device_free(env, d);
233                 return ERR_PTR(rc);
234         }
235         od->od_exp = obd->obd_self_export;
236         return d;
237 }
238
239 static const struct lu_device_type_operations osc_device_type_ops = {
240         .ldto_init = osc_type_init,
241         .ldto_fini = osc_type_fini,
242
243         .ldto_start = osc_type_start,
244         .ldto_stop  = osc_type_stop,
245
246         .ldto_device_alloc = osc_device_alloc,
247         .ldto_device_free  = osc_device_free,
248
249         .ldto_device_init    = osc_device_init,
250         .ldto_device_fini    = osc_device_fini
251 };
252
253 struct lu_device_type osc_device_type = {
254         .ldt_tags     = LU_DEVICE_CL,
255         .ldt_name     = LUSTRE_OSC_NAME,
256         .ldt_ops      = &osc_device_type_ops,
257         .ldt_ctx_tags = LCT_CL_THREAD
258 };
259
260 /** @} osc */