Ask Computer Engineering Expert

Detailed Question: Build a CPU

Overview

This is first part of a two-part project in which you will build a simple, but complete computer in Logisim. For this part, you will build three components that will be key parts of the overall computer design.

Each of these components should be created as separate circuits. For this assignment, you should use the "main" circuit to test the three components. In part 2 of this assignment, you will build the complete computer which will incorporate the components from this assignment, with some additional logic.

Arithmetic Logic Unit

The first of three components is an Arithmetic Logic Unit (ALU) which is a circuit which can perform multiple operations on input values.

The ALU should have three input pins:

The first argument which is a 16-bit value.

The second argument which is also a 16-bit value.

The operation code, or "opcode" which selects which of its operations the ALU should perform on the arguments. The opcodes are given below:

Opcode Operation Meaning
0 And output = in1 & in2
1 Or output = in1 | in2
2 Xor output = in1 ^ in2
3 Not output = ~in1
4 Add output = in1 + in2
5 Subtract output = in1 - in2
6 Multiply output = in1 * in2
7 Set less than output = (in1 < in2) ? 1 : 0
8 Shift left output = in1 << in2
9 Shift right output = in1 >> in2
10 - output = in1
11 - output = in1
12 - output = in2
13 - output = 0
14 Equal Zero? output = (in1 == 0)
15 Not Equal Zero? output = (in1 != 0)

The ALU should contain a single output pin which is a 16-bit value containing the result of the operation as described above.

The blank operations will be used for operations such as memory accesses that do not use the ALU. Each of the outputs just passes along an input (or 0) which will make wiring is slightly simpler.

In order to build the ALU, you should route the arguments through circuits which compute each of the results, and route those into a multiplexer (under the "Plexers" menu). Use the opcode as the selector input of the multiplexer.

To implement the comparison operations, use a "Comparator" circuit. Because our CPU will support negative numbers, you should use 2′s complement comparisons.

For this reason, the right shift operation should be done using an "arithmetic right shift", which maintains the sign bit as it shifts, as opposed to a "logical right shift" which does not.

The comparators output a single bit. In order to extend this to the 16-bit result, you can use a "bit extender" to zero extend the value (pad some number of zeroes to the end).

To test your ALU, create one in main, and connect pins for the inputs and the opcode, and connect the output to an output pin. Check that each opcode works as described above on a few inputs each.

Register File

The register file is a very small memory that contains the working set of values used by our computer. The register file stores just 16 registers, each of which is 16 bits large. The register file supports two reads and a write at the same time.

The register file should take the following inputs:

The clock signal, so that the writes can be synchronized with the rest of the CPU.

A clear signal, which can be used to set all 16 registers back to 0.

The write data, which is a 16-bit value.

The write address, which is a 4-bit value which determines which of the 16 registers we are writing.

A write enable signal, which is a single bit and determines whether we are doing a write this clock cycle. If 0, nothing is written. If 1, then the write happens when the clock goes from low to high.

Read address 1, which is a 4-bit value determining which of the registers to read for the first read value.

Read address 2, which is a 4-bit value determining which of the registers to read for the second read value.

The register file has only two outputs:

Read 1 value, which is a 16-bit value giving the first read value.

Read 2 value, which is a 16-bit value giving the second read value.

To create the register file, add 16 registers from the "memory" section and set them to store a 16-bit value. Connect all of the clear inputs to the incoming clear signal, and all of the clock inputs to the incoming clock signal.

To allow data to be stored in the register file, connect the write data to the data port of each register. You must ensure that data is only written to each register when the incoming write enable input is true, and also when the write address matches the register in question. You should use a "decoder" for this purpose (under the Plexers menu). The decoder will transform the 4-bit address into 16 1-bit selection lines. You should change the decoder's "disabled output" to "zero" instead of "floating".

To allow the register file to be read, you should connect each of the register output values into a multiplexer, and use the read address input as the multiplexer's selector signal. The output of the multiplexer would then give you the value of the register being read. You will need to to this twice: once for each of the two values we can read.

To test your register file, create one in main and connect pins to it. It should store values which you can later retrieve using the read and write inputs.

Screen Memory

Our CPU is going to have a screen somewhat like the Game Boy Advance in that the pixel values are mapped to a section of memory. Writing into this memory will update the screen. To support this, you should create a screen memory component.

The screen memory is similar to the register file in that it will store 16 values which are each 16-bits. Our computer's screen will be 16 rows by 16 columns, and be monochrome - each pixels is either on or off. Each of the 16 registers represents one row, and each bit position represents one column.

The screen memory will also be capable of reading and writing values, and will contain the following pins:

The clock signal, so that the writes can be synchronized with the rest of the CPU.

A clear signal, which can be used to set all pixels to 0.

The write data, which is a 16-bit value. Each write will be for an entire row.

The write address, which is a 4-bit value which determines which of the 16 screen rows we are writing.

A write enable signal, which is a single bit and determines whether we are doing a write this clock cycle. If 0, nothing is written. If 1, then the write happens when the clock goes from low to high.

The read address, which is a 4-bit value determining which of the registers to read. Unlike the register file, only one read can happen at a time.

The screen memory has one 16-bit output which provides the value read using the read address.

The screen memory will have an additional 16 output pins, each of which is 16 bits. These will provide each of the 16 rows and will be fed into the actual screen of the computer.

To test the screen memory, create one in main, and try to store and retrieve values. If you want to see how it will work when connected to a screen, you can add an "LED Matrix" from the Input/Output section, and set it to be 16 by 16, and set the Input Format to be Rows. Then connect the 16 row outputs of the screen memory to the 16 inputs to the LED screen.

Computer Engineering, Engineering

  • Category:- Computer Engineering
  • Reference No.:- M91729321
  • Price:- $60

Guranteed 36 Hours Delivery, In Price:- $60

Have any Question?


Related Questions in Computer Engineering

Does bmw have a guided missile corporate culture and

Does BMW have a guided missile corporate culture, and incubator corporate culture, a family corporate culture, or an Eiffel tower corporate culture?

Rebecca borrows 10000 at 18 compounded annually she pays

Rebecca borrows $10,000 at 18% compounded annually. She pays off the loan over a 5-year period with annual payments, starting at year 1. Each successive payment is $700 greater than the previous payment. (a) How much was ...

Jeff decides to start saving some money from this upcoming

Jeff decides to start saving some money from this upcoming month onwards. He decides to save only $500 at first, but each month he will increase the amount invested by $100. He will do it for 60 months (including the fir ...

Suppose you make 30 annual investments in a fund that pays

Suppose you make 30 annual investments in a fund that pays 6% compounded annually. If your first deposit is $7,500 and each successive deposit is 6% greater than the preceding deposit, how much will be in the fund immedi ...

Question -under what circumstances is it ethical if ever to

Question :- Under what circumstances is it ethical, if ever, to use consumer information in marketing research? Explain why you consider it ethical or unethical.

What are the differences between four types of economics

What are the differences between four types of economics evaluations and their differences with other two (budget impact analysis (BIA) and cost of illness (COI) studies)?

What type of economic system does norway have explain some

What type of economic system does Norway have? Explain some of the benefits of this system to the country and some of the drawbacks,

Among the who imf and wto which of these governmental

Among the WHO, IMF, and WTO, which of these governmental institutions do you feel has most profoundly shaped healthcare outcomes in low-income countries and why? Please support your reasons with examples and research/doc ...

A real estate developer will build two different types of

A real estate developer will build two different types of apartments in a residential area: one- bedroom apartments and two-bedroom apartments. In addition, the developer will build either a swimming pool or a tennis cou ...

Question what some of the reasons that evolutionary models

Question : What some of the reasons that evolutionary models are considered by many to be the best approach to software development. The response must be typed, single spaced, must be in times new roman font (size 12) an ...

  • 4,153,160 Questions Asked
  • 13,132 Experts
  • 2,558,936 Questions Answered

Ask Experts for help!!

Looking for Assignment Help?

Start excelling in your Courses, Get help with Assignment

Write us your full requirement for evaluation and you will receive response within 20 minutes turnaround time.

Ask Now Help with Problems, Get a Best Answer

Why might a bank avoid the use of interest rate swaps even

Why might a bank avoid the use of interest rate swaps, even when the institution is exposed to significant interest rate

Describe the difference between zero coupon bonds and

Describe the difference between zero coupon bonds and coupon bonds. Under what conditions will a coupon bond sell at a p

Compute the present value of an annuity of 880 per year

Compute the present value of an annuity of $ 880 per year for 16 years, given a discount rate of 6 percent per annum. As

Compute the present value of an 1150 payment made in ten

Compute the present value of an $1,150 payment made in ten years when the discount rate is 12 percent. (Do not round int

Compute the present value of an annuity of 699 per year

Compute the present value of an annuity of $ 699 per year for 19 years, given a discount rate of 6 percent per annum. As