aboutsummaryrefslogtreecommitdiff
path: root/libpager/chg-compl.c
diff options
context:
space:
mode:
authorJustus Winter <4winter@informatik.uni-hamburg.de>2014-03-03 20:48:20 +0100
committerJustus Winter <4winter@informatik.uni-hamburg.de>2014-04-02 17:44:00 +0200
commitb7cbdde8854ee4c51ec9cd49ce639bd02d646355 (patch)
tree7c1cf1b5011763d20584733d2bb7be1b586b667a /libpager/chg-compl.c
parent64b5d358fcaa039ca2e7634aceaa5ed4c3a10cc4 (diff)
downloadhurd-b7cbdde8854ee4c51ec9cd49ce639bd02d646355.tar.gz
hurd-b7cbdde8854ee4c51ec9cd49ce639bd02d646355.tar.bz2
hurd-b7cbdde8854ee4c51ec9cd49ce639bd02d646355.zip
libpager: fix receiver lookups
Previously, the receiver lookup was done manually in all the server functions. Use mig translator functions instead. * libpager/mig-decls.h: New file. * libpager/mig-mutate.h: Likewise. * libpager/Makefile (MIGSFLAGS): Include mig-mutate.h. * libpager/chg-compl.c: Fix receiver lookups. * libpager/data-request.c: Likewise. * libpager/data-return.c: Likewise. * libpager/data-unlock.c: Likewise. * libpager/lock-completed.c: Likewise. * libpager/object-init.c: Likewise. * libpager/object-terminate.c: Likewise. * libpager/stubs.c: Likewise. * libpager/seqnos.c (_pager_update_seqno): Move the actual functionality... (_pager_update_seqno_p): ... into a new function that can be called with a pointer to struct pager. * libpager/priv.h (_pager_update_seqno_p): New declaration.
Diffstat (limited to 'libpager/chg-compl.c')
-rw-r--r--libpager/chg-compl.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/libpager/chg-compl.c b/libpager/chg-compl.c
index 0b0c99c2..d77c46cf 100644
--- a/libpager/chg-compl.c
+++ b/libpager/chg-compl.c
@@ -22,16 +22,15 @@
when a memory_object_change_attributes call has completed. Read this
in combination with pager-attr.c. */
kern_return_t
-_pager_seqnos_memory_object_change_completed (mach_port_t obj,
+_pager_seqnos_memory_object_change_completed (struct pager *p,
mach_port_seqno_t seq,
boolean_t maycache,
memory_object_copy_strategy_t strat)
{
- struct pager *p;
struct attribute_request *ar;
-
- p = ports_lookup_port (0, obj, _pager_class);
- if (!p)
+
+ if (!p
+ || p->port.class != _pager_class)
{
printf ("Bad change completed\n");
return EOPNOTSUPP;
@@ -50,6 +49,5 @@ _pager_seqnos_memory_object_change_completed (mach_port_t obj,
_pager_release_seqno (p, seq);
pthread_mutex_unlock (&p->interlock);
- ports_port_deref (p);
return 0;
}