Whamcloud - gitweb
b=16098
[fs/lustre-release.git] / lnet / klnds / qswlnd / qswlnd_modparams.c
1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2  * vim:expandtab:shiftwidth=8:tabstop=8:
3  *
4  * Copyright  2008 Sun Microsystems, Inc. All rights reserved
5  *
6  * Author: Eric Barton <eric@bartonsoftware.com>
7  *
8  * This file is part of Portals, http://www.lustre.org
9  *
10  * Portals is free software; you can redistribute it and/or
11  * modify it under the terms of version 2 of the GNU General Public
12  * License as published by the Free Software Foundation.
13  *
14  * Portals is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with Portals; if not, write to the Free Software
21  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22  *
23  */
24
25 #include "qswlnd.h"
26
27 static int tx_maxcontig = (1<<10);
28 CFS_MODULE_PARM(tx_maxcontig, "i", int, 0444,
29                 "maximum payload to de-fragment");
30
31 static int ntxmsgs = 512;
32 CFS_MODULE_PARM(ntxmsgs, "i", int, 0444,
33                 "# tx msg buffers");
34
35 static int credits = 128;
36 CFS_MODULE_PARM(credits, "i", int, 0444,
37                 "# concurrent sends");
38
39 static int peer_credits = 8;
40 CFS_MODULE_PARM(peer_credits, "i", int, 0444,
41                 "# per-peer concurrent sends");
42
43 static int nrxmsgs_large = 64;
44 CFS_MODULE_PARM(nrxmsgs_large, "i", int, 0444,
45                 "# 'large' rx msg buffers");
46
47 static int ep_envelopes_large = 256;
48 CFS_MODULE_PARM(ep_envelopes_large, "i", int, 0444,
49                 "# 'large' rx msg envelope buffers");
50
51 static int nrxmsgs_small = 256;
52 CFS_MODULE_PARM(nrxmsgs_small, "i", int, 0444,
53                 "# 'small' rx msg buffers");
54
55 static int ep_envelopes_small = 2048;
56 CFS_MODULE_PARM(ep_envelopes_small, "i", int, 0444,
57                 "# 'small' rx msg envelope buffers");
58
59 static int optimized_puts = (32<<10);
60 CFS_MODULE_PARM(optimized_puts, "i", int, 0644,
61                 "zero-copy puts >= this size");
62
63 static int optimized_gets = 2048;
64 CFS_MODULE_PARM(optimized_gets, "i", int, 0644,
65                 "zero-copy gets >= this size");
66
67 #if KQSW_CKSUM
68 static int inject_csum_error = 0;
69 CFS_MODULE_PARM(inject_csum_error, "i", int, 0644,
70                 "test checksumming");
71 #endif
72
73 kqswnal_tunables_t kqswnal_tunables = {
74         .kqn_tx_maxcontig       = &tx_maxcontig,
75         .kqn_ntxmsgs            = &ntxmsgs,
76         .kqn_credits            = &credits,
77         .kqn_peercredits        = &peer_credits,
78         .kqn_nrxmsgs_large      = &nrxmsgs_large,
79         .kqn_ep_envelopes_large = &ep_envelopes_large,
80         .kqn_nrxmsgs_small      = &nrxmsgs_small,
81         .kqn_ep_envelopes_small = &ep_envelopes_small,
82         .kqn_optimized_puts     = &optimized_puts,
83         .kqn_optimized_gets     = &optimized_gets,
84 #if KQSW_CKSUM
85         .kqn_inject_csum_error  = &inject_csum_error,
86 #endif
87 };
88
89 #if defined(CONFIG_SYSCTL) && !CFS_SYSFS_MODULE_PARM
90 static cfs_sysctl_table_t kqswnal_ctl_table[] = {
91         {
92                 .ctl_name = 1,
93                 .procname = "tx_maxcontig",
94                 .data     = &tx_maxcontig,
95                 .maxlen   = sizeof (int),
96                 .mode     = 0444,
97                 .proc_handler = &proc_dointvec
98         },
99         {
100                 .ctl_name = 2,
101                 .procname = "ntxmsgs",
102                 .data     = &ntxmsgs,
103                 .maxlen   = sizeof (int),
104                 .mode     = 0444,
105                 .proc_handler = &proc_dointvec
106         },
107         {
108                 .ctl_name = 3,
109                 .procname = "credits",
110                 .data     = &credits,
111                 .maxlen   = sizeof (int),
112                 .mode     = 0444,
113                 .proc_handler = &proc_dointvec
114         },
115         {
116                 .ctl_name = 4,
117                 .procname = "peer_credits",
118                 .data     = &peer_credits,
119                 .maxlen   = sizeof (int),
120                 .mode     = 0444,
121                 .proc_handler = &proc_dointvec
122         },
123         {
124                 .ctl_name = 5,
125                 .procname = "nrxmsgs_large",
126                 .data     = &nrxmsgs_large,
127                 .maxlen   = sizeof (int),
128                 .mode     = 0444,
129                 .proc_handler = &proc_dointvec
130         },
131         {
132                 .ctl_name = 6,
133                 .procname = "ep_envelopes_large",
134                 .data     = &ep_envelopes_large,
135                 .maxlen   = sizeof (int),
136                 .mode     = 0444,
137                 .proc_handler = &proc_dointvec
138         },
139         {
140                 .ctl_name = 7,
141                 .procname = "nrxmsgs_small",
142                 .data     = &nrxmsgs_small,
143                 .maxlen   = sizeof (int),
144                 .mode     = 0444,
145                 .proc_handler = &proc_dointvec
146         },
147         {
148                 .ctl_name = 8,
149                 .procname = "ep_envelopes_small",
150                 .data     = &ep_envelopes_small,
151                 .maxlen   = sizeof (int),
152                 .mode     = 0444,
153                 .proc_handler = &proc_dointvec
154         },
155         {
156                 .ctl_name = 9,
157                 .procname = "optimized_puts",
158                 .data     = &optimized_puts,
159                 .maxlen   = sizeof (int),
160                 .mode     = 0644,
161                 .proc_handler = &proc_dointvec
162         },
163         {
164                 .ctl_name = 10,
165                 .procname = "optimized_gets",
166                 .data     = &optimized_gets,
167                 .maxlen   = sizeof (int),
168                 .mode     = 0644,
169                 .proc_handler = &proc_dointvec
170         },
171 #if KQSW_CKSUM
172         {
173                 .ctl_name = 11,
174                 .procname = "inject_csum_error",
175                 .data     = &inject_csum_error,
176                 .maxlen   = sizeof (int),
177                 .mode     = 0644,
178                 .proc_handler = &proc_dointvec
179         },
180 #endif
181         {0}
182 };
183
184 static cfs_sysctl_table_t kqswnal_top_ctl_table[] = {
185         {
186                 .ctl_name = 201,
187                 .procname = "qswnal",
188                 .data     = NULL,
189                 .maxlen   = 0,
190                 .mode     = 0555,
191                 .child    = kqswnal_ctl_table
192         },
193         {0}
194 };
195
196 int
197 kqswnal_tunables_init ()
198 {
199         kqswnal_tunables.kqn_sysctl =
200                 cfs_register_sysctl_table(kqswnal_top_ctl_table, 0);
201
202         if (kqswnal_tunables.kqn_sysctl == NULL)
203                 CWARN("Can't setup /proc tunables\n");
204
205         return 0;
206 }
207
208 void
209 kqswnal_tunables_fini ()
210 {
211         if (kqswnal_tunables.kqn_sysctl != NULL)
212                 cfs_unregister_sysctl_table(kqswnal_tunables.kqn_sysctl);
213 }
214 #else
215 int
216 kqswnal_tunables_init ()
217 {
218         return 0;
219 }
220
221 void
222 kqswnal_tunables_fini ()
223 {
224 }
225 #endif