Professional Documents
Culture Documents
Lecture # 7
Lecture # 7
Lecture # 7
Course Instructor: Dr. Afshan Jamil
Outline
• Introduction
• Basic RISC-V implementation
• Logic design conventions
• Clocking methodology
• Building the Datapath
Introduction
• Performance of a computer is determined by three key
factors:
– instruction count
– clock cycle time
– clock cycles per instruction (CPI).
• The compiler and the ISA determine the instruction
count required for a given program.
• The implementation of the processor determines both
the clock cycle time and the number of clock cycles per
instruction.
Basic RISC-V Implementation
• Implementation includes a subset of the core RISC-V
instruction set:
– The memory-reference instructions load
doubleword (ld) and store doubleword (sd)
– The arithmetic-logical instructions add, sub, and
and or
– The conditional branch instruction branch if equal
(beq)
• Most of the implementation of these instructions is
same, independent of the exact class of instruction.
CONTD…
• For every instruction, the first two steps are identical:
• 1. Send the program counter (PC) to the memory that
contains the code and fetch the instruction from that
memory.
• 2. Read one or two registers, using fields of the
instruction. For the load doubleword instruction, we
need to read only one register, but most other
instructions require reading two registers.
• After these two steps, the actions required to complete
the instruction depend on the instruction class.
Logic design conventions
• The data path elements in the RISC-V implementation
consist of two different types of logic elements:
• Combinational, The elements that operate on data values
such as an AND gate or an ALU. Their outputs depend
only on the current inputs.
• State/Sequential, An element that has some internal
storage such as register or memory. A state element has at
least two inputs and one output. The required inputs are
the data value to be written into the element and the
clock, which determines when the data value is written.
Clocking Methodology
Instruction
address
PC
Instruction Add Sum
Instruction
memory