Commit cbd4d4a8 authored by Bobi Jam's avatar Bobi Jam Committed by Greg Kroah-Hartman

staging: lustre: llite: remove duplicate fiemap defines

 * replace struct ll_user_fiemap with struct fiemap
 * replace struct ll_fiemap_extent with struct fiemap_extent
 * remove kernel defined FIEMAP_EXTENT_* constants
 * remove kernel defined FIEMAP_FLAG_* flags
 * add member prefix for struct ll_fiemap_info_key

 * Add cl_object_operations::coo_fiemap().
 * Add cl_object_fiemap() to get FIEMAP mappings.
Signed-off-by: default avatarBobi Jam <bobijam.xu@intel.com>
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-5823
Reviewed-on: http://review.whamcloud.com/12535
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-6201
Reviewed-on: http://review.whamcloud.com/13608Reviewed-by: default avatarJohn L. Hammond <john.hammond@intel.com>
Reviewed-by: default avatarJinshan Xiong <jinshan.xiong@intel.com>
Reviewed-by: default avatarYang Sheng <yang.sheng@intel.com>
Reviewed-by: default avatarOleg Drokin <oleg.drokin@intel.com>
Signed-off-by: default avatarJames Simmons <jsimmons@infradead.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e7226dd4
...@@ -400,6 +400,12 @@ struct cl_object_operations { ...@@ -400,6 +400,12 @@ struct cl_object_operations {
*/ */
int (*coo_getstripe)(const struct lu_env *env, struct cl_object *obj, int (*coo_getstripe)(const struct lu_env *env, struct cl_object *obj,
struct lov_user_md __user *lum); struct lov_user_md __user *lum);
/**
* Get FIEMAP mapping from the object.
*/
int (*coo_fiemap)(const struct lu_env *env, struct cl_object *obj,
struct ll_fiemap_info_key *fmkey,
struct fiemap *fiemap, size_t *buflen);
}; };
/** /**
...@@ -2184,6 +2190,9 @@ int cl_object_prune(const struct lu_env *env, struct cl_object *obj); ...@@ -2184,6 +2190,9 @@ int cl_object_prune(const struct lu_env *env, struct cl_object *obj);
void cl_object_kill(const struct lu_env *env, struct cl_object *obj); void cl_object_kill(const struct lu_env *env, struct cl_object *obj);
int cl_object_getstripe(const struct lu_env *env, struct cl_object *obj, int cl_object_getstripe(const struct lu_env *env, struct cl_object *obj,
struct lov_user_md __user *lum); struct lov_user_md __user *lum);
int cl_object_fiemap(const struct lu_env *env, struct cl_object *obj,
struct ll_fiemap_info_key *fmkey, struct fiemap *fiemap,
size_t *buflen);
/** /**
* Returns true, iff \a o0 and \a o1 are slices of the same object. * Returns true, iff \a o0 and \a o1 are slices of the same object.
......
...@@ -41,79 +41,24 @@ ...@@ -41,79 +41,24 @@
#ifndef _LUSTRE_FIEMAP_H #ifndef _LUSTRE_FIEMAP_H
#define _LUSTRE_FIEMAP_H #define _LUSTRE_FIEMAP_H
struct ll_fiemap_extent { #ifndef __KERNEL__
__u64 fe_logical; /* logical offset in bytes for the start of #include <stddef.h>
* the extent from the beginning of the file #include <fiemap.h>
*/ #endif
__u64 fe_physical; /* physical offset in bytes for the start
* of the extent from the beginning of the disk
*/
__u64 fe_length; /* length in bytes for this extent */
__u64 fe_reserved64[2];
__u32 fe_flags; /* FIEMAP_EXTENT_* flags for this extent */
__u32 fe_device; /* device number for this extent */
__u32 fe_reserved[2];
};
struct ll_user_fiemap {
__u64 fm_start; /* logical offset (inclusive) at
* which to start mapping (in)
*/
__u64 fm_length; /* logical length of mapping which
* userspace wants (in)
*/
__u32 fm_flags; /* FIEMAP_FLAG_* flags for request (in/out) */
__u32 fm_mapped_extents;/* number of extents that were mapped (out) */
__u32 fm_extent_count; /* size of fm_extents array (in) */
__u32 fm_reserved;
struct ll_fiemap_extent fm_extents[0]; /* array of mapped extents (out) */
};
#define FIEMAP_MAX_OFFSET (~0ULL)
#define FIEMAP_FLAG_SYNC 0x00000001 /* sync file data before /* XXX: We use fiemap_extent::fe_reserved[0] */
* map #define fe_device fe_reserved[0]
*/
#define FIEMAP_FLAG_XATTR 0x00000002 /* map extended attribute
* tree
*/
#define FIEMAP_EXTENT_LAST 0x00000001 /* Last extent in file. */
#define FIEMAP_EXTENT_UNKNOWN 0x00000002 /* Data location unknown. */
#define FIEMAP_EXTENT_DELALLOC 0x00000004 /* Location still pending.
* Sets EXTENT_UNKNOWN.
*/
#define FIEMAP_EXTENT_ENCODED 0x00000008 /* Data can not be read
* while fs is unmounted
*/
#define FIEMAP_EXTENT_DATA_ENCRYPTED 0x00000080 /* Data is encrypted by fs.
* Sets EXTENT_NO_DIRECT.
*/
#define FIEMAP_EXTENT_NOT_ALIGNED 0x00000100 /* Extent offsets may not be
* block aligned.
*/
#define FIEMAP_EXTENT_DATA_INLINE 0x00000200 /* Data mixed with metadata.
* Sets EXTENT_NOT_ALIGNED.*/
#define FIEMAP_EXTENT_DATA_TAIL 0x00000400 /* Multiple files in block.
* Sets EXTENT_NOT_ALIGNED.
*/
#define FIEMAP_EXTENT_UNWRITTEN 0x00000800 /* Space allocated, but
* no data (i.e. zero).
*/
#define FIEMAP_EXTENT_MERGED 0x00001000 /* File does not natively
* support extents. Result
* merged for efficiency.
*/
static inline size_t fiemap_count_to_size(size_t extent_count) static inline size_t fiemap_count_to_size(size_t extent_count)
{ {
return (sizeof(struct ll_user_fiemap) + extent_count * return sizeof(struct fiemap) + extent_count *
sizeof(struct ll_fiemap_extent)); sizeof(struct fiemap_extent);
} }
static inline unsigned fiemap_size_to_count(size_t array_size) static inline unsigned fiemap_size_to_count(size_t array_size)
{ {
return ((array_size - sizeof(struct ll_user_fiemap)) / return (array_size - sizeof(struct fiemap)) /
sizeof(struct ll_fiemap_extent)); sizeof(struct fiemap_extent);
} }
#define FIEMAP_FLAG_DEVICE_ORDER 0x40000000 /* return device ordered mapping */ #define FIEMAP_FLAG_DEVICE_ORDER 0x40000000 /* return device ordered mapping */
......
...@@ -3331,14 +3331,14 @@ struct ost_body { ...@@ -3331,14 +3331,14 @@ struct ost_body {
/* Key for FIEMAP to be used in get_info calls */ /* Key for FIEMAP to be used in get_info calls */
struct ll_fiemap_info_key { struct ll_fiemap_info_key {
char name[8]; char lfik_name[8];
struct obdo oa; struct obdo lfik_oa;
struct ll_user_fiemap fiemap; struct fiemap lfik_fiemap;
}; };
void lustre_swab_ost_body(struct ost_body *b); void lustre_swab_ost_body(struct ost_body *b);
void lustre_swab_ost_last_id(__u64 *id); void lustre_swab_ost_last_id(__u64 *id);
void lustre_swab_fiemap(struct ll_user_fiemap *fiemap); void lustre_swab_fiemap(struct fiemap *fiemap);
void lustre_swab_lov_user_md_v1(struct lov_user_md_v1 *lum); void lustre_swab_lov_user_md_v1(struct lov_user_md_v1 *lum);
void lustre_swab_lov_user_md_v3(struct lov_user_md_v3 *lum); void lustre_swab_lov_user_md_v3(struct lov_user_md_v3 *lum);
......
...@@ -82,7 +82,6 @@ typedef struct stat lstat_t; ...@@ -82,7 +82,6 @@ typedef struct stat lstat_t;
#define FSFILT_IOC_SETVERSION _IOW('f', 4, long) #define FSFILT_IOC_SETVERSION _IOW('f', 4, long)
#define FSFILT_IOC_GETVERSION_OLD _IOR('v', 1, long) #define FSFILT_IOC_GETVERSION_OLD _IOR('v', 1, long)
#define FSFILT_IOC_SETVERSION_OLD _IOW('v', 2, long) #define FSFILT_IOC_SETVERSION_OLD _IOW('v', 2, long)
#define FSFILT_IOC_FIEMAP _IOWR('f', 11, struct ll_user_fiemap)
#endif #endif
/* FIEMAP flags supported by Lustre */ /* FIEMAP flags supported by Lustre */
......
...@@ -1506,15 +1506,17 @@ int ll_release_openhandle(struct inode *inode, struct lookup_intent *it) ...@@ -1506,15 +1506,17 @@ int ll_release_openhandle(struct inode *inode, struct lookup_intent *it)
/** /**
* Get size for inode for which FIEMAP mapping is requested. * Get size for inode for which FIEMAP mapping is requested.
* Make the FIEMAP get_info call and returns the result. * Make the FIEMAP get_info call and returns the result.
*
* \param fiemap kernel buffer to hold extens
* \param num_bytes kernel buffer size
*/ */
static int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap, static int ll_do_fiemap(struct inode *inode, struct fiemap *fiemap,
size_t num_bytes) size_t num_bytes)
{ {
struct obd_export *exp = ll_i2dtexp(inode); struct ll_fiemap_info_key fmkey = { .lfik_name = KEY_FIEMAP, };
struct lov_stripe_md *lsm = NULL; struct lu_env *env;
struct ll_fiemap_info_key fm_key = { .name = KEY_FIEMAP, }; int refcheck;
__u32 vallen = num_bytes; int rc = 0;
int rc;
/* Checks for fiemap flags */ /* Checks for fiemap flags */
if (fiemap->fm_flags & ~LUSTRE_FIEMAP_FLAGS_COMPAT) { if (fiemap->fm_flags & ~LUSTRE_FIEMAP_FLAGS_COMPAT) {
...@@ -1529,21 +1531,9 @@ static int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap, ...@@ -1529,21 +1531,9 @@ static int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap,
return rc; return rc;
} }
lsm = ccc_inode_lsm_get(inode); env = cl_env_get(&refcheck);
if (!lsm) if (IS_ERR(env))
return -ENOENT; return PTR_ERR(env);
/* If the stripe_count > 1 and the application does not understand
* DEVICE_ORDER flag, then it cannot interpret the extents correctly.
*/
if (lsm->lsm_stripe_count > 1 &&
!(fiemap->fm_flags & FIEMAP_FLAG_DEVICE_ORDER)) {
rc = -EOPNOTSUPP;
goto out;
}
fm_key.oa.o_oi = lsm->lsm_oi;
fm_key.oa.o_valid = OBD_MD_FLID | OBD_MD_FLGROUP;
if (i_size_read(inode) == 0) { if (i_size_read(inode) == 0) {
rc = ll_glimpse_size(inode); rc = ll_glimpse_size(inode);
...@@ -1551,24 +1541,23 @@ static int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap, ...@@ -1551,24 +1541,23 @@ static int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap,
goto out; goto out;
} }
obdo_from_inode(&fm_key.oa, inode, OBD_MD_FLSIZE); fmkey.lfik_oa.o_valid = OBD_MD_FLID | OBD_MD_FLGROUP;
obdo_set_parent_fid(&fm_key.oa, &ll_i2info(inode)->lli_fid); obdo_from_inode(&fmkey.lfik_oa, inode, OBD_MD_FLSIZE);
obdo_set_parent_fid(&fmkey.lfik_oa, &ll_i2info(inode)->lli_fid);
/* If filesize is 0, then there would be no objects for mapping */ /* If filesize is 0, then there would be no objects for mapping */
if (fm_key.oa.o_size == 0) { if (fmkey.lfik_oa.o_size == 0) {
fiemap->fm_mapped_extents = 0; fiemap->fm_mapped_extents = 0;
rc = 0; rc = 0;
goto out; goto out;
} }
memcpy(&fm_key.fiemap, fiemap, sizeof(*fiemap)); memcpy(&fmkey.lfik_fiemap, fiemap, sizeof(*fiemap));
rc = obd_get_info(NULL, exp, sizeof(fm_key), &fm_key, &vallen,
fiemap, lsm);
if (rc)
CERROR("obd_get_info failed: rc = %d\n", rc);
rc = cl_object_fiemap(env, ll_i2info(inode)->lli_clob,
&fmkey, fiemap, &num_bytes);
out: out:
ccc_inode_lsm_put(inode, lsm); cl_env_put(env, &refcheck);
return rc; return rc;
} }
...@@ -1616,68 +1605,6 @@ int ll_fid2path(struct inode *inode, void __user *arg) ...@@ -1616,68 +1605,6 @@ int ll_fid2path(struct inode *inode, void __user *arg)
return rc; return rc;
} }
static int ll_ioctl_fiemap(struct inode *inode, unsigned long arg)
{
struct ll_user_fiemap *fiemap_s;
size_t num_bytes, ret_bytes;
unsigned int extent_count;
int rc = 0;
/* Get the extent count so we can calculate the size of
* required fiemap buffer
*/
if (get_user(extent_count,
&((struct ll_user_fiemap __user *)arg)->fm_extent_count))
return -EFAULT;
if (extent_count >=
(SIZE_MAX - sizeof(*fiemap_s)) / sizeof(struct ll_fiemap_extent))
return -EINVAL;
num_bytes = sizeof(*fiemap_s) + (extent_count *
sizeof(struct ll_fiemap_extent));
fiemap_s = libcfs_kvzalloc(num_bytes, GFP_NOFS);
if (!fiemap_s)
return -ENOMEM;
/* get the fiemap value */
if (copy_from_user(fiemap_s, (struct ll_user_fiemap __user *)arg,
sizeof(*fiemap_s))) {
rc = -EFAULT;
goto error;
}
/* If fm_extent_count is non-zero, read the first extent since
* it is used to calculate end_offset and device from previous
* fiemap call.
*/
if (extent_count) {
if (copy_from_user(&fiemap_s->fm_extents[0],
(char __user *)arg + sizeof(*fiemap_s),
sizeof(struct ll_fiemap_extent))) {
rc = -EFAULT;
goto error;
}
}
rc = ll_do_fiemap(inode, fiemap_s, num_bytes);
if (rc)
goto error;
ret_bytes = sizeof(struct ll_user_fiemap);
if (extent_count != 0)
ret_bytes += (fiemap_s->fm_mapped_extents *
sizeof(struct ll_fiemap_extent));
if (copy_to_user((void __user *)arg, fiemap_s, ret_bytes))
rc = -EFAULT;
error:
kvfree(fiemap_s);
return rc;
}
/* /*
* Read the data_version for inode. * Read the data_version for inode.
* *
...@@ -2119,8 +2046,6 @@ ll_file_ioctl(struct file *file, unsigned int cmd, unsigned long arg) ...@@ -2119,8 +2046,6 @@ ll_file_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
case LL_IOC_LOV_GETSTRIPE: case LL_IOC_LOV_GETSTRIPE:
return ll_file_getstripe(inode, return ll_file_getstripe(inode,
(struct lov_user_md __user *)arg); (struct lov_user_md __user *)arg);
case FSFILT_IOC_FIEMAP:
return ll_ioctl_fiemap(inode, arg);
case FSFILT_IOC_GETFLAGS: case FSFILT_IOC_GETFLAGS:
case FSFILT_IOC_SETFLAGS: case FSFILT_IOC_SETFLAGS:
return ll_iocontrol(inode, file, cmd, arg); return ll_iocontrol(inode, file, cmd, arg);
...@@ -3022,13 +2947,12 @@ static int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, ...@@ -3022,13 +2947,12 @@ static int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
{ {
int rc; int rc;
size_t num_bytes; size_t num_bytes;
struct ll_user_fiemap *fiemap; struct fiemap *fiemap;
unsigned int extent_count = fieinfo->fi_extents_max; unsigned int extent_count = fieinfo->fi_extents_max;
num_bytes = sizeof(*fiemap) + (extent_count * num_bytes = sizeof(*fiemap) + (extent_count *
sizeof(struct ll_fiemap_extent)); sizeof(struct fiemap_extent));
fiemap = libcfs_kvzalloc(num_bytes, GFP_NOFS); fiemap = libcfs_kvzalloc(num_bytes, GFP_NOFS);
if (!fiemap) if (!fiemap)
return -ENOMEM; return -ENOMEM;
...@@ -3036,9 +2960,10 @@ static int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, ...@@ -3036,9 +2960,10 @@ static int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
fiemap->fm_extent_count = fieinfo->fi_extents_max; fiemap->fm_extent_count = fieinfo->fi_extents_max;
fiemap->fm_start = start; fiemap->fm_start = start;
fiemap->fm_length = len; fiemap->fm_length = len;
if (extent_count > 0 && if (extent_count > 0 &&
copy_from_user(&fiemap->fm_extents[0], fieinfo->fi_extents_start, copy_from_user(&fiemap->fm_extents[0], fieinfo->fi_extents_start,
sizeof(struct ll_fiemap_extent)) != 0) { sizeof(struct fiemap_extent))) {
rc = -EFAULT; rc = -EFAULT;
goto out; goto out;
} }
...@@ -3050,11 +2975,10 @@ static int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, ...@@ -3050,11 +2975,10 @@ static int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
if (extent_count > 0 && if (extent_count > 0 &&
copy_to_user(fieinfo->fi_extents_start, &fiemap->fm_extents[0], copy_to_user(fieinfo->fi_extents_start, &fiemap->fm_extents[0],
fiemap->fm_mapped_extents * fiemap->fm_mapped_extents *
sizeof(struct ll_fiemap_extent)) != 0) { sizeof(struct fiemap_extent))) {
rc = -EFAULT; rc = -EFAULT;
goto out; goto out;
} }
out: out:
kvfree(fiemap); kvfree(fiemap);
return rc; return rc;
......
This diff is collapsed.
...@@ -342,6 +342,38 @@ int cl_object_getstripe(const struct lu_env *env, struct cl_object *obj, ...@@ -342,6 +342,38 @@ int cl_object_getstripe(const struct lu_env *env, struct cl_object *obj,
} }
EXPORT_SYMBOL(cl_object_getstripe); EXPORT_SYMBOL(cl_object_getstripe);
/**
* Get fiemap extents from file object.
*
* \param env [in] lustre environment
* \param obj [in] file object
* \param key [in] fiemap request argument
* \param fiemap [out] fiemap extents mapping retrived
* \param buflen [in] max buffer length of @fiemap
*
* \retval 0 success
* \retval < 0 error
*/
int cl_object_fiemap(const struct lu_env *env, struct cl_object *obj,
struct ll_fiemap_info_key *key,
struct fiemap *fiemap, size_t *buflen)
{
struct lu_object_header *top;
int result = 0;
top = obj->co_lu.lo_header;
list_for_each_entry(obj, &top->loh_layers, co_lu.lo_linkage) {
if (obj->co_ops->coo_fiemap) {
result = obj->co_ops->coo_fiemap(env, obj, key, fiemap,
buflen);
if (result)
break;
}
}
return result;
}
EXPORT_SYMBOL(cl_object_fiemap);
/** /**
* Helper function removing all object locks, and marking object for * Helper function removing all object locks, and marking object for
* deletion. All object pages must have been deleted at this point. * deletion. All object pages must have been deleted at this point.
......
...@@ -218,6 +218,94 @@ static int osc_object_prune(const struct lu_env *env, struct cl_object *obj) ...@@ -218,6 +218,94 @@ static int osc_object_prune(const struct lu_env *env, struct cl_object *obj)
return 0; return 0;
} }
static int osc_object_fiemap(const struct lu_env *env, struct cl_object *obj,
struct ll_fiemap_info_key *fmkey,
struct fiemap *fiemap, size_t *buflen)
{
struct obd_export *exp = osc_export(cl2osc(obj));
ldlm_policy_data_t policy;
struct ptlrpc_request *req;
struct lustre_handle lockh;
struct ldlm_res_id resid;
enum ldlm_mode mode = 0;
struct fiemap *reply;
char *tmp;
int rc;
fmkey->lfik_oa.o_oi = cl2osc(obj)->oo_oinfo->loi_oi;
if (!(fmkey->lfik_fiemap.fm_flags & FIEMAP_FLAG_SYNC))
goto skip_locking;
policy.l_extent.start = fmkey->lfik_fiemap.fm_start & PAGE_MASK;
if (OBD_OBJECT_EOF - fmkey->lfik_fiemap.fm_length <=
fmkey->lfik_fiemap.fm_start + PAGE_SIZE - 1)
policy.l_extent.end = OBD_OBJECT_EOF;
else
policy.l_extent.end = (fmkey->lfik_fiemap.fm_start +
fmkey->lfik_fiemap.fm_length +
PAGE_SIZE - 1) & PAGE_MASK;
ostid_build_res_name(&fmkey->lfik_oa.o_oi, &resid);
mode = ldlm_lock_match(exp->exp_obd->obd_namespace,
LDLM_FL_BLOCK_GRANTED | LDLM_FL_LVB_READY,
&resid, LDLM_EXTENT, &policy,
LCK_PR | LCK_PW, &lockh, 0);
if (mode) { /* lock is cached on client */
if (mode != LCK_PR) {
ldlm_lock_addref(&lockh, LCK_PR);
ldlm_lock_decref(&lockh, LCK_PW);
}
} else { /* no cached lock, needs acquire lock on server side */
fmkey->lfik_oa.o_valid |= OBD_MD_FLFLAGS;
fmkey->lfik_oa.o_flags |= OBD_FL_SRVLOCK;
}
skip_locking:
req = ptlrpc_request_alloc(class_exp2cliimp(exp),
&RQF_OST_GET_INFO_FIEMAP);
if (!req) {
rc = -ENOMEM;
goto drop_lock;
}
req_capsule_set_size(&req->rq_pill, &RMF_FIEMAP_KEY, RCL_CLIENT,
sizeof(*fmkey));
req_capsule_set_size(&req->rq_pill, &RMF_FIEMAP_VAL, RCL_CLIENT,
*buflen);
req_capsule_set_size(&req->rq_pill, &RMF_FIEMAP_VAL, RCL_SERVER,
*buflen);
rc = ptlrpc_request_pack(req, LUSTRE_OST_VERSION, OST_GET_INFO);
if (rc) {
ptlrpc_request_free(req);
goto drop_lock;
}
tmp = req_capsule_client_get(&req->rq_pill, &RMF_FIEMAP_KEY);
memcpy(tmp, fmkey, sizeof(*fmkey));
tmp = req_capsule_client_get(&req->rq_pill, &RMF_FIEMAP_VAL);
memcpy(tmp, fiemap, *buflen);
ptlrpc_request_set_replen(req);
rc = ptlrpc_queue_wait(req);
if (rc)
goto fini_req;
reply = req_capsule_server_get(&req->rq_pill, &RMF_FIEMAP_VAL);
if (!reply) {
rc = -EPROTO;
goto fini_req;
}
memcpy(fiemap, reply, *buflen);
fini_req:
ptlrpc_req_finished(req);
drop_lock:
if (mode)
ldlm_lock_decref(&lockh, LCK_PR);
return rc;
}
void osc_object_set_contended(struct osc_object *obj) void osc_object_set_contended(struct osc_object *obj)
{ {
obj->oo_contention_time = cfs_time_current(); obj->oo_contention_time = cfs_time_current();
...@@ -263,7 +351,8 @@ static const struct cl_object_operations osc_ops = { ...@@ -263,7 +351,8 @@ static const struct cl_object_operations osc_ops = {
.coo_attr_get = osc_attr_get, .coo_attr_get = osc_attr_get,
.coo_attr_update = osc_attr_update, .coo_attr_update = osc_attr_update,
.coo_glimpse = osc_object_glimpse, .coo_glimpse = osc_object_glimpse,
.coo_prune = osc_object_prune .coo_prune = osc_object_prune,
.coo_fiemap = osc_object_fiemap,
}; };
static const struct lu_object_operations osc_lu_obj_ops = { static const struct lu_object_operations osc_lu_obj_ops = {
......
...@@ -2543,103 +2543,6 @@ static int osc_iocontrol(unsigned int cmd, struct obd_export *exp, int len, ...@@ -2543,103 +2543,6 @@ static int osc_iocontrol(unsigned int cmd, struct obd_export *exp, int len,
return err; return err;
} }
static int osc_get_info(const struct lu_env *env, struct obd_export *exp,
u32 keylen, void *key, __u32 *vallen, void *val,
struct lov_stripe_md *lsm)
{
if (!vallen || !val)
return -EFAULT;
if (KEY_IS(KEY_FIEMAP)) {
struct ll_fiemap_info_key *fm_key = key;
struct ldlm_res_id res_id;
ldlm_policy_data_t policy;
struct lustre_handle lockh;
enum ldlm_mode mode = 0;
struct ptlrpc_request *req;
struct ll_user_fiemap *reply;
char *tmp;
int rc;
if (!(fm_key->fiemap.fm_flags & FIEMAP_FLAG_SYNC))
goto skip_locking;
policy.l_extent.start = fm_key->fiemap.fm_start &
PAGE_MASK;
if (OBD_OBJECT_EOF - fm_key->fiemap.fm_length <=
fm_key->fiemap.fm_start + PAGE_SIZE - 1)
policy.l_extent.end = OBD_OBJECT_EOF;
else
policy.l_extent.end = (fm_key->fiemap.fm_start +
fm_key->fiemap.fm_length +
PAGE_SIZE - 1) & PAGE_MASK;
ostid_build_res_name(&fm_key->oa.o_oi, &res_id);
mode = ldlm_lock_match(exp->exp_obd->obd_namespace,
LDLM_FL_BLOCK_GRANTED |
LDLM_FL_LVB_READY,
&res_id, LDLM_EXTENT, &policy,
LCK_PR | LCK_PW, &lockh, 0);
if (mode) { /* lock is cached on client */
if (mode != LCK_PR) {
ldlm_lock_addref(&lockh, LCK_PR);
ldlm_lock_decref(&lockh, LCK_PW);
}
} else { /* no cached lock, needs acquire lock on server side */
fm_key->oa.o_valid |= OBD_MD_FLFLAGS;
fm_key->oa.o_flags |= OBD_FL_SRVLOCK;
}
skip_locking:
req = ptlrpc_request_alloc(class_exp2cliimp(exp),
&RQF_OST_GET_INFO_FIEMAP);
if (!req) {
rc = -ENOMEM;
goto drop_lock;
}
req_capsule_set_size(&req->rq_pill, &RMF_FIEMAP_KEY,
RCL_CLIENT, keylen);
req_capsule_set_size(&req->rq_pill, &RMF_FIEMAP_VAL,
RCL_CLIENT, *vallen);
req_capsule_set_size(&req->rq_pill, &RMF_FIEMAP_VAL,
RCL_SERVER, *vallen);
rc = ptlrpc_request_pack(req, LUSTRE_OST_VERSION, OST_GET_INFO);
if (rc) {
ptlrpc_request_free(req);
goto drop_lock;
}
tmp = req_capsule_client_get(&req->rq_pill, &RMF_FIEMAP_KEY);
memcpy(tmp, key, keylen);
tmp = req_capsule_client_get(&req->rq_pill, &RMF_FIEMAP_VAL);
memcpy(tmp, val, *vallen);
ptlrpc_request_set_replen(req);
rc = ptlrpc_queue_wait(req);
if (rc)
goto fini_req;
reply = req_capsule_server_get(&req->rq_pill, &RMF_FIEMAP_VAL);
if (!reply) {
rc = -EPROTO;
goto fini_req;
}
memcpy(val, reply, *vallen);
fini_req:
ptlrpc_req_finished(req);
drop_lock:
if (mode)
ldlm_lock_decref(&lockh, LCK_PR);
return rc;
}
return -EINVAL;
}
static int osc_set_info_async(const struct lu_env *env, struct obd_export *exp, static int osc_set_info_async(const struct lu_env *env, struct obd_export *exp,
u32 keylen, void *key, u32 vallen, u32 keylen, void *key, u32 vallen,
void *val, struct ptlrpc_request_set *set) void *val, struct ptlrpc_request_set *set)
...@@ -3112,7 +3015,6 @@ static struct obd_ops osc_obd_ops = { ...@@ -3112,7 +3015,6 @@ static struct obd_ops osc_obd_ops = {
.setattr = osc_setattr, .setattr = osc_setattr,
.setattr_async = osc_setattr_async, .setattr_async = osc_setattr_async,
.iocontrol = osc_iocontrol, .iocontrol = osc_iocontrol,
.get_info = osc_get_info,
.set_info_async = osc_set_info_async, .set_info_async = osc_set_info_async,
.import_event = osc_import_event, .import_event = osc_import_event,
.process_config = osc_process_config, .process_config = osc_process_config,
......
...@@ -1772,7 +1772,7 @@ void lustre_swab_fid2path(struct getinfo_fid2path *gf) ...@@ -1772,7 +1772,7 @@ void lustre_swab_fid2path(struct getinfo_fid2path *gf)
} }
EXPORT_SYMBOL(lustre_swab_fid2path); EXPORT_SYMBOL(lustre_swab_fid2path);
static void lustre_swab_fiemap_extent(struct ll_fiemap_extent *fm_extent) static void lustre_swab_fiemap_extent(struct fiemap_extent *fm_extent)
{ {
__swab64s(&fm_extent->fe_logical); __swab64s(&fm_extent->fe_logical);
__swab64s(&fm_extent->fe_physical); __swab64s(&fm_extent->fe_physical);
...@@ -1781,7 +1781,7 @@ static void lustre_swab_fiemap_extent(struct ll_fiemap_extent *fm_extent) ...@@ -1781,7 +1781,7 @@ static void lustre_swab_fiemap_extent(struct ll_fiemap_extent *fm_extent)
__swab32s(&fm_extent->fe_device); __swab32s(&fm_extent->fe_device);
} }
void lustre_swab_fiemap(struct ll_user_fiemap *fiemap) void lustre_swab_fiemap(struct fiemap *fiemap)
{ {
__u32 i; __u32 i;
......
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