Loading...
iokit/Kernel/IOSharedDataQueue.cpp xnu-8020.101.4 xnu-6153.61.1
--- xnu/xnu-8020.101.4/iokit/Kernel/IOSharedDataQueue.cpp
+++ xnu/xnu-6153.61.1/iokit/Kernel/IOSharedDataQueue.cpp
@@ -26,13 +26,10 @@
  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 
-#define IOKIT_ENABLE_SHARED_PTR
-
 #include <IOKit/IOSharedDataQueue.h>
 #include <IOKit/IODataQueueShared.h>
 #include <IOKit/IOLib.h>
 #include <IOKit/IOMemoryDescriptor.h>
-#include <libkern/c++/OSSharedPtr.h>
 
 #ifdef enqueue
 #undef enqueue
@@ -46,28 +43,29 @@
 
 OSDefineMetaClassAndStructors(IOSharedDataQueue, IODataQueue)
 
-OSSharedPtr<IOSharedDataQueue>
-IOSharedDataQueue::withCapacity(UInt32 size)
-{
-	OSSharedPtr<IOSharedDataQueue> dataQueue = OSMakeShared<IOSharedDataQueue>();
+IOSharedDataQueue *IOSharedDataQueue::withCapacity(UInt32 size)
+{
+	IOSharedDataQueue *dataQueue = new IOSharedDataQueue;
 
 	if (dataQueue) {
 		if (!dataQueue->initWithCapacity(size)) {
-			return nullptr;
+			dataQueue->release();
+			dataQueue = NULL;
 		}
 	}
 
 	return dataQueue;
 }
 
-OSSharedPtr<IOSharedDataQueue>
+IOSharedDataQueue *
 IOSharedDataQueue::withEntries(UInt32 numEntries, UInt32 entrySize)
 {
-	OSSharedPtr<IOSharedDataQueue> dataQueue = OSMakeShared<IOSharedDataQueue>();
+	IOSharedDataQueue *dataQueue = new IOSharedDataQueue;
 
 	if (dataQueue) {
 		if (!dataQueue->initWithEntries(numEntries, entrySize)) {
-			return nullptr;
+			dataQueue->release();
+			dataQueue = NULL;
 		}
 	}
 
@@ -84,7 +82,7 @@
 		return false;
 	}
 
-	_reserved = IOMallocType(ExpansionData);
+	_reserved = (ExpansionData *)IOMalloc(sizeof(struct ExpansionData));
 	if (!_reserved) {
 		return false;
 	}
@@ -117,7 +115,7 @@
 	appendix->version   = 0;
 
 	if (!notifyMsg) {
-		notifyMsg = IOMallocType(mach_msg_header_t);
+		notifyMsg = IOMalloc(sizeof(mach_msg_header_t));
 		if (!notifyMsg) {
 			return false;
 		}
@@ -136,23 +134,23 @@
 		IOFreeAligned(dataQueue, round_page(getQueueSize() + DATA_QUEUE_MEMORY_HEADER_SIZE + DATA_QUEUE_MEMORY_APPENDIX_SIZE));
 		dataQueue = NULL;
 		if (notifyMsg) {
-			IOFreeType(notifyMsg, mach_msg_header_t);
+			IOFree(notifyMsg, sizeof(mach_msg_header_t));
 			notifyMsg = NULL;
 		}
 	}
 
 	if (_reserved) {
-		IOFreeType(_reserved, ExpansionData);
+		IOFree(_reserved, sizeof(struct ExpansionData));
 		_reserved = NULL;
 	}
 
 	super::free();
 }
 
-OSSharedPtr<IOMemoryDescriptor>
+IOMemoryDescriptor *
 IOSharedDataQueue::getMemoryDescriptor()
 {
-	OSSharedPtr<IOMemoryDescriptor> descriptor;
+	IOMemoryDescriptor *descriptor = NULL;
 
 	if (dataQueue != NULL) {
 		descriptor = IOMemoryDescriptor::withAddress(dataQueue, getQueueSize() + DATA_QUEUE_MEMORY_HEADER_SIZE + DATA_QUEUE_MEMORY_APPENDIX_SIZE, kIODirectionOutIn);
@@ -184,7 +182,7 @@
 		UInt32              headOffset   = dataQueue->head;
 		UInt32              queueSize    = getQueueSize();
 
-		if (headOffset > queueSize) {
+		if (headOffset >= queueSize) {
 			return NULL;
 		}