summaryrefslogtreecommitdiff
path: root/libpager
diff options
context:
space:
mode:
authorMiles Bader <miles@gnu.org>1996-02-21 00:26:22 +0000
committerMiles Bader <miles@gnu.org>1996-02-21 00:26:22 +0000
commit77579eba9fac2abf55043e9295d08a1e1f5b761f (patch)
tree2ae2c62bdb79c2605c02ce7a267078fff8ade9c9 /libpager
parent443886acfed9baee785d5df3baa1cbb03bb59ebe (diff)
(_pager_do_write_request):
Always wait for and release SEQNO if OBJECT is a valid pager.
Diffstat (limited to 'libpager')
-rw-r--r--libpager/data-return.c46
1 files changed, 20 insertions, 26 deletions
diff --git a/libpager/data-return.c b/libpager/data-return.c
index 1517d67c..709f9de2 100644
--- a/libpager/data-return.c
+++ b/libpager/data-return.c
@@ -1,5 +1,5 @@
/* Implementation of memory_object_data_return for pager library
- Copyright (C) 1994, 1995 Free Software Foundation
+ Copyright (C) 1994, 1995, 1996 Free Software Foundation
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
@@ -38,7 +38,6 @@ _pager_do_write_request (mach_port_t object,
{
struct pager *p;
char *pm_entries;
- error_t err;
int npages, i;
error_t *pagerrs;
struct lock_request *lr;
@@ -50,48 +49,40 @@ _pager_do_write_request (mach_port_t object,
p = ports_lookup_port (0, object, _pager_class);
if (!p)
return EOPNOTSUPP;
+
+ /* Acquire the right to meddle with the pagemap */
+ mutex_lock (&p->interlock);
+ _pager_wait_for_seqno (p, seqno);
/* sanity checks -- we don't do multi-page requests yet. */
if (control != p->memobjcntl)
{
printf ("incg data return: wrong control port\n");
- err = 0;
- goto out;
+ goto release_out;
}
if (length % __vm_page_size)
{
printf ("incg data return: bad length size %d\n", length);
- err = 0;
- goto out;
+ goto release_out;
}
if (offset % __vm_page_size)
{
printf ("incg data return: misaligned request\n");
- err = 0;
- goto out;
- }
-
- if (!dirty)
- {
- err = 0;
- goto out;
+ goto release_out;
}
- npages = length / __vm_page_size;
- pagerrs = alloca (npages * sizeof (error_t));
-
- /* Acquire the right to meddle with the pagemap */
- mutex_lock (&p->interlock);
- _pager_wait_for_seqno (p, seqno);
+ if (! dirty)
+ goto release_out;
if (p->pager_state != NORMAL)
{
printf ("pager in wrong state for write\n");
- _pager_release_seqno (p, seqno);
- mutex_unlock (&p->interlock);
- goto out;
+ goto release_out;
}
+ npages = length / __vm_page_size;
+ pagerrs = alloca (npages * sizeof (error_t));
+
_pager_block_termination (p); /* until we are done with the pagemap
when the write completes. */
@@ -193,6 +184,12 @@ _pager_do_write_request (mach_port_t object,
out:
ports_port_deref (p);
return 0;
+
+ release_out:
+ _pager_release_seqno (p, seqno);
+ mutex_unlock (&p->interlock);
+ ports_port_deref (p);
+ return 0;
}
/* Implement pageout call back as described by <mach/memory_object.defs>. */
@@ -209,6 +206,3 @@ _pager_seqnos_memory_object_data_return (mach_port_t object,
return _pager_do_write_request (object, seqno, control, offset, data,
length, dirty, kcopy, 0);
}
-
-
-