/* $Copyright: * * Copyright 2004-2006 by the Massachusetts Institute of Technology. * * All rights reserved. * * Export of this software from the United States of America may require a * specific license from the United States Government. It is the * responsibility of any person or organization contemplating export to * obtain such a license before exporting. * * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and distribute * this software and its documentation for any purpose and without fee is * hereby granted, provided that the above copyright notice appear in all * copies and that both that copyright notice and this permission notice * appear in supporting documentation, and that the name of M.I.T. not be * used in advertising or publicity pertaining to distribution of the * software without specific, written prior permission. Furthermore if you * modify this software you must label your software as modified software * and not distribute it in such a fashion that it might be confused with * the original MIT software. M.I.T. makes no representations about the * suitability of this software for any purpose. It is provided "as is" * without express or implied warranty. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF * MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. * * Individual source code files are copyright MIT, Cygnus Support, * OpenVision, Oracle, Sun Soft, FundsXpress, and others. * * Project Athena, Athena, Athena MUSE, Discuss, Hesiod, Kerberos, Moira, * and Zephyr are trademarks of the Massachusetts Institute of Technology * (MIT). No commercial use of these trademarks may be made without prior * written permission of MIT. * * "Commercial use" means use of a name in a product or other for-profit * manner. It does NOT prevent a commercial firm from referring to the MIT * trademarks in order to convey information (although in doing so, * recognition of their trademark status should be given). * $ */ #include <mach/std_types.defs> #include <mach/mach_types.defs> import "cci_mig_types.h"; subsystem ccapi 128; /* Note the 1024 must be the same as kCCAPIMaxILMsgSize */ type cci_mipc_inl_request_t = array [ * : 1024 ] of char; type cci_mipc_ool_request_t = array [] of char; type cci_mipc_inl_reply_t = array [ * : 1024 ] of char; type cci_mipc_ool_reply_t = array [] of char; serverprefix ccs_mipc_; userprefix cci_mipc_; routine create_client_connection (in_server_port : mach_port_t; out out_connection_port : mach_port_t = MACH_MSG_TYPE_MAKE_SEND); /* ",dealloc" means that the vm_read() memory will be moved to * the other process rather than copied. This is necessary on the * server side because we can't know when mach has copied our * buffers so we can't vm_deallocate() then ourselves. We also * use ",dealloc" on the client because it is more efficient to * let mach do the work. */ routine handle_message (in_connection_port : mach_port_t; in_inl_request : cci_mipc_inl_request_t; in_ool_request : cci_mipc_ool_request_t, dealloc; out out_inl_reply : cci_mipc_inl_reply_t; out out_ool_reply : cci_mipc_ool_reply_t, dealloc);