static int llog_remove_log(struct llog_handle *cat, struct llog_logid *logid) { struct llog_handle *log; int rc, index = 0; ENTRY; cfs_down_write(&cat->lgh_lock); rc = llog_cat_id2handle(cat, &log, logid); if (rc) { CDEBUG(D_IOCTL, "cannot find log #"LPX64"#"LPX64"#%08x\n", logid->lgl_oid, logid->lgl_oseq, logid->lgl_ogen); GOTO(out, rc = -ENOENT); } index = log->u.phd.phd_cookie.lgc_index; LASSERT(index); rc = llog_destroy(log); if (rc) { CDEBUG(D_IOCTL, "cannot destroy log\n"); GOTO(out, rc); } llog_cat_set_first_idx(cat, index); rc = llog_cancel_rec(cat, index); out: llog_free_handle(log); cfs_up_write(&cat->lgh_lock); RETURN(rc); }
static int mds_precleanup(struct obd_device *obd, enum obd_cleanup_stage stage) { struct mds_obd *mds = &obd->u.mds; struct llog_ctxt *ctxt; int rc = 0; ENTRY; switch (stage) { case OBD_CLEANUP_EARLY: break; case OBD_CLEANUP_EXPORTS: mds_lov_early_clean(obd); cfs_down_write(&mds->mds_notify_lock); mds_lov_disconnect(obd); mds_lov_clean(obd); ctxt = llog_get_context(obd, LLOG_CONFIG_ORIG_CTXT); if (ctxt) llog_cleanup(ctxt); ctxt = llog_get_context(obd, LLOG_LOVEA_ORIG_CTXT); if (ctxt) llog_cleanup(ctxt); rc = obd_llog_finish(obd, 0); mds->mds_lov_exp = NULL; cfs_up_write(&mds->mds_notify_lock); break; } RETURN(rc); }
/* * generic_quota_on is very lazy and tolerant about current quota settings * @global means to turn on quotas on each OST additionally to local quotas; * should not be called from filter_quota_ctl on MDS nodes (as it starts * admin quotas on MDS nodes). */ int generic_quota_on(struct obd_device *obd, struct obd_quotactl *oqctl, int global) { struct obd_device_target *obt = &obd->u.obt; struct lvfs_run_ctxt saved; int id, is_master, rc = 0, local; /* means we need a local quotaon */ cfs_down(&obt->obt_quotachecking); push_ctxt(&saved, &obd->obd_lvfs_ctxt, NULL); id = UGQUOTA2LQC(oqctl->qc_type); local = (obt->obt_qctxt.lqc_flags & id) != id; oqctl->qc_cmd = Q_QUOTAON; oqctl->qc_id = obt->obt_qfmt; is_master = !strcmp(obd->obd_type->typ_name, LUSTRE_MDS_NAME); if (is_master) { cfs_down_write(&obd->u.mds.mds_qonoff_sem); if (local) { /* turn on cluster wide quota */ rc = mds_admin_quota_on(obd, oqctl); if (rc && rc != -ENOENT) CERROR("%s: %s admin quotaon failed. rc=%d\n", obd->obd_name, global ? "global":"local", rc); } } if (rc == 0) { if (local) { rc = fsfilt_quotactl(obd, obt->obt_sb, oqctl); if (rc) { if (rc != -ENOENT) CERROR("%s: %s quotaon failed with" " rc=%d\n", obd->obd_name, global ? "global" : "local", rc); } else { obt->obt_qctxt.lqc_flags |= UGQUOTA2LQC(oqctl->qc_type); build_lqs(obd); } } if (rc == 0 && global && is_master) rc = obd_quotactl(obd->u.mds.mds_lov_exp, oqctl); } if (is_master) cfs_up_write(&obd->u.mds.mds_qonoff_sem); pop_ctxt(&saved, &obd->obd_lvfs_ctxt, NULL); cfs_up(&obt->obt_quotachecking); return rc; }
int libcfs_deregister_ioctl(struct libcfs_ioctl_handler *hand) { int rc = 0; cfs_down_write(&ioctl_list_sem); if (cfs_list_empty(&hand->item)) rc = -ENOENT; else cfs_list_del_init(&hand->item); cfs_up_write(&ioctl_list_sem); return rc; }
int libcfs_register_ioctl(struct libcfs_ioctl_handler *hand) { int rc = 0; cfs_down_write(&ioctl_list_sem); if (!cfs_list_empty(&hand->item)) rc = -EBUSY; else cfs_list_add_tail(&hand->item, &ioctl_list); cfs_up_write(&ioctl_list_sem); return rc; }
static int mds_quota_fs_cleanup(struct obd_device *obd) { struct mds_obd *mds = &obd->u.mds; struct obd_quotactl oqctl; ENTRY; if (unlikely(!mds->mds_quota)) RETURN(0); mds->mds_quota = 0; memset(&oqctl, 0, sizeof(oqctl)); oqctl.qc_type = UGQUOTA; cfs_down_write(&mds->mds_qonoff_sem); mds_admin_quota_off(obd, &oqctl); cfs_up_write(&mds->mds_qonoff_sem); RETURN(0); }
int llog_ioctl(struct llog_ctxt *ctxt, int cmd, struct obd_ioctl_data *data) { struct llog_logid logid; int err = 0; struct llog_handle *handle = NULL; ENTRY; if (*data->ioc_inlbuf1 == '#') { err = str2logid(&logid, data->ioc_inlbuf1, data->ioc_inllen1); if (err) GOTO(out, err); err = llog_create(ctxt, &handle, &logid, NULL); if (err) GOTO(out, err); } else if (*data->ioc_inlbuf1 == '$') { char *name = data->ioc_inlbuf1 + 1; err = llog_create(ctxt, &handle, NULL, name); if (err) GOTO(out, err); } else { GOTO(out, err = -EINVAL); } err = llog_init_handle(handle, 0, NULL); if (err) GOTO(out_close, err = -ENOENT); switch (cmd) { case OBD_IOC_LLOG_INFO: { int l; int remains = data->ioc_inllen2 + cfs_size_round(data->ioc_inllen1); char *out = data->ioc_bulk; l = snprintf(out, remains, "logid: #"LPX64"#"LPX64"#%08x\n" "flags: %x (%s)\n" "records count: %d\n" "last index: %d\n", handle->lgh_id.lgl_oid, handle->lgh_id.lgl_oseq, handle->lgh_id.lgl_ogen, handle->lgh_hdr->llh_flags, handle->lgh_hdr->llh_flags & LLOG_F_IS_CAT ? "cat" : "plain", handle->lgh_hdr->llh_count, handle->lgh_last_idx); out += l; remains -= l; if (remains <= 0) CERROR("not enough space for log header info\n"); GOTO(out_close, err); } case OBD_IOC_LLOG_CHECK: { LASSERT(data->ioc_inllen1); err = llog_process(handle, llog_check_cb, data, NULL); if (err == -LLOG_EEMPTY) err = 0; GOTO(out_close, err); } case OBD_IOC_LLOG_PRINT: { LASSERT(data->ioc_inllen1); err = llog_process(handle, class_config_dump_handler,data,NULL); if (err == -LLOG_EEMPTY) err = 0; else err = llog_process(handle, llog_print_cb, data, NULL); GOTO(out_close, err); } case OBD_IOC_LLOG_CANCEL: { struct llog_cookie cookie; struct llog_logid plain; char *endp; cookie.lgc_index = simple_strtoul(data->ioc_inlbuf3, &endp, 0); if (*endp != '\0') GOTO(out_close, err = -EINVAL); if (handle->lgh_hdr->llh_flags & LLOG_F_IS_CAT) { cfs_down_write(&handle->lgh_lock); err = llog_cancel_rec(handle, cookie.lgc_index); cfs_up_write(&handle->lgh_lock); GOTO(out_close, err); } err = str2logid(&plain, data->ioc_inlbuf2, data->ioc_inllen2); if (err) GOTO(out_close, err); cookie.lgc_lgl = plain; if (!(handle->lgh_hdr->llh_flags & LLOG_F_IS_CAT)) GOTO(out_close, err = -EINVAL); err = llog_cat_cancel_records(handle, 1, &cookie); GOTO(out_close, err); } case OBD_IOC_LLOG_REMOVE: { struct llog_logid plain; if (handle->lgh_hdr->llh_flags & LLOG_F_IS_PLAIN) { err = llog_destroy(handle); if (!err) llog_free_handle(handle); GOTO(out, err); } if (!(handle->lgh_hdr->llh_flags & LLOG_F_IS_CAT)) GOTO(out_close, err = -EINVAL); if (data->ioc_inlbuf2) { /*remove indicate log from the catalog*/ err = str2logid(&plain, data->ioc_inlbuf2, data->ioc_inllen2); if (err) GOTO(out_close, err); err = llog_remove_log(handle, &plain); } else { /*remove all the log of the catalog*/ llog_process(handle, llog_delete_cb, NULL, NULL); } GOTO(out_close, err); } } out_close: if (handle->lgh_hdr && handle->lgh_hdr->llh_flags & LLOG_F_IS_CAT) llog_cat_put(handle); else llog_close(handle); out: RETURN(err); }