diff options
author | Justus Winter <4winter@informatik.uni-hamburg.de> | 2014-03-03 20:48:20 +0100 |
---|---|---|
committer | Justus Winter <4winter@informatik.uni-hamburg.de> | 2014-04-02 17:44:00 +0200 |
commit | b7cbdde8854ee4c51ec9cd49ce639bd02d646355 (patch) | |
tree | 7c1cf1b5011763d20584733d2bb7be1b586b667a /libpager/chg-compl.c | |
parent | 64b5d358fcaa039ca2e7634aceaa5ed4c3a10cc4 (diff) | |
download | hurd-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.c | 10 |
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; } |