HY130 Ψηφιακή Σχεδίαση

Σχετικά έγγραφα
ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Εργαστήριο Ψηφιακών Κυκλωμάτων. Χειμερινό Εξάμηνο

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωµάτων

HY430 Εργαςτήριο Ψηφιακών Κυκλωμάτων.

HY430 Εργαστήριο Ψηφιακών Κυκλωμάτων. Πολυπλέκτες Καμπύλη Παρέτο. Κωδικοποιητές/Από-κωδικοποιητές D FF

VERILOG. Γενικά περί γλώσσας

ΠΛΕ- 027 Μικροεπεξεργαστές 4ο μάθημα: γλώσσα περιγραφής υλικού Verilog

«Σχεδιασμός Ολοκληρωμένων Κυκλωμάτων» Χειμερινό εξάμηνο Ακολουθιακός Κώδικας

ΜΥΥ- 402 Αρχιτεκτονική Υπολογιστών Γλώσσα περιγραφής υλικού: Verilog

Επιβεβαίωση ορθής λειτουργίας απλών ψηφιακών κυκλωμάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Επεξεργαστής Υλοποίηση ενός κύκλου μηχανής

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωµάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Εργαστήριο Ψηφιακών Κυκλωμάτων

8 η Θεµατική Ενότητα : Εισαγωγή στις Γλώσσες Περιγραφής Υλικού: Μοντέλα Συνδυαστικών Κυκλωµάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Εργαστήριο Ψηφιακών Κυκλωμάτων

ΗΥ-225. Verilog HDL. Τα βασικά...

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωµάτων

ΗΥ220: Εργαστήριο σχεδίασης ψηφιακών κυκλωμάτων Χριστόφορος Κάχρης

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Μετρητής Ριπής ΛΟΓΙΚΗ ΣΧΕΔΙΑΣΗ. Αναφορά 9 ης. εργαστηριακής άσκησης: ΑΦΡΟΔΙΤΗ ΤΟΥΦΑ Α.Μ.:

Επεξεργαστής Υλοποίηση ενός κύκλου μηχανής

Εισαγωγή στη Verilog με το ISE

ΗΥ225 Οργάνωση Υπολογιστών. Εισαγωγή στη Verilog

Αρχιτεκτονική Υπολογιστών

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωµάτων

Σχεδίαση Ψηφιακών Συστημάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

HY430 Εργαςτήριο Ψηφιακών Κυκλωμάτων. Πολυπλζκτεσ Καμπφλθ Παρζτο. Κωδικοποιθτζσ/Από-κωδικοποιθτζσ D FF

Λογική Σχεδίαση Ι - Εξεταστική Φεβρουαρίου 2013 Διάρκεια εξέτασης : 160 Ονοματεπώνυμο : Α. Μ. Έτος σπουδών:

Δημοκρίτειο Πανεπιστήμιο Θράκης Τμήμα Ηλεκτρολόγων Μηχανικών & Μηχανικών Υπολογιστών. Συστήματα VLSI. Πρόοδος Άνοιξη 2018

Χ. Σωτηρίου. Σχήμα 1: Προτεινόμενο Πρόγραμμα Επαλήθευσης του ολοκληρωμένου Επεξεργαστή

7 η διάλεξη Ακολουθιακά Κυκλώματα

Εργαστήριο Οργάνωσης Η/Υ. Δαδαλιάρης Αντώνιος

Χ. Σωτηρίου. 0: lw $1, 8($0) 4: lw $2, 9($0) 8: add $1, $2, $3 c: or $4, $2, $3 10: beq $4, $0, -5-20: 5 24: fffe

100 ΕΡΩΤΗΣΕΙΣ ΜΕ ΤΙΣ ΑΝΤΙΣΤΟΙΧΕΣ ΑΠΑΝΤΗΣΕΙΣ ΓΙΑ ΤΟ ΜΑΘΗΜΑ ΨΗΦΙΑΚΑ ΚΥΚΛΩΜΑΤΑ

«Σχεδιασμός Ολοκληρωμένων Κυκλωμάτων» Χειμερινό εξάμηνο Μηχανές Πεπερασμένων Καταστάσεων

Οδηγίες εγκατάστασης και χρήσης του Quartus

Εργαστήριο Αρχιτεκτονικής Υπολογιστών Ι. Εισαγωγή στη VHDL

ΗΜΥ 210: Σχεδιασμός Ψηφιακών Συστημάτων. VHDL για Ακολουθιακά Κυκλώματα 1

Ακολουθιακές εντολές. (Peter Ashenden, The Students Guide to VHDL)

ΠΑΡΑΡΤΗΜΑ Β. Verification

Μοντέλα. χαρακτηριστικά χωρίς να συνοδεύεται από λεπτοµέρειες.

Περιγραφή Κυκλωμάτων με χρήση της VHDL. Καταχωρητές και χρονισμός με ρολόι

«Σχεδιασμός Ολοκληρωμένων Κυκλωμάτων» Χειμερινό εξάμηνο Συντρέχων Κώδικας

VHDL για Σχεδιασµό Ακολουθιακών Κυκλωµάτων

alpha Language age (3/5) alpha Language Φροντιστήριο Syntax Directed Translation and

Κυκλωμάτων» Χειμερινό εξάμηνο

Η εντολή if-else. Η απλή μορφή της εντολής if είναι η ακόλουθη: if (συνθήκη) { Η γενική μορφή της εντολής ifelse. εντολή_1; εντολή_2;..

ΗΜΥ 210 ΣΧΕΔΙΑΣΜΟΣ ΨΗΦΙΑΚΩΝ ΣΥΣΤΗΜΑΤΩΝ. Χειµερινό Εξάµηνο 2016 Συµπληρωµατική ΔΙΑΛΕΞΗ 14: Περιγραφή Ακολουθιακών Κυκλωµάτων στη VHDL

ΗΜΥ 210: Σχεδιασμός Ψηφιακών Συστημάτων. Καταχωρητές 1

Εισαγωγή στον Προγραμματισμό

HY220 Pipelines and FSMs Χειμεριν Χειμερι ό Εξ άμη Εξ ν άμη ο

26-Nov-09. ΗΜΥ 210: Λογικός Σχεδιασμός, Χειμερινό Εξάμηνο Καταχωρητές 1. Διδάσκουσα: Μαρία Κ. Μιχαήλ

«Σχεδιασμός Ψηφιακών Συστημάτων σε FPGA» Εαρινό εξάμηνο Διάλεξη 8 η : Μηχανές Πεπερασμένων Κaταστάσεων σε FPGAs

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Πανεπιστήμιο Πατρών Τμήμα Φυσικής Εργαστήριο Ηλεκτρονικής. Ψηφιακά Ηλεκτρονικά. Μονάδες Μνήμης και Διατάξεις Προγραμματιζόμενης Λογικής

Τέτοιες λειτουργίες γίνονται διαμέσου του

Εισαγωγή στον Προγραµµατισµό. Διάλεξη 2 η : Βασικές Έννοιες της γλώσσας προγραµµατισµού C Χειµερινό Εξάµηνο 2011

K24 Ψηφιακά Ηλεκτρονικά 9: Flip-Flops

Behavioral & Mixed VHDL Architectures Finite State Machines in VHDL

Μία μέθοδος προσομοίωσης ψηφιακών κυκλωμάτων Εξελικτικής Υπολογιστικής

HY340, 2009 Α. Σαββίδης Slide 2 / 143. HY340, 2009 Α. Σαββίδης Slide 3 / 143. HY340, 2009 Α. Σαββίδης Slide 4 / 143

Xρονισμός ψηφιακών κυκλωμάτων

«Σχεδιασμός Ολοκληρωμένων Κυκλωμάτων» Χειμερινό εξάμηνο Τύποι Δεδομένων και Τελεστές

Behavioral & Mixed VHDL Architectures Finite State Machines in VHDL

ΗΜΥ 210 ΣΧΕΔΙΑΣΜΟΣ ΨΗΦΙΑΚΩΝ ΣΥΣΤΗΜΑΤΩΝ

Δομημένος Προγραμματισμός (ΤΛ1006)

Στόχοι και αντικείμενο ενότητας. Εκφράσεις. Η έννοια του τελεστή. #2.. Εισαγωγή στη C (Μέρος Δεύτερο) Η έννοια του Τελεστή

Προγραμματισμός Ι (ΗΥ120)

ΗΜΥ211 Εργαστήριο Ψηφιακών Συστημάτων

Ελίνα Μακρή

ΗΥ-150. Προγραμματισμός

γρηγορότερα. Αν θέλουμε να μηδενίσουμε όλα τα υπόλοιπα bit μπορούμε να χρησιμοποιήσουμε την εντολή:

ΗΜΥ 210 ΣΧΕΔΙΑΣΜΟΣ ΨΗΦΙΑΚΩΝ ΣΥΣΤΗΜΑΤΩΝ. Χειµερινό Εξάµηνο 2016 ΔΙΑΛΕΞΗ 15: Καταχωρητές (Registers)

ΗΥ-150. Προγραμματισμός

6.1 Καταχωρητές. Ένας καταχωρητής είναι μια ομάδα από f/f αλλά μπορεί να περιέχει και πύλες. Καταχωρητής των n ψηφίων αποτελείται από n f/f.

HY430 Εργαστήριο Ψηφιακών Κυκλωμάτων.

Μηχανοτρονική. Τμήμα Μηχανικών Παραγωγής και Διοίκησης 7 ο Εξάμηνο,

Διάλεξη 3η: Τύποι Μεταβλητών, Τελεστές, Είσοδος/Έξοδος

Κεφάλαιο 7 ο. Γ. Τσιατούχας. VLSI Technology and Computer Architecture Lab. Ακολουθιακή Λογική 2

Εργαστήριο Οργάνωσης Η/Υ. Δαδαλιάρης Αντώνιος

Εισαγωγή στη Matlab 2 Εισαγωγή στην Αριθμητική Ανάλυση Διδάσκων: Γεώργιος Ακρίβης Βοηθός: Δημήτριος Ζαβαντής

Περιεχόμενα. Πρόλογος... 21

HY330 Ψηφιακά Κυκλώματα - Εισαγωγή στα Συστήματα VLSI. 1 ΗΥ330 - Διάλεξη 7η - Ακολουθιακά Κυκλώματα

Υπολογισμός - Εντολές Επανάληψης

Χρονισμός και Απόδοση Υπολογιστικών Συστημάτων

ΗΥ220 Εργαστήριο Ψηφιακών Κυκλωμάτων

Ανάπτυξη και Σχεδίαση Λογισμικού

K15 Ψηφιακή Λογική Σχεδίαση 7-8: Ανάλυση και σύνθεση συνδυαστικών λογικών κυκλωμάτων

«Σχεδιασμός Ολοκληρωμένων Κυκλωμάτων» Χειμερινό εξάμηνο Συναρτήσεις, Διαδικασίες και Δομές Ελέγχου Λειτουργίας Κυκλωμάτων (testbenches)

Προγραμματισμό για ΗΜΥ

ΗΜΥ 100 Εισαγωγή στην Τεχνολογία

Εισαγωγή στη γλώσσα περιγραφής υλικού VHDL. Γενικά χαρακτηριστικά, σύνταξη και τύποι. Ψηφιακή Σχεδίαση µε CAD ΙΙ - ιάλεξη 1 -

Πρόγραμμα Μεταπτυχιακών Σπουδών «Πληροφορική και Εφαρμογές»

2. Δήλωση μεταβλητών. #include <avr/io.h> #include <util/delay.h> unsigned char i=0xa0; register unsigned char i asm("r3");

Transcript:

HY130 Ψηφιακή Σχεδίαση Διδάσκων Εργαστηρίου: Χ. Σωτηρίου http://inf-server.inf.uth.gr/courses/ce130/ 1 2 1

3 Μοιάζει αρκετά με την C Προ-επεξεργαστή (Preprocessor) Λέξεις Κλειδιά (Keywords) Τελεστές = ==,!= <, >, <=, >= &&? : & and or ~ not ^ xor `timescale 1ns / 1ns `define dh 2 // e.g.: q <= #`dh d; // `undef dh `ifdef dh / `ifndef dh... `else... `if `include def.h Είναι βασισμένη στην έννοια του «γεγονότος» (event) 4 2

5 @() (διαβάζεται at) Λογική έκφραση Επιτρέπονται μόνο οι εκφράσεις: or posedge (+ακμή), negedge (-ακμή) always @(posedge clk or negedge rst_)... always @(opcode or b or c) if (opcode == 32 h52a0234e) a = b ^ (~c); always @(posedge a or posedge b)... always @(posedge a, posedge b) always #5 clk=~clk Στην περιγραφή συνδυαστικής λογικής, όλα τα σήματα πρέπει να περιλαμβάνονται Οι (+, -) ακμές χρησιμοποιούνται μόνο για Ρολόγια Σήματα αρχικοποίησης (reset) 6 3

7 Τμήματα always και initial Τμήμα initial initial // run once a=0; b=0; #5; a=1; b=1; Τμήμα always always @(b or c) // run always a <= b & c; Εκτελείται μια φορά, στην εκκίνηση της προσομοίωσης Δεν επαναλαμβάνεται Χρησιμοποιείται για να παρέχει διανύσματα εισόδου στο κύκλωμα Δεν είναι συνθέσιμο Εκτελείται στην εκκίνηση της προσομοίωσης Είναι άπειρος βρόχος Χρησιμοποιείται για να περιγράφει διαρκή και μόνιμη συμπεριφορά (συνδυαστική ή ακολουθιακή) Είναι συνθέσιμο 8 4

9 Τιμές Σήματος σε Λογική 4-ρων τιμών (4-value logic) Τιμή Ερμηνεία Χρήση 0 Λογικό 0, άρνηση Λογικό 0 1 Λογικό 1, κατάφαση Λογικό 1 X Άγνωστο ή Μη αρχικοποιημένο i. Τιμή εκκίνησης ακολουθιακών στοιχείων και σημάτων, ii. Έξοδος πύλης με εισόδους στο Z, iii. Τιμή σε περίπτωση ταυτόχρονης ανάθεσης (0 και 1) Z Υψηλής εμπέδησης ασύνδετο ή τρικατάστατο i. Τιμή μη οδηγούμενης εισόδου, ii. Έξοδος τρικατάστατου οδηγητή 10 5

AND 2 εισόδων: AND 4-ρων τιμών 0 1 X Z 0 0 1 0 0 1 0 1 X X initial... X 0 X X X always @(posedge clk) if (reset)... else... Z 0 X X X 11 if (a==1 bx) // report error Μπορεί να έχει νόημα για την προσομοίωση Δεν έχει πραγματικό νόημα στην κυκλωματική υλοποίηση 12 6

13 Συνένωση Σημάτων // sign-ext 8-bit number // a b 3 5 8 c wire [7:0] unsigned; wire [15:0] sign_ext = { (unsigned[7]? 8 hff : 8 h0), unsigned }; wire [2:0] a; wire [4:0] b; wire [7:0] c = {a, b}; wire [2:0] a; wire [4:0] b; wire [7:0] c = {a, b}; wire [11:0] d = {2{b}, b}; wire [11:0] d = {b, b, b}; wire [25:0] e = {2{3{b}}, a}; 14 7

15 Συνθήκη if-else Περιγραφή Verilog Κυκλωματική Μορφή always @(a or b or data1 or data2 or data3) a if (a == 0) y = data1; else if (b == 0) y = data2; else y = data3; data2 data3 data1 b 0 1 0 1 y 16 8

Συνθήκη if-else Σε περίπτωση ένθετου if, το else αντιστοιχεί στο κοντινότερο προηγούμενο if always @(a or b or data1 ) if (a==0) if (b==0) y = data1; else y = data2; always @(a or b or data1 ) if (a==0) if (b==0) y = data1; else y = data2; 17 Συνθήκη if-else Περιγραφή Verilog Κυκλωματική Μορφή always @(a or b or data1 or data2) data2 Latch y2 if (a==0) y1 = data1; else y2 = data2; a data1 y1 Latch 18 9

Συνθήκη if-else Περιγραφή Verilog Κυκλωματική Μορφή always @(a or b or data1 or data2) y1 = 0; y2 = 0; if (a==0) y1 = data1; else y2 = data2; 0 data2 a data1 0 y2 y1 19 Συνθήκη case always @(a or b or c or d or sel ) case (sel) 2 b00: out <= a; 2 b01: out <= b; 2 b10: out <= c; 2 b11: out <= d; default: out <= 5 bx; case always @(a or b or c or d or sel ) case (sel) 2 b00: out <= 2 b00; 2 b01: out <= 2 b01; 2 b10: out <= 2 b11; 2 b11: out <= 2 b10; default: out <= 2 bx; case Μετατροπέας Δυαδικού Αριθμού σε Κώδικα grey 0000 0101 1011 1110 20 10

Συνθήκη case Ελλιπής Συνθήκη case Συνεπάγεται Latches! always @(a or b or c or d or sel ) case (sel) 2 b00: out <= 2 b00; 2 b01: out <= 2 b01; 2 b10: out <= 2 b11; case Οι περιπτώσεις που δεν καλύπτονται συνεπάγονται μνήμη, δηλ. out <= out 00 01 10 sel[1:0] out 21 Συνθήκη case με Αδιάφορες (DC) τιμές casex casex (A) // X,? Or Z = DC input // 4 b1xxx : Y = 3; 4 b01xx : Y = 2; 4 b001x : Y = 1; default : Y = 0; case casez casez (A) //? Or Z = DC input // 4 b1??? : Y = 3; 4 b01?? : Y = 2; 4 b001? : Y = 1; default : Y = 0; case Οι αδιάφορες τιμές (don t cares DC) αντιστοιχούν με 0 ή 1 Χρησιμοποιούνται για απλοποίηση στο B 22 11

23 Βρόχοι for και while Λειτουργούν όπως σε παραδοσιακές γλώσσες προγραμματισμού Δεν υποστηρίζονται: break, continue i++, i-- Χρήση: i. testbench ii. επαναληπτική εμφάνιση integer i; initial for (i = 0; i < 10; i = i + 1) $display ( i= %d,i); integer j; initial j=0; while (j < 10) $display ( j= %b,j); j=j + 1; 24 12

Βρόχοι for και while Περιγραφή Verilog Κυκλωματική Μορφή integer i; always @(b or c) for (i = i; i < 5; i = i + 1) a[i] <= b[i] & c[i]; b[1] c[1] b[2] c[2] b[3] c[3] b[4] c[4] b[5] c[5] a[1] a[2] a[3] a[4] a[5] 25 Βρόχοι for και while Περιγραφή Verilog Κυκλωματική Μορφή integer i; always @(b or c) for (i = i; i < 5; i = i + 1) a <= i; #10 26 13

27 και Χρήση τους Καταχωρητής Μεταβλητού Πλάτους module RegLd(D, Q, load, clk); parameter N = 8; parameter dh = 2; input [N-1:0] D; output [N-1:0] Q; input load, clk; reg [N-1:0] Q; always @(posedge clk) if (load) Q = #dh D; Πιθανές Εμφάνισεις του RegLd reg0(d0, q0, ld, clk); RegLd #(16,2) reg1(d1, q1, ld, clk); RegLd reg2(d2, q2, ld, clk); defparam reg2.n = 4; defparam reg2.dh = 4; module 28 14

29 32 15

από Καταχωρητές υποστηρίζονται ως πίνακες ψηφίων reg [7:0] mem [3:0]; Μνήμη με τέσσερις λέξεις των 8-bit Αρχικοποίηση ειδικές διαδικασίες συστήματος $readhmemh, $readmemb $writememh, $writememb Για μεγάλες μνήμες SRAM ή Αρχείο Καταχωρητών (Register File) επεξεργαστή, είναι προτιμότερο να χρησιμοποιούνται έτοιμες μονάδες η υλοποίηση από την σύνθεση δεν είναι ανάλογη σε ταχύτητα και εμβαδό 33 από Καταχωρητές Παραδείγματα Περιγραφής Verilog wire [15:0] word_in; wire [15:0] word_out; wire [ 9:0] addr; reg [15:0] memory [1023:0]; always @(posedge clk) if (we) memory[addr] = word_in; else word_out = memory[addr]; Αρχικοποίηση always @(negedge rst_n) $readmemh( memory.dat, memory); initial $readmemh( memory.dat, memory); End memory.dat: 0F00 00F1 0F02 34 16

35 Συναρτήσης Δήλωση function [range_or_type] function_name; input declarations; local variable declarations; statements; function Αποτέλεσμα με ανάθεση Χρήση function_name = expression; function_name(expression, ) με την σειρά που ορίζονται στην δήλωση Παράδειγμα function [15:0] average; input [15:0] a, b, c, d; average = (a + b + c + d) >> 2; function; wire x = average(e, f, g, h); 36 17

Η καθιερωμένη επιστροφή είναι το 1-bit Επιτρέπονται πολλαπλά ορίσματα εισόδου Μια συνάρτηση μπορεί να κάνει χρήση άλλης Μια συνάρτηση δεν επιτρέπεται να χρησιμοποιεί διαδικασίες (tasks) Δεν υποστηρίζεται η αναδρομή Δεν υποστηρίζονται εκφράσεις με την έννοια του χρόνου Χρησιμοποιούνται για την σύνθεση συνδυαστικής λογικής 37 Παραδείγματα function calc_parity; input [31:0] val; calc_parity = ^val; function function [7:0] GetByte; input [63:0] Word; input [3:0] ByteNum; integer Bit; reg [7:0] temp; for (Bit=0; Bit<=7; Bit=Bit+1) temp[bit] = Word[((ByteNum-1)*8)+Bit]; GetByte = temp ; Endfunction 38 18

39 Οι διαδικασίες είναι ουσιαστικά υπο-ρουτίνες Μπορούν να περιέχουν πολλαπλές εισόδους και πολλαπλές εξόδους Επιτρέπονται οι χρονικές λειτουργίες (#) (@, wait) Δεν υποστηρίζουν αναδρομή Μπορούν να κάνουν χρήση από άλλες διαδικασίες και συναρτήσεις Μπορεί να μην είναι συνθέσιμες, εξαρτάται από την περιγραφή 40 19

Παραδείγματα task ReverseByte; input [7:0] a; output [7:0] ra; integer j; for (j = 0; j <= 7; j++) ra[j] = a[7-j]; task task read_mem; input [15:0] address; output [31:0] data; read_request = 1; wait (read_grant) addr_bus = address; data = data_bus; #5 addr_bus = 16'bz; read_request = 0; task 41 και Διαδικασίες Ορίζονται εντός μονάδων και είναι τοπικές Χρησιμοποιούνται μόνο για περιγραφή συνδυαστικών τμημάτων Δεν μπορούν να εμπεριέχουν τμήματα always ή initial Μπορούν όμως να χρησιμοποιούνται μέσα σε always ή initial Γενικά, οποιοδήποτε διαδικασία μπορεί να περιγραφεί εναλλακτικά από μια (ή περισσότερες) συνάρτησεις 42 20

και Διαδικασίες Μπορούν να χρησιμοποιούν άλλες συναρτήσεις αλλά όχι διαδικασίες Εκτελούνται σε μηδενικό χρόνο Δεν επιτρέπουν χρονικό έλεγχο (καθυστερήσεις, γεγονότα) Διαδικασίες Μπορούν να χρησιμοποιούν άλλες συναρτήσεις και διαδικασίες Μπορούν να διαρκούν συγκεκριμένο χρόνο Επιτρέπονται οι χρονικοί έλεγχοι Έχουν τουλάχιστον μια είσοδο Επιστρέφουν μια έξοδο Έχουν μηδενικές ή περισσότερες εισόδους και εξόδους Επιστρέφουν έμμεσα μια ή περισσότερες εξόδους 43 Διαδικασίες Συστήματος Καθιερωμένες διαδικασίες που ορίζει ένα εργαλείο EDA Ξεκινούν με $, λ.χ. $monitor Όνομα Διαδικασίας $time $display $monitor $stop $finish $random $readmemh, $readmemb 44 Λειτουργία Επιστρέφει τον χρόνο της προσομοίωσης Τυπώνει τιμές σημάτων ανάλογη της printf $display("format-string", expr1,, exprn); %d (decimal), %h (hex), %b (binary), %t (time) Παρακολουθεί σήματα ως γεγονότα, και τα τυπώνει όταν αποκτήσουν νέα τιμή έχει ανάλογα ορίσματα όπως η $display Διακόπτει την προσομοίωση Ολοκληρώνει την προσομοίωση Επιστρέφει ένα 32-bit ψευδοτυχαίο αριθμό Ανάγνωση περιεχομένων μνήμης 21

Διαδικασίες Συστήματος Παραδείγματα $display("error at time %t: value is %h, expected %h", $time, actual_value, expected_value); $monitor("cs=%b, ns=%b", cs, ns) $random %64 Όνομα Διαδικασίας $dumpon, $dumpoff, $dumpvars $setup, $hold, $period Λειτουργία Ορίσματα αρχείου Verilog Change Dump (VCD) Έλεγχοι χρονικών περιορισμών $fopen, $fclose, $fmonitor, $fdisplay $sdf_annotate αρχείων Επισύναψη αρχείου SDF (Standard Delay Format) στις εμφανίσεις 45 46 22

Χρόνος και Η σημασιολογία και προσομοίωση βασίζονται σε αξιολόγηση γεγονότων a = #5 b; #10 c = a; wait (a) b = 1; always @(posedge clk) a = b + 1; a <= b; always clk = #(`period/2) ~clk; b <= a; c <= a & b; @(negedge clk); Κάθε πρόταση της Verilog συνεπάγεται Αξιολόγηση εκφράσεων (Δεξιά) (t, e) Εισαγωγή της ανάθεσης στην ουρά γεγονότων (Αριστερά) Για γεγονότα που συμβαίνουν παράλληλα δεν υπάρχει εγγύηση ως προς την σειρά τους 47 Χρόνος και Ανάθεση Register_data_type = expression; Σημασιολογία Κλειδωμένη (blocking) ανάθεση η έκφραση αξιολογείται και γίνεται η ανάθεση πριν την εκτέλεση επόμενης γραμμής Register_data_type <= expression; i. Αξιολόγηση άμεσα Δεξιά και Ανάθεση Αριστερά, ii. Εκτέλεση εν σειρά της επόμενης πρότασης. Μη κλειδωμένη (non-blocking) ανάθεση η έκφραση αξιολογείται, αλλά η ανάθεση θα γίνει στο τέλος του τρέχοντος βήματος χρόνου και η εκτέλεση συνεχίζει i. Αξιολόγηση άμεσα Δεξιά, ii. Ανάθεση αριστερά στο τέλος του χρόνου Δ, iii. Άμεση εκτέλεση της επόμενης πρότασης. 48 23

49 και Εξωτερική Καθυστέρηση #5 a = b + c; #4 d = a; @t=5: a = b + c ; //b, c @t=5 // @t=9: d = a ; // a @t=9 // Εσωτερική Καθυστέρηση a = #5 b + c; d = #4 a; @t=5: a = b + c ; //b, c @t=0 // @t=9:d = a; // a @t =5 // Με μη-κλειδωμένες αναθέσεις a <= #5 b + c; d <= #4 a; @t=5: a = b + c; //b, c @t=0 // @t=4:d = a; // a @t =0 // 50 24

και Κάθε πρόταση συνδέεται με τον αρχικό της χρόνο Τμήματα initial, always λειτουργούν σειριακά, εκτός αν περιέχουν αναθέσεις <= initial a = 0; b = 0; c = 0; clk = 0; always clk = #10 1; clk = #10 0; wire #4 [3:0] comb = a + b; 0 10, 20, 30, 40, 50 4, 14, 34 0 10 20 30 40 50 always @(posedge clk) a <= b + 1; always @(posedge clk) b <= c + 1; always @(posedge clk) c <= #5 a + 1; 10, 30 10, 30 15, 35 51 56 25

Παραδείγματα wire a,b,c; assign #2 c = a & b; wire a,b,d; wire #2 c; assign c = a & b; assign d = a & b; 57 58 26

Εξαρτήσεις μεταξύ παράλληλων Περιγραφή Verilog Αξιολόγηση 1 ου, 2 ου Αξιολόγηση 2 ου, 1 ου always @(posedge clock) y1 = a; clock a clock a always @(posedge clock) if (y1 == 1) y2 = b; else y2 = 0; b y1 y2 b y1 y2 Ασυμφωνία προσομοίωσης συμπεριφοράς και σύνθεσης b a clock y1 y2 59 60 27

Α Β C tmp Z Α Β C tmp Z 0 5 10 15 20 25 ns Έστω Δ AND = 2ns, Δ OR = 1ns, με μηδενική καθυστέρηση των συνδέσεων Πόσα και ποια μονοπάτια υπάρχουν; Οι κύματομορφές δείχνουν την συμπεριφορά του κυκλώματος για διανύσματα A, B, C. 61 Α Β C tmp Z Α Β C tmp Z 0 5 10 15 20 25 ns Έστω Δ AND = 2ns, Δ OR = 1ns, με μηδενική καθυστέρηση των συνδέσεων always@(a or b or c) tmp = #2 B & C; Z = #1 A tmp; 62 28

63 και περιορισμοί Ρολογιού 0 5 10 15 20 25 ns Clk Α Β C Z Clk Q Α Β C Z Q Έστω T Clk = 10ns, Δ clk Q = 2ns Tsetup = 1ns, T hold = 0.5ns Παραβιάζονται οι περιορισμοί setup και hold; ΟΚ Άγνωστη Τιμή Παραβίαση 64 29

μετά από Σύνθεση Οι καθυστερήσεις των πυλών μετά από σύνθεση δεν θα είναι εκ προοιμίου γνωστές Εξαρτώνται από Την συγκεκριμένη πύλη που απαιτείται Το μέγεθος της πύλης Το φορτίο της πύλης από (1) τις πύλες που οδηγεί, (2) τις συνδέσεις που οδηγεί 65 Παραδείγματα Καθυστερήσεων Διεργασία 90nm (Pentium III) Καθυστέρηση AND2 2ns 65nm (Pentium 4) 0.5ns 45nm (Core Duo) 0.4ns 66 30

67 fork/join Το τμήμα fork εκτελεί παράλληλα όλες τις προτάσεις μέχρι το join Δύσκολα υποστηρίζονται στην σύνθεση Μορφή fork statement; statement; statement; join 68 31

Παράδειγμα Παράλληλων Αναθέσεων Χωρίς fork/join Με fork/join reg x,y; reg [1:0] z; initial x = 1 b0; // time 0 #5 y = 1 b1; // time 5 #10 z = {x,y};// time 15 reg x,y; reg [1:0] z; initial fork x = 1 b0; // time 0 #5 y = 1 b1; // time 5 #10 z = {x,y};// time 10 join 69 Modelsim Χρησιμοποιείται για την προσομοίωση κυκλωμάτων σε Verilog, VHDL 70 32

Modelsim Introduction 1. Δημιουργία βιβλιοθήκης 2. Compile του κώδικα 3. Εκτέλεση και προσομοίωση 71 Modelsim Window 72 33