Repeat instruction explained

In computer instruction set architectures (ISA), a repeat instruction is a machine language instruction which repeatedly executes another instruction a fixed number of times, or until some condition is met.

Since it is an instruction that operates on other instructions like the execute instruction, it has been classified as a meta-instruction.[1]

Computer models

The Univac 1103 (1953) includes a repeat instruction (op code mnemonic:) which executes the following instruction a fixed number of times, possibly incrementing one or both of the address fields of that instruction.[2] This compensates for the architecture's lack of index registers.[3]

The GE-600/Honeywell 6000 series (1964) supports a single-instruction repeat, a double-instruction repeat, and a linked-list repeat .[4] [5]

The x86 ISA, starting with the 8086, includes a series of special-purpose repeat instructions which are called "repeat string operation prefixes" and may only be applied to a small number of string instructions . These instructions repeat an operation and decrement a counter until it is zero, or may also stop when a certain condition is met.[6]

The Texas Instruments TMS320 digital signal processor (1983) includes an instruction for repeating a single-cycle instruction or two single-cycle instruction in parallel and an instruction for repeating a block of instructions . These use special block-repeat counter registers .[7]

Semantics

The instruction or instruction pair to be executed follows the repeat instruction. Fields in the instruction determine the loop termination condition.[5] In the case of the TMS320, a block of up to 64Kbytes can be repeated.

Notes

  1. George E.. Rossman. A Course of Study in Computer Hardware Architecture. IEEE Computer. 8. 12. 44–63. December 1975. 10.1109/C-M.1975.218835. 977792., p. 50
  2. Remington Rand Univac. Reference Manual: Univac Scientific 1103A Computer. 1956. 30.
  3. Conrad Weisert, "Simulating an Obsolete Computer in 1960", Part 1: The main processor https://www.idinews.com/history/Simulator.html
  4. General Electric Computer Department. GE-635 System Manual. July 1964. A6.
  5. General Electric Information Systems. GE-625/635 Programming Reference Manual. July 1964.
  6. Intel Corporation, "Instruction Set Reference", Intel 64 and IA-32 Architectures Software Developer's Manual, Order Number 253667-060US, September 2016, 2B:4-550 full text
  7. Book: Kuo, Sen-Maw . Real-time Digital Signal Processing: Implementations, Applications, and Experiments with the TMS320C55X . 2003 . 清华大学出版社有限公司 . 978-7-302-07700-8 . 67–68 . en.