X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustre%2Fquota%2Fqmt_dev.c;h=19605fad2f34928edebf6ce260571c885ed0e083;hp=8b501c3195c59f74c9362d61f77c7c2205124429;hb=c228613e18d4496d026d56040e394fe90273de2f;hpb=b1e595c09e1b07a6840142b3ae015b8a5a8affeb diff --git a/lustre/quota/qmt_dev.c b/lustre/quota/qmt_dev.c index 8b501c3..19605fa 100644 --- a/lustre/quota/qmt_dev.c +++ b/lustre/quota/qmt_dev.c @@ -21,7 +21,7 @@ * GPL HEADER END */ /* - * Copyright (c) 2012, Intel Corporation. + * Copyright (c) 2012, 2017, Intel Corporation. * Use is subject to license terms. * * Author: Johann Lombardi @@ -107,7 +107,8 @@ static struct lu_device *qmt_device_fini(const struct lu_env *env, } /* stop rebalance thread */ - qmt_stop_reba_thread(qmt); + if (!qmt->qmt_child->dd_rdonly) + qmt_stop_reba_thread(qmt); /* disconnect from OSD */ if (qmt->qmt_child_exp != NULL) { @@ -240,15 +241,17 @@ static int qmt_device_init0(const struct lu_env *env, struct qmt_device *qmt, GOTO(out, rc); /* set up and start rebalance thread */ - thread_set_flags(&qmt->qmt_reba_thread, SVC_STOPPED); + thread_set_flags(&qmt->qmt_reba_thread, SVC_STARTING); init_waitqueue_head(&qmt->qmt_reba_thread.t_ctl_waitq); INIT_LIST_HEAD(&qmt->qmt_reba_list); spin_lock_init(&qmt->qmt_reba_lock); - rc = qmt_start_reba_thread(qmt); - if (rc) { - CERROR("%s: failed to start rebalance thread (%d)\n", - qmt->qmt_svname, rc); - GOTO(out, rc); + if (!qmt->qmt_child->dd_rdonly) { + rc = qmt_start_reba_thread(qmt); + if (rc) { + CERROR("%s: failed to start rebalance thread (%d)\n", + qmt->qmt_svname, rc); + GOTO(out, rc); + } } /* at the moment there is no linkage between lu_type and obd_type, so @@ -256,9 +259,12 @@ static int qmt_device_init0(const struct lu_env *env, struct qmt_device *qmt, type = class_search_type(LUSTRE_QMT_NAME); LASSERT(type != NULL); + /* put reference taken by class_search_type */ + kobject_put(&type->typ_kobj); + /* register proc directory associated with this qmt */ - qmt->qmt_proc = lprocfs_seq_register(qmt->qmt_svname, type->typ_procroot, - NULL, NULL); + qmt->qmt_proc = lprocfs_register(qmt->qmt_svname, type->typ_procroot, + NULL, NULL); if (IS_ERR(qmt->qmt_proc)) { rc = PTR_ERR(qmt->qmt_proc); CERROR("%s: failed to create qmt proc entry (%d)\n", @@ -452,7 +458,7 @@ static int qmt_device_prepare(const struct lu_env *env, /* initialize on-disk indexes associated with each pool */ rc = qmt_pool_prepare(env, qmt, qmt_root); - lu_object_put(env, &qmt_root->do_lu); + dt_object_put(env, qmt_root); RETURN(rc); }