]> git.saurik.com Git - apple/xnu.git/blobdiff - iokit/IOKit/IOInterruptEventSource.h
xnu-1699.22.73.tar.gz
[apple/xnu.git] / iokit / IOKit / IOInterruptEventSource.h
index 0be7caf4575ee0a02c011dbc04ec5fb2136a734f..2e1a82765681f212bf98015bad4e3994ad4efc1d 100644 (file)
@@ -112,6 +112,10 @@ protected:
     @result Return true if this function needs to be called again before all its outstanding events have been processed. */
     virtual bool checkForWork();
 
+/*! @function setWorkLoop
+    @abstract Sub-class implementation of setWorkLoop method. */
+    virtual void setWorkLoop(IOWorkLoop *inWorkLoop);
+
 public:
 
 /*! @function interruptEventSource
@@ -185,6 +189,20 @@ state when checkForWork is called. */
     @param nub Where did the interrupt originate from
     @param ind What is this interrupts index within 'nub'. */
     virtual void disableInterruptOccurred(void *, IOService *nub, int ind);
+    
+/*! @function warmCPU
+    @abstract Tries to reduce latency for an interrupt which will be received near a specified time.
+    @discussion Warms up a CPU in advance of an interrupt so that the interrupt may be serviced with predictable latency.  
+    The warm-up is not periodic; callers should call warmCPU once in advance of each interrupt.  It is recommended that
+    requests be issues in serial (i.e. each after the target for the previous call has elapsed), as there is a systemwide
+    cap on the number of outstanding requests.  This routine may be disruptive to the system if used with very small intervals
+    between requests; it should be used only in cases where interrupt latency is absolutely critical, and tens or hundreds of 
+    milliseconds between targets is the expected time scale.  NOTE: it is not safe to call this method with interrupts disabled.
+    @param abstime Time at which interrupt is expected. */
+    IOReturn warmCPU(uint64_t abstime);
+
+private:
+    IOReturn registerInterruptHandler(IOService *inProvider, int inIntIndex);
 
 private:
     OSMetaClassDeclareReservedUnused(IOInterruptEventSource, 0);