]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blob - drivers/staging/lustre/lustre/ptlrpc/ptlrpc_module.c
staging: add Lustre file system client support
[mirror_ubuntu-bionic-kernel.git] / drivers / staging / lustre / lustre / ptlrpc / ptlrpc_module.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) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
28 * Use is subject to license terms.
29 *
30 * Copyright (c) 2011, 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
37 #define DEBUG_SUBSYSTEM S_RPC
38
39
40 #include <obd_support.h>
41 #include <obd_class.h>
42 #include <lustre_net.h>
43 #include <lustre_req_layout.h>
44
45 #include "ptlrpc_internal.h"
46
47 extern spinlock_t ptlrpc_last_xid_lock;
48 #if RS_DEBUG
49 extern spinlock_t ptlrpc_rs_debug_lock;
50 #endif
51 extern struct mutex pinger_mutex;
52 extern struct mutex ptlrpcd_mutex;
53
54 __init int ptlrpc_init(void)
55 {
56 int rc, cleanup_phase = 0;
57 ENTRY;
58
59 lustre_assert_wire_constants();
60 #if RS_DEBUG
61 spin_lock_init(&ptlrpc_rs_debug_lock);
62 #endif
63 mutex_init(&ptlrpc_all_services_mutex);
64 mutex_init(&pinger_mutex);
65 mutex_init(&ptlrpcd_mutex);
66 ptlrpc_init_xid();
67
68 rc = req_layout_init();
69 if (rc)
70 RETURN(rc);
71
72 rc = ptlrpc_hr_init();
73 if (rc)
74 RETURN(rc);
75
76 cleanup_phase = 1;
77
78 rc = ptlrpc_init_portals();
79 if (rc)
80 GOTO(cleanup, rc);
81 cleanup_phase = 2;
82
83 rc = ptlrpc_connection_init();
84 if (rc)
85 GOTO(cleanup, rc);
86 cleanup_phase = 3;
87
88 ptlrpc_put_connection_superhack = ptlrpc_connection_put;
89
90 rc = ptlrpc_start_pinger();
91 if (rc)
92 GOTO(cleanup, rc);
93 cleanup_phase = 4;
94
95 rc = ldlm_init();
96 if (rc)
97 GOTO(cleanup, rc);
98 cleanup_phase = 5;
99
100 rc = sptlrpc_init();
101 if (rc)
102 GOTO(cleanup, rc);
103
104 cleanup_phase = 7;
105 rc = ptlrpc_nrs_init();
106 if (rc)
107 GOTO(cleanup, rc);
108
109 cleanup_phase = 8;
110 rc = tgt_mod_init();
111 if (rc)
112 GOTO(cleanup, rc);
113 RETURN(0);
114
115 cleanup:
116 switch(cleanup_phase) {
117 case 8:
118 ptlrpc_nrs_fini();
119 case 7:
120 sptlrpc_fini();
121 case 5:
122 ldlm_exit();
123 case 4:
124 ptlrpc_stop_pinger();
125 case 3:
126 ptlrpc_connection_fini();
127 case 2:
128 ptlrpc_exit_portals();
129 case 1:
130 ptlrpc_hr_fini();
131 req_layout_fini();
132 default: ;
133 }
134
135 return rc;
136 }
137
138 static void __exit ptlrpc_exit(void)
139 {
140 tgt_mod_exit();
141 ptlrpc_nrs_fini();
142 sptlrpc_fini();
143 ldlm_exit();
144 ptlrpc_stop_pinger();
145 ptlrpc_exit_portals();
146 ptlrpc_hr_fini();
147 ptlrpc_connection_fini();
148 }
149
150 MODULE_AUTHOR("Sun Microsystems, Inc. <http://www.lustre.org/>");
151 MODULE_DESCRIPTION("Lustre Request Processor and Lock Management");
152 MODULE_LICENSE("GPL");
153
154 cfs_module(ptlrpc, "1.0.0", ptlrpc_init, ptlrpc_exit);