Jump to content

Instruction cycle

From Wikipedia, the free encyclopedia

The instruction cycle (also known as the fetch–decode–execute cycle, or simply the fetch–execute cycle) is the cycle that the central processing unit (CPU) follows from boot-up until the computer has shut down in order to process instructions. It is composed of three main stages: the fetch stage, the decode stage, and the execute stage.

This is a simple diagram illustrating the individual stages of the fetch-decode-execute cycle. Legend:

In simpler CPUs, the instruction cycle is executed sequentially, each instruction being processed before the next one is started. In most modern CPUs, the instruction cycles are instead executed concurrently, and often in parallel, through an instruction pipeline: the next instruction starts being processed before the previous instruction has finished, which is possible because the cycle is broken up into separate steps.[1]

Role of components

[edit]

The program counter (PC) is a special register that holds the memory address of the next instruction to be executed. During the fetch stage, the address stored in the PC is copied into the memory address register (MAR) and then the PC is incremented in order to "point" to the memory address of the next instruction to be executed. The CPU then takes the instruction at the memory address described by the MAR and copies it into the memory data register (MDR). The MDR also acts as a two-way register that holds data fetched from memory or data waiting to be stored in memory (it is also known as the memory buffer register (MBR) because of this). Eventually, the instruction in the MDR is copied into the current instruction register (CIR) which acts as a temporary holding ground for the instruction that has just been fetched from memory.

During the decode stage, the control unit (CU) will decode the instruction in the CIR. The CU then sends signals to other components within the CPU, such as the arithmetic logic unit (ALU) and the floating point unit (FPU). The ALU performs arithmetic operations such as addition and subtraction and also multiplication via repeated addition and division via repeated subtraction. It also performs logic operations such as AND, OR, NOT, and binary shifts as well. The FPU is reserved for performing floating-point operations.

Summary of stages

[edit]

Each computer's CPU can have different cycles based on different instruction sets, but will be similar to the following cycle:

  1. Fetch stage: The next instruction is fetched from the memory address that is currently stored in the program counter and stored into the instruction register. At the end of the fetch operation, the PC points to the next instruction that will be read at the next cycle.
  2. Decode stage: During this stage, the encoded instruction presented in the instruction register is interpreted by the decoder.
    • Determine effective address: In the case of an instruction which references memory, the execution phase will need to have the memory address to use. Although some instructions may directly contain the address to use, often the effective address will need to be developed by combining a value from a field of the instruction with the value held in a register, and in some machine architectures there can be an optional variant requiring an extra memory access to obtain the needed address from memory.
  3. Execute stage: The control unit of the CPU passes the decoded information as a sequence of control signals to the relevant functional units of the CPU to perform the actions required by the instruction, such as reading values from registers, passing them to the ALU to perform mathematical or logic functions on them, and writing the result back to a register. If the ALU is involved, it sends a condition signal back to the CU. The result generated by the operation is stored in the main memory or sent to an output device. Based on the feedback from the ALU, the PC may be updated to a different address from which the next instruction will be fetched.
  4. Repeat cycle

In addition, on most processors interrupts can occur. This will cause the CPU to jump to an interrupt service routine, execute that and then return. In some cases, an instruction can be interrupted in the middle, the instruction will have no effect but will be re-executed after return from the interrupt.

Initiation

[edit]

The first instruction cycle begins as soon as power is applied to the system, with an initial PC value that is predefined by the system's architecture (for instance, in Intel IA-32 CPUs, the predefined PC value is 0xfffffff0 or 0x00000000 for ARM architecture family based CPUs). Typically, this address points to a set of instructions in read-only memory (ROM), which begins the process of loading (or booting) the operating system.[2]

Fetch stage

[edit]

The fetch step is the same for each instruction:

  1. The PC stores the address of the instruction to be fetched
  2. This address is copied to the MAR, where this address is used to poll for the location of the instruction
  3. The CU sends a signal to the control bus to read the memory at the address in MAR - this data read is placed in the data bus
  4. The data is transferred back to the CPU via the data bus, where it's loaded into the MDR - at this stage, the PC increments by one
  5. The contents of the MDR are copied into the CIR (where the instruction consists of the instruction opcode and data operand)

Decode stage

[edit]

The decoding process allows the processor to determine what instruction is to be performed so that the CPU can tell how many operands it needs to fetch in order to perform the instruction. The opcode fetched from the memory is decoded for the next steps and moved to the appropriate registers. The decoding is typically performed by binary decoders in the CPU's control unit.

Determine the effective address

[edit]

This step evaluates which type of operation is to be performed, and if it is a memory operation, the computer determines the effective memory address to be used in the following Execute stage. There are various possible ways that a computer architecture can specify for determining the address, usually called the addressing modes.

Some common ways the effective address can be found are:

  • Directly taken from a field of the instruction
  • Taken from a machine register
  • Adding an instruction field with a machine register value
  • Adding an instruction field and values from two machine registers (typically a base address and an indexing value)
  • Indirect mode – the effective address is read from memory at an address found by one of the above methods

Execute stage

[edit]

The CPU sends the decoded instruction (decoded from the CU) as a set of control signals to the corresponding computer components. Depending on the type of instruction, any of these can happen:

  • Logical or arithmetic operations can be executed by the ALU
  • Read/writes from memory (such as load byte/store byte instructions in RISC-V) can be executed
  • Control flow alterations (such as jumps or branches) can be executed - at this stage, if a jump were to occur, instead of the PC incrementing to the adjacent "pointer", it would jump to the pointer specified[3]

This is the only stage of the instruction cycle that is useful from the perspective of the end-user. Everything else is overhead required to make the execute step happen.

See also

[edit]

References

[edit]
  1. ^ Crystal Chen, Greg Novick and Kirk Shimano (2000). "Pipelining". Retrieved 2019-06-26.
  2. ^ Bosky Agarwal (2004). "Instruction Fetch Execute Cycle" (PDF). Archived from the original (PDF) on June 11, 2009. Retrieved 2012-10-14.
  3. ^ Rwatooro T., Davis (2013). "Chapter 3.3 Computer Architecture and the Fetch-Execute Cycle" (PDF). Vienna College ICT Department Portal. p. 3. Retrieved 2025-01-02.{{cite web}}: CS1 maint: url-status (link)