em tìm được code này nhưng biên dịch bị lỗi, chưa sửa được các bác a! mong các bác sửa giúp hoặc đề xuất phuơng án tốt hơn. em xin cảm ơn!
Thông báo
Collapse
No announcement yet.
các bác cho em hỏi cách tạo 1 thanh ghi bằng D flipflop trong verilog?
Collapse
X
-
module dff (data,clk,reset,q);
input data, clk, reset ;
output q;
reg q;
always @ ( posedge clk or negedge reset)
if (~reset) begin
q <= 1'b0;
end else begin
q <= data;
end
endmodule
module rg(datain,clk,reset,q);
input datain[15:0];
input clk,reset;
integer N,i;
wire [15:0] datain;
wire clk,reset;
output [15:0] q;
reg [15:0] q;
always @ ( posedge clk or negedge reset)
begin
dff s(datain[0],clk,reset,q[0]);
for(N=1;N<=15;N=N+1)
begin
dff s(data[N],clk,reset,q[0]);
for(i=0;i<N;i=i+1)
begin
dff s(q[i],clk,reset,q[i+1]);
end
end
end
endmodule
-
theo mình thì có lẽ làNguyên văn bởi huy2207 Xem bài viếtmodule dff (data,clk,reset,q);
input data, clk, reset ;
output q;
reg q;
always @ ( posedge clk or negedge reset)
if (~reset) begin
q <= 1'b0;
end else begin
q <= data;
end
endmodule
module rg(datain,clk,reset,q);
input datain[15:0];
input clk,reset;
integer N,i;
wire [15:0] datain;
wire clk,reset;
output [15:0] q;
reg [15:0] q;
always @ ( posedge clk or negedge reset)
begin
dff s(datain[0],clk,reset,q[0]);
for(N=1;N<=15;N=N+1)
begin
dff s(data[N],clk,reset,q[0]);
for(i=0;i<N;i=i+1)
begin
dff s(q[i],clk,reset,q[i+1]);
end
end
end
endmodule
always @ ( posedge clk or negedge reset)
begin
dff s(datain[0],clk,reset,q[0]);
for(N=1;N<=15;N=N+1)
begin
dff s(data[N],clk,reset,q[0]);
end
for(i=0;i<N;i=i+1)
begin
dff s(q[i],clk,reset,q[i+1]);
end
end
cũng không rõ có đúng không...nếu sai thì xin lượng thứ
Comment
-
Hi huy2207,
Mình không biết yêu cầu thiết của bạn là gì nên mình chỉ góp ý vài chỗ trong code bạn viết:
1) Tại module thứ 2 ("module rg ..."): bạn khai báo q là "reg" và sử dụng trong "allways" với hình thức ghép ghép chân tín hiệu trực tiếp từ module khác. Điều này là sai! Bạn có thể sửa theo 2 cách sau.
- Bạn có thể sử dụng q khai báo "reg" và sử dụng always để tạo thanh ghi theo cách của module 1
- Bạn sử dụng module 1 - D flipflop làm thành phần cơ bản để tạo thanh ghi thì khai báo q là "wire". Sau đó ghép các khối D-FF theo qui luật mà bạn thiết kế.
+ Bạn có thể sử dụng "generate" và "endgenerate" kết hợp với vòng lặp "for" để mô tả thanh ghi (viết theo code verilog 2001)
+ Bạn có thể sử dụng ghep các khối bằng cách liệt kê đầy đủ các D-FF và ghép nó với nhau (viết theo code verilog 1995)
2) Tại các module bạn khai báo tên của "output" và tên của "reg" trùng nhau. Điều này OK, tuy nhiên không nên sử dụng vì nó có thể vi phạm "văn phong" trong viết code. Điều này được quy định trong các chương trình kiểm tra phương thức mô tả phần cứng. Bạn có thể khai báo:
output data_out;
reg data_reg;
assign data_out = data_reg;
3) Bạn nên tìm hiểu thêm về "Coding Style" cho ngôn ngữ mô tả phần cứng Verilog, VHDL. Cái này thì hỏi google thì có rất nhiều. Hãy luyện tập cách thức viết code như vậy sẽ có lợi cho bạn.
4) Đây là lời khuyên chân thành cho các bạn mới bắt đầu với Verilog và VHDL: Các bạn nên vẽ sơ đồ chi tiết của thiết kế trước bắt đầu mô tả chúng bằng ngô nữ mô tả phần cứng. Điều này sẽ giúp cho bạn mô tả chính xác thiết kế. Đừng sợ cực với việc vẽ sơ đồ thiết kế, nó chính là công việc chính của người thiết kế phần cứng cho chip. Viết code mô tả phần cứng chỉ là phần cuối cùng của quá trình mô tả phần cứng.
Hi vọng những điều trên giúp ích cho bạn.
^_^
Comment
Bài viết mới nhất
Collapse
-
bởi DomitilaXin lỗi vì đã làm phiền, tôi có một câu hỏi dành cho mọi người.
Tôi đang sử dụng công tắc tiệm cận để chuyển mạch giới hạn trên thiết bị của mình. Mỗi khi động cơ bước được kích hoạt, tín hiệu của công tắc nhảy lung tung, ngay cả khi động cơ không quay.
...-
Channel: Điện tử công suất
hôm nay, 13:02 -
-
Trả lời cho Thắc mắc pin 21v ?bởi mèomướpDạ áp sạc như vậy là đúng rồi ạ. Pin li ion mật độ điện cao và dễ cháy nổ khi mạch bảo vệ lỗi. Chú muốn an toàn thì dùng pin sắt li fe ạ, hoặc mới hơn là pin natri. Tuy nhiên loại này to nặng, dòng xả thấp hơn nên ko phù hợp cho dụng cụ cầm tay ạ...
-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 19:29 -
-
bởi trung30000Các bác cho em hỏi pin 21 volt, 5s , khi sạc đầy cục sạc chuyển màu xanh, em đo điện áp khi đầy là 21.05 v, như vậy có nguy hiểm đến pin không các bác, vì mỗi Cell pin chỉ chịu tối đa được 4.2v,
-tại sao nhà sản xuất không thiết kế cục sạc khi đầy chỉ 20v để bảo vệ pin .-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 10:51 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi vi van phamCảm ơn cháu đã bỏ chút thời gian vàng ngọc xem ông già gần 80 tuổi kể hối ký chuyện tình cùa mình. Những chương trình học hồi lớp 6 ( đệ thất) và lớp 7 ( đệ luc) học họa và nhạc sau này đã giúp đỡ tôi rất nhiều trong việc tìm...
-
Channel: Tâm tình dân kỹ thuật
16-05-2026, 22:15 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Chúc mừng bác có cuộc tình rất lãng mạn, cuộc hôn nhân gắn bó dài lâu nhé!...
-
Channel: Tâm tình dân kỹ thuật
16-05-2026, 13:49 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi vi van phamHôn nhân của tôi dường như có bàn tay sắp đặt của ông tơ, bà nguyệt. Bà xả nói tôi viết hồi ký duyên số này. Tôi đã viết vào tập 100 trang học sinh. Sau 50 năm lật tới, lật lui xem quyển hối ký có nơi rách nát. Tôi viết lại bằng AI, giọng đọc VBBe, ca sĩ hát là là Synthesizer V.
...-
Channel: Tâm tình dân kỹ thuật
15-05-2026, 14:18 -
-
Trả lời cho Công thức tính định luật kirchhoffbởi nguyendinhvanCông thức này chắc là để áp dụng cho UAV để bắn máy bay F15....
-
Channel: Hỗ trợ học tập
14-05-2026, 21:17 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92GIỚI THIỆU CA KHÚC VỀ CHA MẸ:
Nặng Nghĩa Mẹ Cha
Sáng tác: Hoàng Đình Thường
Giọng hát: AI
Công cha cao tựa như Thái Sơn
Nghĩa mẹ sâu nước biếc xanh trong
Mong con khôn lớn đời hạnh phúc
Mẹ cha...-
Channel: Tâm tình dân kỹ thuật
12-05-2026, 16:22 -
-
bởi afrendlyCảm ơn bạn. Mình hỏi để thợ có thể tham khảo thôi chứ không đủ kiển thức để sửa, mà cũng không có đồ nghề, mua đồ nghề quá tiền máy. Gọi nhiều lần mà thợ hẹn mãi chưa có tới ấy bạn. Mình muốn sửa được chứ bỏ thì uống, nhưng sợ là được mỗi người thợ mà lại không sửa nổi....
-
Channel: Điện tử gia dụng
11-05-2026, 00:34 -
-
bởi mèomướpDạ nó bị tắc ẩm hoặc rò thiếu gas hoặc lốc yếu hoặc van tiết lưu có vấn đề hoặc tất cả những nguyên nhân trên ạ. Chú ko chuyên về mảng này thì bán đi, giành thời gian trồng rau sạch đem ra chợ bán lấy tiền mua tủ mới ạ. Còn...
-
Channel: Điện tử gia dụng
10-05-2026, 17:01 -

Comment