RTL Design Methodology Transition from Pseudocode & Interface

Slides:



Advertisements
Similar presentations
IAY 0600 Digitaalsüsteemide disain Register Transfer Level Design. FSM Synthesis. Alexander Sudnitson Tallinn University of Technology.
Advertisements

© 1998, Peter J. AshendenVHDL Quick Start1 Basic VHDL Concepts Interfaces Behavior Structure Test Benches Analysis, elaboration, simulation Synthesis.
Verilog Intro: Part 1.
Give qualifications of instructors: DAP
CS 151 Digital Systems Design Lecture 37 Register Transfer Level
George Mason University ECE 448 – FPGA and ASIC Design with VHDL ECE 448 Lecture 10 Advanced Testbenches.
George Mason University ECE 448 – FPGA and ASIC Design with VHDL Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts,
9/15/09 - L25 Registers & Load Enable Copyright Joanne DeGroat, ECE, OSU1 Registers & Load Enable.
CS/EE 3700 : Fundamentals of Digital System Design
ECE 545 Project 1 Part IV Key Scheduling Final Integration List of Deliverables.
Figure A flip-flop with an enable input. D Q Q Q R Clock E 0 1.
Lecture 9 RTL Design Methodology Sorting Example.
SHA-3 Candidate Evaluation 1. FPGA Benchmarking - Phase Round-2 SHA-3 Candidates implemented by 33 graduate students following the same design.
George Mason University Design of Controllers Finite State Machines and Algorithmic State Machine (ASM) Charts ECE 545 Lecture 14.
1 ECE 545—Digital System Design with VHDL Lecture 6 Behavioral VHDL Coding (for Synthesis): Finite State Machines and ASMs 9/30/08.
LOGO A Convolution Accelerator for OR1200 Dawei Fan.
George Mason University Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts, and VHDL Code ECE 448 Lecture 6.
Lecture 9 RTL Design Methodology. Structure of a Typical Digital System Datapath (Execution Unit) Controller (Control Unit) Data Inputs Data Outputs Control.
Figure ASM chart for the bit counter.. Figure Verilog code for the bit-counting circuit (Part a). module bitcount (Clock, Resetn, LA, s,
RTL Design Methodology Transition from Pseudocode & Interface
Lecture 5B Block Diagrams HASH Example.
Algorithmic State Machines Sorting Signed & Unsigned Data Types
Lecture 3 RTL Design Methodology Transition from Pseudocode & Interface to a Corresponding Block Diagram.
Lecture 13 PicoBlaze I/O & Interrupt Interface Example of Assembly Language Routine ECE 448 – FPGA and ASIC Design with VHDL.
CDA 4253 FPGA System Design RTL Design Methodology 1 Hao Zheng Comp Sci & Eng USF.
Encryption / Decryption on FPGA Final Presentation Written by: Daniel Farcovich ID Saar Vigodskey ID Advisor: Mony Orbach Summer.
1 ECE 545 – Introduction to VHDL Algorithmic State Machines Sorting Example ECE 656 Lecture 8.
ECE 448 Lecture 6 Finite State Machines State Diagrams vs. Algorithmic State Machine (ASM) Charts.
George Mason University Design of Controllers using Algorithmic State Machine (ASM) Charts ECE 545 Lecture 12.
ECE 545 Project 1 Introduction & Specification Part I.
George Mason University Advanced Testbenches Lecture 4.
1 강의노트 09 Logic Design with ASM Charts: Based on Digital Systems Design Using VHDL, Chapter 5, by Charles H. Roth, Jr.
George Mason University Finite State Machines Refresher ECE 545 Lecture 11.
Project 2: Byte Rotation
Implementing Combinational
Class Exercise 1B.
RTL Design Methodology Transition from Pseudocode & Interface
ECE 448 Lecture 6 Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts, and VHDL Code.
Hash Function Performance Metrics
Hao Zheng Comp Sci & Eng USF
Basics of digital systems
ECE 448 Lecture 6 Finite State Machines State Diagrams vs. Algorithmic State Machine (ASM) Charts.
RTL Design Methodology
RTL Design Methodology
Implementing Combinational and Sequential Logic in VHDL
RTL Design Methodology
Lecture 18 SORTING in Hardware.
ECE 448 Lecture 13 Multipliers Timing Parameters
ECE 545 Lecture 12 Design of Controllers Finite State Machines and Algorithmic State Machine (ASM) Charts.
ECE 545 Lecture 10 Design of Controllers Finite State Machines and Algorithmic State Machine (ASM) Charts.
ECE 545 Lecture 9 Design of Controllers Finite State Machines and Algorithmic State Machine (ASM) Charts.
ECE 545 Lecture 11 Design of Controllers Finite State Machines and Algorithmic State Machine (ASM) Charts.
Sequential Logic for Synthesis Based on Aldec Active-HDL
ECE 545 Remaining Tasks.
Data Flow Description of Combinational-Circuit Building Blocks
RTL Design Methodology
RTL Design Methodology Transition from Pseudocode & Interface
ECE 448 Lecture 6 Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts, and VHDL Code.
RTL Design Methodology
RTL Design Methodology Transition from Pseudocode & Interface
RTL Design Methodology
RTL Design Methodology
RTL Design Methodology Transition from Pseudocode & Interface
RTL Design Methodology
ECE 448 Lecture 6 Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts, and VHDL code ECE 448 – FPGA and ASIC Design.
RTL Design Methodology
RTL Design Methodology
ECE 448 Lecture 6 Finite State Machines State Diagrams vs. Algorithmic State Machine (ASM) Charts.
ECE 448: Spring 2018 Lab 3 – Part 2 Design of Controllers
RTL Design Methodology
Presentation transcript:

RTL Design Methodology Transition from Pseudocode & Interface Lecture 8 RTL Design Methodology Transition from Pseudocode & Interface to a Corresponding Block Diagram

Structure of a Typical Digital System Data Inputs Control & Status Inputs Control Signals Datapath (Execution Unit) Controller (Control Unit) Status Signals Data Outputs Control & Status Outputs

Hardware Design with RTL VHDL Pseudocode Interface Datapath Controller Block diagram Block diagram State diagram or ASM chart VHDL code VHDL code VHDL code

Steps of the Design Process Text description Interface Pseudocode Block diagram of the Datapath Interface with the division into the Datapath and the Controller ASM chart of the Controller RTL VHDL code of the Datapath, the Controller, and the Top Unit Testbench of the Datapath, the Controller, and the Top Unit Functional simulation and debugging Synthesis and post-synthesis simulation Implementation and timing simulation Experimental testing

Steps of the Design Process Practiced in Class Today Text description Interface Pseudocode Block diagram of the Datapath Interface with the division into the Datapath and the Controller ASM chart of the Controller RTL VHDL code of the Datapath, the Controller, and the Top Unit Testbench of the Datapath, the Controller, and the Top Unit Functional simulation and debugging Synthesis and post-synthesis simulation Implementation and timing simulation Experimental testing

Steps of the Design Process Covered Before the Midterm Exam Text description Interface Pseudocode Block diagram of the Datapath Interface with the division into the Datapath and the Controller ASM chart of the Controller RTL VHDL code of the Datapath, the Controller, and the Top Unit Testbench of the Datapath, the Controller, and the Top Unit Functional simulation and debugging Synthesis and post-synthesis simulation Implementation and timing simulation Experimental testing

Statistics example

Circuit Interface n 2 clk reset din go done dout dout_mode Statistics

Pseudocode no_1 = no_2 = no_3 = sum = 0 for i=0 to k-1 do sum = sum + din if din > no_1 then no_3 = no_2 no_2 = no_1 no_1 = din elseif (din > no_2) then no_2 = din elseif (din > no_3) then no_3 = din end if end for avr = sum / k

Interface Table Port Width Meaning clk 1 System clock. reset System reset. din n Input Data. go Signal active high for k clock cycles during which Input Data is read by the circuit. done Signal set to high after the output is ready. dout Output dependent on the dout_mode input. dout_mode 2 Control signal determining value available at the output. 00: avr, 01: no_1, 10: no_2, 11: no_3.

Sorting example

Sorting - Required Interface Clock Resetn DataIn N DataOut Done RAdd L WrInit S (0=initialization 1=computations) Rd

Sorting - Required Interface

Simulation results for the sort operation (1) Loading memory and starting sorting

Simulation results for the sort operation (2) Completing sorting and reading out memory

Sorting - Example During Sorting 1 2 3 3 3 2 2 1 1 1 1 2 2 3 3 3 3 2 2 After sorting Before sorting i=0 i=0 i=0 i=1 i=1 i=2 j=1 j=2 j=3 j=2 j=3 j=3 Address 1 2 3 3 3 2 2 1 1 1 1 2 2 3 3 3 3 2 2 4 4 4 4 4 4 4 3 1 1 1 1 2 2 3 4 Legend: position of memory indexed by i position of memory indexed by j Mi Mj

Pseudocode [load input data] [load input data] for i = to 2 do for i = FOR k = 4 FOR any k ≥ 2 [load input data] [load input data] for i = to 2 do for i = to k - 2 do A = Mi ; A = Mi ; for j = i + 1 to 3 do for j = i + 1 to k – 1 do B = Mj ; B = Mj ; if B < A then if B < A then Mi = B ; Mi = B ; Mj = A ; Mj = A ; A = Mi ; A = Mi ; endif ; endif ; endfor; endfor; endfor; endfor; [read output data] [read output data]

Pseudocode wait for s=1 for i=0 to k-2 do A = Mi for j=i+1 to k-1 do B = Mj if A > B then Mi = B Mj = A end if end for Done wait for s=0 go to the beginning

Block diagram of the Execution Unit DIN DOUT ADDR WE CLK EN RST A>B 1 s WrInit Clock Resetn Wr Bout EA EB AgtB Addr DataIn RAdd Rd DataOut Csel LD Li Ei Lj Ej = k-2 = k-1 zi zj N L ABMux A B i j Mij Din We +1 Block diagram of the Execution Unit

Interface with the division into the Datapath and the Controller RAddr DataIn WrInit Clock Rd Resetn s N L AgtB zi zj Datapath Controller Wr Li Ei Lj Ej EA EB Bout Csel N DataOut Done

RC5

RC5 One of the fastest ciphers Basic operations: w Basic operations: w B A<<<B C=A<<<B Rotation by a variable number of bits w C w A + B Addition modulo 2w where w is the size of operands A and B C C = A + B mod 2w

RC5 w/r/b w - word size in bits w = 16, 32, 64 input/output block = 2 words = 2w bits Typical value: w=32  64-bit input/output block r - number of rounds b - key size in bytes 0  b  255 key size in bits = 8b bits Recommended version: RC5 32/12/16 64 bit block 12 rounds 128 bit key

Pseudocode Split M into two halves A and B, w bits each A = A + S[0] B = B + S[1] for j= 1 to r do { A’ = ((A⊕B) <<< B) + S[2j] B’ = ((B⊕A’) <<< A’) + S[2j+1] A = A’ B = B’ } C= A || B

Notation ⊕ = an XOR of two w-bit words A, B, A’, B’ = w-bit variables S[2j], S[2j+1] = a pair of round keys, each round key is a w-bit variable ⊕ = an XOR of two w-bit words + = unsigned addition mod 2w A <<< B = rotation of the variable A by a number of positions given by the current value of the variable B A || B = concatenation of A and B The algorithms has two parameters: • r = number of rounds (e.g., 3) • w = word size (always a power of 2, e.g., w = 24 = 16)

Circuit Interface 2w clk reset M write_M Si Done C RC5 write_Si w i m

Circuit Interface

Protocol (1) An external circuit first loads all round keys S[0], S[1], S[2], …, S[2r], [2r+1] to the two internal memories of the RC5 unit. The first memory stores values of S[i=2j], i.e., only round keys with even indices. The second memory stores values of S[i=2j+1], i.e. only round keys with odd indices. Loading round keys is performed using inputs: Si, i, write_Si, clk. Then, the external circuits, loads a message block M to the RC5 unit, using inputs: M, write_M, clk. After the message block M is loaded to the RC5 unit, the encryption starts automatically.

Protocol (2) When the encryption is completed, signal Done becomes active, and the output C changes to the new value of the ciphertext. The output C keeps the last value of the ciphertext at the output, until the next encryption is completed. Before the first encryption is completed, this output should be equal to zero.

Assumptions • one round of the main for loop of the pseudocode executes in one clock cycle • you can access only one position of each internal memory of round keys per clock cycle As a result, the entire encryption of a single message block M should last r+1 clock cycles.