DiskArbitration.h   [plain text]


/*
 * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
 *
 * @APPLE_LICENSE_HEADER_START@
 *
 * "Portions Copyright (c) 1999 Apple Computer, Inc.  All Rights
 * Reserved.  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 1.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.apple.com/publicsource 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 OR NON-INFRINGEMENT.  Please see the
 * License for the specific language governing rights and limitations
 * under the License."
 *
 * @APPLE_LICENSE_HEADER_END@
 */

/* DiskArbitration.h */

#ifndef __DISKARBITRATION_H
#define __DISKARBITRATION_H


#include <DiskArbitration/DiskArbitrationPublicAPI.h>
#include <DiskArbitration/DiskArbitrationTypes.h>

#include <mach/mach.h>

#if __cplusplus
extern          "C" {
#endif



/*
-- Callback registration
*/

//PRIVATE CALLBACKS - NOT PUBLISHED
// All of these callbacks eventually call DiskArbAddCallbackHandler with overwrite = 1

/* This callback is only invoked if the disk is mounted */

typedef int (*DiskArbCallback_DiskAppearedWithMountpoint_t) (
                                DiskArbDiskIdentifier diskIdentifier,
                                                        unsigned flags,
                                        DiskArbMountpoint mountpoint);

void            DiskArbRegisterCallback_DiskAppearedWithMountpoint(DiskArbCallback_DiskAppearedWithMountpoint_t callback);

/* This callback is only invoked if the disk is not mounted */

typedef int     (*DiskArbCallback_DiskAppearedWithoutMountpoint_t) (
                                DiskArbDiskIdentifier diskIdentifier,
                                                    unsigned flags);

void            DiskArbRegisterCallback_DiskAppearedWithoutMountpoint(DiskArbCallback_DiskAppearedWithoutMountpoint_t callback);


/* Obsoleted by: DiskArbCallback_DiskAppeared2_t */

typedef int     (*DiskArbCallback_DiskAppeared_t) (
                                DiskArbDiskIdentifier diskIdentifier,
                                                        unsigned flags,
                                        DiskArbMountpoint mountpoint,
                                        DiskArbIOContent ioContent);

/* Obsoleted by: DiskArbRegisterCallback_DiskAppeared2 */

void            DiskArbRegisterCallback_DiskAppeared(DiskArbCallback_DiskAppeared_t callback);

void            DiskArbRegisterCallback_DiskAppeared2(DiskArbCallback_DiskAppeared2_t callback);

/*
    * Obsoleted by: DiskArbCallback_UnmountPreNotification_t +
    * DiskArbCallback_UnmountPostNotification_t
    */

typedef int     (*DiskArbCallback_UnmountNotification_t) (
                                DiskArbDiskIdentifier diskIdentifier,
                                                    int pastOrFuture,
                                                        int willEject);

void            DiskArbRegisterCallback_UnmountNotification(DiskArbCallback_UnmountNotification_t callback);


/*
-- Async unmount + eject
*/
void            DiskArbRegisterCallback_UnmountPreNotification(DiskArbCallback_UnmountPreNotification_t callback);
void            DiskArbRegisterCallback_UnmountPostNotification(DiskArbCallback_UnmountPostNotification_t callback);
void            DiskArbRegisterCallback_EjectPreNotification(DiskArbCallback_EjectPreNotification_t callback);
void            DiskArbRegisterCallback_EjectPostNotification(DiskArbCallback_EjectPostNotification_t callback);


void            DiskArbRegisterCallback_ClientDisconnectedNotification(DiskArbCallback_ClientDisconnectedNotification_t callback);

/*
-- Blue Box boot volume
*/


typedef void    (*DiskArbCallback_BlueBoxBootVolumeUpdated_t) (
                                                            int seqno);

void            DiskArbRegisterCallback_BlueBoxBootVolumeUpdated(DiskArbCallback_BlueBoxBootVolumeUpdated_t callback);

void            DiskArbRegisterCallback_DiskChangedNotification(DiskArbCallback_DiskChangedNotification_t callback);
void            DiskArbRegisterCallback_DiskWillBeCheckedNotification(DiskArbCallback_DiskWillBeCheckedNotification_t callback);
void            DiskArbRegisterCallback_CallFailedNotification(DiskArbCallback_CallFailedNotification_t callback);
void            DiskArbRegisterCallback_CallSucceededNotification(DiskArbCallback_CallSucceededNotification_t callback);
void            DiskArbRegisterCallback_NotificationComplete(DiskArbCallback_NotificationComplete_t callback);

/*
-- Unknown File System Insertion
*/

typedef void    (*DiskArbCallback_UnknownFileSystemNotification_t) (DiskArbDiskIdentifier diskIdentifier,
                                                        char *fsType,
                                                    char *deviceType,
                                                        int isWritable,
                                                    int isRemovable,
                                                        int isWhole);

void            DiskArbRegisterCallback_UnknownFileSystemNotification(DiskArbCallback_UnknownFileSystemNotification_t callback);

/*
-- Server -> Client
*/


boolean_t       DiskArbHandleMsg(
                                        mach_msg_header_t * InHeadP,
                                        mach_msg_header_t * OutHeadP);


/*
-- Client -> Server
*/


kern_return_t   DiskArbRegister(
                                                mach_port_t server,
                                                mach_port_t client,
                                                unsigned flags);

kern_return_t   DiskArbRegisterWithPID(
                                                    mach_port_t server,
                                                    mach_port_t client,
                                                    unsigned flags);

kern_return_t   DiskArbDeregister(
                                                    mach_port_t server,
                                                mach_port_t client);

kern_return_t   DiskArbDiskAppearedWithMountpointPing(
                                                    mach_port_t server,
                                DiskArbDiskIdentifier diskIdentifier,
                                                        unsigned flags,
                                        DiskArbMountpoint mountpoint);

kern_return_t   DiskArbDiskDisappearedPing(
                                                    mach_port_t server,
                                DiskArbDiskIdentifier diskIdentifier,
                                                    unsigned flags);

kern_return_t   DiskArbRequestMount(
                                                    mach_port_t server,
                                DiskArbDiskIdentifier diskIdentifier);

kern_return_t   DiskArbRequestMountAndOwn(
                                                    mach_port_t server,
                                DiskArbDiskIdentifier diskIdentifier);

kern_return_t   DiskArbRefresh(
                                                mach_port_t server);

/*
-- "automagic" versions of Client -> Server
*/


kern_return_t   DiskArbRegister_auto(
                                                    mach_port_t client,
                                                        unsigned flags);

kern_return_t   DiskArbDeregister_auto(
                                                mach_port_t client);

kern_return_t   DiskArbRegisterWithPID_auto(
                                                    mach_port_t client,
                                                    unsigned flags);

kern_return_t   DiskArbUpdateClientWithPID_auto(
                                                    unsigned flags);


kern_return_t   DiskArbDeregisterWithPID_auto(
                                                mach_port_t client);


kern_return_t   DiskArbMarkPIDNew_auto(
                                                    mach_port_t client,
                                                    unsigned flags);

kern_return_t   DiskArbDiskAppearedWithMountpointPing_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                        unsigned flags,
                                        DiskArbMountpoint mountpoint);

kern_return_t   DiskArbDiskDisappearedPing_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                    unsigned flags);

kern_return_t   DiskArbRequestMount_auto(
                                DiskArbDiskIdentifier diskIdentifier);

kern_return_t   DiskArbRequestMountAndOwn_auto(
                                DiskArbDiskIdentifier diskIdentifier);


kern_return_t   DiskArbRefresh_auto();



/*
    * -- DiskArbStart()               -- Before calling this, register
    * any desired callbacks. -- Output is a receive right for a port.  A
    * send right for that port has been passed via -- a message to the
    * server.  Messages from the server to this client will be sent on
    * that -- port and should be handled via the public routine
    * DiskArbHandleMsg(). -- Also returns an error code.
    */


kern_return_t   DiskArbStart(mach_port_t * portPtr);

/*
    * -- DiskArbInit()               -- Clients that don't register any
    * callbacks should call DiskArbInit() instead of DiskArbStart(). --
    * Returns an error code.
    */


kern_return_t   DiskArbInit(void);

/*
-- Async unmount + eject
*/


kern_return_t   DiskArbUnmountRequest_async_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                    unsigned flags);

kern_return_t   DiskArbUnmountPreNotifyAck_async_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                        int errorCode);

kern_return_t   DiskArbEjectRequest_async_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                    unsigned flags);

kern_return_t   DiskArbEjectPreNotifyAck_async_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                        int errorCode);

kern_return_t   DiskArbUnmountAndEjectRequest_async_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                                    unsigned flags);

/*
-- Async Helper
*/


/*
    * DiskArbMsgLoop() == DiskArbMsgLoopWithTimeout(
    * MACH_MSG_TIMEOUT_NONE )
    */

kern_return_t   DiskArbMsgLoop(void);

/*
    * Caller should be ready to handle a MACH_RCV_TIMED_OUT return
    * value.
    */

kern_return_t   DiskArbMsgLoopWithTimeout(mach_msg_timeout_t timeout);


/*
-- Blue Box boot volume
*/


/*
    * Sets the kDiskArbIAmBlueBox flag on the corresponding client
    * record.
    */

kern_return_t   DiskArbSetBlueBoxBootVolume_async_auto(
                                                            int pid,
                                                            int seqno);

/*
-- Request Disk Update
*/

kern_return_t   DiskArbRequestDiskChange_auto(
                                DiskArbDiskIdentifier diskIdentifier,
                                    DiskArbGenericString mountPoint,
                                                            int flags);

/*
-- Change the currently logged in user, pass kDiskArbNoUser (-1) to signify no user logged in to console
*/

kern_return_t   DiskArbSetCurrentUser_auto(int user);

/*
-- VSDB functionality - these calls update the status of the vsdb database.
-- A device that is "owned" has it's permissions observed
-- A device that is not owned has it's permissions ignored
-- This is only functional against HFS(-+) filesystems
*/

kern_return_t   DiskArbVSDBAdoptVolume_auto(DiskArbDiskIdentifier diskIdentifier);
kern_return_t   DiskArbVSDBDisownVolume_auto(DiskArbDiskIdentifier diskIdentifier);

                //blocking routine, use sparingly
int             DiskArbVSDBGetVolumeStatus_auto(DiskArbDiskIdentifier diskIdentifier);


/*
    * -- HFS Volume Encoding -- the encodings that are allowed are part
    * of the HFS filesystem specification
    */

kern_return_t   DiskArbSetVolumeEncoding_auto(DiskArbDiskIdentifier diskIdentifier, int VolumeEncoding);

                //blocking routine, use sparingly
int             DiskArbGetVolumeEncoding_auto(DiskArbDiskIdentifier diskIdentifier);

/*
    -- No Op - specifically allows the Carbon framework to load disk arb earlier in process
    */

void            DiskArbNoOp();

/*
-- Uninitialized Disk Handler
*/


/*
    * Sets/unsets the kDiskArbClientHandlesUninitializedDisks flag on
    * the corresponding client record. Pass 1 or 0 as the flag.
    */

kern_return_t   DiskArbClientHandlesUninitializedDisks_auto(
                                                            int flag);

/*
    * Sets the security token for an application if the token has not
    * been passed before
    */

void            SetSecure(void);

#if __cplusplus
}
#endif

#endif