Thông báo

Collapse
No announcement yet.

--vhdl--

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • --vhdl--

    xin mấy cao thủ giúp mình xem đoạn code sau, ở đây mình không hiểu, ở đoạn lệnh gán tín hiệu: ALG_DATA <= ALG_DATA_INT;KS_CV<= CV_INT; nó thực hiện trước process main hay là sau?Nếu mà nó say ra trước thì mình không hiểu gán thế thì ALG_DATA ,KS_CV nhận 1 tín hiệu gì ở đây?Rất cảm ơn anh em!


    library ieee;
    use ieee.std_logic_1164.all;
    use WORK.twofish_pack.all;

    -- ================================================== =========================
    -- =========================== Interface Description =========================
    -- ================================================== =========================

    entity INTERFACE is

    port (clock : in std_logic;
    reset : in std_logic;

    DATA_LOAD : in std_logic; -- data load pulse
    DATAIN : in SLV_128; -- 128 bit block
    CV_LOAD : in std_logic; -- crypto variable load pulse
    CVIN : in SLV_128;
    ENC_DEC_B : in std_logic; -- '1' = encrypt, '0' = decrypt

    CTRL_DATA_LOAD : out std_logic; -- data load signal to controller
    CTRL_ENC_DEC_B : out std_logic;
    ALG_DATA : out SLV_128; -- 128 bit data block to algorithm
    KS_CVLOAD : out std_logic;
    KS_CV : out SLV_128
    );

    end INTERFACE;

    architecture INTERFACE_RTL of INTERFACE is

    -- ================================================== =========================
    -- =========================== Signal Definition =============================
    -- ================================================== =========================

    signal ALG_DATA_INT : SLV_128;
    signal CV_INT : SLV_128;

    begin

    -- ================================================== =========================
    -- =========================== Data Movement =================================
    -- ================================================== =========================

    ALG_DATA <= ALG_DATA_INT;
    KS_CV <= CV_INT;




    main: process( clock, reset )

    begin

    if reset = '1' then

    CTRL_DATA_LOAD <= '0';
    CTRL_ENC_DEC_B <= '0';
    KS_CVLOAD <= '0';
    CV_INT <= (others => '0');
    ALG_DATA_INT <= (others => '0');

    elsif clock'event and clock = '1' then

    CTRL_DATA_LOAD <= DATA_LOAD; -- pass control signals through
    CTRL_ENC_DEC_B <= ENC_DEC_B;
    KS_CVLOAD <= CV_LOAD;

    if DATA_LOAD = '1' then
    ALG_DATA_INT <= DATAIN;
    else
    ALG_DATA_INT <= ALG_DATA_INT;
    end if;

    if CV_LOAD = '1' then -- latch CV
    CV_INT <= CVIN;
    else -- hold previous CV data
    CV_INT <= CV_INT;
    end if; -- CV_LOAD = '1'


    end if; -- reset = '1'

    end process;

    end INTERFACE_RTL;
    |

  • #2
    Theo cooloo thì VHDL là concurrent language . Cái gì trước thì nó process trước .

    Comment


    • #3
      Bạn mô phỏng ra là thấy ngay thôi mà.

      @cooloo: concurrent language khác với sequential language. Chắc bạn nói lộn !


      Comment


      • #4
        Nguyên văn bởi yesme@ Xem bài viết
        Bạn mô phỏng ra là thấy ngay thôi mà.

        @cooloo: concurrent language khác với sequential language. Chắc bạn nói lộn !
        Cảm ơn yesme . cooloo đả không làm vhdl gần 15 năm nay rùi . Sorry .

        Comment


        • #5
          Mình mới viết nên cũng hông rành lắm, mà cái này tự học mới ác. Mình nghĩ là nó trước process, sau 1 vòng process rồi nó lại gán giá trị mới vào (đang mệt nên cũng o đọc kỹ code) . Còn nếu bạn hỏi là mới đầu nó gán cái gì thì tùy theo giá trị đầu của nó thôi. Lúc mô phỏng dạng tín hiệu phải gán giá trị vào mà. Bạn nên thêm 1 biến ngõ ra để quan sát thay đổi của ALG_DATA_INT, và CV_INT . Nghĩ vậy thôi chứ hem biết đúng hông nữa >_<

          Comment


          • #6
            Code:
            ALG_DATA <= ALG_DATA_INT;
            KS_CV <= CV_INT;
            2 câu lệnh này không nằm trong một Process nào. Do đó nó thực hiện song song với tất cả các câu lệnh khác. Chỉ các câu lệnh nằm trong Process mới được thực hiện tuần tự.

            Như vậy đây chỉ là 2 port ra được nối đến 2 tín hiệu (khai báo signal) ALG_DATA_INTCV_INT. Vì 2 port được khai báo là out nên không thể đọc trở lại, nên khai báo một tín hiệu khác để thao tác đọc, ghi.

            Trong chương trình bạn có thể thấy ALG_DATA_INTCV_INT vừa được đọc và ghi.

            Bạn có thể thử không cần dùng 2 lệnh đó và thay ALG_DATA_INT bằng ALG_DATA, và CV_INT bằng KS_CV. Synthesize sẽ báo lỗi là port out không thể đọc trở lại .

            Chúc bạn thành công.
            Technical sale at WT Microelectronics S'pore
            Hỗ trợ dự án sử dụng các hãng Texas Instrument, STMicro, Freescale, Fairchild, International Rectifier, Ublox, Lumiled, Maxim
            Liên hệ: 0915.560.511 hoặc ngo.haibac@wtmec.com

            Comment


            • #7
              Cảm ơn anh Bắc.Nhưng cho em hỏi nếu như mình đặt lệnh ALG_DATA <= ALG_DATA_INT;KS_CV <= CV_INT; sau process thì kết quả có thay đổi hay không?Cảm ơn anh em nhiều!
              |

              Comment


              • #8
                Với cái này ALG_DATA <= ALG_DATA_INT; KS_CV <= CV_INT; bất cứ khi nào ALG_DATA_INT hay CV_INT thay đổi giá trị thì ALG_DATA hay KS_CV sẽ được cập nhật.

                Bạn phải hiểu ở đây nó là phần cứng chứ ko phải là câu lệnh ngôn ngữ lập trình chạy theo "dòng".

                Comment


                • #9
                  @gacon_hihi: bạn phải đọc lại khái niệm "ngôn ngữ mô tả phần cứng" thì mới hiểu rõ hơn về những vấn đề này.


                  Comment

                  Về tác giả

                  Collapse

                  gacon_hihi Tìm hiểu thêm về gacon_hihi

                  Bài viết mới nhất

                  Collapse

                  • dinhthuong80
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi dinhthuong80
                    Bác nói rất khách quan và chính xác. Ngoại ngữ là chìa khóa thăng tiến dù làm gì. Chả thế mà nay nước mình dạy tiếng Anh từ tiểu học.

                    Nhớ hồi năm 2006 em ra Hải Phòng, Hải Dương tìm việc, thời đó ở Bình Dương lương công...
                    hôm nay, 14:51
                  • dinhthuong80
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi dinhthuong80
                    Cảm ơn bạn, ĐT cũng có ý nghĩ như vậy.

                    Thực ra, lỗi của hãng đó ( gọi là hãng vì không chỉ một model sản phẩm) là về phần cứng, ĐT tuy không biết về lập trình phần mềm nhưng cũng thấy rằng sẽ chẳng khó khăn gì đáng...
                    hôm nay, 14:39
                  • dinhthuong80
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi dinhthuong80
                    Dạ, bác bảy mấy tuổi đời rồi cũng không kém bố cháu bao nhiêu. Tuổi nghề thì bác cũng đáng tuổi cha chú.

                    Nhưng 2 điều trên thì chưa hẳn đã đáng quí và đáng tôn trọng bằng việc bác rất nhiệt tình chia sẻ kinh nghiệm chuyên...
                    hôm nay, 14:28
                  • bqviet
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi bqviet
                    Đúng, nếu chú tâm thì chỉ cần mỗi tiếng Việt là đã khá đủ để làm đa số công việc thông thường, ở thời đại ngày nay khi tài liệu sách vở phương tiện thông tin liên lạc đã nhiều. Nhưng cũng chính ở thời nay giao lưu các nước nhiều...
                    Hôm qua, 20:26
                  • mèomướp
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi mèomướp
                    Dạ cháu nghĩ chú dinh... cứ mạnh dạn gửi thư đi ạ, chú có thể gửi bằng văn bản in chuyển phát nhanh sẽ có giá trị hơn. Vấn đề chưa hẳn là cần hãng làm gì đó, mà chỉ đơn giản là mình cảm thấy nhẹ lòng vì đã làm những việc bản...
                    Hôm qua, 12:32
                  • vi van pham
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi vi van pham
                    Những lần hắt hơi sổ mũi làm tôi mệt lã, phải dùng rượu uống để ngũ. Tôi cũng đang uống rượu 1 mình, viết vài dòng này cho em ( có lẽ dt chỉ bằng tuổi em tôi).

                    Dinh thuong dang đi vào vết xe đổ của tôi. Càng chứng minh, có...
                    20-02-2025, 21:31
                  • bqviet
                    Trả lời cho Hỏi về cách hàn linh kiện ( giúp tớ với )
                    bởi bqviet
                    Thiết nghĩ thi thoảng bác lên đây chia xẻ ít kinh nghiệm cũng vui rồi. Còn chuyện con người sinh lão bệnh tử là thường, sống cùng với quy luật đó thôi. Bqv nhớ trước đây bác từng kể về chuyện rang chì ô-xít bằng chảo để phục hồi bình điện, đấy cũng là thành quả đáng nể phục ở thời kỳ thiếu thốn đó.
                    20-02-2025, 17:22
                  • dinhthuong80
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi dinhthuong80
                    Tiếng Anh, Đình Thường phải nói là rất tệ, khiến việc giao tiếp đời thường thôi cũng khó chứ nói gì về kĩ thuật.

                    Nhân tiện, nhờ các bạn, các bác xem giúp thư ĐT viết thế này liệu có thể gửi tới địa chỉ nhận hay chăng,...
                    20-02-2025, 11:52
                  • vi van pham
                    Trả lời cho Hỏi về cách hàn linh kiện ( giúp tớ với )
                    bởi vi van pham
                    Uống rượu 1 mình, thấy trang này nhớ lại cách đây vài chục năm hàn thiếc với inox cực kỳ khó, phải dùng acid Hcl tác dụng lên kẻm Zn để có Zncl2 làm thuốc trợ hàn, lúc đó làm gì có acid Hcl và thuốc trợ hàn?

                    Cái khó bó cái...
                    19-02-2025, 23:05
                  • nhathung1101
                    Trả lời cho Tiếng Anh cho người Việt
                    bởi nhathung1101
                    Nếu chú tâm thì học tiếng Việt cũng đủ rồi, thừa sức làm việc rồi.

                    Học tiếng Anh cũng chỉ phụ trợ để đọc thêm tài liệu, hướng dẫn.

                    Nhưng có hiểu điều đó không mới là vấn đề. Khi mà học ngoại ngữ để đi đạp xích lô đón khách???...
                    19-02-2025, 21:27
                  Đang tải...
                  X