Whamcloud - gitweb
LU-3285 osc: prepare OSC code to be used from MDC
[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.gnu.org/licenses/gpl-2.0.html
19  *
20  * GPL HEADER END
21  */
22 /*
23  * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
24  * Use is subject to license terms.
25  *
26  * Copyright (c) 2012, 2015, Intel Corporation.
27  */
28 /*
29  * This file is part of Lustre, http://www.lustre.org/
30  * Lustre is a trademark of Sun Microsystems, Inc.
31  *
32  * Implementation of cl_device, for OSC layer.
33  *
34  *   Author: Nikita Danilov <nikita.danilov@sun.com>
35  */
36
37 #define DEBUG_SUBSYSTEM S_OSC
38
39 /* class_name2obd() */
40 #include <obd_class.h>
41 #include <lustre_osc.h>
42
43 #include "osc_internal.h"
44
45 /** \addtogroup osc
46  * @{
47  */
48
49 struct kmem_cache *osc_lock_kmem;
50 struct kmem_cache *osc_object_kmem;
51 struct kmem_cache *osc_thread_kmem;
52 struct kmem_cache *osc_session_kmem;
53 struct kmem_cache *osc_extent_kmem;
54 struct kmem_cache *osc_quota_kmem;
55
56 struct lu_kmem_descr osc_caches[] = {
57         {
58                 .ckd_cache = &osc_lock_kmem,
59                 .ckd_name  = "osc_lock_kmem",
60                 .ckd_size  = sizeof (struct osc_lock)
61         },
62         {
63                 .ckd_cache = &osc_object_kmem,
64                 .ckd_name  = "osc_object_kmem",
65                 .ckd_size  = sizeof (struct osc_object)
66         },
67         {
68                 .ckd_cache = &osc_thread_kmem,
69                 .ckd_name  = "osc_thread_kmem",
70                 .ckd_size  = sizeof (struct osc_thread_info)
71         },
72         {
73                 .ckd_cache = &osc_session_kmem,
74                 .ckd_name  = "osc_session_kmem",
75                 .ckd_size  = sizeof (struct osc_session)
76         },
77         {
78                 .ckd_cache = &osc_extent_kmem,
79                 .ckd_name  = "osc_extent_kmem",
80                 .ckd_size  = sizeof (struct osc_extent)
81         },
82         {
83                 .ckd_cache = &osc_quota_kmem,
84                 .ckd_name  = "osc_quota_kmem",
85                 .ckd_size  = sizeof(struct osc_quota_info)
86         },
87         {
88                 .ckd_cache = NULL
89         }
90 };
91
92 /*****************************************************************************
93  *
94  * Osc device and device type functions.
95  *
96  */
97
98 static void *osc_key_init(const struct lu_context *ctx,
99                           struct lu_context_key *key)
100 {
101         struct osc_thread_info *info;
102
103         OBD_SLAB_ALLOC_PTR_GFP(info, osc_thread_kmem, GFP_NOFS);
104         if (info == NULL)
105                 info = ERR_PTR(-ENOMEM);
106         return info;
107 }
108
109 static void osc_key_fini(const struct lu_context *ctx,
110                          struct lu_context_key *key, void *data)
111 {
112         struct osc_thread_info *info = data;
113
114         lu_buf_free(&info->oti_ladvise_buf);
115         OBD_SLAB_FREE_PTR(info, osc_thread_kmem);
116 }
117
118 struct lu_context_key osc_key = {
119         .lct_tags = LCT_CL_THREAD,
120         .lct_init = osc_key_init,
121         .lct_fini = osc_key_fini
122 };
123
124 static void *osc_session_init(const struct lu_context *ctx,
125                               struct lu_context_key *key)
126 {
127         struct osc_session *info;
128
129         OBD_SLAB_ALLOC_PTR_GFP(info, osc_session_kmem, GFP_NOFS);
130         if (info == NULL)
131                 info = ERR_PTR(-ENOMEM);
132         return info;
133 }
134
135 static void osc_session_fini(const struct lu_context *ctx,
136                              struct lu_context_key *key, void *data)
137 {
138         struct osc_session *info = data;
139         OBD_SLAB_FREE_PTR(info, osc_session_kmem);
140 }
141
142 struct lu_context_key osc_session_key = {
143         .lct_tags = LCT_SESSION,
144         .lct_init = osc_session_init,
145         .lct_fini = osc_session_fini
146 };
147
148 /* type constructor/destructor: osc_type_{init,fini,start,stop}(). */
149 LU_TYPE_INIT_FINI(osc, &osc_key, &osc_session_key);
150
151 static int osc_cl_process_config(const struct lu_env *env,
152                                  struct lu_device *d, struct lustre_cfg *cfg)
153 {
154         ENTRY;
155         RETURN(osc_process_config_base(d->ld_obd, cfg));
156 }
157
158 static const struct lu_device_operations osc_lu_ops = {
159         .ldo_object_alloc      = osc_object_alloc,
160         .ldo_process_config    = osc_cl_process_config,
161         .ldo_recovery_complete = NULL
162 };
163
164 static int osc_device_init(const struct lu_env *env, struct lu_device *d,
165                            const char *name, struct lu_device *next)
166 {
167         RETURN(0);
168 }
169
170 static struct lu_device *osc_device_fini(const struct lu_env *env,
171                                          struct lu_device *d)
172 {
173         return NULL;
174 }
175
176 static struct lu_device *osc_device_free(const struct lu_env *env,
177                                          struct lu_device *d)
178 {
179         struct osc_device *od = lu2osc_dev(d);
180
181         cl_device_fini(lu2cl_dev(d));
182         OBD_FREE_PTR(od);
183         return NULL;
184 }
185
186 static struct lu_device *osc_device_alloc(const struct lu_env *env,
187                                           struct lu_device_type *t,
188                                           struct lustre_cfg *cfg)
189 {
190         struct lu_device *d;
191         struct osc_device *od;
192         struct obd_device *obd;
193         int rc;
194
195         OBD_ALLOC_PTR(od);
196         if (od == NULL)
197                 RETURN(ERR_PTR(-ENOMEM));
198
199         cl_device_init(&od->od_cl, t);
200         d = osc2lu_dev(od);
201         d->ld_ops = &osc_lu_ops;
202
203         /* Setup OSC OBD */
204         obd = class_name2obd(lustre_cfg_string(cfg, 0));
205         LASSERT(obd != NULL);
206         rc = osc_setup(obd, cfg);
207         if (rc) {
208                 osc_device_free(env, d);
209                 RETURN(ERR_PTR(rc));
210         }
211         od->od_exp = obd->obd_self_export;
212         RETURN(d);
213 }
214
215 static const struct lu_device_type_operations osc_device_type_ops = {
216         .ldto_init = osc_type_init,
217         .ldto_fini = osc_type_fini,
218
219         .ldto_start = osc_type_start,
220         .ldto_stop  = osc_type_stop,
221
222         .ldto_device_alloc = osc_device_alloc,
223         .ldto_device_free  = osc_device_free,
224
225         .ldto_device_init    = osc_device_init,
226         .ldto_device_fini    = osc_device_fini
227 };
228
229 struct lu_device_type osc_device_type = {
230         .ldt_tags     = LU_DEVICE_CL,
231         .ldt_name     = LUSTRE_OSC_NAME,
232         .ldt_ops      = &osc_device_type_ops,
233         .ldt_ctx_tags = LCT_CL_THREAD
234 };
235
236 /** @} osc */