diff options
Diffstat (limited to 'libnetfs')
-rw-r--r-- | libnetfs/dir-link.c | 43 | ||||
-rw-r--r-- | libnetfs/dir-mkdir.c | 6 |
2 files changed, 49 insertions, 0 deletions
diff --git a/libnetfs/dir-link.c b/libnetfs/dir-link.c new file mode 100644 index 00000000..060f2a02 --- /dev/null +++ b/libnetfs/dir-link.c @@ -0,0 +1,43 @@ +/* + Copyright (C) 1995 Free Software Foundation, Inc. + Written by Michael I. Bushnell, p/BSG. + + This file is part of the GNU Hurd. + + The GNU Hurd is free software; you can redistribute it and/or + modify it under the terms of the GNU General Public License as + published by the Free Software Foundation; either version 2, or (at + your option) any later version. + + The GNU Hurd is distributed in the hope that it will be useful, but + WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. */ + +#include "netfs.h" +#include "fs_S.h" + +error_t +netfs_S_dir_link (struct protid *diruser, struct protid *fileuser, char *name) +{ + error_t err; + + if (!diruser) + return EOPNOTSUPP; + + if (!fileuser) + return EXDEV; + + /* Note that nothing is locked here */ + err = netfs_attempt_link (diruser->credential, diruser->po->np, + fileuser->po->np, name); + if (!err) + mach_port_deallocate (mach_task_self (), fileuser->pi.port_right); + return err; +} + + diff --git a/libnetfs/dir-mkdir.c b/libnetfs/dir-mkdir.c index c0370b90..fdfde30c 100644 --- a/libnetfs/dir-mkdir.c +++ b/libnetfs/dir-mkdir.c @@ -25,7 +25,13 @@ error_t netfs_S_dir_mkdir (struct protid *user, char *name, mode_t mode) { error_t err; + + if (!user) + return EOPNOTSUPP; + mode &= ~(S_IFMT|S_ISPARE|S_ISVTX); + mode |= S_IFDIR; + mutex_lock (&user->po->np->lock); err = netfs_attempt_mkdir (user->credential, user->po->np, name, mode); mutex_unlock (&user->po->np->lock); |