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