Commit 882b0a13 authored by Emoly Liu's avatar Emoly Liu Committed by Greg Kroah-Hartman

staging: lustre: obd: add case LCFG_PARAM to osd_process_config

Some proc parameters were moved from ofd to osd module and only
their symlinks were kept in ofd for interoperability/compatibility.
To process this kind of config params passed by ofd, this patch is
to do the following fixes:

 - since these parameters are not included by the static lprocfs var
   list, a pre-check is added for them to avoid "unknown param" error
   message confuses the uses. If they are matched in this check, they
   will be passed to the osd directly.
 - improve the error messages in class_process_proc_param() and
   class_process_proc_seq_param() a little.
Signed-off-by: default avatarEmoly Liu <emoly.liu@intel.com>
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-4221
Reviewed-on: http://review.whamcloud.com/8238Reviewed-by: default avatarAndreas Dilger <andreas.dilger@intel.com>
Reviewed-by: default avatarJames Simmons <uja.ornl@gmail.com>
Signed-off-by: default avatarJames Simmons <jsimmons@infradead.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 6f6c8e7c
...@@ -89,6 +89,7 @@ int class_parse_nid_quiet(char *buf, lnet_nid_t *nid, char **endh); ...@@ -89,6 +89,7 @@ int class_parse_nid_quiet(char *buf, lnet_nid_t *nid, char **endh);
/* Prefixes for parameters handled by obd's proc methods (XXX_process_config) */ /* Prefixes for parameters handled by obd's proc methods (XXX_process_config) */
#define PARAM_OST "ost." #define PARAM_OST "ost."
#define PARAM_OSD "osd."
#define PARAM_OSC "osc." #define PARAM_OSC "osc."
#define PARAM_MDT "mdt." #define PARAM_MDT "mdt."
#define PARAM_MDD "mdd." #define PARAM_MDD "mdd."
......
...@@ -1000,7 +1000,13 @@ int class_process_proc_param(char *prefix, struct lprocfs_vars *lvars, ...@@ -1000,7 +1000,13 @@ int class_process_proc_param(char *prefix, struct lprocfs_vars *lvars,
for (i = 1; i < lcfg->lcfg_bufcount; i++) { for (i = 1; i < lcfg->lcfg_bufcount; i++) {
key = lustre_cfg_buf(lcfg, i); key = lustre_cfg_buf(lcfg, i);
/* Strip off prefix */ /* Strip off prefix */
class_match_param(key, prefix, &key); if (class_match_param(key, prefix, &key)) {
/*
* If the prefix doesn't match, return error so we
* can pass it down the stack
*/
return -ENOSYS;
}
sval = strchr(key, '='); sval = strchr(key, '=');
if (!sval || (*(sval + 1) == 0)) { if (!sval || (*(sval + 1) == 0)) {
CERROR("Can't parse param %s (missing '=')\n", key); CERROR("Can't parse param %s (missing '=')\n", key);
...@@ -1033,18 +1039,14 @@ int class_process_proc_param(char *prefix, struct lprocfs_vars *lvars, ...@@ -1033,18 +1039,14 @@ int class_process_proc_param(char *prefix, struct lprocfs_vars *lvars,
j++; j++;
} }
if (!matched) { if (!matched) {
/* If the prefix doesn't match, return error so we CERROR("%.*s: %s unknown param %s\n",
* can pass it down the stack (int)strlen(prefix) - 1, prefix,
*/
if (strnchr(key, keylen, '.'))
return -ENOSYS;
CERROR("%s: unknown param %s\n",
(char *)lustre_cfg_string(lcfg, 0), key); (char *)lustre_cfg_string(lcfg, 0), key);
/* rc = -EINVAL; continue parsing other params */ /* rc = -EINVAL; continue parsing other params */
skip++; skip++;
} else if (rc < 0) { } else if (rc < 0) {
CERROR("writing proc entry %s err %d\n", CERROR("%s: error writing proc entry '%s': rc = %d\n",
var->name, rc); prefix, var->name, rc);
rc = 0; rc = 0;
} else { } else {
CDEBUG(D_CONFIG, "%s.%.*s: Set parameter %.*s=%s\n", CDEBUG(D_CONFIG, "%s.%.*s: Set parameter %.*s=%s\n",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment