diff options
author | rodrigc <rodrigc@FreeBSD.org> | 2005-11-16 02:26:25 +0000 |
---|---|---|
committer | rodrigc <rodrigc@FreeBSD.org> | 2005-11-16 02:26:25 +0000 |
commit | bda951e1164669108d22ffa80eec70c9ff1cfcf1 (patch) | |
tree | a3b3ad6d84f46d46aeea3470f9ec657ea66b4681 /sys/fs | |
parent | b6bd744326afe4135b44dfa824e7c26219583b8c (diff) | |
download | FreeBSD-src-bda951e1164669108d22ffa80eec70c9ff1cfcf1.zip FreeBSD-src-bda951e1164669108d22ffa80eec70c9ff1cfcf1.tar.gz |
- Add errmsg to the list of smbfs mount options.
- Use vfs_mount_error() to propagate smbfs mount errors back to userspace.
Reviewed by: bp (smbfs maintainer)
Diffstat (limited to 'sys/fs')
-rw-r--r-- | sys/fs/smbfs/smbfs_vfsops.c | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/sys/fs/smbfs/smbfs_vfsops.c b/sys/fs/smbfs/smbfs_vfsops.c index aed0c72..f8ddd42 100644 --- a/sys/fs/smbfs/smbfs_vfsops.c +++ b/sys/fs/smbfs/smbfs_vfsops.c @@ -138,7 +138,7 @@ smbfs_cmount(struct mntarg *ma, void * data, int flags, struct thread *td) static const char *smbfs_opts[] = { "dev", "soft", "intr", "strong", "have_nls", "long", "mountpoint", "rootpath", "uid", "gid", "file_mode", "dir_mode", - "caseopt", NULL + "caseopt", "errmsg", NULL }; static int @@ -155,15 +155,20 @@ smbfs_mount(struct mount *mp, struct thread *td) if (mp->mnt_flag & (MNT_UPDATE | MNT_ROOTFS)) return EOPNOTSUPP; - if (vfs_filteropt(mp->mnt_optnew, smbfs_opts)) + if (vfs_filteropt(mp->mnt_optnew, smbfs_opts)) { + vfs_mount_error(mp, "%s", "Invalid option"); return (EINVAL); + } smb_makescred(&scred, td, td->td_ucred); - if (1 != vfs_scanopt(mp->mnt_optnew, "dev", "%d", &v)) + if (1 != vfs_scanopt(mp->mnt_optnew, "dev", "%d", &v)) { + vfs_mount_error(mp, "No dev option"); return (EINVAL); + } error = smb_dev2share(v, SMBM_EXEC, &scred, &ssp); if (error) { printf("invalid device handle %d (%d)\n", v, error); + vfs_mount_error(mp, "invalid device handle %d (%d)\n", v, error); return error; } vcp = SSTOVC(ssp); @@ -177,8 +182,9 @@ smbfs_mount(struct mount *mp, struct thread *td) M_WAITOK|M_USE_RESERVE); #endif if (smp == NULL) { - printf("could not alloc smbmount\n"); - error = ENOMEM; + printf("could not alloc smbmount\n"); + vfs_mount_error(mp, "could not alloc smbmount", v, error); + error = ENOMEM; goto bad; } bzero(smp, sizeof(*smp)); @@ -191,28 +197,33 @@ smbfs_mount(struct mount *mp, struct thread *td) smp->sm_root = NULL; if (1 != vfs_scanopt(mp->mnt_optnew, "caseopt", "%d", &smp->sm_caseopt)) { + vfs_mount_error(mp, "Invalid caseopt"); error = EINVAL; goto bad; } if (1 != vfs_scanopt(mp->mnt_optnew, "uid", "%d", &v)) { + vfs_mount_error(mp, "Invalid uid"); error = EINVAL; goto bad; } smp->sm_uid = v; if (1 != vfs_scanopt(mp->mnt_optnew, "gid", "%d", &v)) { + vfs_mount_error(mp, "Invalid gid"); error = EINVAL; goto bad; } smp->sm_gid = v; if (1 != vfs_scanopt(mp->mnt_optnew, "file_mode", "%d", &v)) { + vfs_mount_error(mp, "Invalid file_mode"); error = EINVAL; goto bad; } smp->sm_file_mode = (v & (S_IRWXU|S_IRWXG|S_IRWXO)) | S_IFREG; if (1 != vfs_scanopt(mp->mnt_optnew, "dir_mode", "%d", &v)) { + vfs_mount_error(mp, "Invalid dir_mode"); error = EINVAL; goto bad; } @@ -240,8 +251,10 @@ smbfs_mount(struct mount *mp, struct thread *td) } vfs_getnewfsid(mp); error = smbfs_root(mp, LK_EXCLUSIVE, &vp, td); - if (error) + if (error) { + vfs_mount_error(mp, "smbfs_root error: %d", error); goto bad; + } VOP_UNLOCK(vp, 0, td); SMBVDEBUG("root.v_usecount = %d\n", vrefcnt(vp)); @@ -324,6 +337,7 @@ smbfs_root(struct mount *mp, int flags, struct vnode **vpp, struct thread *td) if (smp == NULL) { SMBERROR("smp == NULL (bug in umount)\n"); + vfs_mount_error(mp, "smp == NULL (bug in umount)"); return EINVAL; } if (smp->sm_root) { @@ -394,8 +408,10 @@ smbfs_statfs(struct mount *mp, struct statfs *sbp, struct thread *td) struct smb_cred scred; int error = 0; - if (np == NULL) + if (np == NULL) { + vfs_mount_error(mp, "np == NULL"); return EINVAL; + } sbp->f_iosize = SSTOVC(ssp)->vc_txmax; /* optimal transfer block size */ smb_makescred(&scred, td, td->td_ucred); |