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