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
-
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
-
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 Thắc mắc về nguồn tổ ong 12vbởi tuyennhanCách ly dây điện vào , bộ nguồn và đèn khỏi khung xe thì có rò thật cũng không lo bị giật .
-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 08:56 -
-
Trả lời cho Hỏi cách điều chế xungbởi thetungBạn cho qua cái Tờ ri gơ Sờ mít ấy ......
-
Channel: Kỹ thuật điện tử tương tự
16-12-2024, 11:26 -
-
Trả lời cho Hỏi cách điều chế xungbởi nguyendinhvanCó gì mà khó ?
Răn cưa vuông đây
...-
Channel: Kỹ thuật điện tử tương tự
15-12-2024, 23:36 -
-
Trả lời cho hỏi về tụ điệnbởi ndp62Chữ " VENT" không phải là tên hãng sx tụ đâu ,vó thế là 1 ký hiệu liên quan tụ lowesr ?
-
Channel: Điện thanh
15-12-2024, 18:24 -
-
Trả lời cho Thắc mắc về nguồn tổ ong 12vbởi bqvietTrừ trường hợp công suất (rất) thấp, hầu như tất cả các loại nguồn xung thông thường đều có tụ nhỏ 1 - 10nF nối giữa sơ cấp và thứ cấp, để thoát nhiễu và để chống hiện tượng tương tự tĩnh điện. Vụ này đã thảo luận vài...
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 22:02 -
-
Trả lời cho Thắc mắc về nguồn tổ ong 12vbởi namlangnhoE thử 3 cái nguồn nó đều giống nhau. Nên e làm tiếp địa luôn.
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 19:58 -
-
Trả lời cho Thắc mắc về nguồn tổ ong 12vbởi mèomướpDạ chú sắm con át chống giật và thay nguồn tổ ong khác cho an toàn ạ. Đa phần nguồn xung đều xả nhiễu của bên thứ cấp về điện lưới qua 1 con tụ nên cảm giác tê sẽ khó xác định rõ ràng là do rò điện hay là nó vốn vậy...
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 18:51 -
-
bởi namlangnhoXin chào mọi người. E có sử dụng 1 cục nguồn tổ ong 12v-30A chạy đèn led xe trà sữa. Mà thợ thi công bị rò điện nên điện rò ra khung xe. E dùng đồng hồ đo điện ở khung xe và cả output thì thấy có dòng điện xoay chiều hơn 100v. Nên chạm...
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 00:12 -
-
bởi Manh.n.trCác bác cho em hỏi cách điều chế xung răng cưa sang xung vuông với ạ. Em đang thấy khó ạ...
-
Channel: Kỹ thuật điện tử tương tự
13-12-2024, 20:46 -
Comment