Microsequencer Explained

In computer architecture and engineering, a sequencer or microsequencer generates the addresses used to step through the microprogram of a control store. It is used as a part of the control unit of a CPU or as a stand-alone generator for address ranges.

Usually the addresses are generated by some combination of a counter, a field from a microinstruction, and some subset of the instruction register. A counter is used for the typical case, that the next microinstruction is the one to execute. A field from the microinstruction is used for jumps, or other logic.

Since CPUs implement an instruction set, it's very useful to be able to decode the instruction's bits directly into the sequencer, to select a set of microinstructions to perform a CPU's instructions.

Most modern CISC processors use a combination of pipelined logic to process lower complexity opcodes which can be completed in one clock cycle, and microcode to implement ones that take multiple clock cycles to complete.

One of the first integrated microcoded processors was the IBM PALM Processor, which emulated all of the processor's instruction in microcode and was used on the IBM 5100, one of the first personal computers.

Recent examples of similar open-sourced microsequencer-based processors are the MicroCore Labs MCL86, MCL51, and MCL65 cores which emulate the Intel 8086/8088, 8051 and MOS 6502 instruction sets entirely in microcode.

Simple example

The Digital Scientific Corp. Meta 4 Series 16 computer system was a user-microprogrammable system first available in 1970. Branches in the microcode sequence occur inone of three ways.[1]

One more sequencing option allowed on a branch instruction is the execute (XQ) option. When specified, the single instruction at the branch address is executed, but then execution continues after the original branch instruction. The IX option can be used with the XQ option.

Complex example

The IBM System/360 was a series of compatible computers introduced in 1964, many of which were microprogrammed.[2] The System/360 Model 40 is a good example of a microprogrammed machine with complex microsequencing.[3]

The microstore consists of 4,096 56-bit microinstructions that operate ina horizontal microprogramming style. The store is addressed by the 12-bitread-only address register (ROAR). Unlike most registers in theS/360 architecture, bits in the ROAR are numbered from bit 0 on the rightto bit 11 on the left.

  +------------+
  |    ROAR    |
  +------------+
  11          0

The model 40 performs no sequential execution of microinstructions andtherefore the microsequencer doesn't really branch in the conventionalsense. Instead, each microinstruction specifies the address of the next oneto be executed. Four fields in the microinstruction contribute to the newaddress.

There are essentially three combinations or formats of these fields.

Functional branch format

When the CB field contains 15, a functional branch occurs. The bits ofthe new microstore address in the ROAR are determined as follows.

The CC field can specify various tests of the state of the machine. It canalso specify a constant 0 or 1 for an unconditional bit.

This format alters the flow of control to 1 of 16 instruction pairswithin the low 32 words of a 64-word block of microstore (because bit 5 isalways 0). The CC field then determines which instruction of the pairreceives control.

CD = 0, 1, 3 format

When the CD field is 0, 1, or 3, flow of control is directed to aninstruction within the current 64-word block. The bits of the new microstoreaddress are determined as follows.

The CA field selects 1 of 16 4-word groups within the current 64-word block.The CB and CC fields then determine which instruction of the 4 receivescontrol.

CD = 2 format

When the CD field is 2, flow of control is directed in a nonobvious manner. Thebits of the new microstore address are determined as follows:

The next instruction is in the same 1K-word region as the currentinstruction, because bits 11 - 10 remain the same. The CA field determinesthe 64-word block within the region. The instruction is in the same 4-wordgroup within the new block as the current instruction is within the currentblock, because bits 5 - 2 remain the same.The CB and CC fields then determine which instruction of the 4 receivescontrol.

Simplification

This description has been simplified. It ignores the following features.

Notes and References

  1. Book: Digital Scientific Meta 4 Series 16 Computer System Reference Manual. 7032MO. Digital Scientific Corporation. May 1971.
  2. Book: IBM System/360 Principles of Operation. A22-6821-7. International Business Machines Corp.. September 1968.
  3. Book: System/360 Model 40 Functional Units. SY22-2843-1. International Business Machines Corp.. March 1970.