intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Thiết kế mạch số dùng HDL-Chương 5 Thiết kế luận lý bằng mô hình hành vi

Chia sẻ: Nguyễn Doãn Hùng | Ngày: | Loại File: PDF | Số trang:61

144
lượt xem
30
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Cấu trúc (Structural)chỉ ra cấu trúc phần cứng thật sự của mạch Mức trừu tượng thấp. •Các cổng cơ bản (ví dụ and, or, not). •Cấu trúc phân cấp thông qua các module. Tương tự lập trình hợp ngữ. •Hành vi (Behavioral)chỉ ra hoạt động của mạch trên các bit Mức trừu tượng cao hơn. •Biểu diễn bằng các biểu thức (ví dụ out = (a & b) | c) •Không phải tất cả các đặc tả hành vi đều tổng hợp được Không sử dụng: + -* / % = ...

Chủ đề:
Lưu

Nội dung Text: Thiết kế mạch số dùng HDL-Chương 5 Thiết kế luận lý bằng mô hình hành vi

  1. dce 2009 Thiết kế mạch số dùng HDL Chương 5 Thiết kế luận lý bằng mô hình hành vi
  2. Nội dung chính Computer Engineering 2009 1. Mô hình hành vi 2. Mô hình hành vi dựa trên phương trình boole 3. Mô hình hành vi vòng 4. Mô hình hành vi cho các khối cơ bản 5. Giải thuật lặp và lưu đồ máy trạng thái cho mô hình hành vi Thiết kế Vi mạch số dùng HDL 2 ©2008, Pham Quoc Cuong
  3. Nội dung chính Computer Engineering 2009 1. Mô hình hành vi 2. Mô hình hành vi dựa trên phương trình boole 3. Mô hình hành vi vòng 4. Mô hình hành vi cho các khối cơ bản 5. Giải thuật lặp và lưu đồ máy trạng thái cho mô hình hành vi Thiết kế Vi mạch số dùng HDL 3 ©2008, Pham Quoc Cuong
  4. Mô hình hành vi Computer Engineering 2009 • Khái quát mô hình hành vi • Kiểu dữ liệu cho mô hình hành vi • Các phép toán cho mô hình hành vi Thiết kế Vi mạch số dùng HDL 4 ©2008, Pham Quoc Cuong
  5. Mô hình cấu trúc và mô hình hành vi trong HDLs Computer Engineering 2009 • Cấu trúc (Structural) chỉ ra cấu trúc phần cứng thật sự của mạch  Mức trừu tượng thấp • Các cổng cơ bản (ví dụ and, or, not) • Cấu trúc phân cấp thông qua các module  Tương tự lập trình hợp ngữ • Hành vi (Behavioral) chỉ ra hoạt động của mạch trên các bit  Mức trừu tượng cao hơn • Biểu diễn bằng các biểu thức (ví dụ out = (a & b) | c) • Không phải tất cả các đặc tả hành vi đều tổng hợp được  Không sử dụng: + - * / % > >= < >
  6. Mô hình hành vi – đặc điểm Computer Engineering 2009 • Thiết kế các vi mạch lớn • Mô tả chức năng (what) và cách xây dựng (how) phần cứng • Không quan tâm đến trễ truyền lan (được quan tâm trong giai đoạn tổng hợp) • Các bước thiết kế  Nhanh chóng đưa ra nguyên mẫu (prototype)  Kiểm tra chức năng  Dùng công cụ tổng hợp tối ưu và ánh xạ công nghệ Thiết kế Vi mạch số dùng HDL 6 ©2008, Pham Quoc Cuong
  7. Kiểu dữ liệu cho mô hình hành vi Computer Engineering 2009 • Biến trong Verilog biểu diễn một tín hiệu dạng nhị phân của mạch • Tất cả các biến trong Verilog được định nghĩa kiểu trước khi sử dụng  net  register • Net hoạt động như dây nối vật lý  wire • Register hoạt động giống như biến trong các ngôn ngữ lập trình cấp cao  reg  integer • Kích thước mặc định của kiểu dữ liệu reg và wire là 1 bit Thiết kế Vi mạch số dùng HDL 7 ©2008, Pham Quoc Cuong
  8. Các toán tử trong Verilog Computer Engineering 2009 Toán tử Tên Nhóm Toán tử Tên Nhóm [] Chọn > Dịch phải () Ngoặc ! Phủ định (đảo) Logical > Lớn hơn ~ Phủ định (not) Bit-wise >= Nhỏ hơn hay bằng Quan hệ < Nhỏ hơn & Thu giảm AND
  9. Toán tử số học (+, -, *, /, %) Computer Engineering 2009 A C  B • Bất kỳ bit nào trong toán hạng là x hoặc z thì kết quả là x • Kích thước kết quả  Phép nhân thì kích thước kết quả bằng tổng kích thước 2 toán hạng  Các phép toán khác bằng chiều dài lớn nhất của toán hạng • Biểu diễn dấu A = 4’b0010 (2) C = 4’b1101 (13) – integer intA, intB; intA = -12; intB = -’d12; B = 4’b0101 (5) Thiết kế Vi mạch số dùng HDL 9 ©2008, Pham Quoc Cuong
  10. Toán tử quan hệ (, =) Computer Engineering 2009 A True/False (1/0)  B A = 52 A = 3’b001 x True (1)  < B = 8’hx5 B = 3’b011 A = 3’b001 A = 5’b00001 > False (0) B = 5’b01011 Thiết kế Vi mạch số dùng HDL 10 ©2008, Pham Quoc Cuong
  11. Toán tử bằng (==, ===, !=, !===) Computer Engineering 2009 • Bằng luận lý (== và !=)  Giá trị x và z tương tự như toán tử quan hệ  Kết quả có thể là x • Case (=== và !==)  So sánh từng bit  x === x, z === z, x !== z  Kết quả luôn xác định (0 hoặc 1) • Nếu kích thước 2 toán hạng không bằng nhau thì các bit 0 sẽ được thêm vào những bit trọng số cao của toán hạng có kích thước nhỏ Data = 4’b11x0; Addr = 4’b11x0; Data == Addr //x Data === Addr //1 Thiết kế Vi mạch số dùng HDL 11 ©2008, Pham Quoc Cuong
  12. Toán tử luận lý (||, &&, !) Computer Engineering 2009 • Toán hạng là vector khác 0 được xem như 1 • Nếu bất kỳ bit nào của toán hạng có giá trị x hay z thì toán hạng được xem như x ABus = 4’b0110; BBus = 4’b0100; ABus || BBus // 1 ABus && BBus // 1 !ABus // giống như !BBus // 0 Thiết kế Vi mạch số dùng HDL 12 ©2008, Pham Quoc Cuong
  13. Toán tử Bit-wise (&, |, ~, ^, ^~) Computer Engineering 2009 & (and) 0 1 x z | (or) 0 1 x z 0 0 0 0 0 0 0 1 x x 1 0 1 x x 1 1 1 1 1 x 0 x x x x x 1 x x z 0 x x x z x 1 x x ^ (xor) 0 1 x z 0 1 x z ^~ (xnor) 0 0 1 x x 0 1 0 x x 1 1 0 x x 1 0 1 x x x x x x x x x x x x z x x x x z x x x x ~ (not) 0 1 x z 1 0 x x Thiết kế Vi mạch số dùng HDL 13 ©2008, Pham Quoc Cuong
  14. Toán tử thu giảm Computer Engineering 2009 0/1/x f .. .. .. .. x f x .. x .. .. .. z .. .. f & (thu giảm and): &bn-1bn-1…b0 0 1 & & .. 0 .. .. 1111 ~& (thu giảm nand): ~&bn-1bn-1…b0 .. .. .. .. 0/1 ~ & | (thu giảm or): |bn-1bn-1…b0 0 | 1 0000 | .. 1 .. .. ~| (thu giảm nor): ~|bn-1bn-1…b0 0/1 ~ | .. .. .. .. ^ (thu giảm xor): ^bn-1bn-1…b0 If count(bi = 1) mod 2 == 0, kết quả 0 Ngược lại kết quả 1 ~^/^~ (thu giảm xnor): ~^bn-1bn-1…b0 Thiết kế Vi mạch số dùng HDL 14 ©2008, Pham Quoc Cuong
  15. Toán tử dịch () Computer Engineering 2009 A > B .. x .. .. z .. f zzz f zzz .. .. • Dịch toán hạng bên trái số lần biểu diễn bởi toán hạng bên phải  Dịch trái bn bn-1 b2 b1 b0 ... 0 bn-1 bn-2 b1 b0 0 ...  Dịch phải bn bn-1 b2 b1 b0 ... 0 0 bn b3 b2 b1 ... reg [0:7] Qreg; Qreg = 4’b0111; Qreg >> 2 // is 8’b0000_0001 wire [0:3] DecoderOut = 4’d1
  16. Toán tử điều kiện Computer Engineering 2009 Cond_expr ? Expr1 : Expr2 • Nếu Cond_expr có chứa bất kỳ bit nào là x hoặc z thì kết quả là phép toán no bit-wise trên Expr1 và Cond_expr? Expr2 như sau  0 0 => 0 yes  1  1 => 1  Trường hợp khác là x • Toán tử điều kiện có thể Expr2 được lồng nhau vô tận Expr1 wire[15:0]bus_a = drive_a ? data : 16’bz; /* drive_a = 1 thì data được gán vào bus_a drive_a = 0 thì bus_a ở tổng trở cao drive_a = x thì bus_a là x */ Thiết kế Vi mạch số dùng HDL 16 ©2008, Pham Quoc Cuong
  17. Toán tử kết nối/nhân bản Computer Engineering 2009 • Kết nối {expr1, expr2,… , exprN}  Những hằng số không biết kích thước không thể thực hiện kết nối wire [7:0] Dbus; wire [11:0] Abus; assign Dbus[7:4] = {Dbus[0], Dbus[1], Dbus[2], Dbus[3]}; assign Dbus = {Dbus[3:0], Dbus[7:4]}; {Dbus, 5} // not allowed • Nhân bản {rep_number {expr1, expr2,… , exprN}} Abus = {3{4’b1011}}; // 12’b1011_1011_1011 {3{1’b1}} // 111 {3{Ack}} // {Ack, Ack, Ack} Thiết kế Vi mạch số dùng HDL 17 ©2008, Pham Quoc Cuong
  18. Nội dung chính Computer Engineering 2009 1. Mô hình hành vi 2. Mô hình hành vi dựa trên phương trình boole 3. Mô hình hành vi vòng 4. Mô hình hành vi cho các khối cơ bản 5. Giải thuật lặp và lưu đồ máy trạng thái cho mô hình hành vi Thiết kế Vi mạch số dùng HDL 18 ©2008, Pham Quoc Cuong
  19. Mô hình hành vi dựa trên phương trình boole Computer Engineering 2009 • Phép gán liên tục • Thời gian trễ truyền lan và phép gán liên tục • Latch và mạch tích cực mức trong Verilog Thiết kế Vi mạch số dùng HDL 19 ©2008, Pham Quoc Cuong
  20. Phép gán liên tục Computer Engineering 2009 • Phép gán liên tục  assign variable = boolean_expression  wire wire_name = boolean_expression  Boolean_expression được tính lại khi bất kỳ tín hiệu nào trong nó thay đổi • Một module có thể có nhiều phát biểu gán liên tục được thực thi đồng thời Logic description Verilog Description input x_in1, x_in2; circuit Structure output y_out; Schematic model assign y_out = ~(x_in & x_in2); LHS RHS input x_in1, x_in2; Truth User-Define table Primitive output y_out; wire y_out = ~(x_in & x_in2); Boolean Continuous Expressionl Assignments Thiết kế Vi mạch số dùng HDL 20 ©2008, Pham Quoc Cuong
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2