WO2013119842A1 - Using the least significant bits of a called function's address to switch processor modes - Google Patents
Using the least significant bits of a called function's address to switch processor modes Download PDFInfo
- Publication number
- WO2013119842A1 WO2013119842A1 PCT/US2013/025187 US2013025187W WO2013119842A1 WO 2013119842 A1 WO2013119842 A1 WO 2013119842A1 US 2013025187 W US2013025187 W US 2013025187W WO 2013119842 A1 WO2013119842 A1 WO 2013119842A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- mode
- bits
- execution mode
- instruction
- target address
- Prior art date
Links
- 238000000034 method Methods 0.000 claims abstract description 30
- 238000012545 processing Methods 0.000 claims abstract description 14
- 238000004891 communication Methods 0.000 claims description 3
- 239000004065 semiconductor Substances 0.000 claims 1
- 230000006870 function Effects 0.000 description 67
- 210000003813 thumb Anatomy 0.000 description 15
- 238000013459 approach Methods 0.000 description 10
- 230000008859 change Effects 0.000 description 10
- 230000006399 behavior Effects 0.000 description 9
- 230000009471 action Effects 0.000 description 5
- 230000007704 transition Effects 0.000 description 4
- 241000761456 Nops Species 0.000 description 2
- 230000009191 jumping Effects 0.000 description 2
- 239000002245 particle Substances 0.000 description 2
- 230000008901 benefit Effects 0.000 description 1
- 230000002950 deficient Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000011835 investigation Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30181—Instruction operation extension or modification
- G06F9/30189—Instruction operation extension or modification according to execution mode, e.g. mode flag
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/3005—Arrangements for executing specific machine instructions to perform operations for flow control
- G06F9/30054—Unconditional branch instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30076—Arrangements for executing specific machine instructions to perform miscellaneous control operations, e.g. NOP
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30145—Instruction analysis, e.g. decoding, instruction word fields
- G06F9/30149—Instruction analysis, e.g. decoding, instruction word fields of variable length instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30181—Instruction operation extension or modification
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/32—Address formation of the next instruction, e.g. by incrementing the instruction counter
- G06F9/322—Address formation of the next instruction, e.g. by incrementing the instruction counter for non-sequential address
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3802—Instruction prefetching
- G06F9/3816—Instruction alignment, e.g. cache line crossing
Definitions
- Disclosed embodiments relate to switching between execution modes in processing systems. More particularly, exemplary embodiments are directed to processing systems comprising at least two instruction modes and techniques for switching between the at least two instruction modes using one or more least significant bits of addresses of called functions.
- a first execution mode may comprise instructions of fixed-width
- a second execution mode may support variable-width instructions.
- a common address space may be shared between instructions in each mode, such that a same address or program counter (PC) value may point to a first instruction if the processor is in the first execution mode or to a second instruction if the processor is in the second execution mode.
- PC program counter
- an ARM mode supports fixed-width (32- bit) instructions
- a THUMB mode supports variable-width (16-bit and 32-bit) instructions.
- a common address space in a byte-addressable memory may comprise instructions in both ARM and THUMB modes.
- alignment of instructions in the two modes may be different.
- ARM mode instructions may be aligned at 32-bit boundaries, such that the two least significant address bits for the ARM mode instruction will always be "00".
- THUMB mode instructions may be aligned at either 16-bit or 32-bit boundaries, such that the two least significant address bits for the THUMB mode instructions may be "10" or "00.”
- knowing the address alone is insufficient to conclusively determine which one of the two modes, ARM or THUMB, is currently being executed.
- ARM processors In order to track which mode is being executed, ARM processors adopt an approach which includes storing a mode bit in the least significant bit (LSB) of the PC.
- the LSB of the PC in THUMB mode may be a reserved bit because as noted above the two least significant address bits are either "10" or "00" and thus the LSB (which is"0" in both cases) may be used to store a mode bit.
- Execution may switch between the ARM mode and the THUMB mode on function calls, such as a jump instruction.
- a jump instruction transfers execution to a function comprising instructions in THUMB mode
- the ARM processor implements this change in modes to THUMB mode by jumping to the address of the function + 1.
- the value of the two least significant bits in the THUMB mode are either "11” or "01,” thereby distinguishing them from the "00" value of the two least significant bits in the ARM mode.
- Drawbacks in terms of software costs of using a page attribute to determine the mode include, complicating the loader, which would have to determine which mode a page is supposed to be in and then fill in the appropriate bit in the page table entry for that page. Further, the debugger would have to look up the entry in the page table for a particular page before it can disassemble instructions in that page. Similarly deficient are other known approaches that include specific program code for determining the mode associated with addresses using reserved operation code (OpCode) bits.
- OFCode reserved operation code
- Exemplary embodiments of the invention are directed to systems and method for switching between execution modes in processing systems. More particularly, exemplary embodiments are directed to processing systems comprising at least two instruction modes, a classic/aligned mode and a compressed/unaligned mode, and switching between the at least two instruction modes using one or more least significant bits of addresses of called functions.
- an exemplary embodiment is directed to a method of switching between execution modes in a processor, the method comprising: detecting a first instruction when the processor is operating in a first execution mode, analyzing one or more bits a target address of the first instruction, and determining whether to switch operation of the processor from the first execution mode to a second execution mode based on the one or more bits.
- Another exemplary embodiment is directed to an apparatus comprising: a processor configured to execute instructions in at least two execution modes including a first execution mode and a second execution mode, logic configured to detect a first instruction during execution in the first execution mode, logic configured to analyze one or more bits of a target address of the first instruction, and logic configured to determine whether to switch operation of the processor from the first execution mode to the second execution mode based on the one or more bits.
- Yet another exemplary embodiment is directed to a processing system comprising: means for executing instructions in at least two execution modes including a first execution mode and a second execution mode, means for detecting a first instruction during execution in the first execution mode, means for analyzing one or more bits of a target address of the first instruction, and means for determining whether to switch operation of the processor from the first execution mode to the second execution mode based on the one or more bits.
- Another exemplary embodiment is directed to a non-transitory computer-readable storage medium comprising code, which, when executed by a processor, causes the processor to perform operations for switching between execution modes of the processor, the non-transitory computer-readable storage medium comprising: code for detecting a first instruction when the processor is operating in a first execution mode, code for analyzing one or more bits a target address of the first instruction, and code for determining whether to switch operation of the processor from the first execution mode to a second execution mode based on the one or more bits.
- FIG. 1 is a simplified schematic of a processing system configured according to exemplary embodiments.
- FIG. 2 illustrates exemplary code sequences executed by a processor configured to switch between execution modes according to exemplary embodiments.
- FIG. 3 illustrates an operational flow of a method for switching between execution modes according to exemplary embodiments.
- FIGS. 4A-B illustrate schemes for tracking and switching between the execution modes according to exemplary embodiments.
- FIG. 5 illustrates an exemplary wireless communication system 500 in which an embodiment of the disclosure may be advantageously employed.
- Exemplary embodiments include techniques for tracking and switching between execution modes, while avoiding drawbacks associated with existing approaches.
- One embodiment may include at least two execution modes, wherein the execution modes may be defined with regard to the respective alignment of instructions within the modes.
- Reference to alignment of instructions is generally made with respect to 32-bits (or 4- bytes) of memory address space, but this shall not be construed as a limitation.
- Disclosed techniques may be easily extended to other memory address boundaries without departing from the scope of the present disclosure.
- a first execution mode instructions may be allowed to be unaligned/misaligned or arbitrarily aligned without restrictions.
- This first execution mode will be referred to herein as a "compressed" mode.
- a second execution mode alignment of instructions may be restrained to specified boundaries in a corresponding memory address space, such as a 32-bit boundary. This second execution mode will be referred to herein as a "classic" mode.
- Processing system 100 is shown to comprise processor 102 coupled to memory 104. While not illustrated, processing system 100 may comprise various other components such as one or more instruction and/or data caches, I/O devices, coprocessors, etc as are well known in the art.
- Memory 104 may be byte- addressable and comprise instructions which may be unaligned, or aligned at 32-bit boundaries (i.e. both instructions in compressed mode and classic mode respectively).
- Processor 102 may be configured to execute instructions in the classic mode as well as the compressed mode.
- instructions in the classic mode may be aligned to a 32-bit boundary in memory 104, thus mandating the two least significant bits of addresses of each and every instruction in the classic mode to have the value "00.”
- selected instructions in the compressed mode may be forcibly misaligned such that the two least significant bits of addresses of the selected instructions have a non-zero value, i.e. any value other than "00" (e.g. the two least significant bits of addresses of the selected instructions may be forced to be of value "01,” "10,” or "11"). Accordingly, these least significant bits of addresses may be indicative of alignment and may be referred to herein as "alignment bits.”
- the selected instructions in the compressed mode which are forcibly misaligned may correspond to entry points.
- entry points may mark the beginning of a function comprising instructions in the compressed mode; entry points may be instructions following calls from the compressed mode; or entry points may mark the beginning of exception/interrupt handlers.
- the selected instructions which may trigger a switch from execution in the classic mode to execution in the compressed mode may be forcibly misaligned. Alignment of all remaining instructions, such as compressed mode instructions following a function call to the compressed mode, may remain undisturbed (i.e. the alignment bits of addresses of all instructions except for the selected instructions may be of any value, including "00").
- exemplary embodiments may switch between execution in the classic mode to execution in the compressed mode, while avoiding drawbacks of tracking and switching between execution modes in conventional approaches.
- Code sequences 210 and 214 comprise instructions in the classic (aligned) mode
- code sequence 212 comprises instructions in the compressed (unaligned or misaligned) mode.
- code sequence 210 comprises Function 1, which begins at instruction al and includes instructions al-a7.
- the alignment bits of addresses for Function 1 and corresponding instructions al-a7, as well as the call, Call 1 have been illustrated as "00.”
- Some embodiments may include an optional user status register (or "USR,” not explicitly shown), wherein the USR may be configured to provide an indication of the status of the alignment bits.
- the USR may be optionally updated to indicate that the execution is in classic mode.
- this function may begin at instruction bl and include instructions bl-b6, is in a compressed mode. It is necessary for processor 102 to recognize the switch in execution modes caused by taking path 202, in order to avoid erroneous execution in a wrong execution mode. Thus, Function 2 may be recognized as an entry point to the compressed mode in exemplary embodiments.
- Recognizing this switch may be accomplished by forcing the two least significant bits (or alignment bits) of the address of Function 2, "AB" to be any value other than "00.”
- the address of Function 2 may be forcibly misaligned in memory 104, such that "AB" is "01,” “10,” or "11.”
- This forcible misalignment may be accomplished, for example, in a compiler, software, or dedicated logic in processing system 100 (not explicitly shown).
- forcibly misaligning Function 2 may be accomplished by configuring the assembler to add a nop before Function 2 along path 202.
- the size of the nop may be adjusted to ensure that the alignment bits "AB" have a value other than "00.” For example, if the alignment bits "AB" are already of a value other than "00” then the assembler may not insert a nop. On the other hand, if the value of "AB” is equal to "00,” then the assembler may insert a single one-byte nop, which would adjust the starting address of Function 2 such that "AB" is equal to "01.”
- Processor 102 may be configured to investigate the alignment bits for every entry point encountered during execution of instructions. Thus, once processor 102 recognizes that the entry point Function 2 has the alignment bits "AB" as a non-zero value, the USR may be optionally updated to indicate that the execution is now in compressed mode. Alignment of instructions bl-b3 may be left undisturbed, and the alignment bits of their corresponding addresses may have any value, including "00.”
- processor 102 may be configured to investigate the alignment address bits of Function 3, because it is an entry point. However, this time, it may be recognized that the alignment bits of the entry point, Function 3, are "00" because Function 3 is in the aligned classic mode. Thus, processor 102 may recognize that execution is back to classic mode for Function 3 which begins at instruction cl and includes instructions cl-c5. Processor 102 may also optionally update the USR to indicate the return to the classic mode.
- processor 102 may investigate the alignment bits of the entry point.
- the entry point is instruction a5, and thus it may be recognized that the alignment bits of instruction a5 are "00.” Thus, it may be concluded that the execution has returned to the classic mode.
- the USR may be updated to indicate that the execution is in classic mode.
- instruction b4 For the return, Return 2, to instruction b4 along path 208, the entry point will be instruction b4.
- processor 102 must be able to recognize that instruction b4 is in the compressed mode.
- instruction b4 may be forcibly misaligned, such that the alignment bits of instruction b4 are not "00.”
- forcibly misaligning instruction b4 may be accomplished by configuring the assembler to add a nop before the call, Call 2 to Function 3 along path 206.
- the size of the nop may be adjusted to ensure that the least significant bits "CD” have a value other than "00.”
- the size of the call instruction, Call 2 to Function 3 along path 206 may be increased such that the least significant bits "CD" of instruction b4 are forced to a value "01,” “10,” or "11.”
- Alignment of instructions b5 and b6 is unrestricted and undisturbed.
- the alignment bits of addresses of instructions b5 and b6 may be any value, including "00.”
- calls/returns to aligned addresses may remain in classic mode 402 as shown by loop 406.
- calls/returns from classic mode 402 to an unaligned address may transition along path 408 to compressed mode 404.
- Calls/returns to unaligned addresses may remain in compressed mode 404 as shown by loop 412.
- calls/returns from compressed mode 404 to aligned addresses may transition to classic mode 402 along path 410.
- exemplary techniques may be extended to other such instructions.
- some embodiments may be extended to monitor mode switches for instructions such as jump, jumpr, callr, dealloc_return, etc, which will be briefly described with reference to FIG. 4B. These instructions may be monitored for mode switches, and thus, execution may be ensured to be in the correct mode, by following similar techniques as described above for calls/returns.
- jump instructions may be utilized in one of two different manners with regard to exemplary embodiments.
- a jump instruction when encountered within a function, can be used to jump to an instruction within the function.
- a jump instruction may behave as a tail call (or "tailcall"), which as one of skill in the art will recognize, can be used to perform a call-type behavior. While a call to a function may require a return instruction to return to the location of the call, which can be saved on a call stack, a tailcall may not need the location of a call to be remembered or saved on a stack. On the other hand, a tailcall may directly return to an original caller. Instructions such as a jump may need additional considerations, as will be further explained below.
- a jump instruction is encountered within a function in classic mode, and the behavior of the jump instruction is to jump to an instruction within the function, then there must be no mode change.
- the jump instruction has a behavior of a type such as a tailcall instruction, then executing the jump instruction may cause the control flow to move to an entry point which may be outside the function.
- the entry point may lie in either the classic mode or in compressed mode. Therefore, by investigating the least significant bits of the entry point, a determination of whether there needs to be a mode switch can be made.
- the behavior of a jump instruction encountered in the classic mode may be similar to that of the call instruction described above.
- the jump instruction may or may not be aligned.
- the least significant bits of addresses of the remaining instructions within the function may be any value including "00.”
- the address of the target instruction may not have been forcibly misaligned, and thus may be any value.
- embodiments may include special instructions or instructions with special behavior.
- One such special behavior may include, in the compressed mode, restricting the behavior of a jump instruction to only jump to instructions which would not cause a mode switch, such as to a target instruction within a same function as the jump instruction; and defining a separate tailcall instruction for situations which may cause a mode change, such as jumping to a target instruction which may be outside the same function and possibly in a different mode.
- a mode switch such as to a target instruction within a same function as the jump instruction
- defining a separate tailcall instruction for situations which may cause a mode change, such as jumping to a target instruction which may be outside the same function and possibly in a different mode.
- determination of whether the execution of the instruction will cause a mode change or not can be based on the mode within which the instruction is encountered. If the jump instruction is encountered within the classic mode, then the least significant bits of the target address may be used to determine whether a mode change has occurred. On the other hand, if the jump instruction is encountered within the compressed mode, then no mode change will occur or mode changes can be suppressed, regardless of the indications provided by the least significant bits of the target address. Instead, special tailcall instructions may be used in the compressed mode for achieving jump-type behavior which may require mode change, and such mode change may be determined based on the least significant bits of the tailcall instruction. Similarly, in some embodiments, a return instruction may also be restricted to compressed mode, and not used in classic mode.
- Other instructions may include jumpr and tailcallr. While a jump and tailcall may specify the address of the target instruction, the jumpr and tailcallr instructions may specify a register which may hold the address of the target instruction. Similarly, a callr instruction may specify a register which may hold the address of the function to be called.
- a dealloc_return instruction, which may be used to deallocate a register may also be configured such that mode changes related to execution of the dealloc_return instruction may be based on investigating the least significant bits of the target address of the dealloc_return instruction.
- mode switching behavior and tracking for exemplary instructions including the above special instructions is illustrated.
- instructions such as call, callr, jump, jumpr, and dealloc_return may remain in classic mode 452 without causing a mode switch, according to loop 456.
- a mode switch can occur and these instructions, call, callr, jump, jumpr, and dealloc_return, may transition along path 458 to compressed mode 454.
- instructions such as jump and jumpr will not be tracked for mode switches, as previously described. Instead, tailcall, tailcallr, and return may be tracked.
- instructions such as call, callr, tailcall, tailcallr, return, and dealloc_return may remain in compressed mode 454 according to loop 462.
- a mode switch can occur, and these instructions, call, callr, tailcall, tailcallr, return, and dealloc_return may transition along path 460 to classic mode 452.
- only selected instructions such as the entry points to functions in the compressed mode may be forcibly misaligned, and the addresses of remaining instructions in the compressed mode may be left undisturbed.
- the USR may be configured to efficiently provide an indication of the execution mode.
- Call 1 to Function 2 along path 202 and Return 2 to instruction b4 along path 208 may require a nop to be inserted, while instructions such as Return 1 to instruction a5 along 204 and Call 2 to Function 3 along path 206 would not require such nops. Accordingly, only two of the four types of call/return instructions may require misalignment by the introduction of a nop, which means that wastage of code space by introduction of nops is reduced.
- the addresses of instructions may themselves be conveniently used to recognize the execution mode for function calls and returns, without requiring any complex code or expensive tracking mechanisms.
- the USR may be configured to efficiently provide an indication of the execution mode. Because exemplary embodiments avoid the need for a reserved bit to indicate execution mode, the embodiments correspondingly avoid drawbacks associated with restricting addresses of instructions following entry points to functions. Further, using the value of the address to determine the execution mode requires investigation of the address bits only on calls or returns. Thus, there is no need to know ahead of time, what the mode associated with a target instruction is. Additionally, in exemplary embodiments, MMU page table entries do not need to hold information regarding execution modes of instructions.
- an embodiment can include a method of switching between execution modes in a processor (e.g. processor 102) comprising: detecting a first instruction (e.g. a call/return instruction with a target instruction/entry point such as Function 2/instruction a5 respectively in FIG. 2) when the processor is operating in a first execution mode (e.g.
- a first instruction e.g. a call/return instruction with a target instruction/entry point such as Function 2/instruction a5 respectively in FIG. 2
- a first execution mode e.g.
- Block 302 analyzing one or more bits of a target address of the first instruction (e.g. two least significant bits or alignment bits "AB'V'OO" for Function 2/instruction a5 respectively in FIG. 2) - Block 304; and determining whether to switch operation of the processor from the first execution mode to a second execution mode (e.g. compressed mode) based on the one or more bits - Block 306.
- a target address of the first instruction e.g. two least significant bits or alignment bits "AB'V'OO" for Function 2/instruction a5 respectively in FIG. 2
- Block 304 e.g. compressed mode
- a software module may reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art.
- An exemplary storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor.
- FIG. 5 a block diagram of a particular illustrative embodiment of a wireless device that includes a multi-core processor configured according to exemplary embodiments is depicted and generally designated 500.
- the device 500 includes a digital signal processor (DSP) 564, which may include processor 102 of FIG. 1 coupled to memory 532 as shown.
- DSP digital signal processor
- FIG. 5 also shows display controller 526 that is coupled to DSP 564 and to display 528.
- Coder/decoder (CODEC) 534 e.g., an audio and/or voice CODEC
- Other components, such as wireless controller 540 (which may include a modem) are also illustrated.
- Speaker 536 and microphone 538 can be coupled to CODEC 534.
- wireless controller 540 can be coupled to wireless antenna 542.
- DSP 564, display controller 526, memory 532, CODEC 534, and wireless controller 540 are included in a system-in-package or system-on-chip device 522.
- input device 530 and power supply 544 are coupled to the system-on-chip device 522.
- display 528, input device 530, speaker 536, microphone 538, wireless antenna 542, and power supply 544 are external to the system-on-chip device 522.
- each of display 528, input device 530, speaker 536, microphone 538, wireless antenna 542, and power supply 544 can be coupled to a component of the system-on-chip device 522, such as an interface or a controller.
- FIG. 5 depicts a wireless communications device
- DSP 564 and memory 532 may also be integrated into a set-top box, a music player, a video player, an entertainment unit, a navigation device, a personal digital assistant (PDA), a fixed location data unit, or a computer.
- a processor e.g., DSP 564 may also be integrated into such a device.
- an embodiment of the invention can include a computer readable media embodying a method for switching between execution modes in a processor. Accordingly, the invention is not limited to illustrated examples and any means for performing the functionality described herein are included in embodiments of the invention. While the foregoing disclosure shows illustrative embodiments of the invention, it should be noted that various changes and modifications could be made herein without departing from the scope of the invention as defined by the appended claims. The functions, steps and/or actions of the method claims in accordance with the embodiments of the invention described herein need not be performed in any particular order. Furthermore, although elements of the invention may be described or claimed in the singular, the plural is contemplated unless limitation to the singular is explicitly stated.
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Executing Machine-Instructions (AREA)
Abstract
Description
Claims
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2014555869A JP6189866B2 (en) | 2012-02-07 | 2013-02-07 | Use the least significant bit of the address of the called function to switch processor modes |
KR1020147025017A KR101847889B1 (en) | 2012-02-07 | 2013-02-07 | Using the least significant bits of a called function's address to switch processor modes |
EP13706805.2A EP2812792B1 (en) | 2012-02-07 | 2013-02-07 | Using the least significant bits of a called function's address to switch processor modes |
CN201380008133.7A CN104106044B (en) | 2012-02-07 | 2013-02-07 | Carry out handoff processor pattern using the least significant bit of the address of invoked function |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201261595773P | 2012-02-07 | 2012-02-07 | |
US61/595,773 | 2012-02-07 | ||
US13/655,499 US10055227B2 (en) | 2012-02-07 | 2012-10-19 | Using the least significant bits of a called function's address to switch processor modes |
US13/655,499 | 2012-10-19 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2013119842A1 true WO2013119842A1 (en) | 2013-08-15 |
Family
ID=48903962
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2013/025187 WO2013119842A1 (en) | 2012-02-07 | 2013-02-07 | Using the least significant bits of a called function's address to switch processor modes |
Country Status (6)
Country | Link |
---|---|
US (1) | US10055227B2 (en) |
EP (1) | EP2812792B1 (en) |
JP (1) | JP6189866B2 (en) |
KR (1) | KR101847889B1 (en) |
CN (1) | CN104106044B (en) |
WO (1) | WO2013119842A1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20160117961A (en) | 2015-04-01 | 2016-10-11 | 에스케이케미칼주식회사 | Electrolyte composition for secondary cell and secondary cell comprising same |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10152338B2 (en) * | 2016-12-14 | 2018-12-11 | International Business Machines Corporation | Marking external sibling caller routines |
FR3097345B1 (en) * | 2019-06-13 | 2021-06-25 | Stmicroelectronics Grand Ouest Sas | PROCESS FOR MANAGING THE OPERATION OF A COMPUTING UNIT CAPABLE OF OPERATING WITH INSTRUCTIONS OF DIFFERENT SIZES AND CORRESPONDING INTEGRATED CIRCUIT |
US10802854B2 (en) * | 2019-08-30 | 2020-10-13 | Alibaba Group Holding Limited | Method and apparatus for interpreting bytecode instruction stream |
CN114020330B (en) * | 2021-11-04 | 2023-11-03 | 苏州睿芯集成电路科技有限公司 | Method for mode switching in RISC-V processor authentication, electronic device and storage medium |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1065586A2 (en) * | 1999-06-29 | 2001-01-03 | Kabushiki Kaisha Toshiba | Computer system comprising a plurality of parallel processors |
US6209079B1 (en) * | 1996-09-13 | 2001-03-27 | Mitsubishi Denki Kabushiki Kaisha | Processor for executing instruction codes of two different lengths and device for inputting the instruction codes |
GB2374694A (en) * | 2001-02-26 | 2002-10-23 | Advanced Risc Mach Ltd | Storing instruction set information |
US20060174089A1 (en) * | 2005-02-01 | 2006-08-03 | International Business Machines Corporation | Method and apparatus for embedding wide instruction words in a fixed-length instruction set architecture |
GB2435116A (en) * | 2006-02-10 | 2007-08-15 | Imagination Tech Ltd | Determining an instructions set based on the instruction address |
US20100312991A1 (en) * | 2008-05-08 | 2010-12-09 | Mips Technologies, Inc. | Microprocessor with Compact Instruction Set Architecture |
Family Cites Families (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
DE4309532C2 (en) | 1992-03-25 | 1996-10-31 | Intel Corp | Method for backing up a system image of a computer system on a permanent storage device and a computer system |
US6496922B1 (en) | 1994-10-31 | 2002-12-17 | Sun Microsystems, Inc. | Method and apparatus for multiplatform stateless instruction set architecture (ISA) using ISA tags on-the-fly instruction translation |
US5867681A (en) | 1996-05-23 | 1999-02-02 | Lsi Logic Corporation | Microprocessor having register dependent immediate decompression |
US6189090B1 (en) * | 1997-09-17 | 2001-02-13 | Sony Corporation | Digital signal processor with variable width instructions |
US7065633B1 (en) | 1999-01-28 | 2006-06-20 | Ati International Srl | System for delivering exception raised in first architecture to operating system coded in second architecture in dual architecture CPU |
KR100308211B1 (en) * | 1999-03-27 | 2001-10-29 | 윤종용 | Micro computer system with compressed instruction |
US6449712B1 (en) * | 1999-10-01 | 2002-09-10 | Hitachi, Ltd. | Emulating execution of smaller fixed-length branch/delay slot instructions with a sequence of larger fixed-length instructions |
JP2001142692A (en) * | 1999-10-01 | 2001-05-25 | Hitachi Ltd | Microprocessor to execute two different fixed length instruction sets, microcomputer and instruction executing method |
US20050144427A1 (en) * | 2001-10-23 | 2005-06-30 | Ip-First Llc | Processor including branch prediction mechanism for far jump and far call instructions |
US7376812B1 (en) | 2002-05-13 | 2008-05-20 | Tensilica, Inc. | Vector co-processor for configurable and extensible processor architecture |
US7340588B2 (en) | 2003-11-24 | 2008-03-04 | International Business Machines Corporation | Extending the number of instruction bits in processors with fixed length instructions, in a manner compatible with existing code |
US7421568B2 (en) | 2005-03-04 | 2008-09-02 | Qualcomm Incorporated | Power saving methods and apparatus to selectively enable cache bits based on known processor state |
ATE466331T1 (en) | 2006-09-06 | 2010-05-15 | Silicon Hive Bv | DATA PROCESSING CIRCUIT HAVING MULTIPLE TYPES OF INSTRUCTIONS, METHOD FOR OPERATION OF SUCH DATA CIRCUIT, AND SCHEDULING METHOD FOR SUCH DATA CIRCUIT |
US7711927B2 (en) * | 2007-03-14 | 2010-05-04 | Qualcomm Incorporated | System, method and software to preload instructions from an instruction set other than one currently executing |
CN102077195A (en) | 2008-05-08 | 2011-05-25 | Mips技术公司 | Microprocessor with compact instruction set architecture |
-
2012
- 2012-10-19 US US13/655,499 patent/US10055227B2/en active Active
-
2013
- 2013-02-07 JP JP2014555869A patent/JP6189866B2/en not_active Expired - Fee Related
- 2013-02-07 WO PCT/US2013/025187 patent/WO2013119842A1/en active Application Filing
- 2013-02-07 KR KR1020147025017A patent/KR101847889B1/en active IP Right Grant
- 2013-02-07 CN CN201380008133.7A patent/CN104106044B/en not_active Expired - Fee Related
- 2013-02-07 EP EP13706805.2A patent/EP2812792B1/en active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6209079B1 (en) * | 1996-09-13 | 2001-03-27 | Mitsubishi Denki Kabushiki Kaisha | Processor for executing instruction codes of two different lengths and device for inputting the instruction codes |
EP1065586A2 (en) * | 1999-06-29 | 2001-01-03 | Kabushiki Kaisha Toshiba | Computer system comprising a plurality of parallel processors |
GB2374694A (en) * | 2001-02-26 | 2002-10-23 | Advanced Risc Mach Ltd | Storing instruction set information |
US20060174089A1 (en) * | 2005-02-01 | 2006-08-03 | International Business Machines Corporation | Method and apparatus for embedding wide instruction words in a fixed-length instruction set architecture |
GB2435116A (en) * | 2006-02-10 | 2007-08-15 | Imagination Tech Ltd | Determining an instructions set based on the instruction address |
US20100312991A1 (en) * | 2008-05-08 | 2010-12-09 | Mips Technologies, Inc. | Microprocessor with Compact Instruction Set Architecture |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20160117961A (en) | 2015-04-01 | 2016-10-11 | 에스케이케미칼주식회사 | Electrolyte composition for secondary cell and secondary cell comprising same |
Also Published As
Publication number | Publication date |
---|---|
CN104106044A (en) | 2014-10-15 |
EP2812792A1 (en) | 2014-12-17 |
KR101847889B1 (en) | 2018-04-11 |
US10055227B2 (en) | 2018-08-21 |
JP6189866B2 (en) | 2017-08-30 |
KR20140123576A (en) | 2014-10-22 |
EP2812792B1 (en) | 2017-10-18 |
US20130205115A1 (en) | 2013-08-08 |
JP2015511358A (en) | 2015-04-16 |
CN104106044B (en) | 2017-10-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP2812792B1 (en) | Using the least significant bits of a called function's address to switch processor modes | |
RU2417407C2 (en) | Methods and apparatus for emulating branch prediction behaviour of explicit subroutine call | |
JP6796717B2 (en) | Branch target buffer compression | |
US20160350116A1 (en) | Mitigating wrong-path effects in branch prediction | |
US9372773B2 (en) | User-level hardware branch records | |
CN101884025A (en) | Method and a system for accelerating procedure return sequences | |
EP3198400B1 (en) | Dependency-prediction of instructions | |
EP2972789B1 (en) | Method to improve speed of executing return branch instructions in a processor | |
EP2972791B1 (en) | Method and apparatus for forwarding literal generated data to dependent instructions more efficiently using a constant cache | |
WO2019005458A1 (en) | Branch prediction for fixed direction branch instructions | |
US20130283023A1 (en) | Bimodal Compare Predictor Encoded In Each Compare Instruction | |
US10838731B2 (en) | Branch prediction based on load-path history | |
EP3475823B1 (en) | Parity for instruction packets | |
CN110741343A (en) | Multi-labeled branch prediction table | |
CN104423927A (en) | Method and device for processing instructions and processor | |
KR20140111416A (en) | Apparatus and method for non-blocking execution of a static scheduled processor | |
CN113703842B (en) | Value prediction method, device and medium based on branch prediction |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 13706805 Country of ref document: EP Kind code of ref document: A1 |
|
DPE1 | Request for preliminary examination filed after expiration of 19th month from priority date (pct application filed from 20040101) | ||
REEP | Request for entry into the european phase |
Ref document number: 2013706805 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2013706805 Country of ref document: EP |
|
ENP | Entry into the national phase |
Ref document number: 2014555869 Country of ref document: JP Kind code of ref document: A |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
ENP | Entry into the national phase |
Ref document number: 20147025017 Country of ref document: KR Kind code of ref document: A |