Whamcloud - gitweb
LU-2558 test: recovery-small 19a FAIL no eviction
[fs/lustre-release.git] / lustre / ptlrpc / ptlrpc_internal.h
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 /* Intramodule declarations for ptlrpc. */
38
39 #ifndef PTLRPC_INTERNAL_H
40 #define PTLRPC_INTERNAL_H
41
42 #include "../ldlm/ldlm_internal.h"
43
44 struct ldlm_namespace;
45 struct obd_import;
46 struct ldlm_res_id;
47 struct ptlrpc_request_set;
48 extern int test_req_buffer_pressure;
49
50 int ptlrpc_start_thread(struct ptlrpc_service_part *svcpt, int wait);
51 /* ptlrpcd.c */
52 int ptlrpcd_start(int index, int max, const char *name, struct ptlrpcd_ctl *pc);
53
54 /* client.c */
55 struct ptlrpc_bulk_desc *new_bulk(int npages, int type, int portal);
56 void ptlrpc_init_xid(void);
57
58 /* events.c */
59 int ptlrpc_init_portals(void);
60 void ptlrpc_exit_portals(void);
61
62 void ptlrpc_request_handle_notconn(struct ptlrpc_request *);
63 void lustre_assert_wire_constants(void);
64 int ptlrpc_import_in_recovery(struct obd_import *imp);
65 int ptlrpc_set_import_discon(struct obd_import *imp, __u32 conn_cnt);
66 void ptlrpc_handle_failed_import(struct obd_import *imp);
67 int ptlrpc_replay_next(struct obd_import *imp, int *inflight);
68 void ptlrpc_initiate_recovery(struct obd_import *imp);
69
70 int lustre_unpack_req_ptlrpc_body(struct ptlrpc_request *req, int offset);
71 int lustre_unpack_rep_ptlrpc_body(struct ptlrpc_request *req, int offset);
72
73 #ifdef LPROCFS
74 void ptlrpc_lprocfs_register_service(struct proc_dir_entry *proc_entry,
75                                      struct ptlrpc_service *svc);
76 void ptlrpc_lprocfs_unregister_service(struct ptlrpc_service *svc);
77 void ptlrpc_lprocfs_rpc_sent(struct ptlrpc_request *req, long amount);
78 void ptlrpc_lprocfs_do_request_stat (struct ptlrpc_request *req,
79                                      long q_usec, long work_usec);
80 #else
81 #define ptlrpc_lprocfs_register_service(params...) do{}while(0)
82 #define ptlrpc_lprocfs_unregister_service(params...) do{}while(0)
83 #define ptlrpc_lprocfs_rpc_sent(params...) do{}while(0)
84 #define ptlrpc_lprocfs_do_request_stat(params...) do{}while(0)
85 #endif /* LPROCFS */
86
87 /* recovd_thread.c */
88
89 int ptlrpc_expire_one_request(struct ptlrpc_request *req, int async_unlink);
90
91 /* pers.c */
92 void ptlrpc_fill_bulk_md(lnet_md_t *md, struct ptlrpc_bulk_desc *desc);
93 void ptlrpc_add_bulk_page(struct ptlrpc_bulk_desc *desc, cfs_page_t *page,
94                           int pageoffset, int len);
95
96 /* pack_generic.c */
97 struct ptlrpc_reply_state *
98 lustre_get_emerg_rs(struct ptlrpc_service_part *svcpt);
99 void lustre_put_emerg_rs(struct ptlrpc_reply_state *rs);
100
101 /* pinger.c */
102 int ptlrpc_start_pinger(void);
103 int ptlrpc_stop_pinger(void);
104 void ptlrpc_pinger_sending_on_import(struct obd_import *imp);
105 void ptlrpc_pinger_commit_expected(struct obd_import *imp);
106 void ptlrpc_pinger_wake_up(void);
107 void ptlrpc_ping_import_soon(struct obd_import *imp);
108 #ifdef __KERNEL__
109 int ping_evictor_wake(struct obd_export *exp);
110 #else
111 #define ping_evictor_wake(exp)     1
112 #endif
113
114 /* sec_null.c */
115 int  sptlrpc_null_init(void);
116 void sptlrpc_null_fini(void);
117
118 /* sec_plain.c */
119 int  sptlrpc_plain_init(void);
120 void sptlrpc_plain_fini(void);
121
122 /* sec_bulk.c */
123 int  sptlrpc_enc_pool_init(void);
124 void sptlrpc_enc_pool_fini(void);
125 int sptlrpc_proc_read_enc_pool(char *page, char **start, off_t off, int count,
126                                int *eof, void *data);
127
128 /* sec_lproc.c */
129 int  sptlrpc_lproc_init(void);
130 void sptlrpc_lproc_fini(void);
131
132 /* sec_gc.c */
133 int sptlrpc_gc_init(void);
134 void sptlrpc_gc_fini(void);
135
136 /* sec_config.c */
137 void sptlrpc_conf_choose_flavor(enum lustre_sec_part from,
138                                 enum lustre_sec_part to,
139                                 struct obd_uuid *target,
140                                 lnet_nid_t nid,
141                                 struct sptlrpc_flavor *sf);
142 int  sptlrpc_conf_init(void);
143 void sptlrpc_conf_fini(void);
144
145 /* sec.c */
146 int  sptlrpc_init(void);
147 void sptlrpc_fini(void);
148
149 /* recov_thread.c */
150 int llog_recov_init(void);
151 void llog_recov_fini(void);
152
153 static inline int ll_rpc_recoverable_error(int rc)
154 {
155         return (rc == -ENOTCONN || rc == -ENODEV);
156 }
157
158 #ifdef HAVE_SERVER_SUPPORT
159 int tgt_mod_init(void);
160 void tgt_mod_exit(void);
161 #else
162 static inline int tgt_mod_init(void)
163 {
164         return 0;
165 }
166
167 static inline void tgt_mod_exit(void)
168 {
169         return;
170 }
171 #endif
172
173 static inline void ptlrpc_reqset_put(struct ptlrpc_request_set *set)
174 {
175         if (cfs_atomic_dec_and_test(&set->set_refcount))
176                 OBD_FREE_PTR(set);
177 }
178 #endif /* PTLRPC_INTERNAL_H */