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