Xin chào các bác! Em là beginner của VHDL nên có câu hỏi muốn hỏi các bác mong các bác trả lời giúp. Câu hỏi là :Các bác có thể giải thích giùm em "Concurrent Code" và "Sequential Code" là gì và cách phân biệt chúng. Cám ơn nhiều :d
Thông báo
Collapse
No announcement yet.
Concurrent Code - Sequential Code
Collapse
X
-
Hi bạn,
Concurrrent tiếng Anh nghĩa là được simulator thưc hiện đồng thời, cùng lúc
Sequential = theo trình tự, nghĩa là sẽ được simulator thực hiện từ trên xuống dưới.
Trong tài liệu chuẩn của VHDL và verilog người ta sẽ định nghĩa các statement nào là concurrent, statement nào là sequential. Mình không nghĩ bạn có thể phân biệt được. Vì người ta định nghĩa nên mình theo đó, và biết các statement nào là sequential hay concurrent. Có thể cùng tên nhưng tùy trường hợp lúc concurrent, lúc sequential
Ví dụ:
1) process là concurrent.
process1: process(clk, rst) ... begin end process
process2: process(clk, rst) ... begin end process
process1 và process2 sẽ được simulator thực hiện cùng lúc, Từ đó suy ra, bạn sẽ có được 2 mạch logic chạy cùng lúc.
2) Các statements giũa begin và end process là sequential
process (..)
begin
if(rising_edge(clk) then
if(a = '1') then b <= '1'; end if; --statement 1
if(c = '1') then b <= '0'; end if; --statement 2
end if;
end process;
trong ví dụ này: ngay lúc rising_edge của clk, if statement 1 sẽ được simulator thực hiện trước if statement 2
ac = 00: ko có gì xảy ra
ac = 10: b được gán = 1
ac = 01: b được gán = 0
ac = 11: b được gán = 0
Mạch logic sẽ được tạo ra đề có kết quả khớp với simulator.
-
Sau khi đọc bài bạn mình cũng hiểu được 1 ít về "Concurrent Code - Sequential Code" và mình xin được trả lời câu hỏi của bạn như thế này, mình xin mượn code của bạn.
process (..)-- process 1
begin
if(rising_edge(clk) then
if(a = '1') then b <= '1'; end if; --statement 1
end if;
end process;
------------------------
process (..)--process 2
begin
if(rising_edge(clk) then
if(c = '1') then b <= '0'; end if; --statement 2
end if;
end process;
---------------------------------------------
vì process là Concurrent nên khi mô phỏng cả 2 process thực thi cùng 1 lúc:
khi ac=00 thì ko xảy ra điều gì.
khi ac=01 thì b=0
khi ac=10 thì b=1
khi ac=11 Vấn đề sẽ nằm ở đây vì trong Concurrent thì 1 output sẽ không thể gán đồng thời 2 giá trị cùng 1 lúc. và Synthesize có thể báo lỗi
Và trên là câu trả lời của mình. Ko biết đúng ko. Mong bác kiểm tra hộ .Thank
Comment
-
Theo như ví dụ ở trên của bạn, simulator có thể sẽ báo lỗi vì "b" không có thể có 2 giá trị (0 và 1) liền một lúc. Bạn có thể dùng 2 giá trị tạm thời cho đường ra của mỗi process. Rồi dựa trên một dữ kiện nào đó để quyết định giá trị của "b"Nguyên văn bởi enter88 Xem bài viếtSau khi đọc bài bạn mình cũng hiểu được 1 ít về "Concurrent Code - Sequential Code" và mình xin được trả lời câu hỏi của bạn như thế này, mình xin mượn code của bạn.
process (..)-- process 1
begin
if(rising_edge(clk) then
if(a = '1') then b <= '1'; end if; --statement 1
end if;
end process;
------------------------
process (..)--process 2
begin
if(rising_edge(clk) then
if(c = '1') then b <= '0'; end if; --statement 2
end if;
end process;
---------------------------------------------
vì process là Concurrent nên khi mô phỏng cả 2 process thực thi cùng 1 lúc:
khi ac=00 thì ko xảy ra điều gì.
khi ac=01 thì b=0
khi ac=10 thì b=1
khi ac=11 Vấn đề sẽ nằm ở đây vì trong Concurrent thì 1 output sẽ không thể gán đồng thời 2 giá trị cùng 1 lúc. và Synthesize có thể báo lỗi
Và trên là câu trả lời của mình. Ko biết đúng ko. Mong bác kiểm tra hộ .Thank
process (..)-- process 1
begin
if(rising_edge(clk) then
if(a = '1') then b1 <= '1'; end if; --statement 1
end if;
end process;
------------------------
process (..)--process 2
begin
if(rising_edge(clk) then
if(c = '1') then b2 <= '0'; end if; --statement 2
end if;
end process;
------------------------
process (..)--process 3
begin
if(rising_edge(clk) then
if(d = '1') then b <= b1;
else b <= b2; end if; --statement 3
end if;
end process;Last edited by tonyvandinh; 19-11-2010, 09:11.
Comment
-
Đúng roài,
- Chương trình tổng hợp (synthesizer) sẽ báo lỗi, phần cứng nào tạo ra như vậy sẽ lỗi vì 2 flip-flop nối với nhau ở đầu ra. (Lỗi là "multiple driver" cho cùng 1 signal)
- Simulator thì ko chắc có bị lỗi không, vì kiểu std-logic, trong simulator có các giá trị khác: Z, X ... trong trường hợp a = 1 và c = 1, có thể b sẽ bị gán X ... các bạn tự kiểm tra thử
Comment
-
Nếu muốn simulator không báo lỗi, thì phải dùng resolution type cho "b"Nguyên văn bởi jefflieu Xem bài viết- Simulator thì ko chắc có bị lỗi không, vì kiểu std-logic, trong simulator có các giá trị khác: Z, X ... trong trường hợp a = 1 và c = 1, có thể b sẽ bị gán X ... các bạn tự kiểm tra thử
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Cháu không vào được để nghe thử. Mời bác nghe thử bản phối điệu Techno này xem thế nào nhé! Chúc bác vui.
( Cháu nhìn lyrics và cứ thế một mmạch hát demo rồi đưa vào suno. nó hát đạt 80% melody!)...-
Channel: Tâm tình dân kỹ thuật
27-04-2026, 17:00 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Bài này cháu phải "Creat" trên 30 lần rồi cắt ghép mới tạm có hồn tí đó bác. Quá nản luôn!!!
HẸN ƯỚC XUÂN SANG
Sáng tác: Hoàng Đình Thường
Hòa âm & hát: Suno AI
---25/04/2026----
[Verse 1]
Gió...-
Channel: Tâm tình dân kỹ thuật
25-04-2026, 11:05 -
-
bởi dinhthuong92Vậy là Mạch PPT không cần dùng tới cuộn cảm luôn nhỉ!...
-
Channel: Nguồn!
22-04-2026, 11:19 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Hiện nó còn chưa phân biệt được giọng nam giọng nữ trong song ca nữa. Hát mono một giọng thì ok.
Ở bài MỎI CÁNH CHIM BẰNG nó hát lệch: khúc bi ca, từng ngày, mịt mù, địa chỉ, cát bụi, mỏi mòn, hoàng hôn, nơi ấy, dại khờ.-
Channel: Tâm tình dân kỹ thuật
22-04-2026, 11:07 -
-
Trả lời cho Công nghệ TSMC cho thiết kế Digital ICbởi gfasdfa234ai còn cái này không nhỉ , upload lại cho mọi người đi , vì một cộng đồng điện tử việt nam...
-
Channel: Công nghệ ASIC & Advance Techno
22-04-2026, 11:06 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Vâng bác, hiện tại mình phải chấp nhận SUNO như vậy thôi, vì ít ra nó hát đa phần đúng hay hơn mình, đỡ tốn tiền thuê ca sĩ thể hiện.
Cháu nghĩ, có thể nhà phát triển cố tình bảo vệ giới ca sĩ đấy, chứ mà mình nói sao...-
Channel: Tâm tình dân kỹ thuật
22-04-2026, 11:05 -
-
bởi chinhnguyen9Về điện áp:
Trong phạm vi chứa đén 10% quang năng đầu vào thị điên áp đã đạt 90% điện áp tối đa nên điện áp hoàn toàn không nói lên công suất phảt củả pin mặt trời.
Về cường độ dòng điên phát:
Pin năng lương mặt tròi có nội trỏ biến...-
Channel: Nguồn!
22-04-2026, 09:09 -

Comment