GNU Linux-libre 4.9.317-gnu1
[releases.git] / drivers / staging / lustre / lustre / include / lustre_param.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.gnu.org/licenses/gpl-2.0.html
19  *
20  * GPL HEADER END
21  */
22 /*
23  * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
24  * Use is subject to license terms.
25  *
26  * Copyright (c) 2011, 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  * lustre/include/lustre_param.h
33  *
34  * User-settable parameter keys
35  *
36  * Author: Nathan Rutman <nathan@clusterfs.com>
37  */
38
39 #ifndef _LUSTRE_PARAM_H
40 #define _LUSTRE_PARAM_H
41
42 #include "../../include/linux/libcfs/libcfs.h"
43 #include "../../include/linux/lnet/types.h"
44
45 /** \defgroup param param
46  *
47  * @{
48  */
49
50 /* For interoperability */
51 struct cfg_interop_param {
52         char *old_param;
53         char *new_param;
54 };
55
56 /* obd_config.c */
57 int class_find_param(char *buf, char *key, char **valp);
58 int class_parse_nid(char *buf, lnet_nid_t *nid, char **endh);
59 int class_parse_nid_quiet(char *buf, lnet_nid_t *nid, char **endh);
60
61 /****************** User-settable parameter keys *********************/
62 /* e.g.
63         tunefs.lustre --param="failover.node=192.168.0.13@tcp0" /dev/sda
64         lctl conf_param testfs-OST0000 failover.node=3@elan,192.168.0.3@tcp0
65                     ... testfs-MDT0000.lov.stripesize=4M
66                     ... testfs-OST0000.ost.client_cache_seconds=15
67                     ... testfs.sys.timeout=<secs>
68                     ... testfs.llite.max_read_ahead_mb=16
69 */
70
71 /* System global or special params not handled in obd's proc
72  * See mgs_write_log_sys()
73  */
74 #define PARAM_TIMEOUT         "timeout="          /* global */
75 #define PARAM_LDLM_TIMEOUT       "ldlm_timeout="     /* global */
76 #define PARAM_AT_MIN           "at_min="           /* global */
77 #define PARAM_AT_MAX           "at_max="           /* global */
78 #define PARAM_AT_EXTRA       "at_extra="         /* global */
79 #define PARAM_AT_EARLY_MARGIN      "at_early_margin="  /* global */
80 #define PARAM_AT_HISTORY           "at_history="       /* global */
81 #define PARAM_JOBID_VAR            "jobid_var="        /* global */
82 #define PARAM_MGSNODE         "mgsnode="          /* only at mounttime */
83 #define PARAM_FAILNODE       "failover.node="    /* add failover nid */
84 #define PARAM_FAILMODE       "failover.mode="    /* initial mount only */
85 #define PARAM_ACTIVE           "active="           /* activate/deactivate */
86 #define PARAM_NETWORK         "network="          /* bind on nid */
87 #define PARAM_ID_UPCALL         "identity_upcall="  /* identity upcall */
88
89 /* Prefixes for parameters handled by obd's proc methods (XXX_process_config) */
90 #define PARAM_OST                 "ost."
91 #define PARAM_OSD               "osd."
92 #define PARAM_OSC                 "osc."
93 #define PARAM_MDT                 "mdt."
94 #define PARAM_MDD                 "mdd."
95 #define PARAM_MDC                 "mdc."
96 #define PARAM_LLITE             "llite."
97 #define PARAM_LOV                 "lov."
98 #define PARAM_LOD               "lod."
99 #define PARAM_OSP               "osp."
100 #define PARAM_SYS                 "sys."              /* global */
101 #define PARAM_SRPC               "srpc."
102 #define PARAM_SRPC_FLVR     "srpc.flavor."
103 #define PARAM_SRPC_UDESC           "srpc.udesc.cli2mdt"
104 #define PARAM_SEC                 "security."
105 #define PARAM_QUOTA             "quota."            /* global */
106
107 /** @} param */
108
109 #endif /* _LUSTRE_PARAM_H */