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