ENCM 369 Winter 2014 Lab 12 for the Week of April 7
Total Page:16
File Type:pdf, Size:1020Kb
page 1 of 7 ENCM 369 Winter 2014 Lab 12 for the Week of April 7 Steve Norman Department of Electrical & Computer Engineering University of Calgary April 2014 Lab instructions and other documents for ENCM 369 can be found at http://www.enel.ucalgary.ca/People/Norman/encm369winter2014/ 1 This Lab is important, but will not be marked Solutions will be posted sometime during the week of April 7. Please make a serious effort to solve the Exercises yourself before checking so- lutions! You can expect a significant portion of the marks on the final exam to be related to integer multiplication and division, and to floating-point number representation and arithmetic. 2 Exercise A: Practice with mult, multu, div, divu 2.1 Read This First mult and multu were the original integer MIPS multiplication instructions, and are the ones explained in lectures and your textbook. Please use these instructions in this exercise, not any other instructions. There is one more real MIPS instruction for integer multiplication: mul. The mul instruction has two GPRs as sources, and writes bits 31{0 of the product directly to a destination GPR. This is useful for compilers|a compiler can avoid using a mflo instruction when only the low 32 bits of an integer product are needed. MARS assembly language also allows a lot of pseudoinstructions for integer division and multiplication, for example, allowing constants instead of GPRs as sources. Please avoid these pseudoinstructions. To keep things as simple as possible, the ENCM 360 final exam in Winter 2014 will test you on the real instructions mult, multu, div, and divu, not any other real instructions or pseudoinstructions for integer multiplication or division. Of course, that implies that you also need to know how to use mflo or mfhi to copy a result out of Lo or Hi into a GPR. 2.2 What to Do Copy the files in encm369w14lab12/exA Read the two files. You should see that ex12A.asm is a nearly complete translation of ex12A.c|all the tedious work of translating main has been done. However, code must be added to ex12A.asm for the procedures func1 and func2. ENCM 369 Winter 2014 Lab 12 page 2 of 7 Make a copy of ex12A.asm, and add appropriate instructions to func1 and func2 to properly translate the C versions. If you do this correctly, the output of the MARS program should show you the same numbers as the output of the C program. In doing the translation, • do not modify main in any way; • handle multiplication as a typical C compiler would|the result of multiplying two 32-bit integers should be taken as the low 32 bits of the 64-bit product; • do not worry about the possibility of division by zero|in this exercise, you do not need to write code for special behaviour in the case of a zero divisor. 3 Exercise B: IEEE 754 floating-point formats 3.1 Read This First You should be able to do all parts of this exercise with just pencil and paper|the numbers have been set up to make the arithmetic easy to do. 3.2 What to Do Answer the following questions. In each case, take time to write down the steps you take to work toward an answer. 1. If the 32-bit IEEE 754 format is being used, what number does the bit pattern 0xc0a8_0000 represent? 2. If the 32-bit IEEE 754 format is being used, what number does the bit pattern 0x3f20_0000 represent? 3. If the 64-bit IEEE 754 format is being used, what number does the bit pattern 0x4015_0000_0000_0000 represent? 4. If the 64-bit IEEE 754 format is being used, what number does the bit pattern 0xfff0_0000_0000_0000 represent? 5. What is the 32-bit IEEE 754 representation of −3:25? Express your final answer using hexadecimal notation. 6. What is the 64-bit IEEE 754 representation of −3:25? Express your final answer using hexadecimal notation. 4 Exercise C: The minifloat type 4.1 Read This First To understand how floating-point number representation and arithmetic work, it's useful to consider some pencil-and-paper examples. However, doing pencil-and- paper work with 32-bit patterns (or worse, 64-bit patterns) is tedious, so in this exercise we'll do it with an 8-bit floating-point type called the minifloat type. The minifloat type is intended to mimic the IEEE 754 32-bit and 64-bit floating-point types. With only 8 bits, the precision and range of magnitudes for minifloat will obviously be severely limited. The layout of a minifloat is as follows: ENCM 369 Winter 2014 Lab 12 page 3 of 7 bit 7: sign bits 3-0: bit fraction bits 6-4: biased exponent Before continuing to describe the minifloat type, I would like to introduce a bit of notation. I will use the ** operator (borrowed from the Fortran and Python pro- gramming languages) for exponentiation; this is handy when writing mathematics in Web pages and program comments. (So, for example, 2**4 means 24.) Here is the specification for the minifloat type: • The sign bit of a minifloat is 0 for positive numbers and 1 for negative numbers. • The exponent field of a minifloat is used as follows: { Bit patterns 001, 010, 011, 100, 101 and 110 are used for exponents of normal, nonzero numbers. There is a bias of three in the exponent. { The bit pattern 000 is the exponent field in for representations of zero. (IEEE 754 types use all-0 exponents for zero values and also for very- small-magnitude nonzero values called denormalized numbers; we won't bother with denormalized numbers in the minifloat type.) { The bit pattern 111 is not used at all. (IEEE 754 types use all-1 expo- nents to indicate special values of Infinity and NaN|\not a number". We won't bother with Infinity and NaN in the minifloat type.) • In a nonzero minifloat, the fraction bits are used to represent the fractional part of the significand. In representations of zero, the fraction bits must all be 0. Now that the uses of the individual fields have been described, it's possible to determine what real number (if any) is represented by an 8-bit pattern. • First of all, both 00000000 and 10000000 represent zero; note that in an IEEE 754 system, there are also two representations of zero. • Next, there are some bit patterns that don't represent any real number at all. Examples are: 10001010, which has a special exponent of 000 but does not have 0000 in its fraction field; and 01110000, which has the meaningless exponent of 111. • Finally, there are normal, nonzero numbers, such as 01101011. To see what number this is, first split it into fields: the sign bit is 0, the exponent field is 110, and the fraction field is 1011. In base two, then, the number represented is 1.1011 * two ** three Note that the significand is obtained by putting a 1 and a binary point in front of the four-bit fraction field and that the exponent of three is obtained by subtracting the bias of three from the value of six (110). In base ten, the number is (1 + 1=2 + 1=8 + 1=16) × 23 = 1:6875 × 8 = 13:5. ENCM 369 Winter 2014 Lab 12 page 4 of 7 Let's consider the problem of determining a minifloat representation of a number given in base 10, say 0.390625. To start with we need to write our number in the form sign * significand * 2 ** exponent where the significand is greater than or equal to 1 and less than 2. This gives us 0.390625 = 1 * 1.5625 * 2 ** (-2) The sign bit should be 0, obviously. The biased exponent should be −2 + 3, or 001 in base two. What is the fractional part of the significand? Here I will cheat a little and just state that 0.5625 is in fact exactly 1=2 + 1=16, so the correct bit pattern is 1001. Putting all the bit fields together, the minifloat representation is 00011001. The fractional part of the significand in a minifloat is bit3 / 2 + bit2 / 4 + bit1 / 8 + bit0 / 16 From this it should be clear that the fractional part of the significand is always an integer multiple of 1/16. Determining the significand bits in the previous example was relatively easy because 0.5625 just happened to be an integer multiple of 1/16. Most base ten fractions are not integer multiples of 1/16, so usually when converting from base ten to minifloat, the fraction will have to be rounded to an integer multiple of 1/16. The following table is useful for doing such rounding: value base two base ten value base two base ten 0/16 0.0000 0.0000 8/16 0.1000 0.5000 1/16 0.0001 0.0625 9/16 0.1001 0.5625 2/16 0.0010 0.1250 10/16 0.1010 0.6250 3/16 0.0011 0.1875 11/16 0.1011 0.6875 4/16 0.0100 0.2500 12/16 0.1100 0.7500 5/16 0.0101 0.3125 13/16 0.1101 0.8125 6/16 0.0110 0.3750 14/16 0.1110 0.8750 7/16 0.0111 0.4375 15/16 0.1111 0.9375 Let's find a minifloat representation for −3:6, which is −1 × 1:8 × 21. The sign bit is 1 and the exponent field is 100.