EP1221096A1 - Method and apparatus for modifying microinstructions in a static memory device - Google Patents

Method and apparatus for modifying microinstructions in a static memory device

Info

Publication number
EP1221096A1
EP1221096A1 EP00963557A EP00963557A EP1221096A1 EP 1221096 A1 EP1221096 A1 EP 1221096A1 EP 00963557 A EP00963557 A EP 00963557A EP 00963557 A EP00963557 A EP 00963557A EP 1221096 A1 EP1221096 A1 EP 1221096A1
Authority
EP
European Patent Office
Prior art keywords
memory device
jump point
address
microinstructions
microinstruction
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.)
Withdrawn
Application number
EP00963557A
Other languages
German (de)
French (fr)
Inventor
Way-Shing Lee
Gregory B. Foerster
Li Zhang
Qiuzhen Zou
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Qualcomm Inc
Original Assignee
Qualcomm Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Qualcomm Inc filed Critical Qualcomm Inc
Publication of EP1221096A1 publication Critical patent/EP1221096A1/en
Withdrawn legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/22Microcontrol or microprogram arrangements
    • G06F9/26Address formation of the next micro-instruction ; Microprogram storage or retrieval arrangements
    • G06F9/262Arrangements for next microinstruction selection
    • G06F9/268Microinstruction selection not based on processing results, e.g. interrupt, patch, first cycle store, diagnostic programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • G06F8/66Updates of program code stored in read-only memory [ROM]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/32Address formation of the next instruction, e.g. by incrementing the instruction counter
    • G06F9/322Address formation of the next instruction, e.g. by incrementing the instruction counter for non-sequential address
    • G06F9/328Address formation of the next instruction, e.g. by incrementing the instruction counter for non-sequential address for runtime instruction patching

Definitions

  • the present invention relates to the field of control stores for microprocessors. More particularly, the invention relates to the modification of a control store apparatus that utilizes both a Read-Only Memory (ROM) and a Random Access Memory (RAM).
  • ROM Read-Only Memory
  • RAM Random Access Memory
  • Control stores contain executable microinstructions that control the data path of a microprocessor.
  • the control store consists of RAM, in others, the control store is ROM.
  • the contents of a RAM can easily be rewritten with new information.
  • RAM is volatile, i.e., the contents of RAM are retained only during the time period when power is supplied to the circuit.
  • the contents of a ROM are inserted at the time of the ROM's manufacture and cannot be changed or erased, even when powered off.
  • an error in one portion of the code can be isolated and corrected without having to rewrite the entire code.
  • a programmer will create a duplicate subroutine, without the errors, which is called by the program flow instead of the faulty subroutine.
  • This technique is possible by utilizing system RAM and ROM together for storing the microinstruction set.
  • Subroutines are generally stored in ROM, whereas the main program code that calls the subroutines is generally stored in RAM.
  • exit points from the main code allow the program flow to execute the microinstructions of the subroutines in ROM.
  • a jump point register is used to hold a jump point address. This jump point address can trigger an interrupt event in the program flow.
  • a program counter contains the address of the current microinstruction in the program flow. If the program counter holds an address that equals the jump point address in the jump point register, the interrupt event is generated. This interrupt event initiates an alteration in the program flow from a static memory device to a programmable memory device.
  • FIG. 1 is a diagram showing a conventional program flow between RAM and ROM.
  • the present practice among those skilled in the art is to debug faulty subroutines by duplicating the entire subroutine in RAM 100, absent programming errors, and reprogramming the RAM 100 to carry the program flow to the duplicated subroutine in RAM 100, rather than to the faulty subroutine stored in ROM 110.
  • a programming error 106 is discovered in subroutine 105, then the programmer would have to disable the data path 103 from RAM 100 to ROM 110 and create a new data path 104 to a replacement subroutine 107 residing in RAM 100.
  • the data path 108 flows back to any designated microinstruction located in RAM 100 after the disabled data path 103.
  • Control line 304 carries the contents of the program counter to the comparators 308, 318, 328.
  • the program counter is a register that contains the address of the microinstruction to be executed next. In some data processing systems, the program counter is designed to contain the current microinstruction being executed. It would be apparent to one skilled in the art that the contents of the program counter need not be limited to a predictive state or a current state in order to implement any embodiment of the invention.
  • FIG. 4 is a block diagram showing a data processing system. It will be apparent to one skilled in the art that the present invention may be practiced without specific details as to well-known circuits and control logic. In order to avoid obscuring the description, such specific details have been omitted from FIG. 4.
  • the block diagram of FIG. 4 is representative of a system wherein the control logic is segregated from the operation core.
  • the system may be a digital signal processor or an application specific integrated circuit.
  • the present invention can be used in data processing systems with other architectural forms, e.g., where the control logic is combined with the operation core.
  • a program flow control device 400 is coupled to the control store RAM 430, the control store ROM 440, an interrupt circuit 450, and an instruction- decoding device 410.
  • the interrupt circuit 450 may be the interrupt circuit of FIG. 3.
  • the program flow control device 400 generates the contents of the program counter, generates the flags which show whether the current instruction has been executed or canceled, and handles all external events such as direct memory access (DMA) and interrupts.
  • the instruction-decoding device 410 may or may not be integrated within the operation core 420 and is connected to the program flow control device 400 through line 405.
  • the instruction-decoding device 410 is also connected to the control store RAM 430 and control store ROM 440 through line 404.
  • interrupt circuit 450 When interrupt circuit 450 indicates that the current program counter contains an address equal to a jump point address contained in a jump point register (not shown), an interrupt is generated by an interrupt controller (not shown), which may or may not be integrated into the program flow control device 400. When the interrupt circuit 450 generates an interrupt, the program flow control device 400 resets the program counter to hold the address of the next microinstruction specified by the interrupt event.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)
  • Debugging And Monitoring (AREA)

Abstract

Method and apparatus for modifying the program flow of microinstructions residing in a static memory device. When microinstructions from the static memory device need to be modified, a jump point register is used to hold a jump point address that triggers an interrupt event. When the current program counter contains an address equal to the jump point address and the jump point register is enabled, an interrupt event is generated that redirects the program flow away from the static memory device to a programmable memory device. Rather than using the interrupt to indicate the occurrence of an external event, the interrupt is used to bypass portions of the microinstructions residing in the static memory device.

Description

METHOD AND APPARATUS FOR MODIFYING MICROINSTRUCTIONS IN A STATIC MEMORY DEVICE
BACKGROUND I. Field of the Invention
The present invention relates to the field of control stores for microprocessors. More particularly, the invention relates to the modification of a control store apparatus that utilizes both a Read-Only Memory (ROM) and a Random Access Memory (RAM). II. Background
Control stores contain executable microinstructions that control the data path of a microprocessor. On some machines, the control store consists of RAM, in others, the control store is ROM. The contents of a RAM can easily be rewritten with new information. However, RAM is volatile, i.e., the contents of RAM are retained only during the time period when power is supplied to the circuit. In contrast, the contents of a ROM are inserted at the time of the ROM's manufacture and cannot be changed or erased, even when powered off.
ROM is much cheaper than RAM when produced in large volumes. Due to cost considerations of RAM and ROM, microcode programmers generally design new circuitry with RAM so that programming mistakes can be easily corrected, but substitute RAM with ROM in the final design stage to minimize production costs. However, even the most rigorous design review can miss programming errors that will then be permanently embedded in the static ROM. When programming mistakes are discovered in the microinstruction set stored in ROM, programmers create patches to correct the mistakes. "Patch" is a term of art that refers to new code introduced to fix prior code or to add functionality. Microinstructions as a whole are referred to as "code" and designed in a modular manner, wherein the entire code consists of separate subroutines. Hence, an error in one portion of the code can be isolated and corrected without having to rewrite the entire code. When a faulty subroutine is discovered, a programmer will create a duplicate subroutine, without the errors, which is called by the program flow instead of the faulty subroutine. This technique is possible by utilizing system RAM and ROM together for storing the microinstruction set. Subroutines are generally stored in ROM, whereas the main program code that calls the subroutines is generally stored in RAM. As the program flow proceeds down the microinstruction set in RAM, exit points from the main code allow the program flow to execute the microinstructions of the subroutines in ROM. When a subroutine has been executed, the program flow exits the subroutine and reenters the main code in RAM. However, when an error in a subroutine is discovered, the exit point corresponding to the faulty subroutine is disabled and the programmer must patch the mistake with a new subroutine. Since ROM is static, this new subroutine must be stored in RAM. This method is inflexible due to the inability to enter and exit faulty subroutines except at predefined points in the main code. In addition, this method wastes space in RAM since an entire subroutine must be duplicated in RAM in order to fix a programming error within the subroutine, no matter how minor the error. There is a present need in the art to have more flexible exit and entry points in the program flow between ROM and RAM. In addition, there is a present need to minimize the size of RAM required to fix programming errors in ROM.
SUMMARY OF THE INVENTION
The present invention is directed to a method and apparatus for modifying the program flow of microinstructions residing in a ROM in order for programmers to have more direct access and control over the ROM microinstructions. Since the microinstructions in ROM cannot be altered, any changes to the microinstruction set must necessarily be made in RAM. The present invention allows a programmer to directly access a programming error within ROM without having to duplicate the entire subroutine in RAM. The present invention can also allow a programmer to add functionality to outdated ROM rather than replacing the outdated ROM with a newly designed ROM.
The exemplary embodiment of the present invention is a method for modifying the program flow in a static memory device, the method comprising the step of generating an interrupt that triggers a jump from the static memory device to a programmable memory device.
In one embodiment of the invention, a jump point register is used to hold a jump point address. This jump point address can trigger an interrupt event in the program flow. A program counter contains the address of the current microinstruction in the program flow. If the program counter holds an address that equals the jump point address in the jump point register, the interrupt event is generated. This interrupt event initiates an alteration in the program flow from a static memory device to a programmable memory device.
In one embodiment of the invention, the interrupt event can be used to repair programming errors in the static memory device. A programmer can create a patch for a defective portion of code residing in the static memory device. The programmer can then store an exit address in a register or other storage device wherein the exit address corresponds to an address of a predetermined microinstruction within the defective code portion. The exit address is compared to all the microinstructions being executed in the program flow. The microinstructions in the patch are executed when the predetermined microinstruction occurs in the program flow.
In another embodiment of the invention, the interrupt event can produce an alteration in the program flow that adds functionality to the static memory device. The alteration can be in the form of additional code stored in a programmable memory device, which can be executed in the midst of the execution of microcode from the static memory device.
In another embodiment of the invention, multiple jump point registers can be coupled to an interrupt port along with corresponding comparators, which can enable or disable each individual jump point register. Each individual jump point register can be associated with separate interrupt events. Hence, using multiple jump point registers gives flexibility to a programmer and allows her to advantageously allocate jump points according to future need. This modification reduces the requirement of RAM size for fixing firmware mistakes in ROM and improves the functionality of ROM.
Still other objects and advantages of the present invention will become readily apparent to those skilled in the art from the following detailed description.
BRIEF DESCRIPTIONS OF THE DRAWINGS
FIG. 1 is a diagram showing a conventional program flow between RAM and ROM.
FIG. 2 is a diagram showing the program flow between RAM and ROM in an embodiment of the present invention. FIG. 3 is a block diagram of a circuit for implementing program flow between RAM and ROM.
FIG. 4 is a block diagram of a data processing system.
DETAILED DESCRIPTION
FIG. 1 is a block diagram showing a prior art implementation of an error correcting method, i.e., a "debugging" method, for microinstructions in a data processing system such as a computer system or a general purpose microcomputer. For illustrative purposes, the preferred embodiments of the invention are described using ROM and RAM. However, it will be readily apparent in the detailed description below that the methods described are applicable for use with any static storage device and volatile storage device. In FIG. 1, a RAM 100 has been programmed with code that calls subroutines in a ROM 110. A program counter (not shown) containing the address of the microinstruction next to be executed proceeds down the RAM stack until the program counter encounters the address of a microinstruction in the ROM stack. At point 101, the program flow exits the microinstruction set in RAM 100 and enters the microinstruction set in ROM 110. The program counter proceeds down the ROM 110 until it encounters the address of a microinstruction in RAM 100. The program flow exits the microinstruction set in ROM 110 and reenters the microinstruction set in RAM 100 at point 102. This process repeats itself for the various subroutines stored in ROM 110. However, if a programming error needs be corrected in ROM 110, or a different functionality needs to be added, a programmer could reprogram the RAM 100 so that the subroutine stored in ROM 110 can be bypassed. The present practice among those skilled in the art is to debug faulty subroutines by duplicating the entire subroutine in RAM 100, absent programming errors, and reprogramming the RAM 100 to carry the program flow to the duplicated subroutine in RAM 100, rather than to the faulty subroutine stored in ROM 110. As illustrated in FIG. 1, if a programming error 106 is discovered in subroutine 105, then the programmer would have to disable the data path 103 from RAM 100 to ROM 110 and create a new data path 104 to a replacement subroutine 107 residing in RAM 100. When subroutine 107 is complete, the data path 108 flows back to any designated microinstruction located in RAM 100 after the disabled data path 103.
This can be a large waste of RAM resources when the size of the programming error is minimal. Because ROM is static, a programmer cannot change the microinstructions in ROM to redirect the program flow to RAM from a different point in ROM, even if only a small portion of the subroutine need be rewritten.
FIG. 2 is a block diagram showing the program flow between RAM 200 and ROM 210 in an embodiment of the present invention that allows a programmer to debug a faulty subroutine stored in ROM 210 without having to replicate the entire subroutine in RAM 200. In addition, a programmer may include additional features and functions within the subroutines stored in ROM 210. The program flow exits RAM 200 and enters ROM 210 as in FIG. 1 during an error-free portion of the microcode. However, when a bug is discovered in the ROM 210, the program flow of FIG. 2 allows the programmer to create a patch for the bug without sacrificing a large portion of the RAM 200 in order to correct the bug.
A program counter (not shown) proceeds down the RAM stack until the program counter encounters the address of a microinstruction in the ROM stack. At point 201, the program flow exits the microinstruction set in RAM 200 and enters the microinstruction set in ROM 210. The program counter proceeds down the ROM 210 until it encounters the address of a microinstruction in RAM 200. The program flow exits the microinstruction set in ROM 210 and reenters the microinstruction set in RAM 200 at point 202. This process repeats itself for the various subroutines stored in ROM.
Program flow 203 continues to the subroutine 208 containing the programming error 205. Error-free instructions in the subroutine are executed until point 204, at which point the program flow returns to RAM 200 for a patch. At point 206, the patch has been completed and the program flow returns to ROM 210. When the subroutine is complete, the data path 207 returns to RAM 200. In an exemplary embodiment of the present invention, an interrupt circuit is introduced to a prior art data processing system. FIG. 3 is a block diagram of an interrupt circuit that will allow a programmer to create a program flow as shown in FIG. 2.
The interrupt circuit of FIG. 3 consists of a plurality of registers, or any other storage device capable of storing a microinstruction address, and are referred to generically as jump point registers. A jump point register holds a jump point address that triggers an interrupt event. As is well known in the art, an interrupt causes the temporary suspension of a process when an external event occurs outside of that process. An interrupt signal indicates the occurrence of an interrupt event so that the processor suspends the current process and performs the task requested by the interrupt signal. However, in this embodiment of the invention, interrupt signals are used in a very different way. Rather than using the interrupt to indicate the occurrence of an external event, the interrupt circuit of FIG. 3 uses an interrupt to bypass portions of the microcode residing in ROM.
The interrupt circuit embodied in FIG. 3 includes three (3) jump point registers 300, 310, 320. However, it should be apparent to one skilled in the art that the number of jump point registers can vary according to a circuit designer's preference without affecting the scope of the present invention. Each of the three (3) jump point registers is individually coupled to one of three comparators 308, 318, 328, respectively, through lines 303, 313, 323. A comparator is a device that compares two input words and is generally composed of EXCLUSIVE-OR gates, but for this or any other embodiment of the invention, any device that can accomplish a comparison function can be used. However, for illustrative purposes, the term "comparator" will be used. Each comparator 308, 318, 328, is coupled to the processor 320 through control lines 304, 305.
Each jump point register 300, 310, 320, is set with an address corresponding to an interrupt event. Line 301 loads the addresses into each jump point register from the processor 320.
Control line 304 carries the contents of the program counter to the comparators 308, 318, 328. The program counter is a register that contains the address of the microinstruction to be executed next. In some data processing systems, the program counter is designed to contain the current microinstruction being executed. It would be apparent to one skilled in the art that the contents of the program counter need not be limited to a predictive state or a current state in order to implement any embodiment of the invention.
Control line 305 carries a control signal from the processor 320 that enables or disables each comparator 308, 318, 328, in order to achieve the desired functionality associated with each jump point register. Control line 306 carries a status signal from comparators 308, 318, 328 to status registers (not shown) in the processor 320, indicating which jump point register contained the same address as the program counter. Placement of the status registers in the processor 320 is merely a matter of design choice and does not effect the scope of the invention. It should be noted that in an alternative embodiment of the invention, the program counter could be used to identify which jump point register has the same address as the program counter. If a program counter is used, then all the bits in an address must be checked to identify the jump point register in question. If a status register is used, then only one bit need be checked. The choice of using the program counter or the status registers for the purpose of identifying which jump point register contains the jump point address associated with the current interrupt is merely a matter of design choice.
If the address in the program counter is equal to one of the addresses located in jump point registers 300, 310, 320 and a control signal is sent that enables the comparator corresponding to the aforementioned jump point register, then a status signal is sent to the processor 320 and a signal is sent to an interrupt controller (not shown) so that an interrupt occurs.
In this instance, the interrupt event is not an external event which calls for an suspension of the program flow, rather, the interrupt event redirects the program counter to a microinstruction stored in RAM. The program flow continues in RAM until redirected back to the ROM. Since RAM is dynamic, the RAM can redirect the program counter, hence, the program flow, to any microinstruction stored in ROM. For the purposes of debugging the program code, a programmer can identify a bug in a portion of the microinstruction subroutine in ROM and store the address of the bug in a jump point register. If the bug is a minor error that can be fixed with just a few lines of code, a patch for the bug can easily be stored in RAM. When the program counter encounters the address of the bug, which has been stored in the jump point register, the comparator allows a signal to be sent to the interrupt controller, whereby an interrupt is generated which redirects the program flow to the patch stored in RAM. When the microinstructions contained in the patch have finished executing, the RAM microinstruction immediately following the patch can redirect the program flow to the ROM microinstruction following the erroneous section of the subroutine. In this manner, a subroutine containing a small programming error can be corrected without having to duplicate the entire subroutine in RAM.
For the purpose of adding functionality to the program code stored in ROM, a programmer can advantageously utilize the jump point registers to add further subroutines within the structure of already existing ROM subroutines. In one embodiment of the invention, a programmer can insert a microinstruction address into a jump point register wherein the microinstruction is part of a program subroutine residing in ROM. When the program counter contains the address of this microinstruction, the program flow will jump to a corresponding set of microinstructions stored in RAM. The last instruction of the corresponding set of microinstructions will redirect the program flow back to the subroutine at whichever point the programmer desires. In this manner, a programmer can add a new function to the ROM subroutine without replacing the old, programmed ROM. Hence, a ROM can be updated without having to be replaced by a reprogrammed ROM.
The interrupt circuit of Fig. 3 is one embodiment of the invention where three (3) jump points and corresponding comparators are connected through a OR gate 330 to an interrupt request (IRQ) pin in a processor, i.e., the interrupt controller. In yet another embodiment of the invention, multiple interrupt circuits can be used in a data processing system in order to minimize the amount of checking for new code that will occur whenever an interrupt is triggered. When there is a large number of jump point registers within a single interrupt circuit, a large amount of MIPS is consumed to determine which new code corresponds to the interrupt that was just triggered. However, when there are numerous interrupt circuits, each with only three or fewer jump point registers, and each connected to an individual IRQ pin, less MIPS are consumed in implementing the code corresponding to the triggered interrupt event. The use of multiple interrupt circuits or a single interrupt circuit is a matter of design choice according to the needs of the circuit board designer. However, any variation of the interrupt circuit as described herein falls within the scope of this invention.
FIG. 4 is a block diagram showing a data processing system. It will be apparent to one skilled in the art that the present invention may be practiced without specific details as to well-known circuits and control logic. In order to avoid obscuring the description, such specific details have been omitted from FIG. 4. The block diagram of FIG. 4 is representative of a system wherein the control logic is segregated from the operation core. The system may be a digital signal processor or an application specific integrated circuit. However, it should be noted that the present invention can be used in data processing systems with other architectural forms, e.g., where the control logic is combined with the operation core.
A program flow control device 400 is coupled to the control store RAM 430, the control store ROM 440, an interrupt circuit 450, and an instruction- decoding device 410. The interrupt circuit 450 may be the interrupt circuit of FIG. 3. The program flow control device 400 generates the contents of the program counter, generates the flags which show whether the current instruction has been executed or canceled, and handles all external events such as direct memory access (DMA) and interrupts. The instruction-decoding device 410 may or may not be integrated within the operation core 420 and is connected to the program flow control device 400 through line 405. The instruction-decoding device 410 is also connected to the control store RAM 430 and control store ROM 440 through line 404. The interrupt circuit 450 is coupled to the program flow control device 400, control store RAM 430, control store ROM 440, and the operation core 420. The program flow control device 400 generates the program counter based upon input from control store RAM 430, control store ROM 440 or the interrupt circuit 450. Lines RAM_CS 401, ROM_CS 403, and EXEC 412 are used by the program flow control device 400 to enable input from the control store RAM 430, control store ROM 440, or the interrupt circuit 450. Line 422 loads jump point addresses into the jump point registers (not shown) in the interrupt circuit 450. Line 402 carries the contents of the program counter to the control store RAM 430, control store ROM 440 and the interrupt circuit 450. When interrupt circuit 450 indicates that the current program counter contains an address equal to a jump point address contained in a jump point register (not shown), an interrupt is generated by an interrupt controller (not shown), which may or may not be integrated into the program flow control device 400. When the interrupt circuit 450 generates an interrupt, the program flow control device 400 resets the program counter to hold the address of the next microinstruction specified by the interrupt event.
The data processing system of FIG. 4 is just one illustrative example of how an embodiment of the present invention may be used. It should be noted that the present invention may be realized using a variety of computer programming languages and hardware, and is not limited to any particular hardware and software configuration. For example, the functions of program flow control device 400, the instruction decoder 410, and the operation core 420 can be achieved through the use of a general-purpose processor, as illustrated in block 490. The present invention may be utilized in any embodiment which has code stored in a static storage device such as a ROM, a magnetic tape storage unit, a compact disk or a floppy disk.
As will be realized, the invention is capable of other and different embodiments and its several details are capable of modifications in various respects, all without departing from the invention. Accordingly, the drawings and description are to be regarded as illustrative in nature, and not as restrictive.
WE CLAIM:

Claims

1. A method for modifying the program flow in a static memory device, the method comprising the step of generating an interrupt that triggers a jump from the static memory device to a programmable memory device.
2. The method of Claim 1, wherein the step of generating the interrupt comprises the steps of: storing a copy of an address of a first microinstruction, wherein the first microinstruction is a portion of a first set of microinstructions, and the first set of microinstructions is a subset of a subroutine residing in the static memory device; storing a replacement set of microinstructions in the programmable memory device; comparing the address of each microinstruction in the subroutine with the stored copy during the program flow; and substituting the first set of microinstructions with the replacement set of microinstructions when the comparing step results in a match, wherein the substituting step produces a jump in the program flow from the static memory device to the programmable memory device.
3. The method of Claim 2, wherein the static memory device comprises a Read-Only Memory (ROM) device and the programmable memory device comprises a Random Access Memory (RAM) device.
4. The method of Claim 3, wherein the replacement set of microinstructions comprises a patch for a programming error present in the subroutine.
5. The method of Claim 1, wherein the step of generating an interrupt comprises the steps of: storing a copy of an address of a first microinstruction, wherein the first microinstruction is a portion of a first set of microinstructions embedded in a first subroutine, the first subroutine residing in the static memory device; storing an additional set of microinstructions in a programmable memory device; comparing the address of each microinstruction in the subroutine with the stored copy during the program flow; and adding the additional set of microinstructions when the comparing step results in a match, wherein the adding step produces a jump in the program flow from the static memory device to the programmable memory device.
6. The method of Claim 5, wherein the additional set of microinstructions is a second subroutine with an additional functionality.
7. The method of Claim 1, wherein the step of generating an interrupt comprises the steps of: using a jump point register to hold a jump point address, the jump point address triggering an interrupt event; executing a first set of microinstructions in a sequential order, wherein the first set of microinstructions resides in the static memory device, wherein each sequentially executed microinstruction in the first set of microinstructions has a corresponding address that is individually stored in a program counter during the sequential order of execution; and interrupting the program flow with the interrupt event if the program counter holds an address that equals the jump point address in the jump point register.
8. The method of Claim 7 wherein the step of interrupting the program flow comprises the steps of: setting a control signal to conditionally enable a comparator, wherein the comparator compares the address in the program counter with the address contained in the jump point register; and executing a second set of microinstructions corresponding to the jump point address if the comparator receives an enable control signal, wherein the second set of microinstructions reside in a programmable memory device.
9. The method of Claim 8 wherein the programmable memory device is a Random Access Memory (RAM) device.
10. The method of Claim 1 wherein the step of generating an interrupt further comprises the steps of: storing a plurality of jump point addresses, each jump point address stored in a corresponding jump point register, each jump point address triggering a corresponding interrupt event; predetermining which jump point address of the plurality of jump point addresses is to be enabled; executing a first set of microinstructions in a sequential order, said first set of microinstructions reside in the static memory device, wherein a program counter sequentially holds an address for each microinstruction being executed; and implementing the corresponding interrupt event if the program counter holds an address that equals one of the plurality of jump point addresses and if the jump point address is enabled.
11. The method of Claim 10 wherein the step of implementing the interrupt event comprises the steps of: predetermining a plurality of microinstruction sets corresponding to each of the plurality of jump point addresses; setting a control signal to conditionally enable each member of a plurality of comparators, wherein each comparator is coupled to a corresponding jump point register and the program counter; and executing a corresponding set of microinstructions associated with the jump point address if one of the plurality of comparators receives an enable control signal, wherein the jump point address is equal to the address in the program counter, wherein the corresponding set of microinstructions reside in a programmable memory device.
12. The method of Claim 11 wherein the step of executing the corresponding set of microinstructions is followed by the step of executing a subsequent microinstruction from the first set of microinstructions.
13. Apparatus for processing programmable machine instruction signals, comprising: a jump point register containing at least one predetermined jump point; a static memory device containing a first microinstruction set, the static memory device coupled to the jump point register; a random access memory device containing a second microinstruction set, the random access memory device coupled to said jump point register and static memory device; a program control unit coupled to the jump point register, the static memory device and the random access memory device, wherein the program control unit sends a plurality of control signals to the jump point register, the static memory device and the random access memory device; and a comparator coupled to the jump point register and the program control unit, wherein the comparator makes a comparison between the predetermined jump point with at least one of the plurality of control signals and generates an interrupt signal according to the comparison.
14. The apparatus of Claim 13, further comprising: a plurality of jump point registers, each of said plurality of jump point registers storing at least one predetermined jump point; wherein the program control unit sends a plurality of control signals to each of the plurality of jump point registers, the static memory device and the random access memory device; and a plurality of comparators, each comparator coupled to one of the plurality of jump point registers and the program control unit, wherein each comparator makes a comparison between the corresponding jump point address and at least one of the plurality of control signals, and generates an interrupt signal according to the comparison.
15. Apparatus for modifying the program flow of microinstructions residing in a static memory device, comprising: means for storing a predetermined microinstruction address apart from the static memory device; means for storing a first set of microinstruction addresses, wherein said storage means is volatile; means for comparing the predetermined microinstruction address with each address of the first set of microinstruction addresses; and means for generating a plurality of control signals, the means coupled to the predetermined microinstruction address storage means, the volatile storage means, and the comparison means, wherein the control signal means enable a modification of the program flow from the static memory device to the volatile storage means.
EP00963557A 1999-09-14 2000-09-14 Method and apparatus for modifying microinstructions in a static memory device Withdrawn EP1221096A1 (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US39891299A 1999-09-14 1999-09-14
US398912 1999-09-14
PCT/US2000/025474 WO2001020453A1 (en) 1999-09-14 2000-09-14 Method and apparatus for modifying microinstructions in a static memory device

Publications (1)

Publication Number Publication Date
EP1221096A1 true EP1221096A1 (en) 2002-07-10

Family

ID=23577324

Family Applications (1)

Application Number Title Priority Date Filing Date
EP00963557A Withdrawn EP1221096A1 (en) 1999-09-14 2000-09-14 Method and apparatus for modifying microinstructions in a static memory device

Country Status (6)

Country Link
EP (1) EP1221096A1 (en)
JP (1) JP2003509769A (en)
KR (1) KR20020029921A (en)
CN (1) CN1373872A (en)
AU (1) AU7495300A (en)
WO (1) WO2001020453A1 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7464248B2 (en) 2005-04-25 2008-12-09 Mediatek Incorporation Microprocessor systems and bus address translation methods
CN103268237A (en) * 2013-05-10 2013-08-28 东信和平科技股份有限公司 Patching function extension method and device for mask smart card
CN106484369B (en) * 2013-10-24 2019-11-29 华为技术有限公司 A kind of method and device of online patch activation
CN104156241B (en) * 2014-07-31 2019-08-13 中国船舶重工集团公司第七0九研究所 The initiated configuration method and system of processor microprogram

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH01232447A (en) * 1988-03-11 1989-09-18 Mitsubishi Electric Corp Single chip microcomputer
US5357627A (en) * 1989-03-28 1994-10-18 Olympus Optical Co., Ltd. Microcomputer having a program correction function
JPH08166877A (en) * 1994-12-13 1996-06-25 Olympus Optical Co Ltd One-chip microcomputer that can execute correction program and microcomputer that can correct rom
US5901225A (en) * 1996-12-05 1999-05-04 Advanced Micro Devices, Inc. System and method for performing software patches in embedded systems

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See references of WO0120453A1 *

Also Published As

Publication number Publication date
AU7495300A (en) 2001-04-17
WO2001020453A1 (en) 2001-03-22
CN1373872A (en) 2002-10-09
KR20020029921A (en) 2002-04-20
JP2003509769A (en) 2003-03-11

Similar Documents

Publication Publication Date Title
US7613937B2 (en) Method and apparatus for utilizing a microcontroller to provide an automatic order and timing power and reset sequencer
US4524415A (en) Virtual machine data processor
EP0554917B1 (en) Digital signal processing system having two instruction memories accessed by a processor under control of host
US4635193A (en) Data processor having selective breakpoint capability with minimal overhead
US4831517A (en) Branch and return on address instruction and methods and apparatus for implementing same in a digital data processing system
EP0128156B1 (en) Data processor version validation
US7900036B2 (en) System and method for implementing boot/recovery on a data processing sysem
US4488228A (en) Virtual memory data processor
US6006030A (en) Microprocessor with programmable instruction trap for deimplementing instructions
JPH08263282A (en) Branching control system for rom program processor
JP2875842B2 (en) Programmable controller
US6925522B2 (en) Device and method capable of changing codes of micro-controller
EP1221096A1 (en) Method and apparatus for modifying microinstructions in a static memory device
WO1997008618A1 (en) Data processing apparatus and method for correcting faulty microcode
US6990569B2 (en) Handling problematic events in a data processing apparatus
US20030110367A1 (en) External microcode
US20010052114A1 (en) Data processing apparatus
CN111984329A (en) Standardized boot software generation and execution method and system
CA1223079A (en) Data processor having selective breakpoint capability with minimal overhead
GB2373888A (en) Dynamic vector address allocation for a code patching scheme
JPS5835648A (en) Program execution controlling system
JP2005063311A (en) Patch method and patch application program for processor system
JPH04533A (en) Information processing system
JPH04534A (en) Information processing system
JP2004185356A (en) Debug system

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 20020226

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE

AX Request for extension of the european patent

Free format text: AL;LT;LV;MK;RO;SI

RIN1 Information on inventor provided before grant (corrected)

Inventor name: LEE, WAY-SHING

Inventor name: ZOU, QIUZHEN

Inventor name: FOERSTER, GREGORY, B.

Inventor name: ZHANG, LI

17Q First examination report despatched

Effective date: 20020926

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 20021207