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