Whamcloud - gitweb
LU-1030 osc: new IO engine implementation
[fs/lustre-release.git] / 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 /*
31  * This file is part of Lustre, http://www.lustre.org/
32  * Lustre is a trademark of Sun Microsystems, Inc.
33  *
34  * Implementation of cl_device, cl_req for OSC layer.
35  *
36  *   Author: Nikita Danilov <nikita.danilov@sun.com>
37  */
38
39 #define DEBUG_SUBSYSTEM S_OSC
40
41 /* class_name2obd() */
42 #include <obd_class.h>
43
44 #include "osc_cl_internal.h"
45
46 /** \addtogroup osc 
47  * @{ 
48  */
49
50 cfs_mem_cache_t *osc_page_kmem;
51 cfs_mem_cache_t *osc_lock_kmem;
52 cfs_mem_cache_t *osc_object_kmem;
53 cfs_mem_cache_t *osc_thread_kmem;
54 cfs_mem_cache_t *osc_session_kmem;
55 cfs_mem_cache_t *osc_req_kmem;
56 cfs_mem_cache_t *osc_extent_kmem;
57
58 struct lu_kmem_descr osc_caches[] = {
59         {
60                 .ckd_cache = &osc_page_kmem,
61                 .ckd_name  = "osc_page_kmem",
62                 .ckd_size  = sizeof (struct osc_page)
63         },
64         {
65                 .ckd_cache = &osc_lock_kmem,
66                 .ckd_name  = "osc_lock_kmem",
67                 .ckd_size  = sizeof (struct osc_lock)
68         },
69         {
70                 .ckd_cache = &osc_object_kmem,
71                 .ckd_name  = "osc_object_kmem",
72                 .ckd_size  = sizeof (struct osc_object)
73         },
74         {
75                 .ckd_cache = &osc_thread_kmem,
76                 .ckd_name  = "osc_thread_kmem",
77                 .ckd_size  = sizeof (struct osc_thread_info)
78         },
79         {
80                 .ckd_cache = &osc_session_kmem,
81                 .ckd_name  = "osc_session_kmem",
82                 .ckd_size  = sizeof (struct osc_session)
83         },
84         {
85                 .ckd_cache = &osc_req_kmem,
86                 .ckd_name  = "osc_req_kmem",
87                 .ckd_size  = sizeof (struct osc_req)
88         },
89         {
90                 .ckd_cache = &osc_extent_kmem,
91                 .ckd_name  = "osc_extent_kmem",
92                 .ckd_size  = sizeof (struct osc_extent)
93         },
94         {
95                 .ckd_cache = NULL
96         }
97 };
98
99 cfs_lock_class_key_t osc_ast_guard_class;
100
101 /*****************************************************************************
102  *
103  * Type conversions.
104  *
105  */
106
107 static struct lu_device *osc2lu_dev(struct osc_device *osc)
108 {
109         return &osc->od_cl.cd_lu_dev;
110 }
111
112 /*****************************************************************************
113  *
114  * Osc device and device type functions.
115  *
116  */
117
118 static void *osc_key_init(const struct lu_context *ctx,
119                          struct lu_context_key *key)
120 {
121         struct osc_thread_info *info;
122
123         OBD_SLAB_ALLOC_PTR_GFP(info, osc_thread_kmem, CFS_ALLOC_IO);
124         if (info == NULL)
125                 info = ERR_PTR(-ENOMEM);
126         return info;
127 }
128
129 static void osc_key_fini(const struct lu_context *ctx,
130                          struct lu_context_key *key, void *data)
131 {
132         struct osc_thread_info *info = data;
133         OBD_SLAB_FREE_PTR(info, osc_thread_kmem);
134 }
135
136 struct lu_context_key osc_key = {
137         .lct_tags = LCT_CL_THREAD,
138         .lct_init = osc_key_init,
139         .lct_fini = osc_key_fini
140 };
141
142 static void *osc_session_init(const struct lu_context *ctx,
143                               struct lu_context_key *key)
144 {
145         struct osc_session *info;
146
147         OBD_SLAB_ALLOC_PTR_GFP(info, osc_session_kmem, CFS_ALLOC_IO);
148         if (info == NULL)
149                 info = ERR_PTR(-ENOMEM);
150         return info;
151 }
152
153 static void osc_session_fini(const struct lu_context *ctx,
154                              struct lu_context_key *key, void *data)
155 {
156         struct osc_session *info = data;
157         OBD_SLAB_FREE_PTR(info, osc_session_kmem);
158 }
159
160 struct lu_context_key osc_session_key = {
161         .lct_tags = LCT_SESSION,
162         .lct_init = osc_session_init,
163         .lct_fini = osc_session_fini
164 };
165
166 /* type constructor/destructor: osc_type_{init,fini,start,stop}(). */
167 LU_TYPE_INIT_FINI(osc, &osc_key, &osc_session_key);
168
169 static int osc_cl_process_config(const struct lu_env *env,
170                                  struct lu_device *d, struct lustre_cfg *cfg)
171 {
172         ENTRY;
173         RETURN(osc_process_config_base(d->ld_obd, cfg));
174 }
175
176 static const struct lu_device_operations osc_lu_ops = {
177         .ldo_object_alloc      = osc_object_alloc,
178         .ldo_process_config    = osc_cl_process_config,
179         .ldo_recovery_complete = NULL
180 };
181
182 static const struct cl_device_operations osc_cl_ops = {
183         .cdo_req_init = osc_req_init
184 };
185
186 static int osc_device_init(const struct lu_env *env, struct lu_device *d,
187                            const char *name, struct lu_device *next)
188 {
189         RETURN(0);
190 }
191
192 static struct lu_device *osc_device_fini(const struct lu_env *env,
193                                          struct lu_device *d)
194 {
195         return 0;
196 }
197
198 static struct lu_device *osc_device_free(const struct lu_env *env,
199                                          struct lu_device *d)
200 {
201         struct osc_device *od = lu2osc_dev(d);
202
203         cl_device_fini(lu2cl_dev(d));
204         OBD_FREE_PTR(od);
205         return NULL;
206 }
207
208 static struct lu_device *osc_device_alloc(const struct lu_env *env,
209                                           struct lu_device_type *t,
210                                           struct lustre_cfg *cfg)
211 {
212         struct lu_device *d;
213         struct osc_device *od;
214         struct obd_device *obd;
215         int rc;
216
217         OBD_ALLOC_PTR(od);
218         if (od == NULL)
219                 RETURN(ERR_PTR(-ENOMEM));
220
221         cl_device_init(&od->od_cl, t);
222         d = osc2lu_dev(od);
223         d->ld_ops = &osc_lu_ops;
224         od->od_cl.cd_ops = &osc_cl_ops;
225
226         /* Setup OSC OBD */
227         obd = class_name2obd(lustre_cfg_string(cfg, 0));
228         LASSERT(obd != NULL);
229         rc = osc_setup(obd, cfg);
230         if (rc) {
231                 osc_device_free(env, d);
232                 RETURN(ERR_PTR(rc));
233         }
234         od->od_exp = obd->obd_self_export;
235         RETURN(d);
236 }
237
238 static const struct lu_device_type_operations osc_device_type_ops = {
239         .ldto_init = osc_type_init,
240         .ldto_fini = osc_type_fini,
241
242         .ldto_start = osc_type_start,
243         .ldto_stop  = osc_type_stop,
244
245         .ldto_device_alloc = osc_device_alloc,
246         .ldto_device_free  = osc_device_free,
247
248         .ldto_device_init    = osc_device_init,
249         .ldto_device_fini    = osc_device_fini
250 };
251
252 struct lu_device_type osc_device_type = {
253         .ldt_tags     = LU_DEVICE_CL,
254         .ldt_name     = LUSTRE_OSC_NAME,
255         .ldt_ops      = &osc_device_type_ops,
256         .ldt_ctx_tags = LCT_CL_THREAD
257 };
258
259 /** @} osc */