diff options
-rw-r--r-- | fs/open.c | 98 |
1 files changed, 56 insertions, 42 deletions
@@ -738,52 +738,15 @@ asmlinkage long sys_fchown(unsigned int fd, uid_t user, gid_t group) | |||
738 | return error; | 738 | return error; |
739 | } | 739 | } |
740 | 740 | ||
741 | /* | 741 | static struct file *__dentry_open(struct dentry *dentry, struct vfsmount *mnt, |
742 | * Note that while the flag value (low two bits) for sys_open means: | 742 | int flags, struct file *f) |
743 | * 00 - read-only | ||
744 | * 01 - write-only | ||
745 | * 10 - read-write | ||
746 | * 11 - special | ||
747 | * it is changed into | ||
748 | * 00 - no permissions needed | ||
749 | * 01 - read-permission | ||
750 | * 10 - write-permission | ||
751 | * 11 - read-write | ||
752 | * for the internal routines (ie open_namei()/follow_link() etc). 00 is | ||
753 | * used by symlinks. | ||
754 | */ | ||
755 | struct file *filp_open(const char * filename, int flags, int mode) | ||
756 | { | ||
757 | int namei_flags, error; | ||
758 | struct nameidata nd; | ||
759 | |||
760 | namei_flags = flags; | ||
761 | if ((namei_flags+1) & O_ACCMODE) | ||
762 | namei_flags++; | ||
763 | if (namei_flags & O_TRUNC) | ||
764 | namei_flags |= 2; | ||
765 | |||
766 | error = open_namei(filename, namei_flags, mode, &nd); | ||
767 | if (!error) | ||
768 | return dentry_open(nd.dentry, nd.mnt, flags); | ||
769 | |||
770 | return ERR_PTR(error); | ||
771 | } | ||
772 | |||
773 | EXPORT_SYMBOL(filp_open); | ||
774 | |||
775 | struct file *dentry_open(struct dentry *dentry, struct vfsmount *mnt, int flags) | ||
776 | { | 743 | { |
777 | struct file * f; | ||
778 | struct inode *inode; | 744 | struct inode *inode; |
779 | int error; | 745 | int error; |
780 | 746 | ||
781 | error = -ENFILE; | ||
782 | f = get_empty_filp(); | ||
783 | if (!f) | ||
784 | goto cleanup_dentry; | ||
785 | f->f_flags = flags; | 747 | f->f_flags = flags; |
786 | f->f_mode = ((flags+1) & O_ACCMODE) | FMODE_LSEEK | FMODE_PREAD | FMODE_PWRITE; | 748 | f->f_mode = ((flags+1) & O_ACCMODE) | FMODE_LSEEK | |
749 | FMODE_PREAD | FMODE_PWRITE; | ||
787 | inode = dentry->d_inode; | 750 | inode = dentry->d_inode; |
788 | if (f->f_mode & FMODE_WRITE) { | 751 | if (f->f_mode & FMODE_WRITE) { |
789 | error = get_write_access(inode); | 752 | error = get_write_access(inode); |
@@ -828,12 +791,63 @@ cleanup_all: | |||
828 | f->f_vfsmnt = NULL; | 791 | f->f_vfsmnt = NULL; |
829 | cleanup_file: | 792 | cleanup_file: |
830 | put_filp(f); | 793 | put_filp(f); |
831 | cleanup_dentry: | ||
832 | dput(dentry); | 794 | dput(dentry); |
833 | mntput(mnt); | 795 | mntput(mnt); |
834 | return ERR_PTR(error); | 796 | return ERR_PTR(error); |
835 | } | 797 | } |
836 | 798 | ||
799 | /* | ||
800 | * Note that while the flag value (low two bits) for sys_open means: | ||
801 | * 00 - read-only | ||
802 | * 01 - write-only | ||
803 | * 10 - read-write | ||
804 | * 11 - special | ||
805 | * it is changed into | ||
806 | * 00 - no permissions needed | ||
807 | * 01 - read-permission | ||
808 | * 10 - write-permission | ||
809 | * 11 - read-write | ||
810 | * for the internal routines (ie open_namei()/follow_link() etc). 00 is | ||
811 | * used by symlinks. | ||
812 | */ | ||
813 | struct file *filp_open(const char * filename, int flags, int mode) | ||
814 | { | ||
815 | int namei_flags, error; | ||
816 | struct nameidata nd; | ||
817 | struct file *f; | ||
818 | |||
819 | namei_flags = flags; | ||
820 | if ((namei_flags+1) & O_ACCMODE) | ||
821 | namei_flags++; | ||
822 | if (namei_flags & O_TRUNC) | ||
823 | namei_flags |= 2; | ||
824 | |||
825 | error = -ENFILE; | ||
826 | f = get_empty_filp(); | ||
827 | if (f == NULL) | ||
828 | return ERR_PTR(error); | ||
829 | |||
830 | error = open_namei(filename, namei_flags, mode, &nd); | ||
831 | if (!error) | ||
832 | return __dentry_open(nd.dentry, nd.mnt, flags, f); | ||
833 | |||
834 | put_filp(f); | ||
835 | return ERR_PTR(error); | ||
836 | } | ||
837 | EXPORT_SYMBOL(filp_open); | ||
838 | |||
839 | struct file *dentry_open(struct dentry *dentry, struct vfsmount *mnt, int flags) | ||
840 | { | ||
841 | int error; | ||
842 | struct file *f; | ||
843 | |||
844 | error = -ENFILE; | ||
845 | f = get_empty_filp(); | ||
846 | if (f == NULL) | ||
847 | return ERR_PTR(error); | ||
848 | |||
849 | return __dentry_open(dentry, mnt, flags, f); | ||
850 | } | ||
837 | EXPORT_SYMBOL(dentry_open); | 851 | EXPORT_SYMBOL(dentry_open); |
838 | 852 | ||
839 | /* | 853 | /* |