2002-04-10  Neal H Walfield  <neal@cs.uml.edu>

       * pager-memcpy.c (pager_memcpy): Pass not the block but the byte
       offset of the page in question to pager_get_error.

2002-04-10  Neal H Walfield  <neal@cs.uml.edu>

	* pager-memcpy.c (VMCOPY_BETTER_THAN_MEMCPY): New macro.
	(pager_memcpy): Rewritten to use vmcopy.

2002-04-01  Neal H Walfield  <neal@cs.uml.edu>

	* data-request.c (_pager_seqnos_memory_object_data_request): Must
	hold P->interlock when calling _pager_allow_termination.

2002-01-19  Roland McGrath  <roland@frob.com>

	* demuxer.c (pager_demuxer): Fix last change so it works.  Add comment.

2001-01-16  Marcus Brinkmann <marcus@gnu.org>

	* demuxer.c (pager_demuxer): If the message was not accepted by
	one of the servers, acquire a reference to the pager and its lock,
	and wait until all previous messages have been processed.  This
	makes sure that the next message that arrives can proceed.
	Reported by Neal H Walfield <neal@cs.uml.edu>

2001-12-29  Roland McGrath  <roland@frob.com>

	* data-init.c, object-create.c: Removed obsolete files.

2001-02-25  Roland McGrath  <roland@frob.com>

	* pager-memcpy.c: Include <string.h> for memcpy decl.

2000-07-25  Thomas Bushnell, BSG  <tb@mit.edu>

	* priv.h (PM_WRITEWAIT): New pagemap bit.
	* data-return.c (_pager_do_write_request): Don't proceed with a
	pageout if one is already in progress.  Once we finish, wake up
	any potential PM_WRITEWAIT waiters.

	* priv.h (PM_INIT): Provide value again.
	* data-return.c (_pager_do_write_request): Track PM_INIT again.

	* priv.h (struct pager): Make pagemap consist of 16-bit elements
	instead of only 8 bits.
	* data-request.c (_pager_seqnos_memory_object_data_request):
	Make PM_ENTRY a short pointer.
	* data-return.c (_pager_do_write_request): Make PM_ENTRIES a short
	pointer.
	* lock-object.c (_pager_lock_object): Make PM_ENTRIES a short
	pointer.
	* mark-error.c (_pager_mark_next_request_error): Make P a short
	pointer.
	(_pager_mark_object_error): Likewise.
	* offer-page.c (pager_offer_page): Make PM_ENTRY a short pointer.
	* object-terminate.c (_pager_free_structure): Interpret
	pagemapsize correctly.
	* pagemap.c (_pager_pagemap_resize): Likewise.

2000-01-24  Roland McGrath  <roland@baalperazim.frob.com>

	* pager-memcpy.c (pager_memcpy): Short-circuit return for zero size.

1999-07-10  Roland McGrath  <roland@baalperazim.frob.com>

	* priv.h: Add #include <sys/mman.h> for munmap decl.
	* pager-memcpy.c: Likewise.

1999-07-09  Thomas Bushnell, BSG  <tb@mit.edu>

	* pagemap.c (_pager_pagemap_resize): Use mmap instead of vm_allocate.

1999-07-03  Thomas Bushnell, BSG  <tb@mit.edu>

	* data-return.c (_pager_do_write_request): Use munmap instead of
	vm_deallocate.
	* object-terminate.c (_pager_free_structure): Likewise.
	* pagemap.c (_pager_pagemap_resize): Likewise.
	* pager-memcpy.c (pager_memcpy): Likewise.

	* pager.h (pager_write_page): Doc adjustment.

Wed Aug 20 14:47:38 1997  Thomas Bushnell, n/BSG  <thomas@gnu.ai.mit.edu>

	* pager.h: Doc fix.

Thu Feb  6 12:01:36 1997  Miles Bader  <miles@gnu.ai.mit.edu>

	* pagemap.c (_pager_pagemap_resize): Return errors.
	* offer-page.c (pager_offer_page): Rewrite for clarity.
	Deal with _pager_pagemap_resize failing.
	* data-request.c (_pager_seqnos_memory_object_data_request): Deal
	with _pager_pagemap_resize failing.
	* lock-object.c (_pager_lock_object): Likewise.
	* mark-error.c (pager_get_error): Likewise.
	* priv.h (_pager_pagemap_resize): Returns an error_t.

Mon Jan 20 16:25:39 1997  Miles Bader  <miles@gnu.ai.mit.edu>

	* pager-memcpy.c (pager_memcpy): `preempter' -> `preemptor'.

Thu Sep 12 16:21:14 1996  Thomas Bushnell, n/BSG  <thomas@gnu.ai.mit.edu>

	* Makefile (HURDLIBS): New variable.
	(libpager.so): Delete special depedency.

Tue Aug 13 10:47:47 1996  Thomas Bushnell, n/BSG  <thomas@gnu.ai.mit.edu>

	* object-terminate.c (_pager_free_structure): Don't bother calling
	mach_port_deallocate if the cells are already null; set the cells
	to null after the deallocation is done.
	(_pager_seqnos_memory_object_terminate): Destroy the rights passed
	in for control and name.

Thu May  9 11:10:11 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* pager-create.c: Get rid of link warning.

	* pager-create.c (pager_create): ports_allocate_port ->
 	ports_create_port; if we get an error return a null structure.

Thu May  2 11:17:17 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* offer-page.c (pager_offer_page): Make sure we hold lock across
 	operation.  Also set incore bit when operation is complete.

Tue Apr 30 12:40:33 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* lock-object.c (_pager_lock_object): Eliminate spurious extra
 	lock acquisition around pagemap frobbing.

Sun Apr 28 15:46:12 1996  Roland McGrath  <roland@delasyd.gnu.ai.mit.edu>

	* pager-create.c (pager_create): Add link warning.

Thu Apr 18 13:03:55 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* data-return.c (_pager_do_write_request): If kernel didn't keep a
	copy, turn off INCORE bit.  Don't track INIT bit for now.
	* lock-object.c (_pager_lock_object): If SYNC and SHOULD_FLUSH,
 	then turn off PM_INCORE bits when flush is complete.
	* data-request.c (_pager_seqnos_memory_object_data_request): Set
 	PM_INCORE.
	* priv.h (PM_INIT): Comment out.
	(PM_INCORE): New bit.
	* offer-page.c: New file.
	* Makefile (SRCS): Add offer-page.c.
	* pager.h (pager_offer_page): New function.

Thu Apr 11 17:50:57 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* pager-memcpy.c (pager_memcpy [copy]): Return error_t so that
	this function has the proper type as an arg for
	hurd_catch_signal.
	(pager_memcpy): Cast FAULT to proper type in call to
	hurd_catch_signal.

Tue Mar 26 15:38:06 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* lock-completed.c: Include <stdio.h>.

	* data-return.c (_pager_do_write_request): Delete unused label
 	`out'.

	* pager-sync.c (pager_sync, pager_sync_some): Ask for RETURN_ALL
	and not just RETURN_DIRTY, because we treat precious pages as
	dirty in this library.
	* pager-return.c (pager_return, pager_return_some): Likewise.

Mon Mar 18 13:10:32 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* pager.h (pager_return, pager_return_some): New declarations.
	* Makefile (SRCS): Add pager-return.c.
	* pager-return.c: New file.

	* pager-flush.c (pager_flush): Lock request should be
 	VM_PROT_NO_CHANGE, not VM_PROT_NONE.
	(pager_flush_some): Likewise.

Wed Mar  6 17:53:20 1996  Miles Bader  <miles@gnu.ai.mit.edu>

	* lock-object.c (_pager_lock_object): Correctly remove LR from
	P's linked list of lock requests.
	* pager-attr.c (pager_change_attributes): Likewise for attributes.

	* lock-object.c (_pager_lock_object): Don't barf anymore.
	* lock-completed.c (_pager_seqnos_memory_object_lock_completed): Ditto.
	* Makefile (SRCS): Remove barf.c.

Wed Feb 21 14:15:26 1996  Miles Bader  <miles@gnu.ai.mit.edu>

	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
	Get rid of bletcherous semi.
	Make barf more voluminous.

	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
	Be picky about always releasing SEQNO.
	* object-init.c (_pager_seqnos_memory_object_init): Likewise.

Tue Feb 20 17:44:59 1996  Miles Bader  <miles@gnu.ai.mit.edu>

	* lock-object.c (_pager_lock_object): Use barf instead of printf.
	* lock-completed.c (_pager_seqnos_memory_object_lock_completed): Ditto.
	* Makefile (SRCS): Add barf.c.

	* data-return.c (_pager_do_write_request): Always wait for and
	release SEQNO if OBJECT is a valid pager.
	* data-request.c (_pager_seqnos_memory_object_data_request): Likewise.
	* object-terminate.c (_pager_seqnos_memory_object_terminate): Likewise.

Tue Feb 20 16:05:42 1996  Michael I. Bushnell, p/BSG  <mib@gnu.ai.mit.edu>

	* lock-object.c (_pager_lock_object): Print debugging message when
	SYNC.
	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
	Print a notice when an incoming lock completion corresponds to no
	outstanding lock request.

Tue Feb 20 15:10:29 1996  Miles Bader  <miles@gnu.ai.mit.edu>

	* lock-object.c (_pager_lock_object): Remove `sync = 0'.

Fri Jan  5 17:09:43 1996  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>

	* pager-memcpy.c: New file.
	* Makefile (SRCS): Add pager-memcpy.c.

Thu Jan  4 15:37:21 1996  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>

	* pager.h: Declare pager_memcpy.

Mon Oct  9 14:57:48 1995  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>

	* priv.h: Declare _pager_page_errors extern, not common.

        * Makefile: Specify shared library dependencies.

Wed Sep 13 14:49:53 1995  Michael I. Bushnell, p/BSG  <mib@duality.gnu.ai.mit.edu>

	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
 	Don't push the locks_pending field negative in the case where the
 	pager was terminated before we get called.

Tue Sep  5 15:50:12 1995  Miles Bader  <miles@churchy.gnu.ai.mit.edu>

	* chg-compl.c (_pager_seqnos_memory_object_change_completed):
	Don't push the attrs_pending field negative in the case where the
	pager was terminated before we get called.

Wed Aug 23 15:00:46 1995  Miles Bader  <miles@churchy.gnu.ai.mit.edu>

	* Makefile (SRCS): Make this the main list of files, from which
	the others are derived.
	(COBJS, REMHDRS): Removed.
	(OBJS): Derived mostly from $(SRCS).

Fri Jul 21 16:43:19 1995  Michael I Bushnell  <mib@geech.gnu.ai.mit.edu>

	* object-create.c (_pager_seqnos_memory_object_create): Drop
	initial reference created by ports_intern_external_reference when
	we're done with P.

Thu Jul  6 15:36:36 1995  Michael I Bushnell  <mib@duality.gnu.ai.mit.edu>

	* Makefile: Removed dependencies that are now automatically
 	generated.

Mon Jun 26 20:15:03 1995  Michael I Bushnell  <mib@duality.gnu.ai.mit.edu>

	* get-upi.c: New file.
	* pager.h (pager_get_upi): New function.
	* Makefile (COBJS): Add get-upi.o.

Thu Jun 22 11:43:15 1995  Michael I Bushnell  <mib@duality.gnu.ai.mit.edu>

	* object-init.c (_pager_seqnos_memory_object_init): Rather than an
	empty `if' body and an unconditional return, how about a real
	test?

	* notify-stubs.c: New file.
	* Makefile (COBJS): Add notify-stubs.o.

Tue Jun 20 12:44:22 1995  Michael I Bushnell  <mib@duality.gnu.ai.mit.edu>

	* chg-compl.c (_pager_seqnos_memory_object_change_completed): Use
	new ports routines.
	* pager-shutdown.c (pager_shutdown): Likewise.
	* object-terminate.c (_pager_free_structure): Likewise.
	* object-init.c (_pager_seqnos_memory_object_init): Likewise.
	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
	Likewise.
	* data-unlock.c (_pager_seqnos_memory_object_data_unlock): Likewise.
	* data-return.c (_pager_do_write_request): Likewise.
	* data-request.c (_pager_seqnos_memory_object_data_request):
	Likewise.
	* pager-create.c (pager_create): New parm BUCKET.  Allocate port
	using new ports interface.  Arrange to have _pager_class
	initialized at startup.
	* clean.c, dropweak.c: New files.
	* no-senders.c: Rename pager_no_senders to
	_pager_do_seqnos_mach_notify_no_senders.  Lookup up port right
	ourselves.  Remove function pager_clean (now in clean.c).
	* priv.h (_pager_class): New var.
	(_pager_clean, _pager_real_dropweak): New decls.
	* Makefile (COBJS): Delete reference.o.  Add clean.o and dropweak.o
	(OBJS): Add notifyServer.o.
	(demuxer.o): Depend on notify_S.h.
	* demuxer.c: Include "notify_S.h".
	(pager_demuxer): Declare and use _pager_seqnos_notify_server.
	* pager.h: Include <hurd/ports.h>.
	(pager_no_senders, pager_reference, pager_unreference,
	pager_port_type, pager_clean): Remove declarations.
	(pager_create): New parm BUCKET.
	(pager_clean): Doc fix.
	(pager_dropweak): New decl.
	* reference.c: Deleted file.

Thu May 11 11:19:44 1995  Miles Bader  <miles@churchy.gnu.ai.mit.edu>

	* priv.h (PM_NEXTERROR, SET_PM_NEXTERROR): Mask 2-bit error code
	with 0x3, not 0x2!

	* mark-error.c (_pager_mark_next_request_error,
	_pager_mark_object_error): Put the error code in the correct place
	in the pagemap rather than always at the beginning.
	(pager_get_error): Get the error code from the pagemap rather than
	just using the pagemap offset!

Wed Nov 23 00:28:19 1994  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>

	* demuxer.c (pager_demuxer): Call
	_pager_seqnos_memory_object_server, not
	seqnos_memory_object_server.

Tue Nov  8 14:15:01 1994  Michael I Bushnell  <mib@geech.gnu.ai.mit.edu>

	* lock-object.c (_pager_lock_object): Hammer SYNC to zero for now;
	there's some deadlock bug in noticing when the sync finishes.

Tue Aug 30 17:55:34 1994  Michael I Bushnell  <mib@geech.gnu.ai.mit.edu>

	* data-return.c: Include <assert.h>.
	(_pager_seqnos_memory_object_data_return): Use return correctly.

Mon Aug 29 17:30:52 1994  Michael I Bushnell  <mib@geech.gnu.ai.mit.edu>

	* priv.h (PM_INIT): New pagemap bit.
	* data-return.c (_pager_do_write-request): Set PM_INIT for
	affected pages.  New var `omitdata' hold a bitmap of the
	pages that we are not actually writing.  Set accordingly
	while looking through pagemap before starting I/O.  Don't
	actually call I/O on these pages or frob the page map with them
	later.

	* data-return.c (_pager_seqnos_memory_object_data_return): Split
	into two functions; _pager_do_write_request does the real work
	now.

	* object-create.c: New file.
	* data-init.c: New file.

Fri Jul 22 11:54:05 1994  Michael I Bushnell  <mib@geech.gnu.ai.mit.edu>

	* Makefile: Rewritten to use new scheme.
	* data-request.c: Include "memory_object_S.h" instead of
	"memory_object.h".
	* data-return.c: Likewise.
	* data-unlock.c: Likewise.
	* lock-completed: Likewise.
	* stubs.c: Likewise.
	* object-init.c: Likewise.
	* demuxer.c: Likewise.
	* object-terminate.c: Likewise.

Tue Jul  5 14:14:17 1994  Michael I Bushnell  (mib@churchy.gnu.ai.mit.edu)

	* Makefile (TAGSHDRS): New variable.

Wed Jun  1 11:41:24 1994  Michael I Bushnell  (mib@churchy.gnu.ai.mit.edu)

	* pager-attr.c (pager_change_attributes): Return immediately
	if we are already in the requested state.

	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
	Call ports_done_with_port before returning to free reference
	created by ports_check_port_type.
	* chg-compl.c (_pager_seqnos_memory_object_change_completed):
	Likewise.

	* seqnos.c (_pager_release_seqno): New second arg SEQNO.
	Set p->seqno here.  All callers changed.
	(_pager_wait_for_seqno): Don't set p->seqno here; then it
	might get released before we actually call _pager_release_seqno.
	* priv.h (_pager_release_seqno): Declare new second arg.

	* priv.h (KERNEL_INIT_RACE): New compilation option.  All the
	changes in this block are conditionalized by this macro.
	* priv.h (struct pager): New members init_head and init_tail.
	(struct pending_init): New type.
	* object-init.c (_pager_seqnos_memory_object_init): If the object
	is not ready for init, then queue the init for later processing.
	* object-terminate.c (_pager_seqnos_memory_object_terminate): If
	there is a pending init, return it here.
	* no-senders.c (pager_clean): Destroy all pending inits here.

	* object-terminate.c (_pager_free_structure): Don't unlock
	interlock or free the seqno here.
	(_pager_seqnos_memory_object_terminate): Unlock interlock and
	free seqno after calling _pager_free_structure.
	* no-senders.c (pager_clean): Unlock interlock after calling
	_pager_free_structure.  Don't free seqno here at all.

Tue May 24 15:25:54 1994  Michael I Bushnell  (mib@churchy.gnu.ai.mit.edu)

	* data-return.c (_pager_seqnos_memory_object_data_return): New
	vars NPAGES, I, and PAGERRS.  Rename var PM_ENTRY to be
	PM_ENTRIES.  Deal with multiple-page data_return calls by dealing
	with multiple pagemap slots and calling pager_write_page multiple
	times.

	* data-return.c (_pager_seqnos_memory_object_data_return): Fix
	printf messages; include length in bogus length messages.

	*data-unlock (_pager_seqnos_memory_object_data_unlock): Likewise.

Mon May 23 13:06:31 1994  Michael I Bushnell  (mib@churchy.gnu.ai.mit.edu)

	* data-request.c (_pager_seqnos_memory_object_data_request):
	Report length in bogus arg messages; terminate messages with
	newlines.

	* chg-compl.c: Include <stdio.h>.

	* priv.h (struct pager [may_cache, copy_strategy]):  New members.
	* pager.h (pager_create_pager): Added new args MAY_CACHE and
	COPY_STRATEGY.
	(pager_report_attributes): Deleted declaration.
	* object-init.c (_pager_seqnos_memory_object_init): Set attributes
	from values in P rather than by calling pager_report_attributes.
	* pager-attr.c (pager_change_attributes): Don't panic if the
	pager isn't yet initialized by the kernel; record the provided
	values in may_cache and copy_strategy.

	* pager-attr.c: Spelling fix.
	Include <assert.h>.
	* Makefile (COBJS): Added pager-attr.o.

Fri May 20 15:41:12 1994  Michael I Bushnell  (mib@geech.gnu.ai.mit.edu)

	* lock-completed.c (_pager_seqnos_memory_object_lock_completed):
	Delete unneeded variable wakeup.  Break out of loop as soon
	as we find the right record.  Call condition_broadcast only
	if we need bother.

	* pager.h (pager_change_attributes, pager_report_attributes):
	New declarations.
	* priv.h (struct attribute_request): New structure.
	(struct pager [attribute_requests]): New member.
	* pager-create.c (pager_create): Initialize new member.
	* object-init.c (_pager_seqnos_memory_object_init): Call
	pager_report_attributes for correct args to memory_object_ready.
	* pager-attr.c: New file.
	* object-terminate.c (_pager_free_structure): Wakeup pending
	pager_change_attribute requests.
	* stubs.c (_pager_seqnos_memory_object_change_completed): Deleted
	function.
	* chg-compl.c: New file.
	* Makefile (COBJS): Added chg-compl.o.

Thu May  5 07:49:21 1994  Roland McGrath  (roland@churchy.gnu.ai.mit.edu)

	* stubs.c (_pager_seqnos_memory_object_supply_completed): Change
	RESULT arg to type kern_return_t; error_t is not compatible.

	* demuxer.c (pager_demuxer): Declare seqnos_memory_object_server.

	* stubs.c, lock-completed.c: Changed return type of all RPC server
	functions to kern_return_t.  error_t is not compatible with the
	declarations in the mig-generated header files.

	* Makefile: Change uses of $(headers) to $(includedir).

Tue Apr 26 15:08:57 1994  Michael I Bushnell  (mib@geech.gnu.ai.mit.edu)

	* object-init.c (_pager_seqnos_memory_object_init): Only check
	for inits of active objects AFTER waiting for seqno; otherwise we
	could race against a prior terminate.