+++ /dev/null
-/*
- * Copyright (c) 2001-2002,2004 Apple Computer, Inc. All Rights Reserved.
- *
- * @APPLE_LICENSE_HEADER_START@
- *
- * This file contains Original Code and/or Modifications of Original Code
- * as defined in and that are subject to the Apple Public Source License
- * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
- *
- * The Original Code and all software distributed under the License are
- * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
- * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
- * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
- * Please see the License for the specific language governing rights and
- * limitations under the License.
- *
- * @APPLE_LICENSE_HEADER_END@
- */
-/*
- * IDENTIFICATION:
- * stub generated Fri Mar 1 18:02:22 2002
- * with a MiG generated Thu Feb 21 15:16:47 PST 2002 by root@blur
- * OPTIONS:
- */
-
-/* Module notify */
-
-#include <string.h>
-#include <mach/ndr.h>
-#include <mach/boolean.h>
-#include <mach/kern_return.h>
-#include <mach/notify.h>
-#include <mach/mach_types.h>
-#include <mach/message.h>
-#include <mach/mig_errors.h>
-#include <mach/port.h>
-
-#include <mach/std_types.h>
-#include <mach/mig.h>
-
-#ifndef mig_internal
-#define mig_internal static
-#endif /* mig_internal */
-
-#ifndef mig_external
-#define mig_external
-#endif /* mig_external */
-
-#ifndef TypeCheck
-#define TypeCheck 0
-#endif /* TypeCheck */
-
-#ifndef LimitCheck
-#define LimitCheck 0
-#endif /* LimitCheck */
-
-#ifndef min
-#define min(a,b) ( ((a) < (b))? (a): (b) )
-#endif /* min */
-
-#ifndef UseStaticTemplates
-#define UseStaticTemplates 1
-#endif /* UseStaticTemplates */
-
-#define _WALIGN_(x) (((x) + 3) & ~3)
-#define _WALIGNSZ_(x) _WALIGN_(sizeof(x))
-#ifndef __DeclareRcvRpc
-#define __DeclareRcvRpc(_NUM_, _NAME_)
-#endif /* __DeclareRcvRpc */
-
-#ifndef __BeforeRcvRpc
-#define __BeforeRcvRpc(_NUM_, _NAME_)
-#endif /* __BeforeRcvRpc */
-
-#ifndef __AfterRcvRpc
-#define __AfterRcvRpc(_NUM_, _NAME_)
-#endif /* __AfterRcvRpc */
-
-#ifndef __DeclareRcvSimple
-#define __DeclareRcvSimple(_NUM_, _NAME_)
-#endif /* __DeclareRcvSimple */
-
-#ifndef __BeforeRcvSimple
-#define __BeforeRcvSimple(_NUM_, _NAME_)
-#endif /* __BeforeRcvSimple */
-
-#ifndef __AfterRcvSimple
-#define __AfterRcvSimple(_NUM_, _NAME_)
-#endif /* __AfterRcvSimple */
-
-#define novalue void
-
-#define msgh_request_port msgh_local_port
-#define MACH_MSGH_BITS_REQUEST(bits) MACH_MSGH_BITS_LOCAL(bits)
-#define msgh_reply_port msgh_remote_port
-#define MACH_MSGH_BITS_REPLY(bits) MACH_MSGH_BITS_REMOTE(bits)
-
-#define MIG_RETURN_ERROR(X, code) {\
- ((mig_reply_error_t *)X)->RetCode = code;\
- ((mig_reply_error_t *)X)->NDR = NDR_record;\
- return;\
- }
-
-/* typedefs for all requests */
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- mach_port_name_t name;
- } __Request__mach_notify_port_deleted_t;
-
- typedef struct {
- mach_msg_header_t Head;
- /* start of the kernel processed data */
- mach_msg_body_t msgh_body;
- mach_msg_port_descriptor_t rights;
- /* end of the kernel processed data */
- } __Request__mach_notify_port_destroyed_t;
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- mach_port_mscount_t mscount;
- } __Request__mach_notify_no_senders_t;
-
- typedef struct {
- mach_msg_header_t Head;
- } __Request__mach_notify_send_once_t;
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- mach_port_name_t name;
- } __Request__mach_notify_dead_name_t;
-
-
-/* typedefs for all replies */
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- kern_return_t RetCode;
- } __Reply__mach_notify_port_deleted_t;
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- kern_return_t RetCode;
- } __Reply__mach_notify_port_destroyed_t;
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- kern_return_t RetCode;
- } __Reply__mach_notify_no_senders_t;
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- kern_return_t RetCode;
- } __Reply__mach_notify_send_once_t;
-
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- kern_return_t RetCode;
- } __Reply__mach_notify_dead_name_t;
-
-
-/* Forward Declarations */
-
-
-mig_internal novalue _Xmach_notify_port_deleted
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP);
-
-mig_internal novalue _Xmach_notify_port_destroyed
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP);
-
-mig_internal novalue _Xmach_notify_no_senders
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP);
-
-mig_internal novalue _Xmach_notify_send_once
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP);
-
-mig_internal novalue _Xmach_notify_dead_name
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP);
-
-
-/* SimpleRoutine mach_notify_port_deleted */
-#ifdef mig_external
-mig_external
-#else
-extern
-#endif /* mig_external */
-kern_return_t cdsa_mach_notify_port_deleted
-(
- mach_port_t notify,
- mach_port_name_t name
-);
-
-/* SimpleRoutine mach_notify_port_deleted */
-mig_internal novalue _Xmach_notify_port_deleted
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP)
-{
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- mach_port_name_t name;
- mach_msg_trailer_t trailer;
- } Request;
-
- typedef __Request__mach_notify_port_deleted_t __Request;
-
- typedef __Reply__mach_notify_port_deleted_t Reply;
- /*
- * typedef struct {
- * mach_msg_header_t Head;
- * NDR_record_t NDR;
- * kern_return_t RetCode;
- * } mig_reply_error_t;
- */
-
- register Request *In0P = (Request *) InHeadP;
- register Reply *OutP = (Reply *) OutHeadP;
- __DeclareRcvSimple(65, "mach_notify_port_deleted")
- __BeforeRcvSimple(65, "mach_notify_port_deleted")
-#if TypeCheck
- if ((In0P->Head.msgh_bits & MACH_MSGH_BITS_COMPLEX) ||
- (In0P->Head.msgh_size != sizeof(__Request)))
- { MIG_RETURN_ERROR(OutP, MIG_BAD_ARGUMENTS); }
-#endif /* TypeCheck */
-
- OutP->RetCode = cdsa_mach_notify_port_deleted(In0P->Head.msgh_request_port, In0P->name);
- __AfterRcvSimple(65, "mach_notify_port_deleted")
-}
-
-/* SimpleRoutine mach_notify_port_destroyed */
-#ifdef mig_external
-mig_external
-#else
-extern
-#endif /* mig_external */
-kern_return_t cdsa_mach_notify_port_destroyed
-(
- mach_port_t notify,
- mach_port_t rights
-);
-
-/* SimpleRoutine mach_notify_port_destroyed */
-mig_internal novalue _Xmach_notify_port_destroyed
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP)
-{
- typedef struct {
- mach_msg_header_t Head;
- /* start of the kernel processed data */
- mach_msg_body_t msgh_body;
- mach_msg_port_descriptor_t rights;
- /* end of the kernel processed data */
- mach_msg_trailer_t trailer;
- } Request;
-
- typedef __Request__mach_notify_port_destroyed_t __Request;
-
- typedef __Reply__mach_notify_port_destroyed_t Reply;
- /*
- * typedef struct {
- * mach_msg_header_t Head;
- * NDR_record_t NDR;
- * kern_return_t RetCode;
- * } mig_reply_error_t;
- */
-
- register Request *In0P = (Request *) InHeadP;
- register Reply *OutP = (Reply *) OutHeadP;
- __DeclareRcvSimple(69, "mach_notify_port_destroyed")
- __BeforeRcvSimple(69, "mach_notify_port_destroyed")
-#if TypeCheck
- if (!(In0P->Head.msgh_bits & MACH_MSGH_BITS_COMPLEX) ||
- (In0P->msgh_body.msgh_descriptor_count != 1) ||
- (In0P->Head.msgh_size != sizeof(__Request)))
- { MIG_RETURN_ERROR(OutP, MIG_BAD_ARGUMENTS); }
-#endif /* TypeCheck */
-
-#if TypeCheck
- if (In0P->rights.type != MACH_MSG_PORT_DESCRIPTOR ||
- In0P->rights.disposition != MACH_MSG_TYPE_MOVE_RECEIVE)
- { MIG_RETURN_ERROR(OutP, MIG_TYPE_ERROR); }
-#endif /* TypeCheck */
-
- OutP->RetCode = cdsa_mach_notify_port_destroyed(In0P->Head.msgh_request_port, In0P->rights.name);
- __AfterRcvSimple(69, "mach_notify_port_destroyed")
-}
-
-/* SimpleRoutine mach_notify_no_senders */
-#ifdef mig_external
-mig_external
-#else
-extern
-#endif /* mig_external */
-kern_return_t cdsa_mach_notify_no_senders
-(
- mach_port_t notify,
- mach_port_mscount_t mscount
-);
-
-/* SimpleRoutine mach_notify_no_senders */
-mig_internal novalue _Xmach_notify_no_senders
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP)
-{
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- mach_port_mscount_t mscount;
- mach_msg_trailer_t trailer;
- } Request;
-
- typedef __Request__mach_notify_no_senders_t __Request;
-
- typedef __Reply__mach_notify_no_senders_t Reply;
- /*
- * typedef struct {
- * mach_msg_header_t Head;
- * NDR_record_t NDR;
- * kern_return_t RetCode;
- * } mig_reply_error_t;
- */
-
- register Request *In0P = (Request *) InHeadP;
- register Reply *OutP = (Reply *) OutHeadP;
- __DeclareRcvSimple(70, "mach_notify_no_senders")
- __BeforeRcvSimple(70, "mach_notify_no_senders")
-#if TypeCheck
- if ((In0P->Head.msgh_bits & MACH_MSGH_BITS_COMPLEX) ||
- (In0P->Head.msgh_size != sizeof(__Request)))
- { MIG_RETURN_ERROR(OutP, MIG_BAD_ARGUMENTS); }
-#endif /* TypeCheck */
-
- OutP->RetCode = cdsa_mach_notify_no_senders(In0P->Head.msgh_request_port, In0P->mscount);
- __AfterRcvSimple(70, "mach_notify_no_senders")
-}
-
-/* SimpleRoutine mach_notify_send_once */
-#ifdef mig_external
-mig_external
-#else
-extern
-#endif /* mig_external */
-kern_return_t cdsa_mach_notify_send_once
-(
- mach_port_t notify
-);
-
-/* SimpleRoutine mach_notify_send_once */
-mig_internal novalue _Xmach_notify_send_once
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP)
-{
- typedef struct {
- mach_msg_header_t Head;
- mach_msg_trailer_t trailer;
- } Request;
-
- typedef __Request__mach_notify_send_once_t __Request;
-
- typedef __Reply__mach_notify_send_once_t Reply;
- /*
- * typedef struct {
- * mach_msg_header_t Head;
- * NDR_record_t NDR;
- * kern_return_t RetCode;
- * } mig_reply_error_t;
- */
-
- register Request *In0P = (Request *) InHeadP;
- register Reply *OutP = (Reply *) OutHeadP;
- __DeclareRcvSimple(71, "mach_notify_send_once")
- __BeforeRcvSimple(71, "mach_notify_send_once")
-#if TypeCheck
- if ((In0P->Head.msgh_bits & MACH_MSGH_BITS_COMPLEX) ||
- (In0P->Head.msgh_size != sizeof(__Request)))
- { MIG_RETURN_ERROR(OutP, MIG_BAD_ARGUMENTS); }
-#endif /* TypeCheck */
-
- OutP->RetCode = cdsa_mach_notify_send_once(In0P->Head.msgh_request_port);
- __AfterRcvSimple(71, "mach_notify_send_once")
-}
-
-/* SimpleRoutine mach_notify_dead_name */
-#ifdef mig_external
-mig_external
-#else
-extern
-#endif /* mig_external */
-kern_return_t cdsa_mach_notify_dead_name
-(
- mach_port_t notify,
- mach_port_name_t name
-);
-
-/* SimpleRoutine mach_notify_dead_name */
-mig_internal novalue _Xmach_notify_dead_name
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP)
-{
- typedef struct {
- mach_msg_header_t Head;
- NDR_record_t NDR;
- mach_port_name_t name;
- mach_msg_trailer_t trailer;
- } Request;
-
- typedef __Request__mach_notify_dead_name_t __Request;
-
- typedef __Reply__mach_notify_dead_name_t Reply;
- /*
- * typedef struct {
- * mach_msg_header_t Head;
- * NDR_record_t NDR;
- * kern_return_t RetCode;
- * } mig_reply_error_t;
- */
-
- register Request *In0P = (Request *) InHeadP;
- register Reply *OutP = (Reply *) OutHeadP;
- __DeclareRcvSimple(72, "mach_notify_dead_name")
- __BeforeRcvSimple(72, "mach_notify_dead_name")
-#if TypeCheck
- if ((In0P->Head.msgh_bits & MACH_MSGH_BITS_COMPLEX) ||
- (In0P->Head.msgh_size != sizeof(__Request)))
- { MIG_RETURN_ERROR(OutP, MIG_BAD_ARGUMENTS); }
-#endif /* TypeCheck */
-
- OutP->RetCode = cdsa_mach_notify_dead_name(In0P->Head.msgh_request_port, In0P->name);
- __AfterRcvSimple(72, "mach_notify_dead_name")
-}
-
-/* union of all requests */
-
-union __RequestUnion__cdsa_notify_subsystem {
- __Request__mach_notify_port_deleted_t Request_mach_notify_port_deleted;
- __Request__mach_notify_port_destroyed_t Request_mach_notify_port_destroyed;
- __Request__mach_notify_no_senders_t Request_mach_notify_no_senders;
- __Request__mach_notify_send_once_t Request_mach_notify_send_once;
- __Request__mach_notify_dead_name_t Request_mach_notify_dead_name;
-};
-
-/* union of all replies */
-
-union __ReplyUnion__cdsa_notify_subsystem {
- __Reply__mach_notify_port_deleted_t Reply_mach_notify_port_deleted;
- __Reply__mach_notify_port_destroyed_t Reply_mach_notify_port_destroyed;
- __Reply__mach_notify_no_senders_t Reply_mach_notify_no_senders;
- __Reply__mach_notify_send_once_t Reply_mach_notify_send_once;
- __Reply__mach_notify_dead_name_t Reply_mach_notify_dead_name;
-};
-
-
-extern boolean_t cdsa_notify_server(
- mach_msg_header_t *InHeadP,
- mach_msg_header_t *OutHeadP);
-
-extern mig_routine_t notify_server_routine(
- mach_msg_header_t *InHeadP);
-
-
-/* Description of this subsystem, for use in direct RPC */
-const struct cdsa_notify_subsystem {
- mig_server_routine_t server; /* Server routine */
- mach_msg_id_t start; /* Min routine number */
- mach_msg_id_t end; /* Max routine number + 1 */
- unsigned int maxsize; /* Max msg size */
- vm_address_t reserved; /* Reserved */
- struct routine_descriptor /*Array of routine descriptors */
- routine[9];
-} cdsa_notify_subsystem = {
- notify_server_routine,
- 64,
- 73,
- sizeof(union __ReplyUnion__cdsa_notify_subsystem),
- (vm_address_t)0,
- {
- {0, 0, 0, 0, 0, 0},
- { (mig_impl_routine_t) 0,
- (mig_stub_routine_t) _Xmach_notify_port_deleted, 2, 0, (routine_arg_descriptor_t)0, sizeof(__Reply__mach_notify_port_deleted_t)},
- {0, 0, 0, 0, 0, 0},
- {0, 0, 0, 0, 0, 0},
- {0, 0, 0, 0, 0, 0},
- { (mig_impl_routine_t) 0,
- (mig_stub_routine_t) _Xmach_notify_port_destroyed, 2, 0, (routine_arg_descriptor_t)0, sizeof(__Reply__mach_notify_port_destroyed_t)},
- { (mig_impl_routine_t) 0,
- (mig_stub_routine_t) _Xmach_notify_no_senders, 2, 0, (routine_arg_descriptor_t)0, sizeof(__Reply__mach_notify_no_senders_t)},
- { (mig_impl_routine_t) 0,
- (mig_stub_routine_t) _Xmach_notify_send_once, 1, 0, (routine_arg_descriptor_t)0, sizeof(__Reply__mach_notify_send_once_t)},
- { (mig_impl_routine_t) 0,
- (mig_stub_routine_t) _Xmach_notify_dead_name, 2, 0, (routine_arg_descriptor_t)0, sizeof(__Reply__mach_notify_dead_name_t)},
- }
-};
-
-mig_external boolean_t cdsa_notify_server
- (mach_msg_header_t *InHeadP, mach_msg_header_t *OutHeadP)
-{
- /*
- * typedef struct {
- * mach_msg_header_t Head;
- * NDR_record_t NDR;
- * kern_return_t RetCode;
- * } mig_reply_error_t;
- */
-
- register mig_routine_t routine;
-
- OutHeadP->msgh_bits = MACH_MSGH_BITS(MACH_MSGH_BITS_REPLY(InHeadP->msgh_bits), 0);
- OutHeadP->msgh_remote_port = InHeadP->msgh_reply_port;
- /* Minimal size: routine() will update it if different */
- OutHeadP->msgh_size = sizeof(mig_reply_error_t);
- OutHeadP->msgh_local_port = MACH_PORT_NULL;
- OutHeadP->msgh_id = InHeadP->msgh_id + 100;
-
- if ((InHeadP->msgh_id > 72) || (InHeadP->msgh_id < 64) ||
- ((routine = cdsa_notify_subsystem.routine[InHeadP->msgh_id - 64].stub_routine) == 0)) {
- ((mig_reply_error_t *)OutHeadP)->NDR = NDR_record;
- ((mig_reply_error_t *)OutHeadP)->RetCode = MIG_BAD_ID;
- return FALSE;
- }
- (*routine) (InHeadP, OutHeadP);
- return TRUE;
-}
-
-mig_external mig_routine_t notify_server_routine
- (mach_msg_header_t *InHeadP)
-{
- register int msgh_id;
-
- msgh_id = InHeadP->msgh_id - 64;
-
- if ((msgh_id > 8) || (msgh_id < 0))
- return 0;
-
- return cdsa_notify_subsystem.routine[msgh_id].stub_routine;
-}