staging: lustre: update Intel copyright messages 2015
[linux-block.git] / drivers / staging / lustre / lustre / osc / osc_dev.c
CommitLineData
d7e09d03
PT
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 *
1dc563a6 30 * Copyright (c) 2012, 2015, Intel Corporation.
d7e09d03
PT
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() */
3ee30015 44#include "../include/obd_class.h"
d7e09d03
PT
45
46#include "osc_cl_internal.h"
47
48/** \addtogroup osc
49 * @{
50 */
51
52struct kmem_cache *osc_lock_kmem;
53struct kmem_cache *osc_object_kmem;
54struct kmem_cache *osc_thread_kmem;
55struct kmem_cache *osc_session_kmem;
56struct kmem_cache *osc_req_kmem;
57struct kmem_cache *osc_extent_kmem;
58struct kmem_cache *osc_quota_kmem;
59
60struct lu_kmem_descr osc_caches[] = {
61 {
62 .ckd_cache = &osc_lock_kmem,
63 .ckd_name = "osc_lock_kmem",
add26043 64 .ckd_size = sizeof(struct osc_lock)
d7e09d03
PT
65 },
66 {
67 .ckd_cache = &osc_object_kmem,
68 .ckd_name = "osc_object_kmem",
add26043 69 .ckd_size = sizeof(struct osc_object)
d7e09d03
PT
70 },
71 {
72 .ckd_cache = &osc_thread_kmem,
73 .ckd_name = "osc_thread_kmem",
add26043 74 .ckd_size = sizeof(struct osc_thread_info)
d7e09d03
PT
75 },
76 {
77 .ckd_cache = &osc_session_kmem,
78 .ckd_name = "osc_session_kmem",
add26043 79 .ckd_size = sizeof(struct osc_session)
d7e09d03
PT
80 },
81 {
82 .ckd_cache = &osc_req_kmem,
83 .ckd_name = "osc_req_kmem",
add26043 84 .ckd_size = sizeof(struct osc_req)
d7e09d03
PT
85 },
86 {
87 .ckd_cache = &osc_extent_kmem,
88 .ckd_name = "osc_extent_kmem",
add26043 89 .ckd_size = sizeof(struct osc_extent)
d7e09d03
PT
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
101struct lock_class_key osc_ast_guard_class;
102
103/*****************************************************************************
104 *
105 * Type conversions.
106 *
107 */
108
109static 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
120static void *osc_key_init(const struct lu_context *ctx,
29ac6840 121 struct lu_context_key *key)
d7e09d03
PT
122{
123 struct osc_thread_info *info;
124
ccaabce1 125 info = kmem_cache_alloc(osc_thread_kmem, GFP_NOFS | __GFP_ZERO);
d7e09d03
PT
126 if (info == NULL)
127 info = ERR_PTR(-ENOMEM);
128 return info;
129}
130
131static 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;
4e1a6d2e 135
50d30362 136 kmem_cache_free(osc_thread_kmem, info);
d7e09d03
PT
137}
138
139struct lu_context_key osc_key = {
140 .lct_tags = LCT_CL_THREAD,
141 .lct_init = osc_key_init,
142 .lct_fini = osc_key_fini
143};
144
145static void *osc_session_init(const struct lu_context *ctx,
146 struct lu_context_key *key)
147{
148 struct osc_session *info;
149
ccaabce1 150 info = kmem_cache_alloc(osc_session_kmem, GFP_NOFS | __GFP_ZERO);
d7e09d03
PT
151 if (info == NULL)
152 info = ERR_PTR(-ENOMEM);
153 return info;
154}
155
156static void osc_session_fini(const struct lu_context *ctx,
157 struct lu_context_key *key, void *data)
158{
159 struct osc_session *info = data;
4e1a6d2e 160
50d30362 161 kmem_cache_free(osc_session_kmem, info);
d7e09d03
PT
162}
163
164struct lu_context_key osc_session_key = {
165 .lct_tags = LCT_SESSION,
166 .lct_init = osc_session_init,
167 .lct_fini = osc_session_fini
168};
169
170/* type constructor/destructor: osc_type_{init,fini,start,stop}(). */
171LU_TYPE_INIT_FINI(osc, &osc_key, &osc_session_key);
172
173static int osc_cl_process_config(const struct lu_env *env,
174 struct lu_device *d, struct lustre_cfg *cfg)
175{
0a3bdb00 176 return osc_process_config_base(d->ld_obd, cfg);
d7e09d03
PT
177}
178
179static const struct lu_device_operations osc_lu_ops = {
180 .ldo_object_alloc = osc_object_alloc,
181 .ldo_process_config = osc_cl_process_config,
182 .ldo_recovery_complete = NULL
183};
184
185static const struct cl_device_operations osc_cl_ops = {
186 .cdo_req_init = osc_req_init
187};
188
189static int osc_device_init(const struct lu_env *env, struct lu_device *d,
190 const char *name, struct lu_device *next)
191{
0a3bdb00 192 return 0;
d7e09d03
PT
193}
194
195static struct lu_device *osc_device_fini(const struct lu_env *env,
196 struct lu_device *d)
197{
5bcfab13 198 return NULL;
d7e09d03
PT
199}
200
201static struct lu_device *osc_device_free(const struct lu_env *env,
202 struct lu_device *d)
203{
204 struct osc_device *od = lu2osc_dev(d);
205
206 cl_device_fini(lu2cl_dev(d));
7795178d 207 kfree(od);
d7e09d03
PT
208 return NULL;
209}
210
211static struct lu_device *osc_device_alloc(const struct lu_env *env,
212 struct lu_device_type *t,
213 struct lustre_cfg *cfg)
214{
215 struct lu_device *d;
216 struct osc_device *od;
217 struct obd_device *obd;
218 int rc;
219
7795178d 220 od = kzalloc(sizeof(*od), GFP_NOFS);
3408e9ae 221 if (!od)
0a3bdb00 222 return ERR_PTR(-ENOMEM);
d7e09d03
PT
223
224 cl_device_init(&od->od_cl, t);
225 d = osc2lu_dev(od);
226 d->ld_ops = &osc_lu_ops;
227 od->od_cl.cd_ops = &osc_cl_ops;
228
229 /* Setup OSC OBD */
230 obd = class_name2obd(lustre_cfg_string(cfg, 0));
231 LASSERT(obd != NULL);
232 rc = osc_setup(obd, cfg);
233 if (rc) {
234 osc_device_free(env, d);
0a3bdb00 235 return ERR_PTR(rc);
d7e09d03
PT
236 }
237 od->od_exp = obd->obd_self_export;
0a3bdb00 238 return d;
d7e09d03
PT
239}
240
241static const struct lu_device_type_operations osc_device_type_ops = {
242 .ldto_init = osc_type_init,
243 .ldto_fini = osc_type_fini,
244
245 .ldto_start = osc_type_start,
246 .ldto_stop = osc_type_stop,
247
248 .ldto_device_alloc = osc_device_alloc,
249 .ldto_device_free = osc_device_free,
250
29ac6840
CH
251 .ldto_device_init = osc_device_init,
252 .ldto_device_fini = osc_device_fini
d7e09d03
PT
253};
254
255struct lu_device_type osc_device_type = {
29ac6840
CH
256 .ldt_tags = LU_DEVICE_CL,
257 .ldt_name = LUSTRE_OSC_NAME,
258 .ldt_ops = &osc_device_type_ops,
d7e09d03
PT
259 .ldt_ctx_tags = LCT_CL_THREAD
260};
261
262/** @} osc */