topical media & game development
lib-of-vs-libs-QTDevWin-CIncludes-IsochronousDataHandler.h / h
/*
File: IsochronousDataHandler.h
Contains: The defines the client API to an Isochronous Data Handler, which is
Version: Technology: xxx put version here xxx
Release: QuickTime 6.0.2
Copyright: (c) 1997-2001 by Apple Computer, Inc., all rights reserved.
Bugs?: For bug reports, consult the following page on
the World Wide Web:
http://developer.apple.com/bugreporter/
*/
//
// Check for Prior Inclusion of IsochronousDataHandler.r
// If this header is trying to be included via a Rez path, make it act
// as a NOP. This will allow both Rez & C files to get to use the
// contants for the component type, subtype, and interface version.
ifndef __ISOCHRONOUSDATAHANDLER_R__
ifndef __ISOCHRONOUSDATAHANDLER__
define __ISOCHRONOUSDATAHANDLER__
ifndef __MACTYPES__
include <MacTypes.h>
endif
ifndef __MOVIESFORMAT__
include <MoviesFormat.h>
endif
ifndef __QUICKTIMECOMPONENTS__
include <QuickTimeComponents.h>
endif
if PRAGMA_ONCE
#pragma once
endif
ifdef __cplusplus
extern "C" {
endif
if PRAGMA_IMPORT
#pragma import on
endif
if PRAGMA_STRUCT_ALIGN
#pragma options align=mac68k
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(push, 2)
#elif PRAGMA_STRUCT_PACK
#pragma pack(2)
endif
enum {
kIDHComponentType = FOUR_CHAR_CODE('ihlr'), /* Component type*/
kIDHSubtypeDV = FOUR_CHAR_CODE('dv '), /* Subtype for DV (over FireWire)*/
kIDHSubtypeFireWireConference = FOUR_CHAR_CODE('fwc ') /* Subtype for FW Conference*/
};
/* Version of Isochronous Data Handler API*/
enum {
kIDHInterfaceVersion1 = 0x0001 /* Initial relase (Summer '99)*/
};
/* atom types*/
enum {
kIDHDeviceListAtomType = FOUR_CHAR_CODE('dlst'),
kIDHDeviceAtomType = FOUR_CHAR_CODE('devc'), /* to be defined elsewhere*/
kIDHIsochServiceAtomType = FOUR_CHAR_CODE('isoc'),
kIDHIsochModeAtomType = FOUR_CHAR_CODE('mode'),
kIDHDeviceIDType = FOUR_CHAR_CODE('dvid'),
kIDHDefaultIOType = FOUR_CHAR_CODE('dfio'),
kIDHIsochVersionAtomType = FOUR_CHAR_CODE('iver'),
kIDHUniqueIDType = FOUR_CHAR_CODE('unid'),
kIDHNameAtomType = FOUR_CHAR_CODE('name'),
kIDHUseCMPAtomType = FOUR_CHAR_CODE('ucmp'),
kIDHIsochMediaType = FOUR_CHAR_CODE('av '),
kIDHDataTypeAtomType = FOUR_CHAR_CODE('dtyp'),
kIDHDataSizeAtomType = FOUR_CHAR_CODE('dsiz'), /* ??? packet size vs. buffer size*/
kIDHDataBufferSizeAtomType = FOUR_CHAR_CODE('dbuf'), /* ??? packet size vs. buffer size*/
kIDHDataIntervalAtomType = FOUR_CHAR_CODE('intv'),
kIDHDataIODirectionAtomType = FOUR_CHAR_CODE('ddir'),
kIDHSoundMediaAtomType = FOUR_CHAR_CODE('soun'),
kIDHSoundTypeAtomType = FOUR_CHAR_CODE('type'),
kIDHSoundChannelCountAtomType = FOUR_CHAR_CODE('ccnt'),
kIDHSoundSampleSizeAtomType = FOUR_CHAR_CODE('ssiz'),
kIDHSoundSampleRateAtomType = FOUR_CHAR_CODE('srat'), /* same as video out... (what does this comment mean?)*/
kIDHVideoMediaAtomType = FOUR_CHAR_CODE('vide'),
kIDHVideoDimensionsAtomType = FOUR_CHAR_CODE('dimn'),
kIDHVideoResolutionAtomType = FOUR_CHAR_CODE('resl'),
kIDHVideoRefreshRateAtomType = FOUR_CHAR_CODE('refr'),
kIDHVideoPixelTypeAtomType = FOUR_CHAR_CODE('pixl'),
kIDHVideoDecompressorAtomType = FOUR_CHAR_CODE('deco'),
kIDHVideoDecompressorTypeAtomType = FOUR_CHAR_CODE('dety'),
kIDHVideoDecompressorContinuousAtomType = FOUR_CHAR_CODE('cont'),
kIDHVideoDecompressorComponentAtomType = FOUR_CHAR_CODE('cmpt')
};
/* I/O Flags */
enum {
kIDHDataTypeIsInput = 1L << 0,
kIDHDataTypeIsOutput = 1L << 1,
kIDHDataTypeIsInputAndOutput = 1L << 2
};
/* Permission Flags */
enum {
kIDHOpenForReadTransactions = 1L << 0,
kIDHOpenForWriteTransactions = 1L << 1,
kIDHOpenWithExclusiveAccess = 1L << 2,
kIDHOpenWithHeldBuffers = 1L << 3, /* IDH will hold buffer until ReleaseBuffer()*/
kIDHCloseForReadTransactions = 1L << 4,
kIDHCloseForWriteTransactions = 1L << 5
};
/*
Errors
These REALLY need to be moved into Errors.h
ooo.needs officially assigned numbers
*/
enum {
kIDHErrDeviceDisconnected = -14101,
kIDHErrInvalidDeviceID = -14102,
kIDHErrDeviceInUse = -14104,
kIDHErrDeviceNotOpened = -14105,
kIDHErrDeviceBusy = -14106,
kIDHErrDeviceReadError = -14107,
kIDHErrDeviceWriteError = -14108,
kIDHErrDeviceNotConfigured = -14109,
kIDHErrDeviceList = -14110,
kIDHErrCompletionPending = -14111,
kIDHErrDeviceTimeout = -14112,
kIDHErrInvalidIndex = -14113,
kIDHErrDeviceCantRead = -14114,
kIDHErrDeviceCantWrite = -14115,
kIDHErrCallNotSupported = -14116
};
/* Holds Device Identification...*/
typedef UInt32 IDHDeviceID;
enum {
kIDHInvalidDeviceID = 0,
kIDHDeviceIDEveryDevice = (long)0xFFFFFFFF
};
/* Values for 5 bit STYPE part of CIP header*/
enum {
kIDHDV_SD = 0,
kIDHDV_SDL = 1,
kIDHDV_HD = 2,
kIDHDVCPro_25 = 0x1E
};
/* Isoch Interval Atom Data*/
struct IDHIsochInterval {
SInt32 duration;
TimeScale scale;
};
typedef struct IDHIsochInterval IDHIsochInterval;
/* Need to fix this. For now, cast this as a FWReferenceID*/
typedef struct OpaquePsuedoID* PsuedoID;
/*
Isoch Device Status
This is atom-like, but isn't an atom
*/
struct IDHDeviceStatus {
UInt32 version;
Boolean physicallyConnected;
Boolean readEnabled;
Boolean writeEnabled;
Boolean exclusiveAccess;
UInt32 currentBandwidth;
UInt32 currentChannel;
PsuedoID localNodeID; /*ooo.may go in atoms */
SInt16 inputStandard; /* One of the QT input standards*/
Boolean deviceActive;
UInt8 inputFormat; /* Expected STYPE of data from device, if version >= 0x200*/
UInt32 outputFormats; /* Bitmask for supported STYPE values, if version >= 0x200*/
};
typedef struct IDHDeviceStatus IDHDeviceStatus;
/*
Isochronous Data Handler Events
*/
typedef UInt32 IDHEvent;
enum {
kIDHEventInvalid = 0,
kIDHEventDeviceAdded = 1L << 0, /* A new device has been added to the bus*/
kIDHEventDeviceRemoved = 1L << 1, /* A device has been removed from the bus*/
kIDHEventDeviceChanged = 1L << 2, /* Some device has changed state on the bus*/
kIDHEventReadEnabled = 1L << 3, /* A client has enabled a device for read*/
kIDHEventReserved1 = 1L << 4, /* Reserved for future use*/
kIDHEventReadDisabled = 1L << 5, /* A client has disabled a device from read*/
kIDHEventWriteEnabled = 1L << 6, /* A client has enabled a device for write*/
kIDHEventReserved2 = 1L << 7, /* Reserved for future use*/
kIDHEventWriteDisabled = 1L << 8, /* A client has disabled a device for write*/
kIDHEventEveryEvent = (unsigned long)0xFFFFFFFF
};
typedef UInt32 IDHNotificationID;
struct IDHEventHeader {
IDHDeviceID deviceID; /* Device which generated event*/
IDHNotificationID notificationID;
IDHEvent event; /* What the event is*/
};
typedef struct IDHEventHeader IDHEventHeader;
/*
IDHGenericEvent
An IDH will often have to post events from at interrupt time. Since memory
allocation cannot occur from the interrupt handler, the IDH can preallocate
storage needed for handling the event by creating some IDHGenericEvent items.
Subsequently, when an event is generated, the type of event (specified in the
IDHEventHeader) will dictate how the IDHGenericEvent should be interpretted.
IMPORTANT NOTE : This means that a specific event structure can NEVER be greater
than the size of the generic one.
*/
struct IDHGenericEvent {
IDHEventHeader eventHeader;
UInt32 pad[4];
};
typedef struct IDHGenericEvent IDHGenericEvent;
/*
IDHDeviceConnectionEvent
For kIDHEventDeviceAdded or kIDHEventDeviceRemoved events.
*/
struct IDHDeviceConnectionEvent {
IDHEventHeader eventHeader;
};
typedef struct IDHDeviceConnectionEvent IDHDeviceConnectionEvent;
/*
IDHDeviceIOEnableEvent
For kIDHEventReadEnabled, kIDHEventReadDisabled, kIDHEventWriteEnabled, or
kIDHEventWriteDisabled.
*/
struct IDHDeviceIOEnableEvent {
IDHEventHeader eventHeader;
};
typedef struct IDHDeviceIOEnableEvent IDHDeviceIOEnableEvent;
typedef CALLBACK_API_C( OSStatus , IDHNotificationProcPtr )(IDHGenericEvent *event, void *userData);
typedef IDHNotificationProcPtr IDHNotificationProc;
typedef TVECTOR_UPP_TYPE(IDHNotificationProcPtr) IDHNotificationUPP;
struct IDHParameterBlock {
UInt32 reserved1;
UInt16 reserved2;
void * buffer;
ByteCount requestedCount;
ByteCount actualCount;
IDHNotificationUPP completionProc;
void * refCon;
OSErr result;
};
typedef struct IDHParameterBlock IDHParameterBlock;
struct IDHResolution {
UInt32 x;
UInt32 y;
};
typedef struct IDHResolution IDHResolution;
struct IDHDimension {
Fixed x;
Fixed y;
};
typedef struct IDHDimension IDHDimension;
EXTERN_API( ComponentResult )
IDHGetDeviceList (ComponentInstance idh,
QTAtomContainer * deviceList) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0001, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHGetDeviceConfiguration (ComponentInstance idh,
QTAtomSpec * configurationID) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0002, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHSetDeviceConfiguration (ComponentInstance idh,
const QTAtomSpec * configurationID) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0003, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHGetDeviceStatus (ComponentInstance idh,
const QTAtomSpec * configurationID,
IDHDeviceStatus * status) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0004, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHGetDeviceClock (ComponentInstance idh,
Component * clock) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0005, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHOpenDevice (ComponentInstance idh,
UInt32 permissions) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0006, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHCloseDevice (ComponentInstance idh) FIVEWORDINLINE(0x2F3C, 0x0000, 0x0007, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHRead (ComponentInstance idh,
IDHParameterBlock * pb) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0008, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHWrite (ComponentInstance idh,
IDHParameterBlock * pb) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0009, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHNewNotification (ComponentInstance idh,
IDHDeviceID deviceID,
IDHNotificationUPP notificationProc,
void * userData,
IDHNotificationID * notificationID) FIVEWORDINLINE(0x2F3C, 0x0010, 0x000A, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHNotifyMeWhen (ComponentInstance idh,
IDHNotificationID notificationID,
IDHEvent events) FIVEWORDINLINE(0x2F3C, 0x0008, 0x000B, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHCancelNotification (ComponentInstance idh,
IDHNotificationID notificationID) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000C, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHDisposeNotification (ComponentInstance idh,
IDHNotificationID notificationID) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000D, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHReleaseBuffer (ComponentInstance idh,
IDHParameterBlock * pb) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000E, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHCancelPendingIO (ComponentInstance idh,
IDHParameterBlock * pb) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000F, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHGetDeviceControl (ComponentInstance idh,
ComponentInstance * deviceControl) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0010, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHUpdateDeviceList (ComponentInstance idh,
QTAtomContainer * deviceList) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0011, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHGetDeviceTime (ComponentInstance idh,
TimeRecord * deviceTime) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0012, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHSetFormat (ComponentInstance idh,
UInt32 format) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0013, 0x7000, 0xA82A);
EXTERN_API( ComponentResult )
IDHGetFormat (ComponentInstance idh,
UInt32 * format) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0014, 0x7000, 0xA82A);
if OPAQUE_UPP_TYPES
EXTERN_API(IDHNotificationUPP)
NewIDHNotificationUPP (IDHNotificationProcPtr userRoutine);
EXTERN_API(void)
DisposeIDHNotificationUPP (IDHNotificationUPP userUPP);
EXTERN_API(OSStatus)
InvokeIDHNotificationUPP (IDHGenericEvent * event,
void * userData,
IDHNotificationUPP userUPP);
else
#define NewIDHNotificationUPP(userRoutine) (userRoutine)
#define DisposeIDHNotificationUPP(userUPP)
#define InvokeIDHNotificationUPP(event, userData, userUPP) (*userUPP)(event, userData)
endif
/* selectors for component calls */
enum {
kIDHGetDeviceListSelect = 0x0001,
kIDHGetDeviceConfigurationSelect = 0x0002,
kIDHSetDeviceConfigurationSelect = 0x0003,
kIDHGetDeviceStatusSelect = 0x0004,
kIDHGetDeviceClockSelect = 0x0005,
kIDHOpenDeviceSelect = 0x0006,
kIDHCloseDeviceSelect = 0x0007,
kIDHReadSelect = 0x0008,
kIDHWriteSelect = 0x0009,
kIDHNewNotificationSelect = 0x000A,
kIDHNotifyMeWhenSelect = 0x000B,
kIDHCancelNotificationSelect = 0x000C,
kIDHDisposeNotificationSelect = 0x000D,
kIDHReleaseBufferSelect = 0x000E,
kIDHCancelPendingIOSelect = 0x000F,
kIDHGetDeviceControlSelect = 0x0010,
kIDHUpdateDeviceListSelect = 0x0011,
kIDHGetDeviceTimeSelect = 0x0012,
kIDHSetFormatSelect = 0x0013,
kIDHGetFormatSelect = 0x0014
};
endif /* ifndef __ISOCHRONOUSDATAHANDLER_R__ */
if PRAGMA_STRUCT_ALIGN
#pragma options align=reset
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(pop)
#elif PRAGMA_STRUCT_PACK
#pragma pack()
endif
ifdef PRAGMA_IMPORT_OFF
#pragma import off
#elif PRAGMA_IMPORT
#pragma import reset
endif
ifdef __cplusplus
}
endif
endif /* __ISOCHRONOUSDATAHANDLER__ */
(C) Æliens
04/09/2009
You may not copy or print any of this material without explicit permission of the author or the publisher.
In case of other copyright issues, contact the author.