summaryrefslogtreecommitdiff
path: root/trans
diff options
context:
space:
mode:
authorMiles Bader <miles@gnu.org>1996-01-27 17:39:58 +0000
committerMiles Bader <miles@gnu.org>1996-01-27 17:39:58 +0000
commit4226a60bb0aa407c145593aa10daba13f10e3861 (patch)
tree61671157cdf3ab1774e487867b8865ad10b1a3be /trans
parentc1a6759c994b46af928ca81cb2311a3212f480fb (diff)
(trivfs_goaway): Handle errors from ports_inhibit_bucket_rpcs.
Diffstat (limited to 'trans')
-rw-r--r--trans/fifo.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/trans/fifo.c b/trans/fifo.c
index 72f48042..e3317593 100644
--- a/trans/fifo.c
+++ b/trans/fifo.c
@@ -1,6 +1,6 @@
/* A translator for fifos
- Copyright (C) 1995 Free Software Foundation, Inc.
+ Copyright (C) 1995, 1996 Free Software Foundation, Inc.
Written by Miles Bader <miles@gnu.ai.mit.edu>
@@ -313,11 +313,15 @@ trivfs_modify_stat (struct trivfs_protid *cred, struct stat *st)
error_t
trivfs_goaway (struct trivfs_control *cntl, int flags)
{
+ error_t err;
+ int force = (flags & FSYS_GOAWAY_FORCE);
struct port_bucket *bucket = ((struct port_info *)cntl)->bucket;
- ports_inhibit_bucket_rpcs (bucket);
- if (ports_count_class (cntl->protid_class) > 0
- && !(flags & FSYS_GOAWAY_FORCE))
+ err = ports_inhibit_bucket_rpcs (bucket);
+ if (err == EINTR || (err && !force))
+ return err;
+
+ if (ports_count_class (cntl->protid_class) > 0 && !force)
/* Still some opens, and we're not being forced to go away, so don't. */
{
ports_enable_class (cntl->protid_class);
@@ -325,7 +329,7 @@ trivfs_goaway (struct trivfs_control *cntl, int flags)
return EBUSY;
}
- exit(0);
+ exit (0);
}
/* ---------------------------------------------------------------- */