summaryrefslogtreecommitdiffstats
path: root/fs/ncpfs/dir.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ncpfs/dir.c')
-rw-r--r--fs/ncpfs/dir.c25
1 files changed, 15 insertions, 10 deletions
diff --git a/fs/ncpfs/dir.c b/fs/ncpfs/dir.c
index e80ea4e37c48..3bcc68aed416 100644
--- a/fs/ncpfs/dir.c
+++ b/fs/ncpfs/dir.c
@@ -75,7 +75,9 @@ const struct inode_operations ncp_dir_inode_operations =
75 */ 75 */
76static int ncp_lookup_validate(struct dentry *, struct nameidata *); 76static int ncp_lookup_validate(struct dentry *, struct nameidata *);
77static int ncp_hash_dentry(struct dentry *, struct qstr *); 77static int ncp_hash_dentry(struct dentry *, struct qstr *);
78static int ncp_compare_dentry (struct dentry *, struct qstr *, struct qstr *); 78static int ncp_compare_dentry(const struct dentry *, const struct inode *,
79 const struct dentry *, const struct inode *,
80 unsigned int, const char *, const struct qstr *);
79static int ncp_delete_dentry(const struct dentry *); 81static int ncp_delete_dentry(const struct dentry *);
80 82
81static const struct dentry_operations ncp_dentry_operations = 83static const struct dentry_operations ncp_dentry_operations =
@@ -113,10 +115,10 @@ static inline int ncp_preserve_entry_case(struct inode *i, __u32 nscreator)
113 115
114#define ncp_preserve_case(i) (ncp_namespace(i) != NW_NS_DOS) 116#define ncp_preserve_case(i) (ncp_namespace(i) != NW_NS_DOS)
115 117
116static inline int ncp_case_sensitive(struct dentry *dentry) 118static inline int ncp_case_sensitive(const struct inode *i)
117{ 119{
118#ifdef CONFIG_NCPFS_NFS_NS 120#ifdef CONFIG_NCPFS_NFS_NS
119 return ncp_namespace(dentry->d_inode) == NW_NS_NFS; 121 return ncp_namespace(i) == NW_NS_NFS;
120#else 122#else
121 return 0; 123 return 0;
122#endif /* CONFIG_NCPFS_NFS_NS */ 124#endif /* CONFIG_NCPFS_NFS_NS */
@@ -129,12 +131,13 @@ static inline int ncp_case_sensitive(struct dentry *dentry)
129static int 131static int
130ncp_hash_dentry(struct dentry *dentry, struct qstr *this) 132ncp_hash_dentry(struct dentry *dentry, struct qstr *this)
131{ 133{
132 if (!ncp_case_sensitive(dentry)) { 134 if (!ncp_case_sensitive(dentry->d_inode)) {
135 struct super_block *sb = dentry->d_sb;
133 struct nls_table *t; 136 struct nls_table *t;
134 unsigned long hash; 137 unsigned long hash;
135 int i; 138 int i;
136 139
137 t = NCP_IO_TABLE(dentry); 140 t = NCP_IO_TABLE(sb);
138 hash = init_name_hash(); 141 hash = init_name_hash();
139 for (i=0; i<this->len ; i++) 142 for (i=0; i<this->len ; i++)
140 hash = partial_name_hash(ncp_tolower(t, this->name[i]), 143 hash = partial_name_hash(ncp_tolower(t, this->name[i]),
@@ -145,15 +148,17 @@ ncp_hash_dentry(struct dentry *dentry, struct qstr *this)
145} 148}
146 149
147static int 150static int
148ncp_compare_dentry(struct dentry *dentry, struct qstr *a, struct qstr *b) 151ncp_compare_dentry(const struct dentry *parent, const struct inode *pinode,
152 const struct dentry *dentry, const struct inode *inode,
153 unsigned int len, const char *str, const struct qstr *name)
149{ 154{
150 if (a->len != b->len) 155 if (len != name->len)
151 return 1; 156 return 1;
152 157
153 if (ncp_case_sensitive(dentry)) 158 if (ncp_case_sensitive(pinode))
154 return strncmp(a->name, b->name, a->len); 159 return strncmp(str, name->name, len);
155 160
156 return ncp_strnicmp(NCP_IO_TABLE(dentry), a->name, b->name, a->len); 161 return ncp_strnicmp(NCP_IO_TABLE(pinode->i_sb), str, name->name, len);
157} 162}
158 163
159/* 164/*