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