Thông báo

Collapse
No announcement yet.

Mọi người giúp mình về cái chuông trình này với. chương trình VHDL chạy trên XILINX

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

  • Mọi người giúp mình về cái chuông trình này với. chương trình VHDL chạy trên XILINX

    library IEEE;
    use IEEE.STD_LOGIC_1164.all;
    use IEEE.STD_LOGIC_ARITH.all;
    use IEEE.STD_LOGIC_UNSIGNED.all;
    use work.CALC1_PAK.all;

    entity CNTRL_FSM is
    port ( DATA_FRAME : in MY_RECORD;
    CLK : in std_logic;
    RESET : in std_logic;
    A_IN : out std_logic_vector(3 downto 0);
    B_IN : out std_logic_vector(3 downto 0);
    C_IN : out std_logic;
    OP_CODE : out std_logic_vector(3 downto 0);
    EXP : out std_logic_vector(3 downto 0);
    ADDR : out std_logic_vector ( 2 downto 0);
    COMP_EN : out std_logic;
    MEM_EN : out std_logic;
    ALU_EN : out std_logic );
    end entity CNTRL_FSM;

    architecture RTL of CNTRL_FSM is

    type CNTRL_STATE is ( S0_INIT, S1_FETCH, S2_ALU, S3_COMP, S4_DONE );
    signal CURR_STATE, NEXT_STATE : CNTRL_STATE;

    signal ADDR_I, ADDR_Q : std_logic_vector ( 2 downto 0 ) := ( others => ‘0’ );
    begin

    ADDR <= ADDR_Q; -- used to update output port from synchronous internal signal

    SYNC : process ( CLK, RESET )
    begin
    if ( RESET = '1' ) then
    CURR_STATE <= S0_INIT;
    ADDR_Q <= ( others => '0' );
    elsif rising_edge (CLK) then
    CURR_STATE <= NEXT_STATE;
    ADDR_Q <= ADDR_I; -- update ADDR_Q with the current value of ADDR_I
    end if;
    end process SYNC;

    COMB : process ( CURR_STATE, DATA_FRAME, ADDR_Q )
    begin
    --default assignments
    A_IN <= DATA_FRAME.A_IN;

    B_IN <= DATA_FRAME.B_IN;

    C_IN <= DATA_FRAME.C_IN;

    OP_CODE <= DATA_FRAME.OP_CODE;

    EXP <= DATA_FRAME.EXP;



    ADDR_I <= ADDR_Q; -- use the registered ADDR_Q to keep ADDR fully synchronous

    case CURR_STATE is

    when S0_INIT =>

    MEM_EN <= '0';

    ALU_EN <= '0';


    COMP_EN <= '0';

    NEXT_STATE <= S1_FETCH;

    when S1_FETCH =>
    MEM_EN <= '1';
    ALU_EN <= '0';
    COMP_EN <= '0';

    NEXT_STATE <= S2_ALU;


    when S2_ALU =>
    MEM_EN <= '0';
    ALU_EN <= '1';
    COMP_EN <= '0';

    NEXT_STATE <= S3_COMP;

    when S3_COMP =>
    MEM_EN <= '0';
    ALU_EN <= '0';
    COMP_EN <= '1';

    NEXT_STATE <= S4_DONE;

    when S4_DONE =>
    if ADDR_Q = "111" then
    NEXT_STATE <= S4_DONE;
    else
    NEXT_STATE <= S1_FETCH ;
    ADDR_I <= ADDR_Q + 1;
    end if;
    MEM_EN <= '0' ;
    ALU_EN <= '0';
    COMP_EN <= '0';


    when others =>
    NEXT_STATE <= S0_INIT;

    MEM_EN <= '0' ;

    ALU_EN <= '0';


    COMP_EN <= '0';

    end case;

    end process COMB;

    end RTL;



    library IEEE;
    use IEEE.STD_LOGIC_1164.ALL;
    use IEEE.STD_LOGIC_ARITH.ALL;
    use IEEE.STD_LOGIC_UNSIGNED.ALL;
    use work.CALC1_PAK.all;ENTITY CNTRL_FSM_TB_vhd IS

    END CNTRL_FSM_TB_vhd;

    ARCHITECTURE behavior OF CNTRL_FSM_TB_vhd IS

    COMPONENT CNTRL_FSM
    PORT(
    DATA_FRAME : IN MY_RECORD;
    CLK : IN std_logic;
    RESET : IN std_logic;
    A_OP : OUT std_logic_vector(3 downto 0);
    B_OP : OUT std_logic_vector(3 downto 0);
    C_IN : OUT std_logic;
    OP_CODE : OUT std_logic_vector(3 downto 0);
    EXP : OUT std_logic_vector(3 downto 0);
    MEM_EN : OUT std_logic;
    ALU_EN : OUT std_logic ;
    COMP_EN : OUT std_logic ;
    ADDR : OUT std_logic_vector(2 downto 0) );
    END COMPONENT;

    SIGNAL DATA_FRAME : MY_RECORD := ("0000", "0000","0000",'0',"0000");
    SIGNAL CLK : std_logic := '0';
    SIGNAL RESET : std_logic := '0';
    SIGNAL A_IN, B_IN : std_logic_vector(3 downto 0);
    SIGNAL C_IN : std_logic;
    SIGNAL OP_CODE : std_logic_vector(3 downto 0);
    SIGNAL EXP : std_logic_vector(3 downto 0);
    SIGNAL ALU_EN, MEM_EN, COMP_EN : std_logic;
    SIGNAL ADDR : std_logic_vector(2 downto 0);
    BEGIN

    uut: CNTRL_FSM PORT MAP(


    DATA_FRAME => DATA_FRAME,

    CLK => CLK,

    RESET => RESET,

    A_IN => A_IN,

    B_IN => B_IN,

    C_IN => C_IN,

    OP_CODE => OP_CODE,

    EXP => EXP,

    ALU_EN => ALU_EN, MEM_EN => MEM_EN, COMP_EN => COMP_EN ,

    ADDR => ADDR );



    CLK <= not CLK after 20 ns;

    RESET <= '1' after 10 ns, '0' after 25 ns;




    tb : PROCESS
    BEGIN
    DATA_FRAME <= ("1000", "0100","0000",'0',"0000");
    wait for 100 ns;
    DATA_FRAME <= ("1000", "0100","0101",'0',"0000");
    wait for 100 ns;
    DATA_FRAME <= ("1000", "0100","0100",'0',"0000");
    wait; -- will wait forever
    END PROCESS;

    END TEST;

Về tác giả

Collapse

thuốc lào 07 Tìm hiểu thêm về thuốc lào 07

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

Collapse

  • mèomướp
    Trả lời cho Công thức điện tử
    bởi mèomướp
    Dạ thời thế giờ thay đổi theo hướng tích cực hơn rồi chú trung sĩ ạ. Kiến thức được chia sẻ ngày càng nhìu nên làm ăn gian dối ko còn dễ dàng như trước đâu ạ. Những thợ nhỏ rồi sẽ thành công nhân sản xuất đồ mới hết thay vì sửa chữa lặt vặt...
    Hôm qua, 21:21
  • mèomướp
    Trả lời cho Xin hỏi về màn hình laptop
    bởi mèomướp
    Dạ cùng chuẩn tín hiệu thì chắc chắn là nhận ạ. Vì bản chất oled hay lcd thì đều phải có mạch chuyển đổi trên thanh gỗ rồi chuyển sang những chip xử lý hàng nghìn chân gắn trên những tab mỏng dính rồi mới ra các điểm ảnh theo hàng...
    Hôm qua, 20:31
  • yname11
    Trả lời cho Xin hỏi về màn hình laptop
    bởi yname11
    Ok , thanks bác đã chỉ...
    Hôm qua, 15:06
  • nguyendinhvan
    Công thức điện tử
    bởi nguyendinhvan
    Sau bao năm nghiên cứu cái dtvn. Tôi phát hiện công thức này. Các anh em xem đúng bao nhiêu phần trăm nhé !

    Chập thì thay. Cháy thì tháo
    Làm thì láo. Báo thì hay
    May thì khoe. Rủi thì bỏ
    Thành tích nhỏ. Báo thành to
    Làm cho có. Báo chi li
    Sai cả li. Báo
    ...
    Hôm qua, 00:35
  • yname11
    Trả lời cho Xin hỏi về màn hình laptop
    bởi yname11
    có chắc ko b, màn lcd phải có cao áp mới sáng, màn led thì ko có, ko có cáp chuyển đổi thì lắp thế nào đc ??...
    25-11-2024, 22:31
  • mèomướp
    Trả lời cho Xin hỏi về màn hình laptop
    bởi mèomướp
    Dạ ý chú là màn oled ấy ạ. Cùng chuẩn lvds cùng độ phân giải thì cắm được ạ. Còn nó mà khác thì hơi khó vì oled các điểm ảnh nó tự phát sáng chứ ko dùng đèn nền như lcd. Cháu chỉ biết đến vậy thôi ạ. Chú muốn nghịch phải tự tìm hiểu kỹ trước khi mua thôi, khó mà ông thợ nào tư vấn vụ này...
    25-11-2024, 22:14
  • bactho
    Trả lời cho Tự làm máy đo Cuộn cảm
    bởi bactho
    Hay đấy bạn ạ. Đây có thể hiểu là máy đo cuộn dây. Tiện đây xin cho hỏi bạn có hiểu rõ về máy nạp rôm pcb 45 của hãng thiên minh không giúp mình cách cài fw của nó với vì mình vừa được anh bạn cho nhưng lại không biết cài fw nên chưa dùng được. Nếu có thể thì bạn giúp mình với...
    25-11-2024, 21:48
  • yname11
    Trả lời cho Xin hỏi về màn hình laptop
    bởi yname11
    màn của mình là LCD , giờ m muốn mua màn LED để thay thế (ko muốn dùng màn LCD nữa) , lên muốn hỏi xem có cáp chuyển đổi nào có thể cắm đc màn LED vào ko , tất nhiên phải có cùng số chân pin với màn cũ rồi . VD: màn cũ là lcd mỏng , 40 pin...
    25-11-2024, 21:43
  • bactho
    Trả lời cho các bạn giúp mình về file HEX với!!!
    bởi bactho
    Bạn vào trang phuclanshop.com ,tìm đến góc kỹ thuật. Tác giả vương khánh hưng nói rất rõ về điều bạn tìm...
    25-11-2024, 21:21
  • mèomướp
    Trả lời cho Xin hỏi về màn hình laptop
    bởi mèomướp
    Dạ màn hình lcd đều có thể lai cấy cho nhau được hết ạ. Các loại cáp, bo mạch chuyển đổi lvds rất nhìu, với dòng sony còn phải nhổ cả chip nhớ của main cũ đưa lên gỗ thì mới lắp sang máy khác đc, chưa kể các bệnh về màu... ngay cả...
    25-11-2024, 20:43
Đang tải...
X