Loading...
iokit/Kernel/IOInterruptController.cpp xnu-792 xnu-792.25.20
--- xnu/xnu-792/iokit/Kernel/IOInterruptController.cpp
+++ xnu/xnu-792.25.20/iokit/Kernel/IOInterruptController.cpp
@@ -427,6 +427,8 @@
   _numInterruptSources = 1;
   
   // Set up the IOInterruptSource to point at this.
+  parentController->retain();
+  parentSource->retain();
   _interruptSources[0].interruptController = parentController;
   _interruptSources[0].vectorData = parentSource;
   
@@ -666,7 +668,8 @@
 
 IOInterruptAction IOSharedInterruptController::getInterruptHandlerAddress(void)
 {
-    return (IOInterruptAction)&IOSharedInterruptController::handleInterrupt;
+    return OSMemberFunctionCast(IOInterruptAction,
+			this, &IOSharedInterruptController::handleInterrupt);
 }
 
 IOReturn IOSharedInterruptController::handleInterrupt(void * /*refCon*/,