diff options
-rw-r--r-- | fs/cifs/cifsfs.c | 4 | ||||
-rw-r--r-- | fs/cifs/cifsglob.h | 13 | ||||
-rw-r--r-- | fs/cifs/cifsproto.h | 3 | ||||
-rw-r--r-- | fs/cifs/connect.c | 2 | ||||
-rw-r--r-- | fs/cifs/inode.c | 32 | ||||
-rw-r--r-- | fs/cifs/smb1ops.c | 32 |
6 files changed, 48 insertions, 38 deletions
diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c index 7a7cda9f7912..db8a404a51dd 100644 --- a/fs/cifs/cifsfs.c +++ b/fs/cifs/cifsfs.c | |||
@@ -549,8 +549,8 @@ cifs_get_root(struct smb_vol *vol, struct super_block *sb) | |||
549 | char *s, *p; | 549 | char *s, *p; |
550 | char sep; | 550 | char sep; |
551 | 551 | ||
552 | full_path = cifs_build_path_to_root(vol, cifs_sb, | 552 | full_path = build_path_to_root(vol, cifs_sb, |
553 | cifs_sb_master_tcon(cifs_sb)); | 553 | cifs_sb_master_tcon(cifs_sb)); |
554 | if (full_path == NULL) | 554 | if (full_path == NULL) |
555 | return ERR_PTR(-ENOMEM); | 555 | return ERR_PTR(-ENOMEM); |
556 | 556 | ||
diff --git a/fs/cifs/cifsglob.h b/fs/cifs/cifsglob.h index 2b1234599e72..340dce0ed07b 100644 --- a/fs/cifs/cifsglob.h +++ b/fs/cifs/cifsglob.h | |||
@@ -164,6 +164,7 @@ struct cifs_ses; | |||
164 | struct cifs_tcon; | 164 | struct cifs_tcon; |
165 | struct dfs_info3_param; | 165 | struct dfs_info3_param; |
166 | struct cifs_fattr; | 166 | struct cifs_fattr; |
167 | struct smb_vol; | ||
167 | 168 | ||
168 | struct smb_version_operations { | 169 | struct smb_version_operations { |
169 | int (*send_cancel)(struct TCP_Server_Info *, void *, | 170 | int (*send_cancel)(struct TCP_Server_Info *, void *, |
@@ -227,6 +228,9 @@ struct smb_version_operations { | |||
227 | int (*get_srv_inum)(const unsigned int, struct cifs_tcon *, | 228 | int (*get_srv_inum)(const unsigned int, struct cifs_tcon *, |
228 | struct cifs_sb_info *, const char *, | 229 | struct cifs_sb_info *, const char *, |
229 | u64 *uniqueid, FILE_ALL_INFO *); | 230 | u64 *uniqueid, FILE_ALL_INFO *); |
231 | /* build a full path to the root of the mount */ | ||
232 | char * (*build_path_to_root)(struct smb_vol *, struct cifs_sb_info *, | ||
233 | struct cifs_tcon *); | ||
230 | }; | 234 | }; |
231 | 235 | ||
232 | struct smb_version_values { | 236 | struct smb_version_values { |
@@ -803,6 +807,15 @@ convert_delimiter(char *path, char delim) | |||
803 | } | 807 | } |
804 | } | 808 | } |
805 | 809 | ||
810 | static inline char * | ||
811 | build_path_to_root(struct smb_vol *vol, struct cifs_sb_info *cifs_sb, | ||
812 | struct cifs_tcon *tcon) | ||
813 | { | ||
814 | if (!vol->ops->build_path_to_root) | ||
815 | return NULL; | ||
816 | return vol->ops->build_path_to_root(vol, cifs_sb, tcon); | ||
817 | } | ||
818 | |||
806 | #ifdef CONFIG_CIFS_STATS | 819 | #ifdef CONFIG_CIFS_STATS |
807 | #define cifs_stats_inc atomic_inc | 820 | #define cifs_stats_inc atomic_inc |
808 | 821 | ||
diff --git a/fs/cifs/cifsproto.h b/fs/cifs/cifsproto.h index 8e93de01c79d..334b867a81ff 100644 --- a/fs/cifs/cifsproto.h +++ b/fs/cifs/cifsproto.h | |||
@@ -57,9 +57,6 @@ extern int init_cifs_idmap(void); | |||
57 | extern void exit_cifs_idmap(void); | 57 | extern void exit_cifs_idmap(void); |
58 | extern void cifs_destroy_idmaptrees(void); | 58 | extern void cifs_destroy_idmaptrees(void); |
59 | extern char *build_path_from_dentry(struct dentry *); | 59 | extern char *build_path_from_dentry(struct dentry *); |
60 | extern char *cifs_build_path_to_root(struct smb_vol *vol, | ||
61 | struct cifs_sb_info *cifs_sb, | ||
62 | struct cifs_tcon *tcon); | ||
63 | extern char *build_wildcard_path_from_dentry(struct dentry *direntry); | 60 | extern char *build_wildcard_path_from_dentry(struct dentry *direntry); |
64 | extern char *cifs_compose_mount_options(const char *sb_mountdata, | 61 | extern char *cifs_compose_mount_options(const char *sb_mountdata, |
65 | const char *fullpath, const struct dfs_info3_param *ref, | 62 | const char *fullpath, const struct dfs_info3_param *ref, |
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index 34588fe11c57..7b4bc1e0b08e 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c | |||
@@ -3684,7 +3684,7 @@ remote_path_check: | |||
3684 | goto mount_fail_check; | 3684 | goto mount_fail_check; |
3685 | } | 3685 | } |
3686 | /* build_path_to_root works only when we have a valid tcon */ | 3686 | /* build_path_to_root works only when we have a valid tcon */ |
3687 | full_path = cifs_build_path_to_root(volume_info, cifs_sb, tcon); | 3687 | full_path = build_path_to_root(volume_info, cifs_sb, tcon); |
3688 | if (full_path == NULL) { | 3688 | if (full_path == NULL) { |
3689 | rc = -ENOMEM; | 3689 | rc = -ENOMEM; |
3690 | goto mount_fail_check; | 3690 | goto mount_fail_check; |
diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c index df071fb2567f..def10064fe9d 100644 --- a/fs/cifs/inode.c +++ b/fs/cifs/inode.c | |||
@@ -731,38 +731,6 @@ static const struct inode_operations cifs_ipc_inode_ops = { | |||
731 | .lookup = cifs_lookup, | 731 | .lookup = cifs_lookup, |
732 | }; | 732 | }; |
733 | 733 | ||
734 | char *cifs_build_path_to_root(struct smb_vol *vol, struct cifs_sb_info *cifs_sb, | ||
735 | struct cifs_tcon *tcon) | ||
736 | { | ||
737 | int pplen = vol->prepath ? strlen(vol->prepath) : 0; | ||
738 | int dfsplen; | ||
739 | char *full_path = NULL; | ||
740 | |||
741 | /* if no prefix path, simply set path to the root of share to "" */ | ||
742 | if (pplen == 0) { | ||
743 | full_path = kmalloc(1, GFP_KERNEL); | ||
744 | if (full_path) | ||
745 | full_path[0] = 0; | ||
746 | return full_path; | ||
747 | } | ||
748 | |||
749 | if (tcon->Flags & SMB_SHARE_IS_IN_DFS) | ||
750 | dfsplen = strnlen(tcon->treeName, MAX_TREE_SIZE + 1); | ||
751 | else | ||
752 | dfsplen = 0; | ||
753 | |||
754 | full_path = kmalloc(dfsplen + pplen + 1, GFP_KERNEL); | ||
755 | if (full_path == NULL) | ||
756 | return full_path; | ||
757 | |||
758 | if (dfsplen) | ||
759 | strncpy(full_path, tcon->treeName, dfsplen); | ||
760 | strncpy(full_path + dfsplen, vol->prepath, pplen); | ||
761 | convert_delimiter(full_path, CIFS_DIR_SEP(cifs_sb)); | ||
762 | full_path[dfsplen + pplen] = 0; /* add trailing null */ | ||
763 | return full_path; | ||
764 | } | ||
765 | |||
766 | static int | 734 | static int |
767 | cifs_find_inode(struct inode *inode, void *opaque) | 735 | cifs_find_inode(struct inode *inode, void *opaque) |
768 | { | 736 | { |
diff --git a/fs/cifs/smb1ops.c b/fs/cifs/smb1ops.c index fa210010358d..7195fadf1cfa 100644 --- a/fs/cifs/smb1ops.c +++ b/fs/cifs/smb1ops.c | |||
@@ -489,6 +489,37 @@ cifs_get_srv_inum(const unsigned int xid, struct cifs_tcon *tcon, | |||
489 | CIFS_MOUNT_MAP_SPECIAL_CHR); | 489 | CIFS_MOUNT_MAP_SPECIAL_CHR); |
490 | } | 490 | } |
491 | 491 | ||
492 | static char * | ||
493 | cifs_build_path_to_root(struct smb_vol *vol, struct cifs_sb_info *cifs_sb, | ||
494 | struct cifs_tcon *tcon) | ||
495 | { | ||
496 | int pplen = vol->prepath ? strlen(vol->prepath) : 0; | ||
497 | int dfsplen; | ||
498 | char *full_path = NULL; | ||
499 | |||
500 | /* if no prefix path, simply set path to the root of share to "" */ | ||
501 | if (pplen == 0) { | ||
502 | full_path = kzalloc(1, GFP_KERNEL); | ||
503 | return full_path; | ||
504 | } | ||
505 | |||
506 | if (tcon->Flags & SMB_SHARE_IS_IN_DFS) | ||
507 | dfsplen = strnlen(tcon->treeName, MAX_TREE_SIZE + 1); | ||
508 | else | ||
509 | dfsplen = 0; | ||
510 | |||
511 | full_path = kmalloc(dfsplen + pplen + 1, GFP_KERNEL); | ||
512 | if (full_path == NULL) | ||
513 | return full_path; | ||
514 | |||
515 | if (dfsplen) | ||
516 | strncpy(full_path, tcon->treeName, dfsplen); | ||
517 | strncpy(full_path + dfsplen, vol->prepath, pplen); | ||
518 | convert_delimiter(full_path, CIFS_DIR_SEP(cifs_sb)); | ||
519 | full_path[dfsplen + pplen] = 0; /* add trailing null */ | ||
520 | return full_path; | ||
521 | } | ||
522 | |||
492 | struct smb_version_operations smb1_operations = { | 523 | struct smb_version_operations smb1_operations = { |
493 | .send_cancel = send_nt_cancel, | 524 | .send_cancel = send_nt_cancel, |
494 | .compare_fids = cifs_compare_fids, | 525 | .compare_fids = cifs_compare_fids, |
@@ -518,6 +549,7 @@ struct smb_version_operations smb1_operations = { | |||
518 | .is_path_accessible = cifs_is_path_accessible, | 549 | .is_path_accessible = cifs_is_path_accessible, |
519 | .query_path_info = cifs_query_path_info, | 550 | .query_path_info = cifs_query_path_info, |
520 | .get_srv_inum = cifs_get_srv_inum, | 551 | .get_srv_inum = cifs_get_srv_inum, |
552 | .build_path_to_root = cifs_build_path_to_root, | ||
521 | }; | 553 | }; |
522 | 554 | ||
523 | struct smb_version_values smb1_values = { | 555 | struct smb_version_values smb1_values = { |