1. Technical Field
Embodiments generally relate to the evaluation of software failures. More particularly, embodiments relate to the replaying of captured architecture data to evaluate software failures.
2. Discussion
Current techniques of debugging software may involve executing test content on the platform in question and manually pruning the test content in order to isolate the source of the failure. Such an approach could require multiple iterations before the issue is resolved. In addition, pruning the test content may only be feasible when the source of the content is available. Other techniques of debugging software might involve the use of a logic analyzer to take traces of the executed software logic, wherein a full scale analysis of the trace data is conducted. Trends toward multi-core and/or multi-threaded processors, however, could lead to an increase in the number of probe channels as well as an increase in the cost and complexity of logic analyzers. Simply put, conventional approaches to debugging software may be time-consuming and expensive.
The various advantages of the embodiments of the present invention will become apparent to one skilled in the art by reading the following specification and appended claims, and by referencing the following drawings, in which:
Embodiments may provide for a method in which architecture data for software executing on a system is captured. The architecture data may be replayed in a simulator, wherein failure information corresponding to the software can be obtained from the simulator.
Other embodiments may include a computer readable storage medium having a set of stored instructions which, if executed by a processor, cause a computer to capture architecture data for software executed on a system and replay the architecture data in a simulator. The instructions may also cause a computer to obtain failure information from the simulator, wherein the failure information is to correspond to the software.
In addition, embodiments can provide for a method in which firmware of a system is used to periodically capture, in response to a plurality of interrupts, architecture data for software executing on the system. The architecture data might include state data and event data. A format of the architecture data may be converted into a format associated with a simulator, wherein the architecture data can be replayed in the simulator. The method may also provide for obtaining failure information from the simulator, wherein the failure information corresponds to the software.
Turning now to
Generally, the illustrated scheme 10 includes a silicon execution sequence 12 and a simulator execution sequence 14. The silicon execution sequence 12 may be associated with the execution of the software by an integrated circuit such as one or more cores of a general purpose processor, fixed functionality hardware (e.g., embedded microprocessor), etc., wherein the integrated circuit might be fabricated using circuit technology such as application specific integrated circuit (ASIC), complementary metal oxide semiconductor (CMOS) or transistor-transistor logic (TTL) technology, or any combination thereof. In one example, the software has a many interactions and dependencies due to a complex execution environment such as a multi-threaded or multi-core environment.
In the illustrated example, the system is placed under test by beginning execution of the software on the system at execution processing block 16. Arrow instances 18 (18a-18b) represent the issuance of interrupts on a periodic or other basis, wherein the interrupts can initiate the capture of architecture state data 22 by a dump handler 20. The captured architecture state data 22 could include data relating to various aspects of the system architecture such as instruction fetch units, instruction decoders, caches, execution units, registers, etc. As the execution of the software continues at subsequent execution processing blocks 30 and 34, architecture event data 24 can also be captured via event capture processing blocks 26 and 32, respectively. The architecture event data may include memory transaction (e.g., load-store) data and other data. The illustrated sequence 12 continues until a point of failure is encountered at block 28.
Illustrated processing block 44 provides for determining whether the memory transaction data capturing firmware is enabled. If so, one or more addresses accessed by operations of the test software may be identified and captured at block 46. The capture can encompass physical as well as linear addresses involved in each memory access. Other execution data such as the instruction in the execution flow that attempted each memory access and the results of each memory operation in the case of load operations (e.g., changes to flags, registers, etc.), may also be collected. Block 48 provides for packaging the captured addresses and execution data and block 50 provides for storing the packaged information for subsequent conversion and/or transmission to a simulator, as discussed below. In addition, the memory operation can be retired at block 52 without causing any change to the macro- or micro-operation flow of the software under test.
Returning now to
For example, in a system debug usage model, architectural replay could enable rapid triage of issues classified as software failures. One by-product might be the isolation of issues in need of a more detailed debug. Also, failure issues manifesting from environmental and BIOS (basic input/output system) related causes can be identified using the illustrated approach.
In the case of validation, failure information could have an impact on interoperability and/or compatibility, particularly while operating in multi-core/multi-threaded environments. Issues that may surface include, but are not limited to, synchronization issues across cores/threads, inter-processor load/store issues, ordering of inter-processor interrupts, and so on. Accordingly, architectural replay can facilitate rapid root-cause analysis of the underlying failures.
Moreover, the illustrated approach may be incorporated into software development kits which, when tied with other tools such as compilers and threading tools, can be used by equipment manufacturers and software vendors to enable and optimize the software tool chain.
The illustrated processor 56 communicates with a platform controller hub (PCH) 64, also known as a Southbridge in certain systems. The PCH 64 may have internal controllers (not shown) such as USB (Universal Serial Bus, e.g., USB Specification 2.0, USB Implementers Forum), Serial ATA (SATA, e.g., SATA Rev. 3.0 Specification, May 27, 2009, SATA International Organization/SATA-IO), High Definition Audio, and other controllers. The PCH 64 can communicate with a network controller 70, which could provide off-platform communication functionality for a wide variety of purposes such as cellular telephone (e.g., W-CDMA (UMTS), CDMA2000 (IS-856/IS-2000), etc.), WiFi (e.g., IEEE 802.11, 1999 Edition, LAN/MAN Wireless LANS), Bluetooth (e.g., IEEE 802.15.1-2005, Wireless Personal Area Networks), WiMax (e.g., IEEE 802.16-2004, LAN/MAN Broadband Wireless LANS), Global Positioning System (GPS), spread spectrum (e.g., 900 MHz), and other radio frequency (RF) telephony purposes. The illustrated PCH 64 is also coupled to one or more mass storage devices, which may include a hard disk drive (HDD) 66, ROM, optical disk, flash memory, etc. In addition, the PCH 64 could provide support for user interface (UI) devices 68 such as a microphone, display, keypad, mouse, speakers, etc., in order to allow a user to interact with and perceive information from the system 54.
The cores 62 may execute a set of probeless logic instructions (e.g., microcode/firmware) 74, which might be initially loaded from BIOS 72 (e.g., from PROM, NAND-based solid state disk (SSD), or flash memory as a patch), dynamically loaded via a tool, or already resident in the UROM (microROM, not shown) of the processor 56. In the illustrated example, execution of the set of probeless logic instructions 74 causes the system 54 to capture architecture data for the software (e.g., OS and other application program code) executed on the system 54 without impacting the execution of the software under test. In addition the logic instructions 74 may replay the captured architecture data in a simulator, and obtain failure information from the simulator, wherein the failure information corresponds to the software executed on the system 54. As already noted, the architecture data could include state data and event data, wherein in one example, the event data includes memory transaction data.
Embodiments of the present invention are applicable for use with all types of semiconductor integrated circuit (“IC”) chips. Examples of these IC chips include but are not limited to processors, controllers, chipset components, programmable logic arrays (PLA), memory chips, network chips, and the like. In addition, in some of the drawings, signal conductor lines are represented with lines. Some may be thicker, to indicate more constituent signal paths, have a number label, to indicate a number of constituent signal paths, and/or have arrows at one or more ends, to indicate primary information flow direction. This, however, should not be construed in a limiting manner. Rather, such added detail may be used in connection with one or more exemplary embodiments to facilitate easier understanding of a circuit. Any represented signal lines, whether or not having additional information, may actually comprise one or more signals that may travel in multiple directions and may be implemented with any suitable type of signal scheme, e.g., digital or analog lines implemented with differential pairs, optical fiber lines, and/or single-ended lines.
Example sizes/models/values/ranges may have been given, although embodiments of the present invention are not limited to the same. As manufacturing techniques (e.g., photolithography) mature over time, it is expected that devices of smaller size could be manufactured. In addition, well known power/ground connections to IC chips and other components may or may not be shown within the figures, for simplicity of illustration and discussion, and so as not to obscure certain aspects of the embodiments of the invention. Further, arrangements may be shown in block diagram form in order to avoid obscuring embodiments of the invention, and also in view of the fact that specifics with respect to implementation of such block diagram arrangements are highly dependent upon the platform within which the embodiment is to be implemented, i.e., such specifics should be well within purview of one skilled in the art. Where specific details (e.g., circuits) are set forth in order to describe example embodiments of the invention, it should be apparent to one skilled in the art that embodiments of the invention can be practiced without, or with variation of, these specific details. The description is thus to be regarded as illustrative instead of limiting.
Some embodiments may be implemented, for example, using a machine or tangible computer-readable medium or article which may store an instruction or a set of instructions that, if executed by a machine, may cause the machine to perform a method and/or operations in accordance with the embodiments. Such a machine may include, for example, any suitable processing platform, computing platform, computing device, processing device, computing system, processing system, computer, processor, or the like, and may be implemented using any suitable combination of hardware and/or software. The machine-readable medium or article may include, for example, any suitable type of memory unit, memory device, memory article, memory medium, storage device, storage article, storage medium and/or storage unit, for example, memory, removable or non-removable media, erasable or non-erasable media, writeable or re-writeable media, digital or analog media, hard disk, floppy disk, Compact Disk Read Only Memory (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), optical disk, magnetic media, magneto-optical media, removable memory cards or disks, various types of Digital Versatile Disk (DVD), a tape, a cassette, or the like. The instructions may include any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, encrypted code, and the like, implemented using any suitable high-level, low-level, object-oriented, visual, compiled and/or interpreted programming language.
Unless specifically stated otherwise, it may be appreciated that terms such as “processing,” “computing,” “calculating,” “determining,” or the like, refer to the action and/or processes of a computer or computing system, or similar electronic computing device, that manipulates and/or transforms data represented as physical quantities (e.g., electronic) within the computing system's registers and/or memories into other data similarly represented as physical quantities within the computing system's memories, registers or other such information storage, transmission or display devices. The embodiments are not limited in this context.
The term “coupled” is used herein to refer to any type of relationship, direct or indirect, between the components in question, and may apply to electrical, mechanical, fluid, optical, electromagnetic, electromechanical or other connections. In addition, the terms “first”, “second”, etc. are used herein only to facilitate discussion, and carry no particular temporal or chronological significance unless otherwise indicated.
Those skilled in the art will appreciate from the foregoing description that the broad techniques of the embodiments of the present invention can be implemented in a variety of forms. Therefore, while the embodiments of this invention have been described in connection with particular examples thereof, the true scope of the embodiments of the invention should not be so limited since other modifications will become apparent to the skilled practitioner upon a study of the drawings, specification, and following claims.
Number | Name | Date | Kind |
---|---|---|---|
5513315 | Tierney et al. | Apr 1996 | A |
6145099 | Shindou | Nov 2000 | A |
7380235 | Fathalla | May 2008 | B1 |
7747844 | McCormick et al. | Jun 2010 | B2 |
7904373 | Kimle et al. | Mar 2011 | B2 |
8103497 | Nemecek et al. | Jan 2012 | B1 |
8135572 | Crawford et al. | Mar 2012 | B2 |
8402318 | Nieh et al. | Mar 2013 | B2 |
8578342 | Artzi et al. | Nov 2013 | B2 |
20030018461 | Beer et al. | Jan 2003 | A1 |
20030126505 | Lacey | Jul 2003 | A1 |
20030200491 | Woo et al. | Oct 2003 | A1 |
20040268331 | Mitchell et al. | Dec 2004 | A1 |
20050010880 | Schubert et al. | Jan 2005 | A1 |
20050071499 | Batra et al. | Mar 2005 | A1 |
20060015852 | Parkinson et al. | Jan 2006 | A1 |
20060155525 | Aguilar et al. | Jul 2006 | A1 |
20060156157 | Haselden et al. | Jul 2006 | A1 |
20070011517 | Boyce | Jan 2007 | A1 |
20070192079 | Rompaey et al. | Aug 2007 | A1 |
20080046696 | Vertes | Feb 2008 | A1 |
20080177525 | Crawford et al. | Jul 2008 | A1 |
20080189246 | Lloyd | Aug 2008 | A1 |
20080243463 | Lovas et al. | Oct 2008 | A1 |
20080243572 | Amos | Oct 2008 | A1 |
20080270958 | Ng et al. | Oct 2008 | A1 |
20080281575 | Okamura et al. | Nov 2008 | A1 |
20090089320 | Tendler et al. | Apr 2009 | A1 |
20090119549 | Vertes | May 2009 | A1 |
20090133033 | Lindo et al. | May 2009 | A1 |
20090210752 | Bartik et al. | Aug 2009 | A1 |
20090248381 | Liu et al. | Oct 2009 | A1 |
20100107158 | Chen et al. | Apr 2010 | A1 |
20100319004 | Hudson et al. | Dec 2010 | A1 |
20110061050 | Sahita et al. | Mar 2011 | A1 |
20110185153 | Henry et al. | Jul 2011 | A1 |
20110202483 | Bergman et al. | Aug 2011 | A1 |
20110320892 | Check et al. | Dec 2011 | A1 |
Number | Date | Country |
---|---|---|
64-052062 | Feb 1989 | JP |
01-251142 | Oct 1989 | JP |
08-063368 | Mar 1996 | JP |
08-147191 | Jun 1996 | JP |
08-314817 | Nov 1996 | JP |
10-111815 | Apr 1998 | JP |
2009-037574 | Feb 2009 | JP |
2012009105 | Jan 2012 | WO |
Entry |
---|
International Search Report and Written Opinion received for PCT application No. PCT/US2011/041086, mailed on Jan. 2, 2012, 7 pages. |
Preliminary Report on Patentability received for PCT application No. PCT/US2011/041086, mailed on Jan. 10, 2013, 7 pages. |
Office Action received for Japanese Patent Application No. 2013-513420, mailed on Nov. 26, 2013, 2 pages of Office Action and 2 pages of English Translation. |
Office Action received for Korean Patent Application No. 10-2012-7030614, mailed on Apr. 29, 2014, 5 pages of Korean Office Action and 5 pages of English Translation. |
Notice of Allowance received for Japanese Patent Application No. 2013-513420, mailed on Mar. 25, 2014, 1 page of Notice of Allowance only. |
Number | Date | Country | |
---|---|---|---|
20110320877 A1 | Dec 2011 | US |