The Integer Unit

updated 24/11/99

 

The Integer Unit (sometimes called the "Arithmetic and Logic Unit" (ALU)) is the central part of the processor: it is basically a combinational logic element, that can do both arithemetic and logical operations on integer numbers: for example, two words can be added, subtracted, ANDed or ORed together. The operation to be executed is controlled by the values on the control inputs to the Integer Unit supplied by the Dispatch Unit.

The Integer Unit deals with either bytes or words (a word is usually 2 or 4 bytes): in general it takes two eight bit numbers, and gives one eight bit answer, or two words and gives another word as an answer. One of the two words or bytes may be a location in memory, the other is usually the contents of one of the registers, or else is eight bits actually stored in the instruction. The latter is called a "literal". (In assembler we normally write a litteral value by preceding it with a hash "#"). The output of the Integer Unit is either written back to memory, or else it is written back to the the register where the data came from.

The control bits (or commands), which come from the Dispatch Unit, determine what happens. The dispatch unit processes the instrcution held in the instrcution register, and decodes this to generate the control bits. These bit dicatet whether the input is taken from a register or from memory; what logical or arithemetic operation is performed; whether the data is a byte or a word; and where the output is written. The instruction also contains the address of the register involved, or the "literal" value to be used.

Status Register

The Integer Unit also has some "status" outputs: for example, if the answer is zero, the Z bit is set to 1; and if there was a "carry" the carry bit is set to 1. The new values of the status bits are stored in the Integer Unit status register after completion of each instruction. Many instructions modify only some status bits, leaving the value of the other bits unchanged.

Executing Instructions in the Integer Unit

Here are some of the elementary instructions which can be done (I am spelling them out in a longer form than they are usually written, the mneumonic in brackets indiactes the more usual short-hand form).

Note that a small number of choices define all these possibilities. Each instruction has three parts: an operation code (opcode) which specifies what the Integer Unit is to do; a size which specifies how many bits are to be used (in many cases the default (usual) size is a whole word); a destination which is where the result of the operation is returned (the destination is usually also read into the Integer Unit for most opcodes); and a source addres, which specifies where the data is to come from.

A list of common instructions follows:

Unary operators (operate on one register)
= assign value (move the value of source to the destination)
~a bit-wise inversion (1's complement of register a)
-a negation (2's complement of register a)
a++ increment a (add 1 to register a)
a-- decrement a (subtract 1 from register a)


Logical operators
a & b Bit-wise logical and of register a with register b, answer in register a
a ^ b Bit-wise exclusive OR (XOR) of register a with register b, answer in register a
a | b Bit-wise OR of register a with register b, answer in register a
a << n Shift register a left n bits (a multiplied by 2 to the power n)
a >> n Shift register a right n bits (a divided by 2 to the power n)


Arithmetic Operators
a +b add a to b, answer in register a
a - b subtract b from a, answer in register a
a * b a multiplied by b, answer in register a
a / b a divided by b, answer in register a