Review Questions:
Machine Code and Assembly
© 1999 Charles Abzug
Answers to Selected Questions:
Answer: The single determining factor is the total number of different op codes that must be represented. This is, in turn, a function of the total number of instructions and the number of addressing modes applicable to each instruction. Consider the set of instructions {Ii}, where i ranges from 1 to n, and where each instruction Ii is associated with some number Ai of addressing modes. Then the total number of different opcodes that must be represented is given by:
n
N = Sumi = 1 (Ii * Ai)
The minimum length of the op codes is then defined by:
L =
é (log2N) ùNote that the symbols é ù denote the ceiling function, which is defined as the smallest integer equal to or greater than the quantity between the two symbols. Thus, for example, if N has a value of 24010, then the base-2 logarithm of N will be somewhere between 7 and 8, actually very close to 8, and the ceiling function of that would be 8. Likewise, if N has a value of 130, then again the base-2 logarithm will be between 7 and 8, in this case very close to 7, and the ceiling function would again have a value of 8.
Answer: See text on pages 12-5 through 12-7 of Bebop Bytes Back, as well as Figure 12.4.
Answer: See the sidebar on page 12-7 of Bebop Bytes Back. (NOTE for excessively serious Graduate Students: No, you do NOT need to know the answer to this question to get a good grade for this course.)
Answer: An address label defines only an address; its value is the memory address associated with the machine instruction where its op code is placed in the program, and therefore it is almost always utilized within the program inside square brackets as a memory reference. Its principal utility is in specifying destination locations for circumstances where the execution order of program operations is required to deviate from the default sequential order. A constant label, on the other hand, defines a memory location where data are stored; it can therefore be used in the program either inside square brackets to specify the address of the data or without square brackets, in which case the reference is to the contents of its memory location (i.e., its value). See pages 12-8 through 12-12 in Bebop Bytes Back.
Answer: The four possible fields are the Label field, the Operation field, the Operand field, and the Comment field. In Beboputer assembly language, none of these fields is universally obligatory, although the Operand field is obligatory when the instruction mnemonic specifies an operation that requires an operand, and the Label field is obligatory for an .EQU directive statement. The fields are all defined syntactically. A character sequence that constitutes a legal Beboputer label, followed by a colon and situated either at the left extremity of the statement line or separated from it exclusively by spaces, defines the label field. The Operation field is either the leftmost field in the statement or the second field after a label field, and it consists of either one of the 43 operation mnemonics listed in Figure C.2 or one of the assembler directives (.ORG, .END, .EQU, .BYTE, .2BYTE, or .4BYTE), also known as pseudo-ops. The Operand field in the Beboputer assembly language consists of a single legal operand specification in the syntax appropriate to the addressing mode of the instruction, i.e., either:
The Comment field consists of the '#' character followed by any number of text characters up to the end of the statement line.
In some assemblers, the various fields are rigidly defined on the basis of number of character positions from the leftmost extremity of the statement line. Thus, a colon might not be necessary to delimit the end of the label field, or a '#' to delimit the beginning of the comment field. This is an artifact of the "old days" of computer history, when programs were entered on punched cards having 80 columns of rigidly fixed equal width, each of which held one text character.
Answer: Label fields are not allowed in statements bearing the .ORG or .END pseudo-ops (directives).
Answer: A declaration statement is used to declare the value of a constant that will be used in the program.
Answer: The unary operator '-' takes the Two's Complement of the number specified immediately to its right, whereas the '!' operator takes the Ones' Complement.
Answer: See pages 12-29 to 12-32 and Figures 12.27 to 12.34 in Bebop Bytes Back, or pages C-3 through C-12 and Figures C.1 through C.9.
Last updated 03 Jan 2000