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