/* * Copyright (c) 1998-2002 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * The contents of this file constitute Original Code as defined in and * are subject to the Apple Public Source License Version 1.1 (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. * * This 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@ */ #ifndef _IOKIT_IOFWPHYSICALADDRESSSPACE_H #define _IOKIT_IOFWPHYSICALADDRESSSPACE_H #include #include /* * Direct physical memory <-> FireWire address. * Accesses to these addresses may be handled automatically by the * hardware without notification. * * The 64 bit FireWire address of (32 bit) physical addr xxxx:xxxx is hostNode:0000:xxxx:xxxx */ class IOFWPhysicalAddressSpace; struct FWSegment { FWAddress address; UInt32 length; }; #pragma mark - /*! @class IOFWPhysicalAddressSpaceAux */ class IOFWPhysicalAddressSpaceAux : public IOFWAddressSpaceAux { OSDeclareDefaultStructors(IOFWPhysicalAddressSpaceAux) friend class IOFWAddressSpace; friend class IOFWPhysicalAddressSpace; protected: /*! @struct ExpansionData @discussion This structure will be used to expand the capablilties of the class in the future. */ struct ExpansionData { }; /*! @var reserved Reserved for future use. (Internal use only) */ ExpansionData *reserved; IODMACommand * fDMACommand; bool fDMACommandPrepared; public: virtual bool init( IOFWAddressSpace * primary ); virtual void free(); void setDMACommand( IODMACommand * dma_command ); IODMACommand * getDMACommand( void ); UInt64 getPhysicalSegment( UInt64 offset, UInt64 * length ); IOReturn prepare( void ); IOReturn synchronize( IOOptionBits options ); IOReturn complete( void ); bool isPrepared( void ); IOReturn getSegments( UInt64 * offset, FWSegment * fw_segments, UInt32 * num_segments ); private: OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 0); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 1); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 2); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 3); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 4); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 5); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 6); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 7); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 8); OSMetaClassDeclareReservedUnused(IOFWPhysicalAddressSpaceAux, 9); }; #pragma mark - /*! @class IOFWPhysicalAddressSpace */ class IOFWPhysicalAddressSpace : public IOFWAddressSpace { OSDeclareDefaultStructors(IOFWPhysicalAddressSpace) friend class IOFWPhysicalAddressSpaceAux; protected: IOMemoryDescriptor * fMem; // unused vm_size_t fLen; // unused virtual void free(); public: /*! @function init @abstract Initialize physical address space. @param bus Points to IOFireWireBus object. @result returns true if success, else false */ virtual bool init( IOFireWireBus * bus ); /*! @function initWithDesc @abstract Initialize physical address space with IOMemoryDescriptor. @param bus Points to IOFireWireBus object. @param mem Points to IOMemoryDescriptor. @result returns true if success, else false */ virtual bool initWithDesc(IOFireWireBus *bus, IOMemoryDescriptor *mem); /*! @function doRead @abstract A method for processing an address space read request @param nodeID FireWire Read from nodeID. @param speed at this 'speed'. @param addr with FireWire address 'addr'. @param len read 'len' bytes from nodeID. @param buf points to a memory descriptor containing the packet data. @param offset start from this 'offset' in 'buf'. @param refcon Can be queried for extra info about the request. @result UIn32 returns kFWResponseComplete on success */ virtual UInt32 doRead(UInt16 nodeID, IOFWSpeed &speed, FWAddress addr, UInt32 len, IOMemoryDescriptor **buf, IOByteCount * offset, IOFWRequestRefCon refcon); /*! @function doWrite @abstract A method for processing an address space write request @param nodeID FireWire Write to nodeID. @param speed at this 'speed'. @param addr with FireWire address 'addr'. @param len write 'len' bytes to nodeID. @param buf obtain bytes from location given by 'buf'. @param reqrefcon Can be queried for extra info about the request. @result UIn32 returns kFWResponseComplete on success */ virtual UInt32 doWrite(UInt16 nodeID, IOFWSpeed &speed, FWAddress addr, UInt32 len, const void *buf, IOFWRequestRefCon refcon); /*! @function getMemoryDescriptor @abstract Gets the memory descriptor, which is associated to this PhysicalAddressSpace. @param none. @result returns the IOMemoryDescriptor */ IOMemoryDescriptor * getMemoryDescriptor( void ); /*! @function setMemoryDescriptor @abstract Sets the memory descriptor, which will be associated to this PhysicalAddressSpace. @param none. @result returns the IOMemoryDescriptor */ IOReturn setMemoryDescriptor( IOMemoryDescriptor * descriptor ); /*! @function getLength @abstract Get the length of the memory backed by PhysicalAddressSpace. @param none. @result returns the length */ UInt64 getLength( void ); /*! @function setDMACommand @abstract Set the DMACommand for this PhysicalAddressSpace. @param dma_command Points to IODMACommand object. @result none */ inline void setDMACommand( IODMACommand * dma_command ) { ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->setDMACommand( dma_command ); }; /*! @function getDMACommand @abstract Get the DMACommand from this PhysicalAddressSpace. @param none. @result return previously assigned IODMACommand, null if not initialized */ inline IODMACommand * getDMACommand( void ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->getDMACommand(); }; /*! @function initWithDMACommand @abstract Initialize physical address space with IODMACommand. @param bus Points to IOFireWireBus object. @param command Points to IODMACommand. @result returns true if success, else false */ virtual bool initWithDMACommand( IOFireWireBus * control, IODMACommand * command ); /*! @function prepare @abstract Prepare the IODMACommand used by this PhysicalAddressSpace. @param none. @result returns kIOReturnSuccess on success */ inline IOReturn prepare( void ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->prepare(); }; /*! @function synchronize @abstract synchronize the IODMACommand used by this PhysicalAddressSpace. @param none. @result returns kIOReturnSuccess on success */ inline IOReturn synchronize( IOOptionBits options ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->synchronize( options ); }; /*! @function complete @abstract complete the IODMACommand used by this PhysicalAddressSpace. @param none. @result returns kIOReturnSuccess on success */ inline IOReturn complete( void ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->complete(); }; /*! @function isPrepared @abstract Inspects whether the IODMACommand was prepared in this PhysicalAddressSpace. @param none. @result returns true if prepared, else false */ inline bool isPrepared( void ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->isPrepared(); }; /*! @function getSegments @abstract Returns the scatter gather list of memory segments from the IODMACommand used in this PhysicalAddressSpace. @param offset input/output parameter, defines the starting and ending offset in the memory descriptor, relative to any offset passed to the prepare() method. FWSegment Points to an array of memory segments. num_segments Size of the FWSegment array. @result returns kIOReturnSuccess on success */ inline IOReturn getSegments( UInt64 * offset, FWSegment * fw_segments, UInt32 * num_segments ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->getSegments( offset, fw_segments, num_segments ); }; /*! @function checkMemoryInRange @abstract Validates the IOMemoryDescriptor, which is used to initialize the PhysicalAddressSpace. @param memory Points to a valid IOMemoryDescriptor. @result returns kIOReturnSuccess on success */ IOReturn checkMemoryInRange( IOMemoryDescriptor * memory ); protected: UInt64 getPhysicalSegment( UInt64 offset, UInt64 * length ) { return ((IOFWPhysicalAddressSpaceAux*)fIOFWAddressSpaceExpansion->fAuxiliary)->getPhysicalSegment( offset, length); }; virtual IOFWAddressSpaceAux * createAuxiliary( void ); }; #endif