Skip to content
Snippets Groups Projects
Commit 89228074 authored by Nathaniel Clark's avatar Nathaniel Clark Committed by Oleg Drokin
Browse files

LU-9551 utils: add l_tunedisk to fix disk tunings


This adds l_tunedisk utility to utilize osd_tune_lustre call for
mount_utils.h.  This can be called from udev.
This adds a udev rule to fix disk tunings.
This in some ways duplicates LU-9132, which sets this value at mount
time, but if a multipath component is removed then re-added, the
multipath's max_sectors_kb will not propgate to the newly added device
and this now will cause an error for I/Os that would violate this.

Test-Parameters: trivial
Signed-off-by: default avatarNathaniel Clark <nathaniel.l.clark@intel.com>
Change-Id: I35330ebe75552d71b71212f9fae00cfdcc028ea1
Reviewed-on: https://review.whamcloud.com/31464


Tested-by: Jenkins
Tested-by: default avatarMaloo <hpdd-maloo@intel.com>
Reviewed-by: default avatarAndreas Dilger <andreas.dilger@intel.com>
Reviewed-by: default avatarBob Glossman <bob.glossman@intel.com>
parent 01fb4edf
No related branches found
No related tags found
No related merge requests found
KERNEL=="obd", MODE="0666"
# Ensure block devices re-added to the system allow for large writes (LU-9551)
ACTION=="add|change", SUBSYSTEM=="block", RUN+="/usr/sbin/l_tunedisk /dev/%k"
# set sysfs values on client
SUBSYSTEM=="lustre", ACTION=="change", ENV{PARAM}=="?*", RUN+="/usr/sbin/lctl set_param $env{PARAM}=$env{SETTING}"
......@@ -24,3 +24,4 @@
/ll_decode_linkea
/lhsmd_posix
/lhsmtool_posix
/l_tunedisk
......@@ -34,7 +34,7 @@ endif # TESTS
if SERVER
sbin_PROGRAMS += mkfs.lustre tunefs.lustre llverdev lr_reader lshowmount \
ll_decode_filter_fid llog_reader
ll_decode_filter_fid llog_reader l_tunedisk
endif
if LIBPTHREAD
sbin_PROGRAMS += lhsmtool_posix
......@@ -188,6 +188,11 @@ tunefs_lustre_CPPFLAGS := -DTUNEFS ${MNTMODCFLAGS}
tunefs_lustre_LDFLAGS := ${MNTMODLDFLAGS}
tunefs_lustre_LDADD := $(mkfs_lustre_LDADD)
l_tunedisk_SOURCES = l_tunedisk.c mount_utils.c mount_utils.h $(GSSSRC)
l_tunedisk_CPPFLAGS := ${MNTMODCFLAGS}
l_tunedisk_LDFLAGS := ${MNTMODLDFLAGS}
l_tunedisk_LDADD := $(mount_lustre_LDADD)
l_getidentity_SOURCES = l_getidentity.c
l_getidentity_LDADD := $(top_builddir)/libcfs/libcfs/libcfs.la
l_getidentity_DEPENDENCIES := $(top_builddir)/libcfs/libcfs/libcfs.la
......
/*
* GPL HEADER START
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 only,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License version 2 for more details (a copy is included
* in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU General Public License
* version 2 along with this program; If not, see
* http://www.gnu.org/licenses/gpl-2.0.html
*
* GPL HEADER END
*/
/*
* Copyright (c) 2018, Intel Corporation.
*/
#if HAVE_CONFIG_H
# include "config.h"
#endif /* HAVE_CONFIG_H */
#ifndef _GNU_SOURCE
#define _GNU_SOURCE
#endif
#include <stdlib.h>
#include <stdio.h>
#include "mount_utils.h"
int verbose;
char *progname;
int main(int argc, char *const argv[])
{
struct mount_opts mop = {
.mo_max_sectors_kb = -1
};
char real_path[PATH_MAX] = {'\0'};
unsigned int mount_type;
int ret;
verbose = 0;
progname = strrchr(argv[0], '/');
progname = progname ? progname + 1 : argv[0];
ret = osd_init();
if (ret != 0) {
vprint("%s: osd_init() failed to initialize: %d\n",
progname, ret);
return ret;
}
/* device is last arg */
mop.mo_usource = argv[argc - 1];
mop.mo_source = realpath(mop.mo_usource, real_path);
if (mop.mo_source == NULL) {
vprint("%s: No realpath for %s\n", progname, mop.mo_usource);
goto out;
}
/* Check whether the disk has already been formatted by mkfs.lustre */
ret = osd_is_lustre(mop.mo_source, &mount_type);
if (ret == 0)
goto out;
ret = osd_tune_lustre(mop.mo_source, &mop);
out:
osd_fini();
return ret;
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment