mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-06 09:56:25 -04:00
staging: lustre: lmv: add new lmv structures
Newer lustre version on metadata servers support different version of lmv magic. This add the new data structures to handle these new lmv magic versions. Signed-off-by: wang di <di.wang@intel.com> Reviewed-on: http://review.whamcloud.com/7043 Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-3531 Reviewed-by: John L. Hammond <john.hammond@intel.com> Reviewed-by: Jinshan Xiong <jinshan.xiong@intel.com> Reviewed-by: Andreas Dilger <andreas.dilger@intel.com> Reviewed-by: Oleg Drokin <oleg.drokin@intel.com> Signed-off-by: James Simmons <jsimmons@infradead.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
1c12cf634e
commit
8e9dfe8a22
@@ -2482,16 +2482,6 @@ struct lmv_desc {
|
||||
struct obd_uuid ld_uuid;
|
||||
};
|
||||
|
||||
/* TODO: lmv_stripe_md should contain mds capabilities for all slave fids */
|
||||
struct lmv_stripe_md {
|
||||
__u32 mea_magic;
|
||||
__u32 mea_count;
|
||||
__u32 mea_master;
|
||||
__u32 mea_padding;
|
||||
char mea_pool_name[LOV_MAXPOOLNAME];
|
||||
struct lu_fid mea_ids[0];
|
||||
};
|
||||
|
||||
#define MEA_MAGIC_LAST_CHAR 0xb2221ca1
|
||||
#define MEA_MAGIC_ALL_CHARS 0xb222a11c
|
||||
#define MEA_MAGIC_HASH_SEGMENT 0xb222a11b
|
||||
@@ -2500,6 +2490,77 @@ struct lmv_stripe_md {
|
||||
#define MAX_HASH_SIZE 0x7fffffffffffffffULL
|
||||
#define MAX_HASH_HIGHEST_BIT 0x1000000000000000ULL
|
||||
|
||||
/* lmv structures */
|
||||
#define LMV_MAGIC_V1 0x0CD10CD0 /* normal stripe lmv magic */
|
||||
#define LMV_USER_MAGIC 0x0CD20CD0 /* default lmv magic*/
|
||||
#define LMV_MAGIC LMV_MAGIC_V1
|
||||
struct lmv_mds_md_v1 {
|
||||
__u32 lmv_magic;
|
||||
__u32 lmv_stripe_count; /* stripe count */
|
||||
__u32 lmv_master_mdt_index; /* master MDT index */
|
||||
__u32 lmv_hash_type; /* dir stripe policy, i.e. indicate
|
||||
* which hash function to be used
|
||||
*/
|
||||
__u32 lmv_layout_version; /* Used for directory restriping */
|
||||
__u32 lmv_padding;
|
||||
char lmv_pool_name[LOV_MAXPOOLNAME]; /* pool name */
|
||||
struct lu_fid lmv_stripe_fids[0]; /* FIDs for each stripe */
|
||||
};
|
||||
|
||||
union lmv_mds_md {
|
||||
__u32 lmv_magic;
|
||||
struct lmv_mds_md_v1 lmv_md_v1;
|
||||
struct lmv_user_md lmv_user_md;
|
||||
};
|
||||
|
||||
static inline ssize_t lmv_mds_md_size(int stripe_count, unsigned int lmm_magic)
|
||||
{
|
||||
ssize_t len = -EINVAL;
|
||||
|
||||
switch (lmm_magic) {
|
||||
case LMV_MAGIC_V1: {
|
||||
struct lmv_mds_md_v1 *lmm1;
|
||||
|
||||
len = sizeof(*lmm1);
|
||||
len += stripe_count * sizeof(lmm1->lmv_stripe_fids[0]);
|
||||
break; }
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return len;
|
||||
}
|
||||
|
||||
static inline int lmv_mds_md_stripe_count_get(const union lmv_mds_md *lmm)
|
||||
{
|
||||
switch (le32_to_cpu(lmm->lmv_magic)) {
|
||||
case LMV_MAGIC_V1:
|
||||
return le32_to_cpu(lmm->lmv_md_v1.lmv_stripe_count);
|
||||
case LMV_USER_MAGIC:
|
||||
return le32_to_cpu(lmm->lmv_user_md.lum_stripe_count);
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
static inline int lmv_mds_md_stripe_count_set(union lmv_mds_md *lmm,
|
||||
unsigned int stripe_count)
|
||||
{
|
||||
int rc = 0;
|
||||
|
||||
switch (le32_to_cpu(lmm->lmv_magic)) {
|
||||
case LMV_MAGIC_V1:
|
||||
lmm->lmv_md_v1.lmv_stripe_count = cpu_to_le32(stripe_count);
|
||||
break;
|
||||
case LMV_USER_MAGIC:
|
||||
lmm->lmv_user_md.lum_stripe_count = cpu_to_le32(stripe_count);
|
||||
break;
|
||||
default:
|
||||
rc = -EINVAL;
|
||||
break;
|
||||
}
|
||||
return rc;
|
||||
}
|
||||
|
||||
enum fld_rpc_opc {
|
||||
FLD_QUERY = 900,
|
||||
FLD_READ = 901,
|
||||
|
||||
66
drivers/staging/lustre/lustre/include/lustre_lmv.h
Normal file
66
drivers/staging/lustre/lustre/include/lustre_lmv.h
Normal file
@@ -0,0 +1,66 @@
|
||||
/*
|
||||
* 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 COPYING 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.sun.com/software/products/lustre/docs/GPLv2.pdf
|
||||
*
|
||||
* GPL HEADER END
|
||||
*/
|
||||
/*
|
||||
* Copyright (c) 2013, Intel Corporation.
|
||||
*/
|
||||
/*
|
||||
* lustre/include/lustre_lmv.h
|
||||
*
|
||||
* Lustre LMV structures and functions.
|
||||
*
|
||||
* Author: Di Wang <di.wang@intel.com>
|
||||
*/
|
||||
|
||||
#ifndef _LUSTRE_LMV_H
|
||||
#define _LUSTRE_LMV_H
|
||||
#include "lustre/lustre_idl.h"
|
||||
|
||||
struct lmv_oinfo {
|
||||
struct lu_fid lmo_fid;
|
||||
u32 lmo_mds;
|
||||
struct inode *lmo_root;
|
||||
};
|
||||
|
||||
struct lmv_stripe_md {
|
||||
__u32 mea_magic;
|
||||
__u32 mea_count;
|
||||
__u32 mea_master;
|
||||
__u32 mea_padding;
|
||||
char mea_pool_name[LOV_MAXPOOLNAME];
|
||||
struct lu_fid mea_ids[0];
|
||||
};
|
||||
|
||||
union lmv_mds_md;
|
||||
|
||||
int lmv_unpack_md(struct obd_export *exp, struct lmv_stripe_md **lsmp,
|
||||
const union lmv_mds_md *lmm, int stripe_count);
|
||||
|
||||
static inline int lmv_alloc_memmd(struct lmv_stripe_md **lsmp, int stripe_count)
|
||||
{
|
||||
return lmv_unpack_md(NULL, lsmp, NULL, stripe_count);
|
||||
}
|
||||
|
||||
static inline void lmv_free_memmd(struct lmv_stripe_md *lsm)
|
||||
{
|
||||
lmv_unpack_md(NULL, &lsm, NULL, 0);
|
||||
}
|
||||
#endif
|
||||
@@ -35,6 +35,7 @@
|
||||
|
||||
#include "../include/lustre/lustre_idl.h"
|
||||
#include "../include/obd.h"
|
||||
#include "../include/lustre_lmv.h"
|
||||
|
||||
#define LMV_MAX_TGT_COUNT 128
|
||||
|
||||
|
||||
@@ -46,6 +46,7 @@
|
||||
#include "../include/lustre_lib.h"
|
||||
#include "../include/lustre_net.h"
|
||||
#include "../include/obd_class.h"
|
||||
#include "../include/lustre_lmv.h"
|
||||
#include "../include/lprocfs_status.h"
|
||||
#include "../include/lustre_lite.h"
|
||||
#include "../include/lustre_fid.h"
|
||||
|
||||
@@ -40,6 +40,7 @@
|
||||
|
||||
#include "../include/lustre_acl.h"
|
||||
#include "../include/obd_class.h"
|
||||
#include "../include/lustre_lmv.h"
|
||||
#include "../include/lustre_fid.h"
|
||||
#include "../include/lprocfs_status.h"
|
||||
#include "../include/lustre_param.h"
|
||||
|
||||
Reference in New Issue
Block a user