The invention relates generally to the field of multi-processing, and more particularly, to compiling and executing code starting at any address in the memory.
A CPU, when released from reset will start fetching and executing code from a fixed known hard-coded reset vector address, which is usually zero (0x0). A given CPU code program will have imbedded data and routine references and the Operating System (OS) will compile and link the code with respect to this hard-coded address (0x0). Accordingly, the generated code bitmap has to be stored in memory starting at that hard-coded location (0x0) for the CPU to fetch and execute the code properly. For multi-processor designs where each CPU executes a different program code, the programmer is faced with the dilemma of how to compile and link the code for each CPU and where to store it in memory. Coupled is the challenge to produce concise code and use of the memory space efficiently.
Prior solutions to this problem were first to use either the same default hard coded start fetch address as shown in
The present multiple processor system compiles and executes code starting at any address in memory. A hardware mechanism external to a CPU re-directs an instruction fetch to the appropriate physical location in memory. The system includes multiple processors with at least one hardware based code locator. The hardware based locator adds a vector base offset to an instruction fetch address within the memory.
Benefits and further features of the present invention will be apparent from a detailed description of preferred embodiment thereof taken in conjunction with the following drawings, wherein like elements are referred to with like reference numbers, and wherein:
a and 1b are hardware structures illustrating the prior art code fetching schemes.
In
In prior art
In addition to software complications in generating the different image bitmaps for each CPU, because of the requirement to remove all imbedded data and routine references within each CPU software program code, a hardware complication is added because each CPU is now seen different than the others from hardware point of view because of the specific hard coded reset vector. This means each CPU must be synthesized and placed and routed separately which requires more hardware engineering time and effort.
A further drawback of the above prior art methods is the restriction on the placement of the code bitmap(s) in memory because of the fixed hard coded reset vectors.
The present invention uses a hardware based code locator solution that is CPU and OS independent as depicted in
Since the re-direct vec_base registers are programmable, CPU bitmaps can be placed differently anywhere in memory each time the code or code sizes change, or the memory requirements change to allow for an efficient usage of memory allocations.
A further advantage of this scheme is to allow all CPUs to execute the same bitmap if needed by just programming all re-direct vec_base registers to the same bitmap start address.
In this case, CPU 110 fetches program code with address fetch_addr—1 starting at the default reset vector, 0x0, and its respective code locator 220 translates that address to new_fetch_addr—1 that starts at vecbase address x in this example, to point to its respective bitmap image code 231. The same is true for the other CPUs. For example CPU 112 fetches program code with address fetch_addr_n starting at the default reset vector 0x0, and its respective code locator 220 translates that address to new_fetch_addr_n that starts at vec_base address z in this example, to point to its respective bitmap image code 233.
The code locator 220 is described in reference to
Because the vec_base register 310 is programmable, the system becomes so flexible that the bitmap of each CPU can be placed anywhere in memory 130 each time the system is started or booted.
To further allow single bus CPUs access to data referenced and embedded within the code bitmap as well as provide access to other places of memory outside the code bitmap for data access, or for CPUs that have different busses for code fetch and data load/store, there is a need to allow the same translation to take place in the load/store data cycles but only within the range of the code image bitmap.
If (0x0 or reset vector address)=<Ldst_addr<image_size→new_ldst_addr=ldst_addr+vec_base
else→new_ldst_addr=ldst_addr
With this hardware re-direct mechanism, each CPU reset vector is left at its default value of 0x0 and the OS will compile and link each CPU code with respect to its default start address of 0x0. Each CPU generated code bitmap would be placed anywhere in memory according to its on-the-fly software programmed re-direct vec_base register 310.
Since the vec_base registers are programmable, CPU bitmaps can be placed differently anywhere in memory each time the code or code sizes change, or the memory requirements change to allow for an efficient usage of memory allocations.
A further advantage of this scheme is to allow all CPUs to execute the same bitmap if needed for debugging for example by just programming all re-direct registers to the same bitmap start address.
Hardware resources and engineering stand to gain from this new process as all CPUs are exactly identical now and hence only one is to be synthesized, routed, and then placed in the system on the chip (SOC) as many times as required.
In view of the foregoing, it will be appreciated that the present system provides a method to compile code and execute starting at any address in the memory versus starting the code at address location zero or a hard coded address location. A mechanism external to CPU constantly re-directs the instruction fetches & the data load/store operation to the appropriate location in memory.
It should be understood that the foregoing relates only to the exemplary embodiments of the present invention, and that numerous changes may be made therein without departing from the spirit and scope of the invention as defined by the following claims. Accordingly, it is the claims set forth below, and not merely the foregoing illustrations, which are intended to define the exclusive rights of the invention.
This application claims priority to the U.S. provisional application No. 60/605,864 titled “Hardware Based Code Relocation” filed on 31 Aug. 2004, which is incorporated in its entirety by reference.
Number | Date | Country | |
---|---|---|---|
60605864 | Aug 2004 | US |