summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiles Bader <miles@gnu.org>1996-01-27 17:02:23 +0000
committerMiles Bader <miles@gnu.org>1996-01-27 17:02:23 +0000
commit41808cd31b8b67b0860eea32ae346582bd2408ae (patch)
treeec4c1195ef09a0cc19b4e4d259b05e220dde38fd
parent166d1d8db09ad7385f4851624ba8208b03b19d90 (diff)
(diskfs_set_readonly): Deal with ports_inhibit_class_rpcs returning an error.
-rw-r--r--libdiskfs/readonly.c58
1 files changed, 30 insertions, 28 deletions
diff --git a/libdiskfs/readonly.c b/libdiskfs/readonly.c
index 18025468..a459f194 100644
--- a/libdiskfs/readonly.c
+++ b/libdiskfs/readonly.c
@@ -1,6 +1,6 @@
/* Change to/from read-only
- Copyright (C) 1995 Free Software Foundation, Inc.
+ Copyright (C) 1995, 1996 Free Software Foundation, Inc.
Written by Miles Bader <miles@gnu.ai.mit.edu>
@@ -35,42 +35,44 @@ diskfs_set_readonly (int readonly)
if (readonly != diskfs_readonly)
{
- ports_inhibit_class_rpcs (diskfs_protid_class);
-
- if (readonly)
+ err = ports_inhibit_class_rpcs (diskfs_protid_class);
+ if (! err)
{
- error_t peropen_writable (void *pi)
+ if (readonly)
{
- if (((struct port_info *)pi)->class == diskfs_protid_class
- && (((struct protid *)pi)->po->openstat & O_WRITE))
- return EBUSY;
- else
- return 0;
+ error_t peropen_writable (void *pi)
+ {
+ if (((struct port_info *)pi)->class == diskfs_protid_class
+ && (((struct protid *)pi)->po->openstat & O_WRITE))
+ return EBUSY;
+ else
+ return 0;
+ }
+
+ /* Any writable open files? */
+ err = ports_bucket_iterate (diskfs_port_bucket, peropen_writable);
+
+ /* Any writable pagers? */
+ if (!err && (diskfs_max_user_pager_prot () & VM_PROT_WRITE))
+ err = EBUSY;
+
+ if (!err)
+ /* Sync */
+ {
+ diskfs_sync_everything (1);
+ diskfs_set_hypermetadata (1, 1);
+ sleep (1); /* XXX! */
+ }
}
- /* Any writable open files? */
- err = ports_bucket_iterate (diskfs_port_bucket, peropen_writable);
-
- /* Any writable pagers? */
- if (!err && (diskfs_max_user_pager_prot () & VM_PROT_WRITE))
- err = EBUSY;
-
if (!err)
- /* Sync */
{
- diskfs_sync_everything (1);
- diskfs_set_hypermetadata (1, 1);
- sleep (1); /* XXX! */
+ diskfs_readonly = readonly;
+ diskfs_readonly_changed (readonly);
}
- }
- if (!err)
- {
- diskfs_readonly = readonly;
- diskfs_readonly_changed (readonly);
+ ports_resume_class_rpcs (diskfs_protid_class);
}
-
- ports_resume_class_rpcs (diskfs_protid_class);
}
return err;