1. Field of the Invention
The present invention relates to program code development. Specifically, the invention relates to apparatus, methods, and systems for debugging source code on complex target platforms.
2. Description of the Related Art
Advances in semiconductors and other computer-related technologies have dramatically increased the computing capacity available to computer-based systems while also fueling a corresponding increase in the size and complexity of the software executed thereon. As a result of the increased power, computer-based systems are required to handle an increasing variety of tasks. For example, computer-based systems are now relied upon for real-time and mission critical applications such as air traffic control, communications, industrial process control, and the like.
Many programs consist of thousands or even millions of lines of source code. The sheer volume of program codes greatly increases the potential for unanticipated side effects commonly known as ‘bugs’. Furthermore, as a result of the size of most computer programs, the source code is often developed by multiple teams of programmers working on different portions or aspects of the program. Each team or individual therein may accomplish similar tasks in a different manner or otherwise produce software that is incompatible with software developed by other teams.
Given the many forms of individual expression and the complexity of many applications, developing source code is often an error prone process that requires considerable design and testing to ensure software quality and reliability. For example, software developers are often required to anticipate a variety of system states and conditions many of which are not obvious and occur infrequently. The conditions and system states to which a program must correctly respond may be timing-dependent or hardware-dependent. Consistent anticipation of all the conditions, states, and dependencies to which program code must respond to remains an elusive challenge of software development tools and methods.
Despite the challenges of software development, the diverse environments in which computer-based systems operate require highly reliable robust software than can recover gracefully from unanticipated states and conditions. Due to the increasing reliance on computer software injust about every aspect of society, finding and eliminating software coding errors has become increasingly important to system usefulness and commercial viability.
“Debugging” is a commonly used term that refers to the process of finding and eliminating coding errors. One form of conventional debugging is often referred to as “interactive debugging” or “source code debugging.” Interactive debugging is typically conducted with a visually oriented “source code debugger” that displays program source code to the developer and facilitates stepping through the program source code while displaying the state of the computer's processor and associated memory to the developer.
To facilitate real time processing conditions, most source code debuggers include the ability to set a “break point” at a specific line of code such as the entry point to a specific function. Once a break point is encountered, the source code debugger halts further execution and thereby facilitates inspection of the computing system. Once at the break point, the developer may “single step” through each line of source code to assess if the program is responding correctly to the conditions and state of the computing system. Despite the tremendous inspection power provided by interactive debugging techniques, providing the stimulus and environment essential to generating a specific system state corresponding to a software error remains problematic.
Currently, software developers and testers use a variety of ad hoc methods and procedures in order to manipulate the computing environment into a system state that reveals a software coding error. For example, a software developer may receive reports from one or more customers indicating that a particular application “crashed” (i.e. failed) within a specific software function. The developer may then attempt to recreate the failure by providing the precise stimulus and inputs that bring the system to the particular internal state that crashes the system. Alternately, in lieu of external stimulus and inputs, the developer may manually change registers and memory locations to bring the system to the particular state that replicates the failure. While commonly used, such techniques are often tedious, error prone, and ineffective in replicating the faulty system state.
Given the aforementioned challenges, what is needed is a more systematic and automatic approach to generating particular system and environmental states corresponding to coding errors. Such an approach would increase the speed and effectiveness of interactive software debugging, resulting in more robust and reliable software in a variety of computing environments.
The present invention has been developed in response to the present state of the art, and in particular, in response to the problems and needs in the art that have not yet been fully solved by currently available software debugging means and methods. Accordingly, the present invention has been developed to provide an apparatus, method, and system for debugging source code that overcome many or all of the above-discussed shortcomings in the art.
In one aspect of the present invention, an apparatus for debugging source code includes a source code debugger configured to display state information and one or more initialization routines configured to initialize a target environment to a particular state. The initialization routines may correspond to a particular target function and may be executed previous to executing a selected target function in order to debug the selected target function under selected states, conditions, and target environments.
In addition to the aforementioned elements, the apparatus for debugging source code may also include a function selector configured to generate an execution request and a task dispatcher configured to dispatch the initialization routines in response to an execution request. In certain embodiments, the function selector generates the execution request in response to selection of the target function by a user.
In one embodiment, the function selector is compiled into the application source code and is displayed on the target platform. In another embodiment, the function selector is integrated into the source code debugger (either on the target platform or on a host,) which sends a message to the task dispatcher to initiate execution of the selected initialization routines and target function within the target environment.
The target environment state generated by the initialization routines may correspond to an application error or error condition. In certain embodiments, the target environment state is generated using information collected from an actual deployed environment. Using information collected from an actual deployed environment facilitates faithful replication of a particular state and associated error conditions.
In one embodiment, the apparatus for debugging source code is equipped with function-independent initialization routines and function-dependent initialization routines. The function-independent initialization routines generate states and conditions that are independent of a particular routine such as a particular system scenario. The function-dependent initialization routines generate states and conditions unique to a particular target function such as data structures passed as parameters to the particular target function.
In another aspect of the present invention, a method for debugging source code includes dispatching at least one initialization routine corresponding to a target function, dispatching the target function, and displaying state information within a source code debugger. The initialization routines initialize the target environment to a particular state. The method may also include collecting state information from a deployed environment and/or collecting state information in response to an application error.
In certain embodiments, dispatching the initialization routines involves dispatching one or more function-independent initialization routines and one or more function-dependent initialization routines. The method may also include recompiling kernel-mode code into user-mode code to facilitate debugging and single stepping through a dispatched target function such as a target function that invokes kernel-mode microcode.
In another aspect of the present invention, a system for debugging source code includes a target environment comprising a target platform including an operating system and a target application, a source code debugger configured to display state information, and one or more initialization routines that initialize the target environment to a particular state. The initialization routines may correspond to a particular target function within the target application. In one embodiment, the user selects the initialization routines and associated target function in order to debug the target function in a particular target environment and associated states and conditions.
The various elements and aspects of the present invention greatly simplify source code development. Rather than generating complex error-prone and often timing-dependent manipulation sequences of registers, memory, peripheral devices, or the like, a user simply selects the initialization routines that generate the particular states and conditions necessary to replicate, isolate, and analyze a particular software error. These and other features and advantages of the present invention will become more fully apparent from the following description and appended claims, or may be learned by the practice of the invention as set forth hereinafter.
In order that the advantages of the invention will be readily understood, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments that are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings, in which:
It will be readily understood that the components of the present invention, as generally described and illustrated in the Figures herein, may be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of the embodiments of the apparatus, method, and system of the present invention, as represented in
Many of the functional units described in this specification have been labeled as modules, in order to more particularly emphasize their implementation independence. For example, a module may be implemented as a hardware circuit comprising custom VLSI circuits or gate arrays, off-the-shelf semiconductors such as logic chips, transistors, or other discrete components. A module may also be implemented in programmable hardware devices such as field programmable gate arrays, programmable array logic, programmable logic devices or the like.
Modules may also be implemented in software for execution by various types of processors. An identified module of executable code may, for instance, comprise one or more physical or logical blocks of computer instructions which may, for instance, be organized as an object, procedure, or function. Nevertheless, the executables of an identified module need not be physically located together, but may comprise disparate instructions stored in different locations which, when joined logically together, comprise the module and achieve the stated purpose for the module.
Indeed, a module of executable code could be a single instruction, or many instructions, and may even be distributed over several different code segments, among different programs, and across several memory devices. Similarly, operational data may be identified and illustrated herein within modules, and may be embodied in any suitable form and organized within any suitable type of data structure. The operational data may be collected as a single data set, or may be distributed over different locations including over different storage devices, and may exist, at least partially, merely as electronic signals on a system or network.
As depicted, the source code debugger 110 facilitates inspection and control of the target processor 170 via the debug interface 130. Typically, various edit fields corresponding to source code variables and data structures and registers on the target processor 170, are displayed on the debug interface 130.
The source code debugger 110 and the debug interface 130 may reside on the target platform 140 or on a host (not shown) in communication with the target platform 140. In certain embodiments, the source code debugger 110 is a separate process on the target platform 140 under control of the debug interface 130. In other embodiments, the source code debugger 110 resides on a host and communicates with the target platform 140 via an emulator (not shown) that also functions as the target processor 170.
The control provided by the source code debugger 110 is limited in that access to system state information is typically restricted to displaying and manipulating processor register values, source code variables and data structures, and memory locations. However, the states and conditions to which software program codes must respond may include the state of peripheral devices—such as registers contained therein—that are not memory mapped and therefore not readily accessible via the debug interface 130. In addition, even when accessible, the amount of state information involved may prove prohibitive to effective development, particularly in light of entry errors typical of user-entered data.
From the above discussion, it can be readily appreciated that a need exists for improved means and methods that facilitate automated initialization of a target environment to a particular system state in order to facilitate isolation and analysis of software errors. Such means and methods would increase the speed and effectiveness of software development in general and software debugging in particular.
The initialization routines 220 initialize the target processor 170 to a particular state. In addition, the initialization routines 220 may also initialize elements of the target environment 120—such as the target application 150, the target platform 140, and peripheral devices associated therewith—to a particular state useful for isolating and analyzing software errors or the like. In order to control the states and conditions to which a target function 160 must respond, one or more initialization routines 220 may be invoked just previous to invocation of the target function 160.
The initialization routines 220 may be custom developed by a developer to generate a specific state corresponding to an anticipated or discovered condition. Custom development facilitates changing state information not readily accessible via the debug a interface of a source code debugger. In addition to anticipated or discovered conditions, the initialization routines 220 may include state information collected from actual deployed systems such as deployed systems in which an error was detected.
In one embodiment, the initialization routines 220 comprise function-independent initialization routines that may be invoked in conjunction with any target function 160, as well as one or more function-dependent initialization routines intended to be invoked with specific target functions 160. The function-independent initialization routines may generate states and conditions that are independent of a particular routine such as a particular system scenario. The function-dependent initialization routines may generate states and conditions unique to a particular target function, such as data structures passed as parameters to the particular target function.
The function selector 310 facilitates selection of a target function 160 that is to be invoked within a target application such as the target application 150 depicted in
In one embodiment, the function selector 310 and the task dispatcher 320 are compiled into a user-mode version of the target application 150. Compilation into a user-mode version of the target application 150 facilitates source code debugging of kernel-mode code such as kernel-mode microcode. In another embodiment, the function selector 310 is integrated into the source code debugger 110, and the task dispatcher 320 is distributed on both the source code debugger 110 and the target application 150.
The depicted source code debugging module 210 leverages the programming power available within a source code development system to the challenges of testing and debugging software code and provides power and flexibility currently not found in integrated debugging environments.
The receive request step 410 receives a function execution request such as the execution request 312 generated by the function selector 310 depicted in
The dispatch target function step 430 dispatches a target function such as one of the target functions 160 depicted in
The display state information step 440 displays state information to a user, such as a software developer, a software tester, a service technician, or the like. In one embodiment, the state information is displayed in a custom manner by display functions included in the target application 150. In another embodiment, the state information is displayed on the debug interface 130.
The present invention facilitates software development and testing in general and isolation, replication, and analysis of software errors in particular. The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.