Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Master sync round 4 #25

Closed
wants to merge 41 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
286294b
staging/lustre/hsm: remove hsm_nl proc file
jhammond-intel Nov 6, 2013
71c0087
staging/lustre/clio: wrong cl_lock usage
Nov 6, 2013
9cccced
staging/lustre/build: fix 'deadcode' errors
sebastienbuisson Nov 6, 2013
4cc83be
staging/lustre/build: fix 'integer handling' issues
sebastienbuisson Nov 6, 2013
bb79b5d
staging/lustre/ptlrpc: add rpc_cache
Nov 6, 2013
24366df
staging/lustre/lnet: build Lustre with Intel OFED for Xeon Phi
Nov 6, 2013
5f3319f
staging/lustre/osd-ldiskfs: remove dependency on mdd module
Nov 6, 2013
149a5fc
staging/lustre/libcfs: improve validity test for valid file descriptors
Nov 6, 2013
9aa0ccf
staging/lustre/llite: use 64bits flags in ll_lov_setea()
NiuYawei Nov 6, 2013
f6356e3
staging/lustre/hsm: small fixes for HSM
Nov 6, 2013
b15df07
staging/lustre/mdt: CDT cleanup follow-on patch
lafoucriere Nov 6, 2013
df4d87a
staging/lustre/utils: Posix copytool fixes.
hdoreau Nov 6, 2013
f6d5d13
staging/lustre/lmv: update coding style
lafoucriere Nov 6, 2013
33615ff
staging/lustre/hsm: copy start error should set HP_FLAG_COMPLETED
Nov 6, 2013
fca446c
staging/lustre/lov: Get the correct address of lmm_objects
Nov 6, 2013
c6def44
staging/lustre/lvfs: remove llog_lvfs.c and other lvfs code from llog
jasimmons1973 Nov 6, 2013
9cabc9b
staging/lustre/llite: reset writeback index in ll_writepages
Nov 6, 2013
a573aab
staging/lustre/llite: Delaying creation of client side proc entries.
gmahajan Nov 6, 2013
f2c1435
staging/lustre/libcfs: Add relocation function to libcfs heap
LiXi-storage Nov 6, 2013
02d9fca
staging/lustre/build: fix 'data race condition' issues
sebastienbuisson Nov 6, 2013
088f753
staging/lustre/autoconf: remove LC_LOCK_MAP_ACQUIRE test
jasimmons1973 Nov 6, 2013
c279ae5
staging/lustre/mdc: document mdc_rpc_lock
nedbass Nov 6, 2013
38a87da
staging/lustre/autoconf: remove LC_FS_STRUCT_USE_PATH
jasimmons1973 Nov 6, 2013
29e3b5c
staging/lustre/obdclass: fix wrong device put in case of race
Nov 6, 2013
cc120d4
staging/lustre/lmv: choose right MDT for open by FID
wangdi1 Nov 6, 2013
1487be1
staging/lustre/osd: remove fld lookup during configuration
wangdi1 Nov 6, 2013
da7ddb8
staging/lustre/mdt: HSM EXIST event not triggered at last rm/mv
lafoucriere Nov 6, 2013
a9b6e3f
staging/lustre/ldlm: ldlm_flock_deadlock() ASSERTION( req != lock ) f…
Nov 6, 2013
f008f17
staging/lustre/changelogs: Account for changelog_ext_rec in CR_MAXSIZE
morrone Nov 6, 2013
b052e9d
staging/lustre/clio: Do not shrink sublock at cancel
Nov 7, 2013
665e129
staging/lustre/build: build error with gcc 4.7.0 20110509
Nov 7, 2013
965e9fa
staging/lustre/build: fix 'NULL pointer dereference' errors
sebastienbuisson Nov 7, 2013
df9f8c4
staging/lustre/clio: honor O_NOATIME
jhammond-intel Nov 7, 2013
32112c0
staging/lustre/llite: return compatible fsid for statfs
Nasf-Fan Nov 7, 2013
76cd509
staging/lustre/llite: cancel open lock before closing file
Nov 7, 2013
bc37cd5
staging/lustre/hsm: Add support to drop all pages for ll_data_version
Nov 7, 2013
1247af9
staging/lustre/build: fix 'no effect' errors
sebastienbuisson Nov 7, 2013
50b2634
staging/lustre/obd: add md_stats to MDC and LMV devices
Nov 7, 2013
d852117
staging/lustre/autoconf: remove LC_SECURITY_PLUG test
jasimmons1973 Nov 7, 2013
6a5976a
staging/lustre/osc: Lustre returns EINTR from writes when SA_RESTART …
jasimmons1973 Nov 7, 2013
7844af8
staging/lustre/llite: restore ll_fiemap
Nov 6, 2013
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
129 changes: 69 additions & 60 deletions drivers/staging/lustre/include/linux/libcfs/libcfs_debug.h
Original file line number Diff line number Diff line change
Expand Up @@ -87,74 +87,83 @@ struct ptldebug_header {

/* Debugging subsystems (32 bits, non-overlapping) */
/* keep these in sync with lnet/utils/debug.c and lnet/libcfs/debug.c */
#define S_UNDEFINED 0x00000001
#define S_MDC 0x00000002
#define S_MDS 0x00000004
#define S_OSC 0x00000008
#define S_OST 0x00000010
#define S_CLASS 0x00000020
#define S_LOG 0x00000040
#define S_LLITE 0x00000080
#define S_RPC 0x00000100
#define S_MGMT 0x00000200
#define S_LNET 0x00000400
#define S_LND 0x00000800 /* ALL LNDs */
#define S_PINGER 0x00001000
#define S_FILTER 0x00002000
#define S_UNDEFINED 0x00000001
#define S_MDC 0x00000002
#define S_MDS 0x00000004
#define S_OSC 0x00000008
#define S_OST 0x00000010
#define S_CLASS 0x00000020
#define S_LOG 0x00000040
#define S_LLITE 0x00000080
#define S_RPC 0x00000100
#define S_MGMT 0x00000200
#define S_LNET 0x00000400
#define S_LND 0x00000800 /* ALL LNDs */
#define S_PINGER 0x00001000
#define S_FILTER 0x00002000
/* unused */
#define S_ECHO 0x00008000
#define S_LDLM 0x00010000
#define S_LOV 0x00020000
#define S_LQUOTA 0x00040000
#define S_ECHO 0x00008000
#define S_LDLM 0x00010000
#define S_LOV 0x00020000
#define S_LQUOTA 0x00040000
#define S_OSD 0x00080000
#define S_LFSCK 0x00100000
/* unused */
/* unused */
#define S_LMV 0x00800000 /* b_new_cmd */
/* unused */
#define S_LMV 0x00800000 /* b_new_cmd */
#define S_SEC 0x02000000 /* upcall cache */
#define S_GSS 0x04000000 /* b_new_cmd */
/* unused */
#define S_SEC 0x02000000 /* upcall cache */
#define S_GSS 0x04000000 /* b_new_cmd */
/* unused */
#define S_MGC 0x10000000
#define S_MGS 0x20000000
#define S_FID 0x40000000 /* b_new_cmd */
#define S_FLD 0x80000000 /* b_new_cmd */
/* keep these in sync with lnet/utils/debug.c and lnet/libcfs/debug.c */
#define S_MGC 0x10000000
#define S_MGS 0x20000000
#define S_FID 0x40000000 /* b_new_cmd */
#define S_FLD 0x80000000 /* b_new_cmd */

#define LIBCFS_DEBUG_SUBSYS_NAMES { \
"undefined", "mdc", "mds", "osc", "ost", "class", "log", \
"llite", "rpc", "mgmt", "lnet", "lnd", "pinger", "filter", "", \
"echo", "ldlm", "lov", "lquota", "osd", "lfsck", "", "", "lmv", \
"", "sec", "gss", "", "mgc", "mgs", "fid", "fld", NULL }

/* Debugging masks (32 bits, non-overlapping) */
/* keep these in sync with lnet/utils/debug.c and lnet/libcfs/debug.c */
#define D_TRACE 0x00000001 /* ENTRY/EXIT markers */
#define D_INODE 0x00000002
#define D_SUPER 0x00000004
#define D_EXT2 0x00000008 /* anything from ext2_debug */
#define D_MALLOC 0x00000010 /* print malloc, free information */
#define D_CACHE 0x00000020 /* cache-related items */
#define D_INFO 0x00000040 /* general information */
#define D_IOCTL 0x00000080 /* ioctl related information */
#define D_NETERROR 0x00000100 /* network errors */
#define D_NET 0x00000200 /* network communications */
#define D_WARNING 0x00000400 /* CWARN(...) == CDEBUG (D_WARNING, ...) */
#define D_BUFFS 0x00000800
#define D_OTHER 0x00001000
#define D_DENTRY 0x00002000
#define D_NETTRACE 0x00004000
#define D_PAGE 0x00008000 /* bulk page handling */
#define D_DLMTRACE 0x00010000
#define D_ERROR 0x00020000 /* CERROR(...) == CDEBUG (D_ERROR, ...) */
#define D_EMERG 0x00040000 /* CEMERG(...) == CDEBUG (D_EMERG, ...) */
#define D_HA 0x00080000 /* recovery and failover */
#define D_RPCTRACE 0x00100000 /* for distributed debugging */
#define D_VFSTRACE 0x00200000
#define D_READA 0x00400000 /* read-ahead */
#define D_MMAP 0x00800000
#define D_CONFIG 0x01000000
#define D_CONSOLE 0x02000000
#define D_QUOTA 0x04000000
#define D_SEC 0x08000000
#define D_LFSCK 0x10000000 /* For both OI scrub and LFSCK */
/* keep these in sync with lnet/{utils,libcfs}/debug.c */

#define D_HSM D_TRACE
#define D_TRACE 0x00000001 /* ENTRY/EXIT markers */
#define D_INODE 0x00000002
#define D_SUPER 0x00000004
#define D_EXT2 0x00000008 /* anything from ext2_debug */
#define D_MALLOC 0x00000010 /* print malloc, free information */
#define D_CACHE 0x00000020 /* cache-related items */
#define D_INFO 0x00000040 /* general information */
#define D_IOCTL 0x00000080 /* ioctl related information */
#define D_NETERROR 0x00000100 /* network errors */
#define D_NET 0x00000200 /* network communications */
#define D_WARNING 0x00000400 /* CWARN(...) == CDEBUG (D_WARNING, ...) */
#define D_BUFFS 0x00000800
#define D_OTHER 0x00001000
#define D_DENTRY 0x00002000
#define D_NETTRACE 0x00004000
#define D_PAGE 0x00008000 /* bulk page handling */
#define D_DLMTRACE 0x00010000
#define D_ERROR 0x00020000 /* CERROR(...) == CDEBUG (D_ERROR, ...) */
#define D_EMERG 0x00040000 /* CEMERG(...) == CDEBUG (D_EMERG, ...) */
#define D_HA 0x00080000 /* recovery and failover */
#define D_RPCTRACE 0x00100000 /* for distributed debugging */
#define D_VFSTRACE 0x00200000
#define D_READA 0x00400000 /* read-ahead */
#define D_MMAP 0x00800000
#define D_CONFIG 0x01000000
#define D_CONSOLE 0x02000000
#define D_QUOTA 0x04000000
#define D_SEC 0x08000000
#define D_LFSCK 0x10000000 /* For both OI scrub and LFSCK */
#define D_HSM 0x20000000

#define LIBCFS_DEBUG_MASKS_NAMES { \
"trace", "inode", "super", "ext2", "malloc", "cache", "info", \
"ioctl", "neterror", "net", "warning", "buffs", "other", \
"dentry", "nettrace", "page", "dlmtrace", "error", "emerg", \
"ha", "rpctrace", "vfstrace", "reada", "mmap", "config", \
"console", "quota", "sec", "lfsck", "hsm", NULL }

#define D_CANTMASK (D_ERROR | D_EMERG | D_WARNING | D_CONSOLE)

Expand Down
1 change: 1 addition & 0 deletions drivers/staging/lustre/include/linux/libcfs/libcfs_heap.h
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,7 @@ cfs_binheap_t *cfs_binheap_create(cfs_binheap_ops_t *ops, unsigned int flags,
cfs_binheap_node_t *cfs_binheap_find(cfs_binheap_t *h, unsigned int idx);
int cfs_binheap_insert(cfs_binheap_t *h, cfs_binheap_node_t *e);
void cfs_binheap_remove(cfs_binheap_t *h, cfs_binheap_node_t *e);
void cfs_binheap_relocate(cfs_binheap_t *h, cfs_binheap_node_t *e);

static inline int
cfs_binheap_size(cfs_binheap_t *h)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ extern int libcfs_kkuc_group_foreach(int group, libcfs_kkuc_cb_t cb_func,
void *cb_arg);

#define LK_FLG_STOP 0x01
#define LK_NOFD -1U

/* kernelcomm control structure, passed from userspace to kernel */
typedef struct lustre_kernelcomm {
Expand Down
2 changes: 2 additions & 0 deletions drivers/staging/lustre/lnet/klnds/o2iblnd/o2iblnd.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@
* Author: Eric Barton <eric@bartonsoftware.com>
*/

#include <linux/version.h>
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/mm.h>
Expand All @@ -57,6 +58,7 @@
#include <linux/kmod.h>
#include <linux/sysctl.h>
#include <linux/pci.h>
#include <linux/pci-dma.h>

#include <net/sock.h>
#include <linux/in.h>
Expand Down
8 changes: 6 additions & 2 deletions drivers/staging/lustre/lnet/selftest/conrpc.c
Original file line number Diff line number Diff line change
Expand Up @@ -938,8 +938,12 @@ lstcon_sesnew_stat_reply(lstcon_rpc_trans_t *trans,
return status;

if (!trans->tas_feats_updated) {
trans->tas_feats_updated = 1;
trans->tas_features = reply->msg_ses_feats;
spin_lock(&console_session.ses_rpc_lock);
if (!trans->tas_feats_updated) { /* recheck with lock */
trans->tas_feats_updated = 1;
trans->tas_features = reply->msg_ses_feats;
}
spin_unlock(&console_session.ses_rpc_lock);
}

if (reply->msg_ses_feats != trans->tas_features) {
Expand Down
6 changes: 5 additions & 1 deletion drivers/staging/lustre/lustre/include/cl_object.h
Original file line number Diff line number Diff line change
Expand Up @@ -2392,7 +2392,11 @@ struct cl_io {
/**
* file is released, restore has to to be triggered by vvp layer
*/
ci_restore_needed:1;
ci_restore_needed:1,
/**
* O_NOATIME
*/
ci_noatime:1;
/**
* Number of pages owned by this IO. For invariant checking.
*/
Expand Down
14 changes: 0 additions & 14 deletions drivers/staging/lustre/lustre/include/linux/lustre_compat25.h
Original file line number Diff line number Diff line change
Expand Up @@ -99,23 +99,9 @@ static inline void ll_set_fs_pwd(struct fs_struct *fs, struct vfsmount *mnt,
#define FS_HAS_FIEMAP (0)
#endif

#define ll_vfs_rmdir(dir,entry,mnt) vfs_rmdir(dir,entry)
#define ll_vfs_mkdir(inode,dir,mnt,mode) vfs_mkdir(inode,dir,mode)
#define ll_vfs_link(old,mnt,dir,new,mnt1) vfs_link(old,dir,new)
#define ll_vfs_unlink(inode,entry,mnt) vfs_unlink(inode,entry)
#define ll_vfs_mknod(dir,entry,mnt,mode,dev) vfs_mknod(dir,entry,mode,dev)
#define ll_security_inode_unlink(dir,entry,mnt) security_inode_unlink(dir,entry)
#define ll_vfs_rename(old,old_dir,mnt,new,new_dir,mnt1) \
vfs_rename(old,old_dir,new,new_dir)

#define cfs_bio_io_error(a,b) bio_io_error((a))
#define cfs_bio_endio(a,b,c) bio_endio((a),(c))

#define cfs_fs_pwd(fs) ((fs)->pwd.dentry)
#define cfs_fs_mnt(fs) ((fs)->pwd.mnt)
#define cfs_path_put(nd) path_put(&(nd)->path)


#ifndef SLAB_DESTROY_BY_RCU
#define SLAB_DESTROY_BY_RCU 0
#endif
Expand Down
84 changes: 0 additions & 84 deletions drivers/staging/lustre/lustre/include/linux/lustre_fsfilt.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,45 +49,20 @@
#include <obd.h>
#include <obd_class.h>

typedef void (*fsfilt_cb_t)(struct obd_device *obd, __u64 last_rcvd,
void *data, int error);

struct fsfilt_operations {
struct list_head fs_list;
struct module *fs_owner;
char *fs_type;
char *(* fs_getlabel)(struct super_block *sb);
void *(* fs_start)(struct inode *inode, int op, void *desc_private,
int logs);
int (* fs_commit)(struct inode *inode, void *handle,int force_sync);
int (* fs_map_inode_pages)(struct inode *inode, struct page **page,
int pages, unsigned long *blocks,
int create, struct mutex *sem);
int (* fs_write_record)(struct file *, void *, int size, loff_t *,
int force_sync);
int (* fs_read_record)(struct file *, void *, int size, loff_t *);
int (* fs_setup)(struct super_block *sb);
};

extern int fsfilt_register_ops(struct fsfilt_operations *fs_ops);
extern void fsfilt_unregister_ops(struct fsfilt_operations *fs_ops);
extern struct fsfilt_operations *fsfilt_get_ops(const char *type);
extern void fsfilt_put_ops(struct fsfilt_operations *fs_ops);

static inline char *fsfilt_get_label(struct obd_device *obd,
struct super_block *sb)
{
if (obd->obd_fsops->fs_getlabel == NULL)
return NULL;
if (obd->obd_fsops->fs_getlabel(sb)[0] == '\0')
return NULL;

return obd->obd_fsops->fs_getlabel(sb);
}

#define FSFILT_OP_UNLINK 1
#define FSFILT_OP_CANCEL_UNLINK 10

#define __fsfilt_check_slow(obd, start, msg) \
do { \
if (cfs_time_before(jiffies, start + 15 * HZ)) \
Expand All @@ -109,63 +84,4 @@ do { \
start = jiffies; \
} while (0)

static inline void *fsfilt_start_log(struct obd_device *obd,
struct inode *inode, int op,
struct obd_trans_info *oti, int logs)
{
unsigned long now = jiffies;
void *parent_handle = oti ? oti->oti_handle : NULL;
void *handle;

handle = obd->obd_fsops->fs_start(inode, op, parent_handle, logs);
CDEBUG(D_INFO, "started handle %p (%p)\n", handle, parent_handle);

if (oti != NULL) {
if (parent_handle == NULL) {
oti->oti_handle = handle;
} else if (handle != parent_handle) {
CERROR("mismatch: parent %p, handle %p, oti %p\n",
parent_handle, handle, oti);
LBUG();
}
}
fsfilt_check_slow(obd, now, "journal start");
return handle;
}

static inline int fsfilt_commit(struct obd_device *obd, struct inode *inode,
void *handle, int force_sync)
{
unsigned long now = jiffies;
int rc = obd->obd_fsops->fs_commit(inode, handle, force_sync);
CDEBUG(D_INFO, "committing handle %p\n", handle);

fsfilt_check_slow(obd, now, "journal start");

return rc;
}

static inline int fsfilt_read_record(struct obd_device *obd, struct file *file,
void *buf, loff_t size, loff_t *offs)
{
return obd->obd_fsops->fs_read_record(file, buf, size, offs);
}

static inline int fsfilt_write_record(struct obd_device *obd, struct file *file,
void *buf, loff_t size, loff_t *offs,
int force_sync)
{
return obd->obd_fsops->fs_write_record(file, buf, size,offs,force_sync);
}

static inline int fsfilt_setup(struct obd_device *obd, struct super_block *fs)
{
if (obd->obd_fsops->fs_setup)
return obd->obd_fsops->fs_setup(fs);
return 0;
}




#endif
5 changes: 0 additions & 5 deletions drivers/staging/lustre/lustre/include/linux/lvfs.h
Original file line number Diff line number Diff line change
Expand Up @@ -64,10 +64,6 @@ struct lvfs_ucred {
struct md_identity *luc_identity;
};

struct lvfs_callback_ops {
struct dentry *(*l_fid2dentry)(__u64 id_ino, __u32 gen, __u64 gr, void *data);
};

#define OBD_RUN_CTXT_MAGIC 0xC0FFEEAA
#define OBD_CTXT_DEBUG /* development-only debugging */
struct lvfs_run_ctxt {
Expand All @@ -76,7 +72,6 @@ struct lvfs_run_ctxt {
mm_segment_t fs;
struct lvfs_ucred luc;
int ngroups;
struct lvfs_callback_ops cb_ops;
struct group_info *group_info;
struct dt_device *dt;
#ifdef OBD_CTXT_DEBUG
Expand Down
8 changes: 7 additions & 1 deletion drivers/staging/lustre/lustre/include/lustre/lustre_idl.h
Original file line number Diff line number Diff line change
Expand Up @@ -611,10 +611,15 @@ static inline obd_id fid_idif_id(obd_seq seq, __u32 oid, __u32 ver)
return ((__u64)ver << 48) | ((seq & 0xffff) << 32) | oid;
}

static inline __u32 idif_ost_idx(obd_seq seq)
{
return (seq >> 16) & 0xffff;
}

/* extract ost index from IDIF FID */
static inline __u32 fid_idif_ost_idx(const struct lu_fid *fid)
{
return (fid_seq(fid) >> 16) & 0xffff;
return idif_ost_idx(fid_seq(fid));
}

/* extract OST sequence (group) from a wire ost_id (id/seq) pair */
Expand Down Expand Up @@ -1501,6 +1506,7 @@ enum obdo_flags {
* clients prior than 2.2 */
OBD_FL_RECOV_RESEND = 0x00080000, /* recoverable resent */
OBD_FL_NOSPC_BLK = 0x00100000, /* no more block space on OST */
OBD_FL_FLUSH = 0x00200000, /* flush pages on the OST */

/* Note that while these checksum values are currently separate bits,
* in 2.x we can actually allow all values from 1-31 if we wanted. */
Expand Down
Loading