

Digital Computer Logic



## Drop Computing Co.

Presented by

6833042821 Chonchanok Srisongkram

6833032521 Jesadakorn Netthong

6833071021 Napat Putsorn

6833098021 Thaweechai Petchkwan

2110252 Semester 1/2025

Department of Computer Engineering,  
Faculty of Engineering, Chulalongkorn University

## Design concept of CPU

This CPU is created by using the concept of a Multiple Cycle Processor. We divided the work into three phases: **input, execution, and output**.

- **Input:** In this phase, the pRAM, which stores the program, will store the input called progIn into the pRAM address when the signal from progLoad is high. It will continue to store the input until the signal from progLoad is low. The size of progIn (input) is 14 bits, divided into the first 6 bits of Opcode, which is an operation number of the operation, and another 8 bits is an operand of the operation.
- **Execution:** After we finish the process in the first phase, all programs in pRAM are ready to be executed. All programs in pRAM will be executed in order from 0-255 when the signal from Start is high. The CPU will fetch the program from pRAM one program at a time. It will then check what this operation needs to do and perform that operation. After finishing the current program, it will fetch and check the next program. The CPU will stop all the processes when it finds the stop operation.
- **Output:** The result that is stored in rRAM is ready to be shown when the stop operation is found. In order to show the result, the result signal must be high. After the result signal is high, the results in rRAM will be displayed in the output in the order they were stored in rRAM. After all results are displayed, the Done signal will be high until the reset signal is high.

## ASM Chart

We have 3 ASM Charts, each one is for each phase that is explained in the Design concept of CPU.



The picture above is the ASM Chart of the Input phase.



The picture above is the ASM Chart of the Output phase.



|                             |                                   |
|-----------------------------|-----------------------------------|
| opcode = 000000: กลับ Fetch |                                   |
| 000001:                     | $accA \leftarrow Operand$ → Fetch |
| 000010:                     | $accB \leftarrow Operand$ → Fetch |
| 000011:                     | $accA \leftarrow accB$ → Fetch    |
| 000100:                     | $accB \leftarrow accA$ → Fetch    |
| 000101:                     | $regC \leftarrow accA$ → Fetch    |
| 000110:                     | $accA \leftarrow regC$ → Fetch    |
| 000111:                     | $regD \leftarrow accA$ → Fetch    |
| 001000:                     | $accA \leftarrow regD$ → Fetch    |



The pictures above are the ASM Chart of the Execution phase

## Data Path



- 2 Mux 64:1\* are used to select the data, processed by ALU, to use by other function or store back to register, controlled by Opcode.  
(\*with some exception for example, jump function, comparison that don't need to store the data)



-the rRam is used for store the value from calculation or operation that Opcode has ordered, by storing in address from 0x00 to 0x0F

## Control Unit



-this part of control unit will control what accumulator or register that need to store the value by comparing the received Opcode to the set of Opcode to allow register to store data



-This part of the control unit contains the Program Counter (“address”), IR, and pRam, which are used to minimize stall time and prevent data hazards. Which Program Counter needs to use as little time as possible before fetching the next operation?

- Program Counter (PC), which is “address”, used to fetch both Opcode and Operand in the pRam to send out of the 2D port
- IR is used to separate Opcode and Operand from the incoming code of progIn
- pRam is used to store the operations before the CPU fetches the operations to run