US7694182B2 - Debugging system and method - Google Patents
Debugging system and method Download PDFInfo
- Publication number
- US7694182B2 US7694182B2 US11/520,806 US52080606A US7694182B2 US 7694182 B2 US7694182 B2 US 7694182B2 US 52080606 A US52080606 A US 52080606A US 7694182 B2 US7694182 B2 US 7694182B2
- Authority
- US
- United States
- Prior art keywords
- task
- debugging
- setting
- switch
- break
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related, expires
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3664—Environments for testing or debugging software
Definitions
- OSs operating systems
- Application programs that operate on a multitask OS are processed in executable units that are called tasks, or may be called processes depending on the OS.
- a plurality of executable units that belong to a same process and share microcomputer resources are called a thread.
- the executable units that operate in a multitask environment are called tasks, unless a particular distinction is being made between an executable unit being a process or a thread.
- Linux if one application program is run as a plurality of processes, the same memory resources are shared when one process is run as a plurality of threads.
- MMU memory management unit
- Linux uses a virtual storage function, and tasks operate in a logical address space.
- each process operates in a different logical address space, but physical address space is shared.
- the threads run in the same logical address space and share physical address space.
- a failure may occur in the operations of a running task that is not a target of debugging, due to a break stop occurring based on a break setting set for another task and an instruction rewritten for debugging being executed.
- This technique suppresses unnecessary breaks in running tasks that are not a target of debugging, thus enabling the tasks to run normally, and improving debugging efficiency in a multitask environment.
- the present invention has an object of providing a debugging system and method in which, in a multitask environment, a break setting for a task that is a target of debugging does not affect operations of tasks that are not a target of debugging.
- the present invention is a debugging system that, in an execution environment in which a plurality of tasks are run successively by being switched between according to a divided time schedule, executes debugging by performing debugging setting and debugging cancellation, the debugging setting being processing for rewriting part of original recording content in a memory area shared by at least two of the tasks, and the debugging cancellation being processing for restoring the original recording content
- the debugging system including: an address space storage unit operable to store, in association with each of the plurality of tasks, a physical address space range that the associated task uses in the memory area; a setting information storage unit operable to store setting information that shows a plurality of target tasks in association with address information, each target task being a task among the plurality of tasks that is a target of debugging, and the address information specifying a physical address at which the debugging setting for the associated target task is set; and a setting control unit operable to, when a task switch occurs, if a next task to be run is a target task
- the present invention is a debugging method that, in an execution environment in which a plurality of tasks are run successively by being switched between according to a divided time schedule, executes debugging by performing debugging setting and debugging cancellation, the debugging setting being processing for rewriting part of original recording content in a memory area shared by at least two of the tasks, and the debugging cancellation being processing for restoring the original recording content
- the debugging method including: an address space storage unit operable to store, in association with each of the plurality of tasks, a physical address space range that the associated task uses in the memory area; and a setting information storage unit operable to store setting information that shows a plurality of target tasks in association with address information, each target task being a task among the plurality of tasks that is a target of debugging, and the address information specifying a physical address at which the debugging setting for the associated target task is set, and the debugging method including: a setting control step of, when a task switch occurs, if a next task to be
- the present invention is able to control such that debugging settings for tasks other than the next task do not affect operations of the next task.
- the setting control unit may further include: a first setting unit operable to, when any of the plurality of tasks is to be run and if the task to be run is a target task, perform debugging setting only at the physical address specified by the address information associated with the task to be run; a second setting unit operable to, each time a task switch period is subsequently arrived at and if a task to be run next is a target task, perform debugging setting only at the physical address specified by the address information associated with the task to be run next; and a cancellation unit operable to, if a pre-switch task is a target task, perform debugging cancellation with respect to the physical address of the debugging setting of the pre-switch task, the pre-switch task being a task running before the task switch.
- a first setting unit operable to, when any of the plurality of tasks is to be run and if the task to be run is a target task, perform debugging setting only at the physical address specified by the address information associated with the task to be run
- the setting control step may include: a first setting step of, when any of the plurality of tasks is to be run and if the task to be run is a target task, performing debugging setting only at the physical address specified by the address information associated with the task to be run; a second setting step of, each time a task switch period is subsequently arrived at and if a task to be run next is a target task, performing debugging setting only at the physical address specified by the address information associated with the task to be run next; and a cancellation step of, if a pre-switch task is a target task, performing debugging cancellation with respect to the physical address of the debugging setting of the pre-switch task, the pre-switch task being a task running before the task switch.
- debugging setting and cancellation is performed only in the physical address of a task that is a target of debugging setting. Therefore, processing for debugging setting and cancellation when a task switch occurs is minimal, and the processing load required for debugging setting and cancellation can be kept to a minimum.
- the setting control unit may further include: a setting judgment unit operable to, each time a task switch period is reached, judge whether or not the pre-switch task and a post-switch task are both target tasks, the post-switch task being a task to be run after the pre-switch task; and an address judgment unit operable to, when the setting judgment unit judges that the pre-switch task and the post-switch task are both target tasks, judge whether or not the physical address specified by the address information of the pre-switch task and the physical address specified by the address information of the post-switch task match each other, and the second setting unit performs the debugging setting and the cancellation unit performs the debugging cancellation only if the physical addresses of the pre-switch task and the post-switch task are judged not to match each other.
- a setting judgment unit operable to, each time a task switch period is reached, judge whether or not the pre-switch task and a post-switch task are both target tasks, the post
- the setting control step may further include: a setting judgment step of, each time a task switch period is reached, judging whether or not the pre-switch task and a post-switch task are both target tasks, the post-switch task being a task to be run after the pre-switch task; and an address judgment step of, when the setting judgment step judges that the pre-switch task and the post-switch task are both target tasks, judging whether or not the physical address specified by the address information of the pre-switch task and the physical address specified by the address information of the post-switch task match each other, and the second setting step performs the debugging setting and the cancellation step performs the debugging cancellation only if the physical addresses of the pre-switch task and the post-switch task are judged not to match each other.
- the setting control unit may further include: a sharing judgment unit operable to, each time a task switch period is reached, judge whether or not the pre-switch task and a post-switch task share a physical address space range, the post-switch task being a task to be run after the task switch, and the cancellation unit performs debugging cancellation only if the pre-switch task and the post-switch task share a physical address space range.
- a sharing judgment unit operable to, each time a task switch period is reached, judge whether or not the pre-switch task and a post-switch task share a physical address space range, the post-switch task being a task to be run after the task switch
- the cancellation unit performs debugging cancellation only if the pre-switch task and the post-switch task share a physical address space range.
- the setting control step may further include: a sharing judgment step of, each time a tasks witch period is reached, judging whether or not the pre-switch task and a post-switch task share a physical address space range, the post-switch task being a task to be run after the task switch, and the cancellation step performs debugging cancellation only if the pre-switch task and the post-switch task share a physical address space range.
- FIG. 1 is a function block diagram showing the structure of a debugging system 100 of a first embodiment of the present invention
- FIG. 2 is a function block diagram showing the structure of a debugging device 10 ;
- FIG. 3 showing a specific example of a break setting table
- FIG. 4 is a visual representation of a page table
- FIG. 5 shows a specific example of task management information
- FIG. 6 is a visual representation of an address conversion process performed by a multitask OS unit 101 ;
- FIG. 7 is a flowchart showing operations for task switch processing A performed by the multitask OS unit 101 ;
- FIG. 8 is a flowchart showing operations for break setting registration processing performed by a break setting unit 102 ;
- FIG. 9 is a flowchart showing break setting processing A performed by the break setting unit 102 ;
- FIG. 10 is a flowchart showing operations for break cancellation processing A performed by a break cancellation unit 103 ;
- FIG. 11 is a flowchart showing operations for task switch processing B performed by a multitask OS unit 201 ;
- FIG. 12 is a flowchart showing operations for break setting processing B performed by a break setting unit 202 ;
- FIG. 13 is a flowchart showing operations for break cancellation processing B performed by a break cancellation unit 203 ;
- FIG. 14 is a flowchart showing operations for break setting processing C performed by a break setting unit 302 ;
- FIG. 15 is a flowchart showing operations for task switch processing C performed by a multitask OS unit 301 ;
- FIG. 16 is a flowchart showing operations for break cancellation processing C performed by a break cancellation unit 303 ;
- FIG. 17 is a flowchart showing operations for task switch processing D performed by a multitask OS unit 401 ;
- FIG. 18 is a flowchart showing operations for break cancellation processing D performed by a break cancellation unit 403 ;
- FIG. 19 is a flowchart showing operations for task switch processing E performed by a multitask OS unit 501 ;
- FIG. 20 is a flowchart showing operations for break cancellation processing E performed by a break cancellation unit 503 ;
- FIG. 21 is a flowchart showing operations for break setting deletion processing performed by the break cancellation unit 103 ;
- FIG. 22 is a function block diagram showing the structure of a debugging device 20 included in a debugging system 200 ;
- FIG. 23 is a function block diagram showing the structure of a debugging device 30 included in a debugging system 300 ;
- FIG. 24 is a function block diagram showing the structure of a debugging device 40 included in a debugging system 400 ;
- FIG. 25 is a function block diagram showing the structure of a debugging device 50 included in a debugging system 500 ;
- FIG. 26 is a flowchart showing operations for break cancellation processing D′ performed by a break cancellation unit 403 .
- the terminals 1 to 3 are connected to the debugging device 10 with respective communication lines.
- Each of the terminals 1 to 3 has a function of outputting various commands to the debugging device 10 via the respective communication line, receiving a processing result from the debugging device 10 based on the particular output command, and displaying the result on a display unit (not illustrated).
- the debugging device 10 has a function of loading an application program to a physical address space in a RAM 12 in accordance with an application program execution command from any of the terminals 1 to 3 , executing a task by executing the application program under the control of a multitask OS 11 , and transmitting the execution result to the one of the terminals 1 to 3 that requested execution of the application program.
- the debugging device 10 If a command received from the one of the terminals 1 to 3 is an execution instruction for an application program that is a debugging target, the debugging device 10 creates a break instruction by rewriting an original instruction that is recorded in an address, in a physical address space of the RAM 12 , that is associated with an address in a logical address space registered in a break setting table (described later). The debugging device 10 then runs the application program that is a target of debugging under the control of the multitask OS 11 , and when the break instruction is detected, stops the application, and transmits a processing result to the one of the terminals 1 to 3 .
- FIG. 1 shows a specific example of a task 1 running as a result of input of an application program execution command from the terminal 1 , a task 2 running as a result of input of an application program execution command from the terminal 2 , and a task 3 running as a result of input of an application program execution command from the terminal 3 .
- FIG. 1 also shows that task 1 , task 2 and task 3 share a memory area in the RAM 12 .
- FIG. 2 is a function block diagram showing the structure of the debugging device 10 .
- the debugging device 10 is composed of a multitask OS unit 101 , a break setting unit 102 , a break cancellation unit 103 , a communication unit 104 , an application storage unit 105 , a page table storage unit 106 , a task management information storage unit 107 , and a break setting table storage unit 108 .
- the multitask OS unit 101 is composed of a CPU, an MMU (memory management unit), and a ROM/RAM 12 that includes the multitask OS 11 .
- the multitask OS unit 101 has a function of executing application programs and performing time division control of execution of tasks caused by the application programs.
- the application storage unit 105 has a function of storing application programs that are a target of debugging and application programs that are not a target of debugging.
- the page table storage unit 106 has a function storing a page table.
- the page table is a table that is created and managed by the multitask OS unit 101 , and is for converting a logical address referenced by an running task into a physical address in the RAM 12 . More specifically, the multitask OS unit 101 segments the logical address space range referenced by tasks into a plurality of blocks (hereinafter, each block is called a “logical page”) based on ranges of logical addresses, and allocates physical address ranges (hereinafter, called a “physical pages”) of a size corresponding to the block units.
- the page table shows, for each task, the correlation between each logical page and the head physical address (hereinafter, called the “base address”) in the physical page allocated to the logical page.
- each logical page is 4 Kbytes.
- the base address of the corresponding physical page is the lowest 12 bits of the logical address are added to the base address of the corresponding physical page as an offset value, based on which conversion from the logical address to the physical address is performed.
- FIG. 4 is a visual representation of the page table. As shown in FIG. 4 , the logical page that each logical address belongs to is specified based on the logical address range, and each specified logical page is allocated a physical page of the same size in the RAM 12 .
- FIG. 6 is a visual representation of the address conversion process performed by the multitask OS unit 101 .
- FIG. 6 shows a specific example of a process for converting a logical address K referenced by task 1 to a physical address.
- the page table ( 602 in FIG. 6 , for convenience assumed to be identical in content to the page table in FIG. 4 ) is used to specify the logical page L 1 to which the logical address K belongs ( 603 in FIG. 6 ), and the page table is further used to specify the base address 1 in the physical page PH 1 that is associated with the logical page L 1 ( 604 in FIG. 6 ).
- the physical address corresponding to the logical address K is calculated based on the specified base address 1 and the offset value of the logical address K ( 605 in FIG. 6 ).
- the task management information storage unit 107 stores task management information.
- the task management information is information expressing sets of the following correlated items: an identifier of a task that is a target of time division control; status information showing the run status of the task; a value of a stack pointer showing the save-destination of the context of the task; and a task priority showing the run priority of the task at the current point in time.
- the task management information is created and managed by the multitask OS unit 101 .
- FIG. 5 shows a specific example of the task management information.
- the break setting unit 102 performs break setting registration processing and break setting processing.
- Break setting refers to designating an instruction for stopping a running application program part way through and the point to stop the application program, according to a logical address.
- the break setting unit 102 analyses the registration command, specifies the task identifier, the logical address set as a break, and the break type designated by the registration command, and registers the specified task identifier, logical address, and break type in the break setting table.
- a plurality of break settings may be registered in the break setting table with respect to one task.
- the break setting table is a table expressing sets of the following correlated items: a task identifier, the logical address of a break setting set with respect to the task, and the break type.
- the break type is an identifier showing whether the type of the break setting is a software break or a hardware break.
- a software break is a break setting whereby a running application program is stopped by rewriting an original instruction in the application program at a specified logical address into an instruction for stopping the application program (hereinafter, an instruction for stopping the application program is called a “break instruction”).
- a hardware break is a break setting whereby a logical address that shows a stop position in the application program (hereinafter, this logical address is called a “break address”) is set in the CPU register, and when the CPU references the set logical address or executes the instruction at this logical address, the running application program stops part way through.
- the break setting is a software break
- the original instruction rewritten with the break instruction is saved to the break setting table, and stored in the break setting table in association with the corresponding task identifier and logical address.
- the break setting unit 102 obtains, from the multitask OS unit 101 , the task identifier of the next task to be run, specifies the task identifier of the next task to be run, and judges whether or not the specified task identifier is registered in the break setting table (described later). If the task identifier is registered, the multitask OS unit 101 further judges, based on the break type associated with the task identifier in the break setting table, whether or not the break setting is a hardware break or a software break. If the break setting is a hardware break, the multitask OS unit 101 sets the registered logical address in the register.
- the multitask OS unit 101 obtains the physical address in the RAM 12 corresponding to the logical address registered in the break setting table, saves the original instruction stored at the physical address to the break setting table, and writes a break instruction at the physical address.
- the break cancellation unit 103 performs break setting deletion processing and break setting cancellation processing.
- the break cancellation unit 103 analyses the deletion command, specifies the task identifier, logical address and break type specified by the deletion command, and deletes the break setting having the specified task identifier, logical address and break type from the break setting table.
- the break cancellation unit 103 obtains the task identifier of the stopped task from the multitask OS unit 101 , and judges whether or not the obtained task identifier is registered in the break setting table. If the obtained task identifier is registered in the break setting table, the break cancellation unit 103 further judges, based on the break type associated with the break identifier in the break setting table, whether the registered break setting is a software break or a hardware break. If the registered break setting is a hardware break, the break cancellation unit 103 cancels the setting of the break address in the register.
- the communication unit 104 receives various commands input from the terminals 1 to 3 , and outputs each command to the multitask OS unit 101 , the break setting unit 102 , the break cancellation unit 103 or the communication 104 , as appropriate.
- the break setting table storage unit 108 stores the break setting table.
- One specific example of the break setting table is that shown in FIG. 3 .
- FIG. 8 is a flowchart showing operations for break setting registration processing performed by the break setting unit 102 .
- the break setting unit 102 analyzes the registration command (step S 802 ), specifies the task identifier, the logical address of the break setting and the break type designated by the registration command (step S 803 ), and registers the specified task identifier, logical address, and the break type in the break setting table (step S 804 ).
- FIG. 21 is a flowchart showing operations for break setting deletion processing performed by the break cancellation unit 103 .
- the break cancellation unit 103 analyses the deletion command (step S 2102 ), specifies the task identifier, logical address and break type designated by the deletion command (step S 2103 ), and deletes the specified task identifier, logical address and break type from the break setting table (step S 2104 ).
- FIG. 7 is a flowchart showing operations for task switch processing A performed by the multitask OS unit 101 .
- step S 701 When a dispatch (task switch) occurs (step S 701 ), the multitask OS unit 101 stops the running task (step S 702 ), and stores the context (register set, program counter, status register, and so on) of the running task to a memory area (stack area) allocated to the task in the RAM 12 , thereby saving the context (step S 703 ).
- the multitask OS unit 101 then rewrites, with the value of the save destination stack pointer, the value of the stack pointer associated with the task identifier in the task management information stored in the task management information storage unit 107 , updates the task priority and the status information of the task, and moves control to the break setting unit 102 which it causes to execute break setting processing A (described later, step S 704 ).
- the multitask OS unit 101 After further moving the control to the break cancellation unit 103 and causing it to execute break cancellation processing A that is described later (step S 705 ), the multitask OS unit 101 refers to the task priorities in the task management information to select the task having the highest task priority as the task to be run next, reads the context of the selected task from the save destination of the context showing the stack pointer of the selected task, restores the context (step S 706 ), and runs the task (step S 707 ).
- FIG. 9 is a flowchart showing operations of break setting processing A performed by the break setting unit 102 .
- the break setting unit 102 obtains, from the multitask OS unit 101 , the task identifier of the next task to be run, specifies the task identifier of the next task to be run, and refers to the break setting table stored in the break setting table storage unit 108 to make a search as to whether or not a break setting is registered for the task identifier (step S 901 ). If a break setting is registered for the task identifier (step S 902 :Y), the break setting unit 102 judges whether or not the break type of the break setting is a software break (step S 903 ).
- the break setting unit 102 notifies the logical address at which the break setting is set to the multitask OS unit 101 , causes the multitask OS unit 101 to specify the physical address in the RAM 12 of the logical address, obtains the specified physical address from the multitask OS unit 101 , and saves the original instruction stored at the physical address, by storing the original address and the task identifier and logical address of the break setting in association in the break setting table (step S 904 ).
- step S 903 If the judgment is negative at step S 903 (step S 903 :N), the break setting unit 102 sets the break address in a register of the CPU (step S 906 ).
- step S 902 If the judgment is negative at step S 902 (step S 902 :N), the break setting unit 102 ends the break setting processing A.
- FIG. 10 is a flowchart showing operations for break cancellation processing A performed by the break cancellation unit 103 .
- the break cancellation unit 103 obtains the identifier of a stopped task from the multitask OS unit 101 , and refers to the break setting table stored in the break setting table storage unit 108 to make a search as to whether or not a break setting is registered for the task identifier (step S 101 ). If a break setting is registered for the task identifier (step S 102 :Y), the break cancellation unit 103 judges whether or not the break type of the break setting is a software break (step S 103 ).
- step S 103 If the judgment is negative at step S 103 (step S 103 :N), the break cancellation unit 103 cancels the break address setting in the register of the CPU (step S 105 ).
- step S 102 If the judgment is negative at step S 102 (step S 102 :N), the break cancellation unit 103 ends the break cancellation processing A.
- break setting processing and break cancellation processing are performed each time a tasks witch occurs.
- break setting processing and break cancellation processing when a break setting has been made for the next task to be run that is the same as the break setting for the directly preceding stopped task, break setting processing and break cancellation processing when task switching occurs are omitted. This enables task switch processing to be performed quickly.
- the debugging system 200 differs from the debugging system 100 of the first embodiment only in terms of structure described below, and other compositional elements are identical. Consequently, a function block diagram showing the structure of the debugging system 200 is omitted. This also applies to debugging systems 300 , 400 and 500 described later.
- compositional elements that are the same as in the debugging system 100 in the first embodiment, and focuses on those that differ.
- FIG. 22 is a function block diagram showing the structure of a debugging device 20 .
- the debugging device 20 is composed of a multitask OS unit 201 , a break setting unit 202 , a break cancellation unit 203 , the communication unit 104 , the application storage unit 105 , the page table storage unit 106 , the task management information storage unit 107 , and the break setting table storage unit 108 .
- compositional elements that are the same as those in the debugging device 10 of the first embodiment have the same reference numbers thereas.
- the break setting unit 202 obtains, from the multitask OS unit 201 , the respective task identifiers of the stopped task and the task that is to be run next, specifies the two task identifiers, and refers to the break setting table stored in the break setting table storage unit 108 to make a search as to whether or not a break setting is registered for both the task identifiers (step S 121 ).
- the multitask OS unit 201 refers to the page table stored in the page table storage unit 106 to specify the physical addresses associated with the notified logical addresses, and notifies the physical addresses to the break setting unit 202 .
- step S 122 If it is judged that a break setting is not registered for both the task identifiers at step S 122 (step S 122 :N), and if a break setting is registered only for the next task to be run (step S 125 :Y), the break setting unit 202 moves to the processing at step S 126 .
- step S 125 If the judgment at step S 125 is negative (step S 125 :N), the break setting unit 202 ends the break setting processing B.
- step S 131 to step S 135 differs from the break cancellation processing A of the first embodiment, and the processing at step S 136 to step S 139 is the same as the processing at step S 103 to step S 106 in the break cancellation processing B of FIG. 10 .
- step S 131 to step S 135 The following describes the processing at step S 131 to step S 135 , and omits a description of the other processing.
- the multitask OS unit 201 refers to the page table stored in the page table storage unit 106 to specify the respective physical pages associated with the notified logical addresses, and notifies the physical pages to the break cancellation unit 203 .
- step S 135 If the judgment at step S 135 is negative (step S 135 :N), the break cancellation unit 203 ends the break cancellation processing B.
- break setting processing and break cancellation processing are performed each time a task switch occurs.
- all break settings registered in the break setting table are performed first, and then all of the break settings whose physical address differs from that of the task to be run next are cancelled.
- compositional elements that are the same as in the debugging system 100 in the first embodiment, and focuses on those that differ.
- FIG. 15 is a flowchart showing operations for task switch processing C performed by the multitask OS unit 301 .
- the task switch processing C differs from the task switch processing A in the first embodiment in terms of the contents of break setting processing and break cancellation processing shown at step S 704 and step S 705 , respectively.
- FIG. 14 is a flowchart showing operations for break setting processing C performed by the break setting unit 302 .
- the break setting unit 302 makes a search of the break settings registered in the break setting table (step S 141 ), and, for each one of the break settings found as a result of the search, judges whether or not the break setting is a software break, based on the break type of the break setting (step S 142 ).
- the break setting unit 302 notifies the logical address set for the break setting to the multitask OS unit 301 , causes the multitask OS unit 301 to specify the physical address in the RAM 12 of the logical address, obtains the specified physical address from the multitask OS unit 301 , and saves the original instruction stored in the logical address, by storing the original address and the task identifier and logical address of the break setting in association in the break setting table (step S 143 ).
- the break setting unit 302 then performs break setting by writing a break instruction to the physical address of the original instruction (step S 144 ), and judges whether or not the break setting table has been searched for all registered break settings (step S 146 ). If the search is complete (step S 146 :Y), the break setting unit 302 ends the break setting processing C. If the search is not complete (step S 146 :N), the break setting unit 302 moves to the processing at step S 141 .
- step S 142 If the judgment is negative at step S 142 (step S 142 :N), the break setting unit 302 sets the break address in a register of the CPU (step S 145 ).
- the break cancellation unit 303 obtains the identifier of the next task to be run from the multitask OS unit 301 , and refers to the break setting table stored in the break setting table storage unit 108 to make a search as to whether or not a break setting is registered for a task identifier other than the task identifier of the next task to be run (step S 161 ).
- step S 162 If a break setting is registered for another task identifier (step S 162 :Y), the break cancellation unit 303 notifies, to the multitask OS unit 301 , the respective logical addresses of the break setting of the other task identifier and the task identifier of the next task to be run, obtains the respective physical pages to which the logical addresses belong, from the multitask OS unit 301 , and judges whether or not the two share a physical page (step S 163 ).
- the multitask OS unit 301 refers to the page table stored in the page table storage unit 106 to specify the physical pages associated with the notified logical addresses, and notifies the physical pages to the break cancellation unit 303 .
- step S 163 if the logical addresses share a physical page (step S 163 :Y), the break cancellation unit 303 judges whether or not the respective offset values of the logical addresses match (step S 164 ). If the offset values match (step S 164 :Y), the break cancellation unit 303 moves to the processing at step S 168 , and if the offset values do not match (step S 164 :N), the break cancellation unit 303 judges whether or not the break type is a software break (step S 165 ).
- the break cancellation unit 303 notifies the logical address at which the break setting is set to the multitask OS unit 301 , causes the multitask OS unit 301 to specify the physical address in the RAM 12 of the logical address, obtains the specified physical address from the multitask OS unit 301 , and writes the original instruction saved to the break setting table with respect to the break setting to the obtained physical address, thereby restoring the original instruction (step S 166 ).
- the break cancellation unit 303 judges whether or the break setting table has been searched for all break settings registered with respect to all identifiers other than the identifier of the next task to be run (step S 168 ). If the search is complete (step S 168 :Y), the break cancellation unit 303 ends the break cancellation processing C. If the search is not complete (step S 168 :N), the break cancellation unit 303 moves to the processing at step S 161 .
- step S 165 If the judgment is negative at step S 165 (step S 165 :N), the break cancellation unit 303 cancels the break address setting in the register of the CPU (step S 167 ).
- step S 162 If the judgment is negative at step S 162 (step S 162 :N), the break cancellation unit 303 ends the break cancellation processing C.
- step S 163 If the judgment is negative at step S 163 (step S 163 :N), the break cancellation unit 303 moves to the processing at step S 165 .
- break cancellation processing is performed each time a task switch occurs.
- break setting is performed in the same manner as in the first embodiment when a task switch occurs, and if the next task to be run and the stopped task do not share a physical page, break cancellation processing is omitted. This lightens the processing load for break cancellation processing.
- compositional elements that are the same as in the debugging system 100 in the first embodiment, and focuses on those that differ.
- FIG. 24 is a function block diagram showing the structure of a debugging device 40 included in the debugging system 400 .
- the debugging device 40 is composed of a multitask OS unit 401 , the break setting unit 102 , a break cancellation unit 403 , the communication unit 104 , the application storage unit 105 , the page table storage unit 106 , the task management information storage unit 107 , and the break setting table storage unit 108 .
- compositional elements that are the same as those in the debugging device 10 of the first embodiment have the same reference numbers there as.
- FIG. 17 is a flowchart showing operations for task switch processing D performed by the multitask OS unit 401 .
- the task switch processing D differs from the task switch processing A in the first embodiment in terms of the contents of break cancellation processing A shown at step S 705 .
- FIG. 18 is a flowchart showing operations for break cancellation processing D performed by the break cancellation unit 403 .
- the break cancellation unit 403 obtains the respective task identifiers of the stopped task and the next task to be run from the multitask OS unit 401 , then, via the multitask OS unit 401 , specifies physical page allocated to the next task to be run and the physical page allocated to the stopped task, and compares the respective specified physical pages (step S 181 ), to judge whether the two tasks share a physical page (step S 182 ).
- the break cancellation unit 403 refers to the break setting table to make a search as to whether or not a break setting is registered for the task identifier of the stopped task (step S 183 ). If a break setting is registered for the task identifier of the stopped task (step S 184 :Y), the break cancellation unit 403 judges whether or not the break setting for the stopped task identifier is a software break (step S 185 ).
- the break cancellation unit 403 notifies the logical address at which the break setting is set to the multitask OS unit 401 , causes the multitask OS unit 401 to specify the physical address in the RAM 12 of the notified logical address, obtains the specified physical address from the multitask OS unit 401 , and writes the original instruction saved to the break setting table with respect to the break setting to the obtained physical address, thereby restoring the original instruction (step S 186 ).
- the break cancellation unit 403 judges whether or the break setting table has been searched for all break settings registered with respect to the identifier of the stopped task (step S 188 ). If the search is complete (step S 188 :Y), the break cancellation unit 403 ends the break cancellation processing D. If the search is not complete (step S 188 :N), the break cancellation unit 403 moves to the processing at step S 181 .
- step S 185 If the judgment is negative at step S 185 (step S 185 :N), the break cancellation unit 403 cancels the break address setting in the register of the CPU (step S 187 ).
- step S 182 If the judgment is negative at step S 182 (step S 182 :N), the break cancellation unit 403 ends the break cancellation processing D.
- step S 184 If the judgment is negative at step S 184 (step S 184 :N.), the break cancellation unit 403 ends the break cancellation processing D.
- compositional elements that are the same as in the debugging system 100 in the first embodiment, and focuses on those that differ.
- FIG. 25 is a function block diagram showing the structure of the debugging device 50 included in the debugging system 500 .
- the debugging device 50 is composed of a multitask OS unit 501 , the break setting unit 102 , a break cancellation unit 503 , the communication unit 104 , the application storage unit 105 , the page table storage unit 106 , the task management information storage unit 107 , and the break setting table storage unit 108 .
- compositional elements that are the same as those in the debugging device 10 of the first embodiment have the same reference numbers there as.
- FIG. 19 is a flowchart showing operations for task switch processing E performed by the multiplex OS unit 501 .
- the task switch processing E differs from the task switch processing A in the first embodiment in that the order of the break setting processing and the break cancellation processing shown at step S 704 and step S 705 is reversed, and in terms of the content of the break cancellation processing shown at step S 705 .
- FIG. 20 is a flowchart showing operations for break cancellation processing E performed by the break cancellation unit 503 .
- the break cancellation unit 503 makes a search of the break settings registered in the break setting table (step S 201 ), and judges, for each break setting found as a result of the search, whether or not the break type is a software break, based on the break type shown by the break setting (step S 202 ).
- the break cancellation unit 503 When the break setting is judged to be a software break at step S 202 (step S 202 :Y), the break cancellation unit 503 notifies the logical address at which the break setting is set to the multitask OS unit 501 , causes the multitask OS unit 501 to specify the physical address in the RAM 12 of the logical address, obtains the specified physical address from the multitask OS unit 501 , and writes the original instruction saved to the break setting table with respect to the break setting to the obtained physical address, thereby restoring the original instruction (step S 203 ), and canceling the break setting. The break cancellation unit 503 then judges whether or not all break settings registered in the break setting table have been cancelled (step S 205 ), and if all have been cancelled (step S 205 :Y), ends the break cancellation processing E. If not all have been cancelled (step S 205 :N), the break cancellation unit 503 moves to the processing at step S 201 .
- step S 202 If the judgment at step S 202 is negative (step S 202 :N), the break cancellation unit 503 cancels the break address setting in the register of the CPU (step S 204 ).
- the present invention is not limited to the described first to fifth embodiments.
- debugging processing is performed in a multitask environment by rewriting an original instruction into a break instruction.
- debugging processing may be performed by rewriting an original instruction not into a break instruction, but into another instruction.
- debugging processing may be performed by rewriting data at a specific physical address.
- debugging processing is performed instead of the break setting processing described in the first to fifth embodiments, and instead of the break cancellation processing, the debugging processing is cancelled by rewriting the rewritten instruction or data to an original instruction or data.
- break setting registration processing, break setting deletion processing and debugging are performed as a result of a command input from any of the terminals 1 to 3 .
- an input unit may be provided in the debugging device, and aforementioned processing and debugging performed as a result of input from the input unit.
- break setting registration processing and break setting deletion processing may be performed by designating an identifier, logical address and break type pertaining to a break setting to be registered or cancelled, via a GUI (Graphic User Interface).
- GUI Graphic User Interface
- break setting processing A is performed when a task switch occurs.
- break setting processing C may be performed instead of break setting processing A, and then break cancellation processing D′ may be performed instead of break processing D for each task other than the next task to be run.
- FIG. 26 is a flowchart showing operations of break cancellation processing D′ performed by the break cancellation unit 403 in the described case.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
Abstract
Description
Claims (4)
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2005267335A JP4676289B2 (en) | 2005-09-14 | 2005-09-14 | Debug system and method |
JP2005-267335 | 2005-09-14 |
Publications (2)
Publication Number | Publication Date |
---|---|
US20070061627A1 US20070061627A1 (en) | 2007-03-15 |
US7694182B2 true US7694182B2 (en) | 2010-04-06 |
Family
ID=37856712
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/520,806 Expired - Fee Related US7694182B2 (en) | 2005-09-14 | 2006-09-14 | Debugging system and method |
Country Status (2)
Country | Link |
---|---|
US (1) | US7694182B2 (en) |
JP (1) | JP4676289B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110202903A1 (en) * | 2010-02-18 | 2011-08-18 | Samsung Electronics Co., Ltd. | Apparatus and method for debugging a shared library |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2008257438A (en) * | 2007-04-04 | 2008-10-23 | Sharp Corp | Exception processor used for control of debugging device, exception processing method, exception processing program, and television and cellphone incorporated with the exception processor |
JP2009043061A (en) * | 2007-08-09 | 2009-02-26 | Oki Electric Ind Co Ltd | Debugging device and debugging method |
US8156476B2 (en) * | 2008-06-10 | 2012-04-10 | Microsoft Corporation | Debugging support for tasks in multithreaded environments |
JP5550581B2 (en) * | 2011-02-17 | 2014-07-16 | 三菱電機株式会社 | Shared memory debugging device and program |
JP6028355B2 (en) * | 2012-03-22 | 2016-11-16 | 日本電気株式会社 | Operation management apparatus, method, and program |
CN111092767B (en) * | 2019-12-20 | 2022-10-18 | 北京百度网讯科技有限公司 | Method and device for debugging equipment |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5632032A (en) * | 1994-02-07 | 1997-05-20 | International Business Machines Corporation | Cross address space thread control in a multithreaded environment |
JP2000172532A (en) | 1998-12-08 | 2000-06-23 | Hiroaki Takada | Device and method for multitask debugging |
US20020046364A1 (en) * | 2000-06-30 | 2002-04-18 | Miyoko Yoshimura | Debugging kernel system |
US6378124B1 (en) * | 1999-02-22 | 2002-04-23 | International Business Machines Corporation | Debugger thread synchronization control points |
US6681384B1 (en) * | 1999-12-23 | 2004-01-20 | International Business Machines Corporation | Multi-threaded break-point |
US20050034024A1 (en) | 1998-11-13 | 2005-02-10 | Alverson Gail A. | Debugging techniques in a multithreaded environment |
US20060053413A1 (en) | 2004-09-06 | 2006-03-09 | Shinichi Kimura | Debug system for debugging multi-task system |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS638947A (en) * | 1986-06-30 | 1988-01-14 | Nec Corp | Program debug supporting system |
-
2005
- 2005-09-14 JP JP2005267335A patent/JP4676289B2/en not_active Expired - Fee Related
-
2006
- 2006-09-14 US US11/520,806 patent/US7694182B2/en not_active Expired - Fee Related
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5632032A (en) * | 1994-02-07 | 1997-05-20 | International Business Machines Corporation | Cross address space thread control in a multithreaded environment |
US20050034024A1 (en) | 1998-11-13 | 2005-02-10 | Alverson Gail A. | Debugging techniques in a multithreaded environment |
JP2000172532A (en) | 1998-12-08 | 2000-06-23 | Hiroaki Takada | Device and method for multitask debugging |
US6378124B1 (en) * | 1999-02-22 | 2002-04-23 | International Business Machines Corporation | Debugger thread synchronization control points |
US6681384B1 (en) * | 1999-12-23 | 2004-01-20 | International Business Machines Corporation | Multi-threaded break-point |
US20020046364A1 (en) * | 2000-06-30 | 2002-04-18 | Miyoko Yoshimura | Debugging kernel system |
US20060053413A1 (en) | 2004-09-06 | 2006-03-09 | Shinichi Kimura | Debug system for debugging multi-task system |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110202903A1 (en) * | 2010-02-18 | 2011-08-18 | Samsung Electronics Co., Ltd. | Apparatus and method for debugging a shared library |
Also Published As
Publication number | Publication date |
---|---|
JP4676289B2 (en) | 2011-04-27 |
JP2007079969A (en) | 2007-03-29 |
US20070061627A1 (en) | 2007-03-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7694182B2 (en) | Debugging system and method | |
US6996828B1 (en) | Multi-OS configuration method | |
US5613114A (en) | System and method for custom context switching | |
US20040215720A1 (en) | Split branch history tables and count cache for simultaneous multithreading | |
WO2009133669A1 (en) | Virtual computer control device, virtual computer control method, and virtual computer control program | |
US6948034B2 (en) | Method for use of stack | |
EP2508990A1 (en) | Hypervisor replacing method and information processing device | |
JP4902501B2 (en) | Power control method, computer system, and program | |
US20100138831A1 (en) | Virtual machine system, hypervisor in virtual machine system, and scheduling method in virtual machine system | |
US7010725B2 (en) | Method and apparatus for getting dump of a computer system | |
US4851992A (en) | Register/saving/restoring system for saving and restoring data in a register of a slave processor | |
KR20070090649A (en) | Apparatus and method for providing cooperative scheduling on multi-core system | |
US6865636B1 (en) | Multitasking processor system for monitoring interrupt events | |
US7434222B2 (en) | Task context switching RTOS | |
US20080229054A1 (en) | Method for performing jump and translation state change at the same time | |
US20080072009A1 (en) | Apparatus and method for handling interrupt disabled section and page pinning apparatus and method | |
JP2006277047A (en) | Data processing device and dynamic substitution method of application program in multithread system | |
JP5382471B2 (en) | Power control method, computer system, and program | |
JP2008225710A (en) | Computer system and process-switching method used in the system | |
JPH06119190A (en) | Task switching processing system | |
JPH11316691A (en) | Execution method for operating system and information processor using the method | |
EP1104899A2 (en) | Data processing apparatus and method of controlling the same | |
JP2005338952A (en) | Program branching method | |
JPH10133872A (en) | Processor equipment having command buffer | |
JPS638947A (en) | Program debug supporting system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MATSUSHITA ELECTRIC INDUSTRIAL CO., LTD.,JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TAKAGI, SHIGEYA;HAMADA, YASUHIKO;MATSUMOTO, HIDETAKA;REEL/FRAME:018782/0828 Effective date: 20060901 Owner name: MATSUSHITA ELECTRIC INDUSTRIAL CO., LTD., JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TAKAGI, SHIGEYA;HAMADA, YASUHIKO;MATSUMOTO, HIDETAKA;REEL/FRAME:018782/0828 Effective date: 20060901 |
|
AS | Assignment |
Owner name: PANASONIC CORPORATION, JAPAN Free format text: CHANGE OF NAME;ASSIGNOR:MATSUSHITA ELECTRIC INDUSTRIAL CO., LTD.;REEL/FRAME:021897/0689 Effective date: 20081001 Owner name: PANASONIC CORPORATION,JAPAN Free format text: CHANGE OF NAME;ASSIGNOR:MATSUSHITA ELECTRIC INDUSTRIAL CO., LTD.;REEL/FRAME:021897/0689 Effective date: 20081001 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: SOCIONEXT INC., JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:PANASONIC CORPORATION;REEL/FRAME:035294/0942 Effective date: 20150302 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552) Year of fee payment: 8 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20220406 |