Provided are a method, system, and program for handling interrupts. A request is received as to whether a device transmitted an interrupt and a determination is made as to whether the device transmitted the interrupt. If the device transmitted the interrupt, then indication is made that the device did not transmit the interrupt and work from the device related to the interrupt is processed.
|
8. A method for handling interrupts, comprising:
receiving a request as to whether a device transmitted an interrupt; determining whether the device transmitted the interrupt; if the device transmitted the interrupt, then indicating that the device did not transmit the interrupt; and processing work from the device related to the interrupt.
29. An article of manufacture for handling interrupts, wherein the article of manufacture causes operations to be performed, the operations comprising:
receiving a request as to whether a device transmitted an interrupt; determining whether the device transmitted the interrupt; if the device transmitted the interrupt, then indicating that the device did not transmit the interrupt; and processing work from the device related to the interrupt.
20. A system for handling interrupts from a device, comprising:
a processor; and a program executed by the processor to perform: (i) receiving a request as to whether a device transmitted an interrupt; (ii) determining whether the device transmitted the interrupt; (iii) if the device transmitted the interrupt, then indicating that the device did not transmit the interrupt; and (iv) processing work from the device related to the interrupt. 1. A method for handling a device interrupt, comprising:
receiving a device interrupt from one of a plurality of devices; polling a device driver to determine whether a device associated with the device driver transmitted the device interrupt; and receiving indication from the device driver that the device did not send the interrupt, wherein the device did send the interrupt and wherein the device driver processes work from the device related to the interrupt.
24. An article of manufacture for handling a device interrupt, wherein the article of manufacture causes operations to be performed, the operations comprising:
receiving a device interrupt from one of a plurality of devices; polling a device driver to determine whether a device associated with the device driver transmitted the device interrupt; and receiving indication from the device driver that the device did not send the interrupt, wherein the device did send the interrupt and wherein the device driver processes work from the device related to the interrupt.
15. A system for handling a device interrupt, wherein the system is in communication with a plurality of devices, comprising:
a processor; a device driver executed by the processor; and a program executed by the processor to perform: (i) receiving a device interrupt from one of a plurality of devices; (ii) polling a device driver to determine whether a device associated with the device driver transmitted the device interrupt; and (iii) receiving indication from the device driver that the device did not send the interrupt, wherein the device did send the interrupt and wherein the device driver processes work from the device related to the interrupt. 2. The method of
receiving a request for processing resources from the device driver after the device driver indicates that the device did not send the interrupt when the device did send the interrupt; and assigning processing resources to the device driver, wherein the device driver uses the assigned processing resources to process work from the device related to the interrupt.
3. The method of
polling a next device driver to determine whether a next device associated with the next device driver transmitted the interrupt after receiving the indication from the device driver.
4. The method of
receiving indication from the next device driver that the next device did not send the interrupt, wherein the next device did send the interrupt and wherein the next device driver processes work from the next device.
5. The method of
context switching to interrupt handling mode after receiving the device interrupt, wherein the next device driver processes work from the next device before context switching out of the interrupt handling mode.
6. The method of
polling a plurality of next device drivers each associated with one device, wherein each polled device driver is capable of indicating that the device did not send the interrupt when the device associated with the next device driver device did send the interrupt.
7. The method of
9. The method of
requesting processing resources if the device transmitted the interrupt, wherein the requested processing resources are used to process work from the device related to the interrupt.
10. The method of
if the device transmitted the interrupt, then communicating with the device to clear the current interrupt and disable the interrupt at the device.
11. The method of
if the device did not transmit the interrupt, then indicating that the device did not transmit the interrupt.
12. The method of
if the device did not transmit the interrupt, then determining whether there is device related work; and if there is device related work and if the device did not transmit the interrupt, then indicating that the device did not transmit the interrupt and processing the device related work.
13. The method of
14. The method of
16. The system of
receiving a request for processing resources from the device driver after the device driver indicates that the device did not send the interrupt when the device did send the interrupt; and assigning processing resources to the device driver, wherein the device driver uses the assigned processing resources to process work from the device related to the interrupt.
17. The system of
polling a next device driver to determine whether a next device associated with the next device driver transmitted the interrupt after receiving the indication from the device driver.
18. The system of
receiving indication from the next device driver that the next device did not send the interrupt, wherein the next device did send the interrupt and wherein the next device driver processes work from the next device.
19. The system of
21. The system of
requesting processing resources if the device transmitted the interrupt, wherein the requested processing resources are used to process work from the device related to the interrupt.
22. The system of
if the device did not transmit the interrupt, then determining whether there is device related work; and if there is device related work and if the device did not transmit the interrupt, then indicating that the device did not transmit the interrupt and processing the device related work.
23. The system of
25. The article of manufacture of
receiving a request for processing resources from the device driver after the device driver indicates that the device did not send the interrupt when the device did send the interrupt; and assigning processing resources to the device driver, wherein the device driver uses the assigned processing resources to process work from the device related to the interrupt.
26. The article of manufacture of
polling a next device driver to determine whether a next device associated with the next device driver transmitted the interrupt after receiving the indication from the device driver.
27. The article of manufacture of
receiving indication from the next device driver that the next device did not send the interrupt, wherein the next device did send the interrupt and wherein the next device driver processes work from the next device.
28. The article of manufacture of
30. The article of manufacture of
requesting processing resources if the device transmitted the interrupt, wherein the requested processing resources are used to process work from the device related to the interrupt.
31. The article of manufacture of
if the device did not transmit the interrupt, then determining whether there is device related work; and if there is device related work and if the device did not transmit the interrupt, then indicating that the device did not transmit the interrupt and processing the device related work.
32. The article of manufacture of
33. The article of manufacture of
|
1. Field of the Invention
The present invention relates to a method, system, and program for method, system, and program for handling interrupt requests.
2. Description of the Related Art
In many operating systems, such as Microsoft Windows®, Linux®, Unix®, etc. multiple devices may communicate over a bus interface with the operating system interrupt service routine (ISR) using a single interrupt line. (Microsoft and Windows are registered trademarks of Microsoft Corporation, Linux is a registered trademark of Linus Torvalds, UNIX is a registered trademark of The Open Group). One of multiple devices using an interrupt line, would assert an interrupt on the bus to the interrupt line assigned to that device to request or transmit data to the operating system. The operating system would further execute various device driver programs that provide a software interface between the operating system and the device. A device driver includes device specific commands to communicate with and control one attached device. Upon receiving a device interrupt, the operating system ISR would poll each device driver interrupt service routine (ISR) running in the operating system to identify the device driver ISR associated with the device that asserted the interrupt.
In response to receiving the polling request from the operating system ISR asking the device driver ISR whether the interrupt is from the device driver's device, the device driver ISR communicates with the associated device and reads an interrupt status register in the device to determine whether the driver's device sent the interrupt request.
In the Microsoft® Windows® operating system (Microsoft and Windows are registered trademarks of Microsoft Corporation), if the device status registers indicate that the device did send an interrupt request, then the device driver ISR responds to the operating system ISR by claiming the interrupt and requesting a deferred procedure call (DPC) to use to process the device request that is the subject of the interrupt request. If a device driver ISR responds that the interrupt is not from the device associated with the driver, then the operating system ISR determines a next device driver in a chain of device drivers to poll and sends the request to the next device driver ISR in the chain. The operating system ISR continues polling device driver ISRs in the list until one device driver ISR claims the interrupt and requests resources to run the DPC. In non-Windows operating systems, such as Linux or Unix, the interrupt device driver would just perform the interrupt related work; no DPC is involved.
The device driver ISRs will set the value for two flags when called by the operating system ISR. One flag indicates whether the device driver ISR claims the interrupt and another flag indicates whether the device driver is requesting a DPC to handle the interrupt. In the prior art, the device driver ISR will set both flags to either "on" or "off". Thus, if the device driver ISR determines that the interrupt request is from the driver's device, then the device driver sets the flag to indicate claiming the interrupt and sets the DPC flag to indicate a request for a DPC resource to process interrupt related work. If the device driver ISR determines that the interrupt is not from the driver's device, then the device driver sets the flag to indicate that it is not claiming the interrupt and sets the DPC flag to indicate no request for a DPC resource to process interrupt related work.
After one device driver ISR claims the interrupt, the operating system ISR switches context and terminates interrupt service handling. Upon receiving a subsequent interrupt, the operating system ISR will have to switch context to interrupt service handling to locate the device driver to handle the interrupt request. This process to switch context between interrupt service handling and other states requires significant processing resources and time. As device bandwidth increases and as more devices are attached to a computer system, the number of interrupts generated has likewise increased significantly. This increase in the number of interrupts places increased burdens on the operating system because the operating system must repeatedly context switch in and out of interrupt service handling in response to each interrupt request.
For these reasons, there is a need in the art to provide improved techniques for handling device interrupt requests.
Referring now to the drawings in which like reference numbers represent corresponding parts throughout:
In the following description, reference is made to the accompanying drawings which form a part hereof and which illustrate several embodiments of the present invention. It is understood that other embodiments may be utilized and structural and operational changes may be made without departing from the scope of the present invention.
The computer 2 further includes an operating system 12, which may comprise any operating system known in the art, such as a Microsoft Windows® operating system, Linux®, a Unix® type operating system, etc. A bus driver 15 comprises a program that provides an interface between the operating system 12 and the bus 8 to enable communication between the operating system 12 and the devices 10a, 10b . . . 10n that communicate on the bus 8. The operating system 12 includes an interrupt service routine (ISR) component 16 that handles interrupt requests received from the devices 10a, 10b . . . 10n transmitted across interrupt lines (not shown) of the bus 8. The operating system 12 further loads into memory 6 and executes one device driver 18a, 18b . . . 18n for each device 10a, 10b . . . 10n recognized by the operating system 12. The device drivers 18a, 18b . . . 18n each include device specific code to enable communication between the operating system 12 and the devices 10a, 10b . . . 10n. The device drivers 18a, 18b . . . 18n each include an interrupt service routine (ISR) 20a, 20b . . . 20n component to handle interrupt requests from the associated device 10a, 10b . . . 10n. The operating system ISR 16 utilizes a device driver list 22 that identifies all the loaded device drivers 18a, 18b . . . 18n registered with the operating system 12.
Further, in Microsoft® Windows® operating systems, the operating system ISR 16 may assign a deferred procedure call (DPC) 24a, 24b . . . 24n to a device driver 18a, 18b . . . 18n to perform device related work. In non-Windows® operating systems, there is no DPC.
If (at block 156) the device 10a, 10b . . . 10n did not send an interrupt, then the device driver ISR 20a, 20b . . . 20n determines (at block 158) whether there is work to do not necessarily related to an interrupt. The work that is determined may or may not relate to a device interrupt. For instance, the device driver ISR 20a, 20b . . . 20n may read descriptors of packets to determine whether the device 10a, 10b . . . 10n may soon send an interrupt. Additionally, to determine whether there is available work to perform, the device driver ISR 20a, 20b . . . 20n may read a register that counts a number of packets, where the number of packets may indicate that there is work to perform. Other techniques may be used to anticipate any work that may be performed in the near future which will require DPC resources. In this way, the device driver ISR 20a, 20b . . . 20n submits a request for a DPC resource as part of an opportunistic search for anticipated work or interrupts that are likely to be generated. Implementations that require DPC resources concern the Microsoft® Windows® operating system. However, certain non-Windows operating systems do not utilize DPCs, and in such systems, the device driver ISR 20a, 20b . . . 20n performs the work itself without requesting a DPC. In such non-Windows implementations, the device driver ISR may respond by not claiming the interrupt and then proceeding to perform the work.
This opportunistic determination saves resources because an interrupt message is avoided by handling the work before the interrupt is requested. Further, the described implementations conserve operating system resources because a context switch to interrupt handling mode is avoided. If (at block 158) there is no anticipated work, control proceeds to block 164 to transmit the flags 30, 32 (
With respect to
With the described implementations, the device driver ISRs 20a, 20b . . . 20n claim an interrupt by requesting a DPC 24a, 24b . . . 24n, but not formally claiming the interrupt to the operating system ISR 16. This causes the operating system ISR 16 to assign the claiming device driver ISR 20a, 20b . . . 20n sufficient DPC 24a, 24b . . . 24n resources to service the interrupt. However, because the interrupt was not claimed, the operating system ISR 16 continues to check device drivers in the list 22, thereby allowing the operating system ISR 16 to handle a subsequent interrupt request for a device driver 10a, 10b . . . 10n lower down the list 22 without having to utilize processor resources to context switch to interrupt handling mode. Further, with the described implementations, the device driver ISR 20a, 20b . . . 20n may anticipate work to perform and request DPC resources 24a, 24b . . . 24n even when the driver's device did not initiate the interrupt in order to handle an anticipated interrupt request from the device 10a, 10b . . . 10n in a manner that relieves the operating system ISR 16 of the burden of having to handle the interrupt, thereby further conserving operating system resources.
The computer 202 further includes an operating system 212, which may comprise any operating system known in the art, such as a Microsoft Windows® operating system, Linux®, a Unix® type operating system, etc. A bus driver 215 comprises a program that provides an interface between the operating system 212 and the bus 208 to enable communication between the operating system 212 and the devices 210a, 210b . . . 210n that communicate on the bus 208. The operating system 212 includes an interrupt service routine (ISR) component 216 that handles interrupt requests received from the devices 210a, 210b . . . 210n transmitted across an interrupt line (not shown) of the bus 208 or transmitted using an interrupt message, such as a Message Signaled Interrupt (MSI). The operating system 212 further loads into memory 206 and executes one device driver 218a, 218b . . . 218n for each device 210a, 210b . . . 210n recognized by the operating system 212. The device drivers 218a, 218b . . . 218n include device specific code to enable communication between the operating system 212 and the devices 210a, 210b . . . 210n. The device drivers 218a, 218b . . . 218n each include an interrupt service routine (ISR) 220a, 220b . . . 220n component to handle interrupt requests from the associated device 210a, 210b . . . 210n. The operating system ISR 216 utilizes a device driver list 222 that identifies all the loaded device drivers 218a, 218b . . . 218n registered with the operating system 212. Further, as discussed, in Microsoft® Windows® operating systems, the operating system ISR 216 may assign a deferred procedure call (DPC) 224a, 224b . . . 224n to a device driver 218a, 218b . . . 218n to perform device related work. In non-Windows® operating systems, there is no DPC.
The device status registers 214a, 214b . . . 214n may each include the following information:
Interrupt Cause/Status Registers (ICR) 230a, 230b . . . 230n: provides interrupt status information, such as whether an interrupt is pending, a priority of a pending interrupt, etc.
ICR Copy 232a, 232b . . . 232n: a copy of the ICR 230a, 230b . . . 230n value used during operations.
IRQ Required 234a, 234b . . . 234n: flag indicates whether an interrupt request (IRQ) signal needs to be sent to the operating system 212 to notify the operating system 212 of a read/write request to be sent.
With respect to
In certain implementations, the message sent at block 326 may comprise a Message Signaled Interrupt (MSI) as described in Section 6.8 of the "PCI Local Bus Specification", Rev. 2.3, published by the PCI Special Interest Group (Mar. 29, 2002), which publication is incorporated herein by reference in its entirety. In MSI messaging, the device 210a, 210b . . . 210n sends a unique vector via a write transaction to a system address. The device 210a, 210b . . . 210n would encode the message with a unique address that the operating system 212 had assigned to the device 210a, 210b . . . 210n during initialization to enable the operating system 212 to distinguish which device 210a, 210b . . . 210n initiated the message. Alternative techniques known in the art for signaling the interrupt may be used.
The device driver ISR 220a, 220b . . . 220n then sends (at block 360) a message to the driver's device 210a, 210b . . . 210n over the bus 208 to acknowledge the current interrupt with the ICR_Image_Save 240a, 240b . . . 240n value and a message for the device 210a, 210b . . . 210n to disable certain of the device's interrupts, such as those indicated in the ICR 230a, 230b . . . 230n register. This acknowledgment message may include the ICR status read from the ICR_Image_Save 240a, 240b . . . 240n value in local memory 206, which causes the device 210a, 210b . . . 210n to deassert the interrupt request line. The device driver ISR 220a, 220b . . . 220n then claims (at block 362) the interrupt and requests a DPC from the operating system ISR 216 to process the interrupt request and exits.
If (at block 406) the ICR_Image 238a, 238b . . . 238n value is not null, nor otherwise indicates that a new interrupt has been received, then the device driver ISR 220a, 220b . . . 220n sets (at block 412) the ICR_Image_Save 240a, 240b . . . 240n value to the ICR_Image 238a, 238b . . . 238n value and then sets (at block 414) the ICR_Image 238a, 238b . . . 238n value to NULL to indicate that the interrupt has been handled. The device driver ISR 220a, 220b . . . 220n then sends (at block 416) a message to the driver's device 210a, 210b . . . 210n over the bus 208 to acknowledge the current interrupt and to disable the device's interrupts in the manner described above with respect to block 360 in FIG. 8. The described logic of
The described implementations thus reduce the time for the device driver ISR 220a, 220b . . . 220n or DPC 224a, 224b . . . 224n to handle an interrupt by having the device driver ISR 220a, 220b . . . 220n or DPC 224a, 224b . . . 224n access ICR status and other information from local memory 206, instead of having to read ICR status information over the bus 208 from the device status registers 214a, 214b . . . 214n. This improved performance of the device driver ISR 220a, 220b . . . 220n or DPC 224a, 224b . . . 224n further improves the general CPU 204 processing performance by minimizing interrupt handling delays.
In certain implementations, the device driver 220a, 220b . . . 220n or DPC 224a, 224b . . . 224n when acknowledging the interrupt and disabling the device's interrupts, such as performed at block 360 in FIG. 8 and block 420 in
In implementations, where the device transmits an interrupt message using a shared interrupt line, the operating system must poll each device driver, such as described above with respect to
Described implementations provide improved techniques for handling interrupts by having the device write interrupt status information to local memory where the information is available to the device driver. This allows the device driver to access the information locally and avoid having to read the data from the device's registers over a bus.
The described techniques for handling device interrupts may be implemented as a method, apparatus or article of manufacture using standard programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof. The term "article of manufacture" as used herein refers to code or logic implemented in hardware logic (e.g., an integrated circuit chip, Programmable Gate Array (PGA), Application Specific Integrated Circuit (ASIC), etc.) or a computer readable medium, such as magnetic storage medium (e.g., hard disk drives, floppy disks,, tape, etc.), optical storage (CD-ROMs, optical disks, etc.), volatile and non-volatile memory devices (e.g., EEPROMs, ROMs, PROMs, RAMs, DRAMs, SRAMs, firmware, programmable logic, etc.). Code in the computer readable medium is accessed and executed by a processor. The code in which preferred embodiments are implemented may further be accessible through a transmission media or from a file server over a network. In such cases, the article of manufacture in which the code is implemented may comprise a transmission media, such as a network transmission line, wireless transmission media, signals propagating through space, radio waves, infrared signals, etc. Thus, the "article of manufacture" may comprise the medium in which the code is embodied. Additionally, the "article of manufacture" may comprise a combination of hardware and software components in which the code is embodied, processed, and executed. Of course, those skilled in the art will recognize that many modifications may be made to this configuration without departing from the scope of the present invention, and that the article of manufacture may comprise any information bearing medium known in the art.
In the described implementations, the bus interrupt handling implementations are included in a computer to handle interrupts from devices coupled to the bus enabling communication with the computer. In alternative implementations, the bus interrupt handling implementations may be implemented in any type of electronic device communicating with other devices, such as a hand held computer, a palm top computer, a laptop computer, a network switch or router, a telephony device, a network appliance, a wireless device, etc.
In the described embodiments, certain operations were described as being performed by the operating system ISR and device driver. In alterative embodiments, operations described as performed by the operating system ISR may be performed by the device driver ISR, and vice versa.
In the described implementations, the devices communicated an interrupt signal for an I/O request over an interrupt line of the bus. In alternative implementations, the devices may signal an interrupt in a different manner than through a bus interrupt signal.
The illustrated operations of
The foregoing description of various embodiments of the invention has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. It is intended that the scope of the invention be limited not by this detailed description, but rather by the claims appended hereto. The above specification, examples and data provide a complete description of the manufacture and use of the composition of the invention. Since many embodiments of the invention can be made without departing from the spirit and scope of the invention, the invention resides in the claims hereinafter appended.
Patent | Priority | Assignee | Title |
6851006, | Aug 25 2001 | International Business Machines Corporation | Interruption handler-operating system dialog for operating system handling of hardware interruptions |
7409483, | Dec 19 2003 | TAHOE RESEARCH, LTD | Methods and apparatuses to provide message signaled interrupts to level-sensitive drivers |
7552260, | May 16 2007 | Inventec Corporation | Method for dynamically arranging interrupt pins |
7702835, | Feb 03 2005 | Oracle America, Inc | Tagged interrupt forwarding |
7721033, | Dec 03 2004 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Interrupt notification block |
7743194, | Dec 19 2003 | TAHOE RESEARCH, LTD | Driver transparent message signaled interrupts |
8166223, | Dec 19 2003 | TAHOE RESEARCH, LTD | Apparatuses to provide a message signaled interrupt to generate a PCI express interrupt |
Patent | Priority | Assignee | Title |
5530872, | Dec 23 1992 | International Business Machines Corporation | Method and system for directing device driver to service multiple sequential interrupt requests generated by I/O device connected thereto |
5708814, | Nov 21 1995 | Microsoft Technology Licensing, LLC | Method and apparatus for reducing the rate of interrupts by generating a single interrupt for a group of events |
6052739, | Mar 26 1998 | Oracle America, Inc | Method and apparatus for object-oriented interrupt system |
6539447, | May 25 1999 | Elmic Systems, Inc. | Interrupt control system |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Dec 18 2002 | Intel Corporation | (assignment on the face of the patent) | / | |||
Dec 18 2002 | DIAMANT, NIMROD | Intel Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 013617 | /0633 |
Date | Maintenance Fee Events |
Jul 20 2004 | ASPN: Payor Number Assigned. |
Sep 13 2005 | ASPN: Payor Number Assigned. |
Sep 13 2005 | RMPN: Payer Number De-assigned. |
Mar 07 2008 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Sep 22 2011 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Feb 24 2016 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Sep 07 2007 | 4 years fee payment window open |
Mar 07 2008 | 6 months grace period start (w surcharge) |
Sep 07 2008 | patent expiry (for year 4) |
Sep 07 2010 | 2 years to revive unintentionally abandoned end. (for year 4) |
Sep 07 2011 | 8 years fee payment window open |
Mar 07 2012 | 6 months grace period start (w surcharge) |
Sep 07 2012 | patent expiry (for year 8) |
Sep 07 2014 | 2 years to revive unintentionally abandoned end. (for year 8) |
Sep 07 2015 | 12 years fee payment window open |
Mar 07 2016 | 6 months grace period start (w surcharge) |
Sep 07 2016 | patent expiry (for year 12) |
Sep 07 2018 | 2 years to revive unintentionally abandoned end. (for year 12) |