1*699cd480SApple OSS Distributions /* 2*699cd480SApple OSS Distributions * Copyright (c) 2004 Apple Computer, Inc. All rights reserved. 3*699cd480SApple OSS Distributions * 4*699cd480SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*699cd480SApple OSS Distributions * 6*699cd480SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*699cd480SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*699cd480SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*699cd480SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*699cd480SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*699cd480SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*699cd480SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*699cd480SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*699cd480SApple OSS Distributions * 15*699cd480SApple OSS Distributions * Please obtain a copy of the License at 16*699cd480SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*699cd480SApple OSS Distributions * 18*699cd480SApple OSS Distributions * The Original Code and all software distributed under the License are 19*699cd480SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*699cd480SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*699cd480SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*699cd480SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*699cd480SApple OSS Distributions * Please see the License for the specific language governing rights and 24*699cd480SApple OSS Distributions * limitations under the License. 25*699cd480SApple OSS Distributions * 26*699cd480SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*699cd480SApple OSS Distributions */ 28*699cd480SApple OSS Distributions 29*699cd480SApple OSS Distributions #ifndef _IOPOLLEDINTERFACE_H_ 30*699cd480SApple OSS Distributions #define _IOPOLLEDINTERFACE_H_ 31*699cd480SApple OSS Distributions 32*699cd480SApple OSS Distributions enum{ 33*699cd480SApple OSS Distributions kIOPolledPreflightState = 1, 34*699cd480SApple OSS Distributions kIOPolledBeforeSleepState = 2, 35*699cd480SApple OSS Distributions kIOPolledAfterSleepState = 3, 36*699cd480SApple OSS Distributions kIOPolledPostflightState = 4, 37*699cd480SApple OSS Distributions 38*699cd480SApple OSS Distributions kIOPolledPreflightCoreDumpState = 5, 39*699cd480SApple OSS Distributions kIOPolledPostflightCoreDumpState = 6, 40*699cd480SApple OSS Distributions 41*699cd480SApple OSS Distributions kIOPolledBeforeSleepStateAborted = 7, 42*699cd480SApple OSS Distributions }; 43*699cd480SApple OSS Distributions 44*699cd480SApple OSS Distributions #if defined(__cplusplus) 45*699cd480SApple OSS Distributions 46*699cd480SApple OSS Distributions #include <libkern/c++/OSObject.h> 47*699cd480SApple OSS Distributions #include <libkern/c++/OSPtr.h> 48*699cd480SApple OSS Distributions #include <IOKit/IOMemoryDescriptor.h> 49*699cd480SApple OSS Distributions 50*699cd480SApple OSS Distributions #define kIOPolledInterfaceSupportKey "IOPolledInterface" 51*699cd480SApple OSS Distributions #define kIOPolledInterfaceActiveKey "IOPolledInterfaceActive" 52*699cd480SApple OSS Distributions #define kIOPolledInterfaceStackKey "IOPolledInterfaceStack" 53*699cd480SApple OSS Distributions 54*699cd480SApple OSS Distributions enum{ 55*699cd480SApple OSS Distributions kIOPolledWrite = 1, 56*699cd480SApple OSS Distributions kIOPolledRead = 2, 57*699cd480SApple OSS Distributions kIOPolledFlush = 3 58*699cd480SApple OSS Distributions }; 59*699cd480SApple OSS Distributions 60*699cd480SApple OSS Distributions typedef void (*IOPolledCompletionAction)( void * target, 61*699cd480SApple OSS Distributions void * parameter, 62*699cd480SApple OSS Distributions IOReturn status, 63*699cd480SApple OSS Distributions uint64_t actualByteCount); 64*699cd480SApple OSS Distributions struct IOPolledCompletion { 65*699cd480SApple OSS Distributions void * target; 66*699cd480SApple OSS Distributions IOPolledCompletionAction action; 67*699cd480SApple OSS Distributions void * parameter; 68*699cd480SApple OSS Distributions }; 69*699cd480SApple OSS Distributions 70*699cd480SApple OSS Distributions class IOPolledInterface : public OSObject 71*699cd480SApple OSS Distributions { 72*699cd480SApple OSS Distributions OSDeclareAbstractStructors(IOPolledInterface); 73*699cd480SApple OSS Distributions 74*699cd480SApple OSS Distributions protected: 75*699cd480SApple OSS Distributions struct ExpansionData { }; 76*699cd480SApple OSS Distributions ExpansionData * reserved; 77*699cd480SApple OSS Distributions 78*699cd480SApple OSS Distributions public: 79*699cd480SApple OSS Distributions virtual IOReturn probe(IOService * target) = 0; 80*699cd480SApple OSS Distributions 81*699cd480SApple OSS Distributions virtual IOReturn open( IOOptionBits state, IOMemoryDescriptor * buffer) = 0; 82*699cd480SApple OSS Distributions virtual IOReturn close(IOOptionBits state) = 0; 83*699cd480SApple OSS Distributions 84*699cd480SApple OSS Distributions virtual IOReturn startIO(uint32_t operation, 85*699cd480SApple OSS Distributions uint32_t bufferOffset, 86*699cd480SApple OSS Distributions uint64_t deviceOffset, 87*699cd480SApple OSS Distributions uint64_t length, 88*699cd480SApple OSS Distributions IOPolledCompletion completion) = 0; 89*699cd480SApple OSS Distributions 90*699cd480SApple OSS Distributions virtual IOReturn checkForWork(void) = 0; 91*699cd480SApple OSS Distributions 92*699cd480SApple OSS Distributions virtual IOReturn setEncryptionKey(const uint8_t * key, size_t keySize); 93*699cd480SApple OSS Distributions 94*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUsedX86(IOPolledInterface, 0); 95*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 1); 96*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 2); 97*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 3); 98*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 4); 99*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 5); 100*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 6); 101*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 7); 102*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 8); 103*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 9); 104*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 10); 105*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 11); 106*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 12); 107*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 13); 108*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 14); 109*699cd480SApple OSS Distributions OSMetaClassDeclareReservedUnused(IOPolledInterface, 15); 110*699cd480SApple OSS Distributions }; 111*699cd480SApple OSS Distributions 112*699cd480SApple OSS Distributions #endif /* defined(__cplusplus) */ 113*699cd480SApple OSS Distributions 114*699cd480SApple OSS Distributions #ifdef XNU_KERNEL_PRIVATE 115*699cd480SApple OSS Distributions 116*699cd480SApple OSS Distributions #include <libkern/crypto/aes.h> 117*699cd480SApple OSS Distributions #include <IOKit/IOTypes.h> 118*699cd480SApple OSS Distributions #include <IOKit/IOHibernatePrivate.h> 119*699cd480SApple OSS Distributions 120*699cd480SApple OSS Distributions // kern_open_file_for_direct_io() flags 121*699cd480SApple OSS Distributions enum{ 122*699cd480SApple OSS Distributions kIOPolledFileCreate = 0x00000001, 123*699cd480SApple OSS Distributions kIOPolledFileHibernate = 0x00000002, 124*699cd480SApple OSS Distributions }; 125*699cd480SApple OSS Distributions 126*699cd480SApple OSS Distributions // kern_open_file_for_direct_io() oflags 127*699cd480SApple OSS Distributions enum{ 128*699cd480SApple OSS Distributions kIOPolledFileSSD = 0x00000001 129*699cd480SApple OSS Distributions }; 130*699cd480SApple OSS Distributions 131*699cd480SApple OSS Distributions #if !defined(__cplusplus) 132*699cd480SApple OSS Distributions typedef struct IORegistryEntry IORegistryEntry; 133*699cd480SApple OSS Distributions typedef struct OSData OSData; 134*699cd480SApple OSS Distributions typedef struct OSArray OSArray; 135*699cd480SApple OSS Distributions typedef struct IOMemoryDescriptor IOMemoryDescriptor; 136*699cd480SApple OSS Distributions typedef struct IOPolledFilePollers IOPolledFilePollers; 137*699cd480SApple OSS Distributions #else 138*699cd480SApple OSS Distributions class IOPolledFilePollers; 139*699cd480SApple OSS Distributions #endif 140*699cd480SApple OSS Distributions 141*699cd480SApple OSS Distributions struct IOPolledFileIOVars { 142*699cd480SApple OSS Distributions IOPolledFilePollers * pollers; 143*699cd480SApple OSS Distributions struct kern_direct_file_io_ref_t * fileRef; 144*699cd480SApple OSS Distributions OSData * fileExtents; 145*699cd480SApple OSS Distributions uint64_t block0; 146*699cd480SApple OSS Distributions uint32_t blockSize; 147*699cd480SApple OSS Distributions uint64_t maxiobytes; 148*699cd480SApple OSS Distributions uint32_t bufferLimit; 149*699cd480SApple OSS Distributions uint8_t * buffer; 150*699cd480SApple OSS Distributions uint32_t bufferSize; 151*699cd480SApple OSS Distributions uint32_t bufferOffset; 152*699cd480SApple OSS Distributions uint32_t bufferHalf; 153*699cd480SApple OSS Distributions uint64_t extentRemaining; 154*699cd480SApple OSS Distributions uint32_t lastRead; 155*699cd480SApple OSS Distributions uint64_t readEnd; 156*699cd480SApple OSS Distributions uint32_t flags; 157*699cd480SApple OSS Distributions uint64_t fileSize; 158*699cd480SApple OSS Distributions uint64_t position; 159*699cd480SApple OSS Distributions uint64_t extentPosition; 160*699cd480SApple OSS Distributions uint64_t encryptStart; 161*699cd480SApple OSS Distributions uint64_t encryptEnd; 162*699cd480SApple OSS Distributions uint64_t cryptBytes; 163*699cd480SApple OSS Distributions AbsoluteTime cryptTime; 164*699cd480SApple OSS Distributions IOPolledFileExtent * extentMap; 165*699cd480SApple OSS Distributions IOPolledFileExtent * currentExtent; 166*699cd480SApple OSS Distributions bool allocated; 167*699cd480SApple OSS Distributions }; 168*699cd480SApple OSS Distributions 169*699cd480SApple OSS Distributions typedef struct IOPolledFileIOVars IOPolledFileIOVars; 170*699cd480SApple OSS Distributions 171*699cd480SApple OSS Distributions struct IOPolledFileCryptVars { 172*699cd480SApple OSS Distributions uint8_t aes_iv[AES_BLOCK_SIZE]; 173*699cd480SApple OSS Distributions aes_ctx ctx; 174*699cd480SApple OSS Distributions }; 175*699cd480SApple OSS Distributions typedef struct IOPolledFileCryptVars IOPolledFileCryptVars; 176*699cd480SApple OSS Distributions 177*699cd480SApple OSS Distributions #if defined(__cplusplus) 178*699cd480SApple OSS Distributions 179*699cd480SApple OSS Distributions IOReturn IOPolledFileOpen(const char * filename, 180*699cd480SApple OSS Distributions uint32_t flags, 181*699cd480SApple OSS Distributions uint64_t setFileSize, uint64_t fsFreeSize, 182*699cd480SApple OSS Distributions void * write_file_addr, size_t write_file_len, 183*699cd480SApple OSS Distributions IOPolledFileIOVars ** fileVars, 184*699cd480SApple OSS Distributions LIBKERN_RETURNS_RETAINED OSData ** imagePath, 185*699cd480SApple OSS Distributions uint8_t * volumeCryptKey, size_t * keySize); 186*699cd480SApple OSS Distributions 187*699cd480SApple OSS Distributions IOReturn IOPolledFileOpen(const char * filename, 188*699cd480SApple OSS Distributions uint32_t flags, 189*699cd480SApple OSS Distributions uint64_t setFileSize, uint64_t fsFreeSize, 190*699cd480SApple OSS Distributions void * write_file_addr, size_t write_file_len, 191*699cd480SApple OSS Distributions IOPolledFileIOVars ** fileVars, 192*699cd480SApple OSS Distributions OSSharedPtr<OSData>& imagePath, 193*699cd480SApple OSS Distributions uint8_t * volumeCryptKey, size_t * keySize); 194*699cd480SApple OSS Distributions 195*699cd480SApple OSS Distributions IOReturn IOPolledFileClose(IOPolledFileIOVars ** pVars, 196*699cd480SApple OSS Distributions off_t write_offset, void * addr, size_t write_length, 197*699cd480SApple OSS Distributions off_t discard_offset, off_t discard_end, bool unlink); 198*699cd480SApple OSS Distributions 199*699cd480SApple OSS Distributions IOReturn IOPolledFilePollersSetup(IOPolledFileIOVars * vars, uint32_t openState); 200*699cd480SApple OSS Distributions 201*699cd480SApple OSS Distributions LIBKERN_RETURNS_NOT_RETAINED IOMemoryDescriptor * IOPolledFileGetIOBuffer(IOPolledFileIOVars * vars); 202*699cd480SApple OSS Distributions 203*699cd480SApple OSS Distributions #endif /* defined(__cplusplus) */ 204*699cd480SApple OSS Distributions 205*699cd480SApple OSS Distributions #if defined(__cplusplus) 206*699cd480SApple OSS Distributions #define __C "C" 207*699cd480SApple OSS Distributions #else 208*699cd480SApple OSS Distributions #define __C 209*699cd480SApple OSS Distributions #endif 210*699cd480SApple OSS Distributions 211*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFileSeek(IOPolledFileIOVars * vars, uint64_t position); 212*699cd480SApple OSS Distributions 213*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFileWrite(IOPolledFileIOVars * vars, 214*699cd480SApple OSS Distributions const uint8_t * bytes, IOByteCount size, 215*699cd480SApple OSS Distributions IOPolledFileCryptVars * cryptvars); 216*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFileRead(IOPolledFileIOVars * vars, 217*699cd480SApple OSS Distributions uint8_t * bytes, IOByteCount size, 218*699cd480SApple OSS Distributions IOPolledFileCryptVars * cryptvars); 219*699cd480SApple OSS Distributions 220*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFileFlush(IOPolledFileIOVars * vars); 221*699cd480SApple OSS Distributions 222*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFilePollersOpen(IOPolledFileIOVars * vars, uint32_t state, bool abortable); 223*699cd480SApple OSS Distributions 224*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFilePollersClose(IOPolledFileIOVars * vars, uint32_t state); 225*699cd480SApple OSS Distributions 226*699cd480SApple OSS Distributions extern __C IOReturn IOPolledFilePollersSetEncryptionKey(IOPolledFileIOVars * vars, 227*699cd480SApple OSS Distributions const uint8_t * key, size_t keySize); 228*699cd480SApple OSS Distributions 229*699cd480SApple OSS Distributions extern __C IOPolledFileIOVars * gCoreFileVars; 230*699cd480SApple OSS Distributions 231*699cd480SApple OSS Distributions #ifdef _SYS_CONF_H_ 232*699cd480SApple OSS Distributions 233*699cd480SApple OSS Distributions __BEGIN_DECLS 234*699cd480SApple OSS Distributions 235*699cd480SApple OSS Distributions typedef void (*kern_get_file_extents_callback_t)(void * ref, uint64_t start, uint64_t size); 236*699cd480SApple OSS Distributions 237*699cd480SApple OSS Distributions struct kern_direct_file_io_ref_t * 238*699cd480SApple OSS Distributions kern_open_file_for_direct_io(const char * name, 239*699cd480SApple OSS Distributions uint32_t flags, 240*699cd480SApple OSS Distributions kern_get_file_extents_callback_t callback, 241*699cd480SApple OSS Distributions void * callback_ref, 242*699cd480SApple OSS Distributions off_t set_file_size, 243*699cd480SApple OSS Distributions off_t fs_free_size, 244*699cd480SApple OSS Distributions off_t write_file_offset, 245*699cd480SApple OSS Distributions void * write_file_addr, 246*699cd480SApple OSS Distributions size_t write_file_len, 247*699cd480SApple OSS Distributions dev_t * partition_device_result, 248*699cd480SApple OSS Distributions dev_t * image_device_result, 249*699cd480SApple OSS Distributions uint64_t * partitionbase_result, 250*699cd480SApple OSS Distributions uint64_t * maxiocount_result, 251*699cd480SApple OSS Distributions uint32_t * oflags); 252*699cd480SApple OSS Distributions void 253*699cd480SApple OSS Distributions kern_close_file_for_direct_io(struct kern_direct_file_io_ref_t * ref, 254*699cd480SApple OSS Distributions off_t write_offset, void * addr, size_t write_length, 255*699cd480SApple OSS Distributions off_t discard_offset, off_t discard_end, bool unlink); 256*699cd480SApple OSS Distributions int 257*699cd480SApple OSS Distributions kern_write_file(struct kern_direct_file_io_ref_t * ref, off_t offset, void * addr, size_t len, int ioflag); 258*699cd480SApple OSS Distributions int 259*699cd480SApple OSS Distributions kern_read_file(struct kern_direct_file_io_ref_t * ref, off_t offset, void * addr, size_t len, int ioflag); 260*699cd480SApple OSS Distributions 261*699cd480SApple OSS Distributions struct mount * 262*699cd480SApple OSS Distributions kern_file_mount(struct kern_direct_file_io_ref_t * ref); 263*699cd480SApple OSS Distributions 264*699cd480SApple OSS Distributions enum{ 265*699cd480SApple OSS Distributions kIOPolledFileMountChangeMount = 0x00000101, 266*699cd480SApple OSS Distributions kIOPolledFileMountChangeUnmount = 0x00000102, 267*699cd480SApple OSS Distributions kIOPolledFileMountChangeWillResize = 0x00000201, 268*699cd480SApple OSS Distributions kIOPolledFileMountChangeDidResize = 0x00000202, 269*699cd480SApple OSS Distributions }; 270*699cd480SApple OSS Distributions extern void IOPolledFileMountChange(struct mount * mp, uint32_t op); 271*699cd480SApple OSS Distributions 272*699cd480SApple OSS Distributions __END_DECLS 273*699cd480SApple OSS Distributions 274*699cd480SApple OSS Distributions #endif /* _SYS_CONF_H_ */ 275*699cd480SApple OSS Distributions 276*699cd480SApple OSS Distributions #endif /* XNU_KERNEL_PRIVATE */ 277*699cd480SApple OSS Distributions 278*699cd480SApple OSS Distributions #endif /* _IOPOLLEDINTERFACE_H_ */ 279