diff options
Diffstat (limited to 'libdiskfs/io-reauthenticate.c')
-rw-r--r-- | libdiskfs/io-reauthenticate.c | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/libdiskfs/io-reauthenticate.c b/libdiskfs/io-reauthenticate.c new file mode 100644 index 00000000..69d78bc5 --- /dev/null +++ b/libdiskfs/io-reauthenticate.c @@ -0,0 +1,66 @@ +/* + Copyright (C) 1994,95,96,2000,01 Free Software Foundation, Inc. + + This program 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. + + This program 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., 675 Mass Ave, Cambridge, MA 02139, USA. */ + +#include "priv.h" +#include "io_S.h" + +/* Implement io_reathenticate as described in <hurd/io.defs>. */ +kern_return_t +diskfs_S_io_reauthenticate (struct protid *cred, + mach_port_t rend_port) +{ + struct protid *newcred; + error_t err; + mach_port_t newright; + struct iouser *user; + + if (cred == 0) + return EOPNOTSUPP; + + /* This routine must carefully ignore EINTR because we + are a simpleroutine, so callers won't know to restart. */ + + pthread_mutex_lock (&cred->po->np->lock); + do + err = diskfs_start_protid (cred->po, &newcred); + while (err == EINTR); + if (err) + { + pthread_mutex_unlock (&cred->po->np->lock); + return err; + } + + newright = ports_get_send_right (newcred); + assert (newright != MACH_PORT_NULL); + + err = iohelp_reauth (&user, diskfs_auth_server_port, rend_port, + newright, 1); + if (! err) + { + diskfs_finish_protid (newcred, user); + iohelp_free_iouser (user); + mach_port_deallocate (mach_task_self (), rend_port); + } + + mach_port_deallocate (mach_task_self (), newright); + + pthread_mutex_unlock (&cred->po->np->lock); + + ports_port_deref (newcred); + + return err; +} |