|
|
1.1 ! root 1: /* ! 2: * Copyright (c) 1994 The University of Utah and ! 3: * the Computer Systems Laboratory (CSL). All rights reserved. ! 4: * ! 5: * Permission to use, copy, modify and distribute this software and its ! 6: * documentation is hereby granted, provided that both the copyright ! 7: * notice and this permission notice appear in all copies of the ! 8: * software, derivative works or modified versions, and any portions ! 9: * thereof, and that both notices appear in supporting documentation. ! 10: * ! 11: * THE UNIVERSITY OF UTAH AND CSL ALLOW FREE USE OF THIS SOFTWARE IN ITS "AS ! 12: * IS" CONDITION. THE UNIVERSITY OF UTAH AND CSL DISCLAIM ANY LIABILITY OF ! 13: * ANY KIND FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. ! 14: * ! 15: * CSL requests users of this software to return to [email protected] any ! 16: * improvements that they make and grant CSL redistribution rights. ! 17: */ ! 18: /* ! 19: * File: ipc_target.c ! 20: * ! 21: * Implementation for common part of IPC ports and port sets ! 22: * representing a target of messages and migrating RPCs. ! 23: */ ! 24: ! 25: #include "sched_prim.h" ! 26: #include "ipc_target.h" ! 27: ! 28: void ! 29: ipc_target_init(struct ipc_target *ipt, mach_port_t name) ! 30: { ! 31: ipt->ipt_name = name; ! 32: ipc_mqueue_init(&ipt->ipt_messages); ! 33: ! 34: #ifdef MIGRATING_THREADS ! 35: ipt->ipt_type = IPT_TYPE_MESSAGE_RPC; ! 36: ipt->ipt_acts = 0; ! 37: ! 38: ipc_target_machine_init(ipt); ! 39: #endif ! 40: } ! 41: ! 42: void ! 43: ipc_target_terminate(struct ipc_target *ipt) ! 44: { ! 45: } ! 46: ! 47: #ifdef MIGRATING_THREADS ! 48: struct Act * ! 49: ipc_target_block(struct ipc_target *ipt) ! 50: { ! 51: struct Act *act; ! 52: ! 53: ipt_lock(ipt); ! 54: while ((act = ipt->ipt_acts) == 0) { ! 55: /* XXX mp unsafe */ ! 56: ipt->ipt_waiting = 1; ! 57: ipt_unlock(ipt); ! 58: thread_wait((int)&ipt->ipt_acts, FALSE); ! 59: ipt_lock(ipt); ! 60: } ! 61: ipt->ipt_acts = act->ipt_next; ! 62: ipt_unlock(ipt); ! 63: ! 64: return act; ! 65: } ! 66: ! 67: void ! 68: ipc_target_wakeup(struct ipc_target *ipt) ! 69: { ! 70: ipt_lock(ipt); ! 71: if (ipt->ipt_waiting) { ! 72: thread_wakeup((int)&ipt->ipt_acts); ! 73: ipt->ipt_waiting = 0; ! 74: } ! 75: ipt_unlock(ipt); ! 76: } ! 77: #endif /* MIGRATING_THREADS */ ! 78:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.