]>
Commit | Line | Data |
---|---|---|
1c79356b | 1 | /* |
55e303ae | 2 | * Copyright (c) 2000-2003 Apple Computer, Inc. All rights reserved. |
1c79356b A |
3 | * |
4 | * @APPLE_LICENSE_HEADER_START@ | |
5 | * | |
43866e37 | 6 | * Copyright (c) 1999-2003 Apple Computer, Inc. All Rights Reserved. |
1c79356b | 7 | * |
43866e37 A |
8 | * This file contains Original Code and/or Modifications of Original Code |
9 | * as defined in and that are subject to the Apple Public Source License | |
10 | * Version 2.0 (the 'License'). You may not use this file except in | |
11 | * compliance with the License. Please obtain a copy of the License at | |
12 | * http://www.opensource.apple.com/apsl/ and read it before using this | |
13 | * file. | |
14 | * | |
15 | * The Original Code and all software distributed under the License are | |
16 | * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER | |
1c79356b A |
17 | * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, |
18 | * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, | |
43866e37 A |
19 | * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. |
20 | * Please see the License for the specific language governing rights and | |
21 | * limitations under the License. | |
1c79356b A |
22 | * |
23 | * @APPLE_LICENSE_HEADER_END@ | |
24 | */ | |
25 | /* | |
26 | * @OSF_COPYRIGHT@ | |
27 | */ | |
28 | /* | |
29 | * Mach Operating System | |
30 | * Copyright (c) 1991,1990,1989 Carnegie Mellon University | |
31 | * All Rights Reserved. | |
32 | * | |
33 | * Permission to use, copy, modify and distribute this software and its | |
34 | * documentation is hereby granted, provided that both the copyright | |
35 | * notice and this permission notice appear in all copies of the | |
36 | * software, derivative works or modified versions, and any portions | |
37 | * thereof, and that both notices appear in supporting documentation. | |
38 | * | |
39 | * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" | |
40 | * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR | |
41 | * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. | |
42 | * | |
43 | * Carnegie Mellon requests users of this software to return to | |
44 | * | |
45 | * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU | |
46 | * School of Computer Science | |
47 | * Carnegie Mellon University | |
48 | * Pittsburgh PA 15213-3890 | |
49 | * | |
50 | * any improvements or extensions that they make and grant Carnegie Mellon | |
51 | * the rights to redistribute these changes. | |
52 | */ | |
53 | /* | |
54 | */ | |
55 | /* | |
56 | * File: ipc/ipc_notify.c | |
57 | * Author: Rich Draves | |
58 | * Date: 1989 | |
59 | * | |
60 | * Notification-sending functions. | |
61 | */ | |
62 | ||
1c79356b A |
63 | #include <mach/port.h> |
64 | #include <mach/message.h> | |
55e303ae | 65 | #include <mach/mach_notify.h> |
1c79356b | 66 | #include <kern/misc_protos.h> |
1c79356b A |
67 | #include <ipc/ipc_notify.h> |
68 | #include <ipc/ipc_port.h> | |
69 | ||
1c79356b A |
70 | /* |
71 | * Routine: ipc_notify_port_deleted | |
72 | * Purpose: | |
73 | * Send a port-deleted notification. | |
74 | * Conditions: | |
75 | * Nothing locked. | |
76 | * Consumes a ref/soright for port. | |
77 | */ | |
78 | ||
79 | void | |
80 | ipc_notify_port_deleted( | |
81 | ipc_port_t port, | |
82 | mach_port_name_t name) | |
83 | { | |
55e303ae | 84 | kern_return_t kr; |
1c79356b | 85 | |
55e303ae A |
86 | kr = mach_notify_port_deleted(port, name); |
87 | if (kr != KERN_SUCCESS) { | |
1c79356b A |
88 | printf("dropped port-deleted (0x%08x, 0x%x)\n", port, name); |
89 | ipc_port_release_sonce(port); | |
1c79356b | 90 | } |
1c79356b A |
91 | } |
92 | ||
93 | /* | |
94 | * Routine: ipc_notify_port_destroyed | |
95 | * Purpose: | |
96 | * Send a port-destroyed notification. | |
97 | * Conditions: | |
98 | * Nothing locked. | |
99 | * Consumes a ref/soright for port. | |
100 | * Consumes a ref for right, which should be a receive right | |
101 | * prepped for placement into a message. (In-transit, | |
102 | * or in-limbo if a circularity was detected.) | |
103 | */ | |
104 | ||
105 | void | |
106 | ipc_notify_port_destroyed( | |
107 | ipc_port_t port, | |
108 | ipc_port_t right) | |
109 | { | |
55e303ae | 110 | kern_return_t kr; |
1c79356b | 111 | |
55e303ae A |
112 | kr = mach_notify_port_destroyed(port, right); |
113 | if (kr != KERN_SUCCESS) { | |
1c79356b A |
114 | printf("dropped port-destroyed (0x%08x, 0x%08x)\n", |
115 | port, right); | |
116 | ipc_port_release_sonce(port); | |
117 | ipc_port_release_receive(right); | |
1c79356b | 118 | } |
1c79356b A |
119 | } |
120 | ||
121 | /* | |
122 | * Routine: ipc_notify_no_senders | |
123 | * Purpose: | |
124 | * Send a no-senders notification. | |
125 | * Conditions: | |
126 | * Nothing locked. | |
127 | * Consumes a ref/soright for port. | |
128 | */ | |
129 | ||
130 | void | |
131 | ipc_notify_no_senders( | |
132 | ipc_port_t port, | |
133 | mach_port_mscount_t mscount) | |
134 | { | |
55e303ae | 135 | kern_return_t kr; |
1c79356b | 136 | |
55e303ae A |
137 | kr = mach_notify_no_senders(port, mscount); |
138 | if (kr != KERN_SUCCESS) { | |
1c79356b A |
139 | printf("dropped no-senders (0x%08x, %u)\n", port, mscount); |
140 | ipc_port_release_sonce(port); | |
1c79356b | 141 | } |
1c79356b A |
142 | } |
143 | ||
144 | /* | |
145 | * Routine: ipc_notify_send_once | |
146 | * Purpose: | |
147 | * Send a send-once notification. | |
148 | * Conditions: | |
149 | * Nothing locked. | |
150 | * Consumes a ref/soright for port. | |
151 | */ | |
152 | ||
153 | void | |
154 | ipc_notify_send_once( | |
155 | ipc_port_t port) | |
156 | { | |
55e303ae | 157 | kern_return_t kr; |
1c79356b | 158 | |
55e303ae A |
159 | kr = mach_notify_send_once(port); |
160 | if (kr != KERN_SUCCESS) { | |
1c79356b A |
161 | printf("dropped send-once (0x%08x)\n", port); |
162 | ipc_port_release_sonce(port); | |
1c79356b | 163 | } |
1c79356b A |
164 | } |
165 | ||
166 | /* | |
167 | * Routine: ipc_notify_dead_name | |
168 | * Purpose: | |
169 | * Send a dead-name notification. | |
170 | * Conditions: | |
171 | * Nothing locked. | |
172 | * Consumes a ref/soright for port. | |
173 | */ | |
174 | ||
175 | void | |
176 | ipc_notify_dead_name( | |
177 | ipc_port_t port, | |
178 | mach_port_name_t name) | |
179 | { | |
55e303ae | 180 | kern_return_t kr; |
1c79356b | 181 | |
55e303ae A |
182 | kr = mach_notify_dead_name(port, name); |
183 | if (kr != KERN_SUCCESS) { | |
1c79356b A |
184 | printf("dropped dead-name (0x%08x, 0x%x)\n", port, name); |
185 | ipc_port_release_sonce(port); | |
1c79356b | 186 | } |
1c79356b | 187 | } |