1*aca3beaaSApple OSS Distributions #include "TestIOConnectMapMemoryPortLeak45265408.h" 2*aca3beaaSApple OSS Distributions #include <IOKit/IOKitKeys.h> 3*aca3beaaSApple OSS Distributions 4*aca3beaaSApple OSS Distributions #if DEVELOPMENT || DEBUG 5*aca3beaaSApple OSS Distributions 6*aca3beaaSApple OSS Distributions #define super IOService 7*aca3beaaSApple OSS Distributions OSDefineMetaClassAndStructors(TestIOConnectMapMemoryPortLeak45265408, IOService); 8*aca3beaaSApple OSS Distributions 9*aca3beaaSApple OSS Distributions bool start(IOService * provider)10*aca3beaaSApple OSS DistributionsTestIOConnectMapMemoryPortLeak45265408::start(IOService *provider) 11*aca3beaaSApple OSS Distributions { 12*aca3beaaSApple OSS Distributions bool ret = super::start(provider); 13*aca3beaaSApple OSS Distributions if (ret) { 14*aca3beaaSApple OSS Distributions OSString * className = OSString::withCStringNoCopy("TestIOConnectMapMemoryPortLeak45265408UserClient"); 15*aca3beaaSApple OSS Distributions setProperty(gIOUserClientClassKey, className); 16*aca3beaaSApple OSS Distributions OSSafeReleaseNULL(className); 17*aca3beaaSApple OSS Distributions registerService(); 18*aca3beaaSApple OSS Distributions } 19*aca3beaaSApple OSS Distributions return ret; 20*aca3beaaSApple OSS Distributions } 21*aca3beaaSApple OSS Distributions 22*aca3beaaSApple OSS Distributions #undef super 23*aca3beaaSApple OSS Distributions #define super IOUserClient 24*aca3beaaSApple OSS Distributions OSDefineMetaClassAndStructors(TestIOConnectMapMemoryPortLeak45265408UserClient, IOUserClient); 25*aca3beaaSApple OSS Distributions 26*aca3beaaSApple OSS Distributions bool start(IOService * provider)27*aca3beaaSApple OSS DistributionsTestIOConnectMapMemoryPortLeak45265408UserClient::start(IOService *provider) 28*aca3beaaSApple OSS Distributions { 29*aca3beaaSApple OSS Distributions bool ret = super::start(provider); 30*aca3beaaSApple OSS Distributions if (ret) { 31*aca3beaaSApple OSS Distributions setProperty(kIOUserClientSharedInstanceKey, kOSBooleanTrue); 32*aca3beaaSApple OSS Distributions this->sharedMemory = IOBufferMemoryDescriptor::withOptions(kIOMemoryKernelUserShared, PAGE_SIZE); 33*aca3beaaSApple OSS Distributions if (this->sharedMemory == NULL) { 34*aca3beaaSApple OSS Distributions ret = false; 35*aca3beaaSApple OSS Distributions } 36*aca3beaaSApple OSS Distributions } 37*aca3beaaSApple OSS Distributions 38*aca3beaaSApple OSS Distributions return ret; 39*aca3beaaSApple OSS Distributions } 40*aca3beaaSApple OSS Distributions 41*aca3beaaSApple OSS Distributions void stop(IOService * provider)42*aca3beaaSApple OSS DistributionsTestIOConnectMapMemoryPortLeak45265408UserClient::stop(IOService *provider) 43*aca3beaaSApple OSS Distributions { 44*aca3beaaSApple OSS Distributions if (this->sharedMemory) { 45*aca3beaaSApple OSS Distributions this->sharedMemory->release(); 46*aca3beaaSApple OSS Distributions this->sharedMemory = NULL; 47*aca3beaaSApple OSS Distributions } 48*aca3beaaSApple OSS Distributions super::stop(provider); 49*aca3beaaSApple OSS Distributions } 50*aca3beaaSApple OSS Distributions 51*aca3beaaSApple OSS Distributions IOReturn clientClose()52*aca3beaaSApple OSS DistributionsTestIOConnectMapMemoryPortLeak45265408UserClient::clientClose() 53*aca3beaaSApple OSS Distributions { 54*aca3beaaSApple OSS Distributions if (!isInactive()) { 55*aca3beaaSApple OSS Distributions terminate(); 56*aca3beaaSApple OSS Distributions } 57*aca3beaaSApple OSS Distributions return kIOReturnSuccess; 58*aca3beaaSApple OSS Distributions } 59*aca3beaaSApple OSS Distributions 60*aca3beaaSApple OSS Distributions IOReturn clientMemoryForType(UInt32 type,IOOptionBits * flags,IOMemoryDescriptor ** memory)61*aca3beaaSApple OSS DistributionsTestIOConnectMapMemoryPortLeak45265408UserClient::clientMemoryForType(UInt32 type, IOOptionBits *flags, IOMemoryDescriptor **memory) 62*aca3beaaSApple OSS Distributions { 63*aca3beaaSApple OSS Distributions *memory = this->sharedMemory; 64*aca3beaaSApple OSS Distributions this->sharedMemory->retain(); 65*aca3beaaSApple OSS Distributions return kIOReturnSuccess; 66*aca3beaaSApple OSS Distributions } 67*aca3beaaSApple OSS Distributions 68*aca3beaaSApple OSS Distributions #endif /* DEVELOPMENT || DEBUG */ 69