⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mt48lc16m16a2.vhd

📁 free hardware ip core about sparcv8,a soc cpu in vhdl
💻 VHD
📖 第 1 页 / 共 5 页
字号:
                -- Check to see if bank is open (ACT) for Read or Write                IF ((Ba="00" AND Pc_b0='1') OR (Ba="01" AND Pc_b1='1') OR (Ba="10" AND Pc_b2='1') OR (Ba="11" AND Pc_b3='1')) THEN                    ASSERT (FALSE)                        REPORT "Cannot Read or Write - Bank is not Activated"                        SEVERITY WARNING;                END IF;                -- Activate to Read or Write                IF Ba = "00" THEN                    ASSERT (NOW - RCD_chk0 >= tRCD)                        REPORT "tRCD violation during Read or Write to Bank 0"                        SEVERITY WARNING;                ELSIF Ba = "01" THEN                    ASSERT (NOW - RCD_chk1 >= tRCD)                        REPORT "tRCD violation during Read or Write to Bank 1"                        SEVERITY WARNING;                ELSIF Ba = "10" THEN                    ASSERT (NOW - RCD_chk2 >= tRCD)                        REPORT "tRCD violation during Read or Write to Bank 2"                        SEVERITY WARNING;                ELSIF Ba = "11" THEN                    ASSERT (NOW - RCD_chk3 >= tRCD)                        REPORT "tRCD violation during Read or Write to Bank 3"                        SEVERITY WARNING;                END IF;                -- Read Command                IF Read_enable = '1' THEN                    -- CAS Latency Pipeline                    IF Cas_latency_3 = '1' THEN                        IF Addr(10) = '1' THEN                            Command(2) := READ_A;                        ELSE                            Command(2) := READ;                        END IF;                        Col_addr (2) := TO_BITVECTOR (Addr(col_bits - 1 DOWNTO 0));                        Bank_addr (2) := TO_BITVECTOR (Ba);                    ELSIF Cas_latency_2 = '1' THEN                        IF Addr(10) = '1' THEN                            Command(1) := READ_A;                        ELSE                            Command(1) := READ;                        END IF;                        Col_addr (1) := TO_BITVECTOR (Addr(col_bits - 1 DOWNTO 0));                        Bank_addr (1) := TO_BITVECTOR (Ba);                    END IF;                    -- Read intterupt a Write (terminate Write immediately)                    IF Data_in_enable = '1' THEN                        Data_in_enable := '0';                    END IF;                -- Write Command                ELSIF Write_enable = '1' THEN                    IF Addr(10) = '1' THEN                        Command(0) := WRITE_A;                    ELSE                        Command(0) := WRITE;                    END IF;                    Col_addr (0) := TO_BITVECTOR (Addr(col_bits - 1 DOWNTO 0));                    Bank_addr (0) := TO_BITVECTOR (Ba);                    -- Write intterupt a Write (terminate Write immediately)                    IF Data_in_enable = '1' THEN                        Data_in_enable := '0';                    END IF;                    -- Write interrupt a Read (terminate Read immediately)                    IF Data_out_enable = '1' THEN                        Data_out_enable := '0';                    END IF;                END IF;                -- Interrupt a Write with Auto Precharge                IF Auto_precharge(TO_INTEGER(RW_Interrupt_Bank)) = '1' AND Write_precharge(TO_INTEGER(RW_Interrupt_Bank)) = '1' THEN                    RW_interrupt_write(TO_INTEGER(RW_Interrupt_Bank)) := '1';                END IF;                -- Interrupt a Read with Auto Precharge                IF Auto_precharge(TO_INTEGER(RW_Interrupt_Bank)) = '1' AND Read_precharge(TO_INTEGER(RW_Interrupt_Bank)) = '1' THEN                    RW_interrupt_read(TO_INTEGER(RW_Interrupt_Bank)) := '1';                END IF;                -- Read or Write with Auto Precharge                IF Addr(10) = '1' THEN                    Auto_precharge (TO_INTEGER(Ba)) := '1';                    Count_precharge (TO_INTEGER(Ba)) := 0;                    RW_Interrupt_Bank := TO_BitVector(Ba);                    IF Read_enable = '1' THEN                        Read_precharge (TO_INTEGER(Ba)) := '1';                    ELSIF Write_enable = '1' THEN                        Write_precharge (TO_INTEGER(Ba)) := '1';                    END IF;                END IF;            END IF;                        -- Read with AutoPrecharge Calculation            --      The device start internal precharge when:            --          1.  BL/2 cycles after command            --      and 2.  Meet tRAS requirement            --       or 3.  Interrupt by a Read or Write (with or without Auto Precharge)            IF ((Auto_precharge(0) = '1') AND (Read_precharge(0) = '1')) THEN                IF (((NOW - RAS_chk0 >= tRAS) AND                    ((Burst_length_1 = '1' AND Count_precharge(0) >= 1)  OR                     (Burst_length_2 = '1' AND Count_precharge(0) >= 2)  OR                     (Burst_length_4 = '1' AND Count_precharge(0) >= 4)  OR                     (Burst_length_8 = '1' AND Count_precharge(0) >= 8))) OR                     (RW_interrupt_read(0) = '1')) THEN                    Pc_b0 := '1';                    Act_b0 := '0';                    RP_chk0 := NOW;                    Auto_precharge(0) := '0';                    Read_precharge(0) := '0';                    RW_interrupt_read(0) := '0';                END IF;            END IF;            IF ((Auto_precharge(1) = '1') AND (Read_precharge(1) = '1')) THEN                IF (((NOW - RAS_chk1 >= tRAS) AND                    ((Burst_length_1 = '1' AND Count_precharge(1) >= 1)  OR                     (Burst_length_2 = '1' AND Count_precharge(1) >= 2)  OR                     (Burst_length_4 = '1' AND Count_precharge(1) >= 4)  OR                     (Burst_length_8 = '1' AND Count_precharge(1) >= 8))) OR                     (RW_interrupt_read(1) = '1')) THEN                    Pc_b1 := '1';                    Act_b1 := '0';                    RP_chk1 := NOW;                    Auto_precharge(1) := '0';                    Read_precharge(1) := '0';                    RW_interrupt_read(1) := '0';                END IF;            END IF;            IF ((Auto_precharge(2) = '1') AND (Read_precharge(2) = '1')) THEN                IF (((NOW - RAS_chk2 >= tRAS) AND                    ((Burst_length_1 = '1' AND Count_precharge(2) >= 1)  OR                     (Burst_length_2 = '1' AND Count_precharge(2) >= 2)  OR                     (Burst_length_4 = '1' AND Count_precharge(2) >= 4)  OR                     (Burst_length_8 = '1' AND Count_precharge(2) >= 8))) OR                     (RW_interrupt_read(2) = '1')) THEN                    Pc_b2 := '1';                    Act_b2 := '0';                    RP_chk2 := NOW;                    Auto_precharge(2) := '0';                    Read_precharge(2) := '0';                    RW_interrupt_read(2) := '0';                END IF;            END IF;            IF ((Auto_precharge(3) = '1') AND (Read_precharge(3) = '1')) THEN                IF (((NOW - RAS_chk3 >= tRAS) AND                    ((Burst_length_1 = '1' AND Count_precharge(3) >= 1)  OR                     (Burst_length_2 = '1' AND Count_precharge(3) >= 2)  OR                     (Burst_length_4 = '1' AND Count_precharge(3) >= 4)  OR                     (Burst_length_8 = '1' AND Count_precharge(3) >= 8))) OR                     (RW_interrupt_read(3) = '1')) THEN                    Pc_b3 := '1';                    Act_b3 := '0';                    RP_chk3 := NOW;                    Auto_precharge(3) := '0';                    Read_precharge(3) := '0';                    RW_interrupt_read(3) := '0';                END IF;            END IF;                        -- Internal Precharge or Bst            IF Command(0) = PRECH THEN                          -- PRECH terminate a read if same bank or all banks                IF Bank_precharge(0) = Bank OR A10_precharge(0) = '1' THEN                    IF Data_out_enable = '1' THEN                        Data_out_enable := '0';                    END IF;                END IF;            ELSIF Command(0) = BST THEN                         -- BST terminate a read regardless of bank                IF Data_out_enable = '1' THEN                    Data_out_enable := '0';                END IF;            END IF;            IF Data_out_enable = '0' THEN                Dq <= TRANSPORT (OTHERS => 'Z') AFTER tOH;            END IF;            -- Detect Read or Write Command            IF Command(0) = READ OR Command(0) = READ_A THEN                Bank := Bank_addr (0);                Col := Col_addr (0);                Col_brst := Col_addr (0);                IF Bank_addr (0) = "00" THEN                    Row := B0_row_addr;                ELSIF Bank_addr (0) = "01" THEN                    Row := B1_row_addr;                ELSIF Bank_addr (0) = "10" THEN                    Row := B2_row_addr;                ELSE                    Row := B3_row_addr;                END IF;                Burst_counter := 0;                Data_in_enable := '0';                Data_out_enable := '1';            ELSIF Command(0) = WRITE OR Command(0) = WRITE_A THEN                Bank := Bank_addr(0);                Col := Col_addr(0);                Col_brst := Col_addr(0);                IF Bank_addr (0) = "00" THEN                    Row := B0_row_addr;                ELSIF Bank_addr (0) = "01" THEN                    Row := B1_row_addr;                ELSIF Bank_addr (0) = "10" THEN                    Row := B2_row_addr;                ELSE                    Row := B3_row_addr;                END IF;                Burst_counter := 0;                Data_in_enable := '1';                Data_out_enable := '0';            END IF;            -- DQ (Driver / Receiver)            Row_index := TO_INTEGER (Row);            Col_index := TO_INTEGER (Col);            IF Data_in_enable = '1' THEN                IF Dqm /= "11" THEN                    Init_mem (Bank, Row_index);                    IF Bank = "00" THEN                        Dq_temp := Bank0 (Row_index) (Col_index);                        IF Dqm = "01" THEN                            Dq_temp (15 DOWNTO 8) := TO_BITVECTOR (Dq (15 DOWNTO 8));                        ELSIF Dqm = "10" THEN                            Dq_temp (7 DOWNTO 0) := TO_BITVECTOR (Dq (7 DOWNTO 0));                        ELSE                            Dq_temp (15 DOWNTO 0) := TO_BITVECTOR (Dq (15 DOWNTO 0));                        END IF;                        Bank0 (Row_index) (Col_index) := ('1' & Dq_temp(data_bits - 1 DOWNTO 0));                    ELSIF Bank = "01" THEN                        Dq_temp := Bank1 (Row_index) (Col_index);                        IF Dqm = "01" THEN                            Dq_temp (15 DOWNTO 8) := TO_BITVECTOR (Dq (15 DOWNTO 8));                        ELSIF Dqm = "10" THEN                            Dq_temp (7 DOWNTO 0) := TO_BITVECTOR (Dq (7 DOWNTO 0));                        ELSE                            Dq_temp (15 DOWNTO 0) := TO_BITVECTOR (Dq (15 DOWNTO 0));                        END IF;                        Bank1 (Row_index) (Col_index) := ('1' & Dq_temp(data_bits - 1 DOWNTO 0));                    ELSIF Bank = "10" THEN                        Dq_temp := Bank2 (Row_index) (Col_index);                        IF Dqm = "01" THEN                            Dq_temp (15 DOWNTO 8) := TO_BITVECTOR (Dq (15 DOWNTO 8));                        ELSIF Dqm = "10" THEN                            Dq_temp (7 DOWNTO 0) := TO_BITVECTOR (Dq (7 DOWNTO 0));                        ELSE                            Dq_temp (15 DOWNTO 0) := TO_BITVECTOR (Dq (15 DOWNTO 0));                        END IF;                        Bank2 (Row_index) (Col_index) := ('1' & Dq_temp(data_bits - 1 DOWNTO 0));                    ELSIF Bank = "11" THEN                        Dq_temp := Bank3 (Row_index) (Col_index);                        IF Dqm = "01" THEN                            Dq_temp (15 DOWNTO 8) := TO_BITVECTOR (Dq (15 DOWNTO 8));                        ELSIF Dqm = "10" THEN                            Dq_temp (7 DOWNTO 0) := TO_BITVECTOR (Dq (7 DOWNTO 0));                        ELSE                            Dq_temp (15 DOWNTO 0) := TO_BITVECTOR (Dq (15 DOWNTO 0));                        END IF;                        Bank3 (Row_index) (Col_index) := ('1' & Dq_temp(data_bits - 1 DOWNTO 0));                    END IF;                    WR_chkp(TO_INTEGER(Bank)) := NOW;                    WR_counter(TO_INTEGER(Bank)) := 0;                END IF;                Burst_decode;            ELSIF Data_out_enable = '1' THEN                IF Dqm_reg0 /= "11" THEN                    Init_mem (Bank, Row_index);                    IF Bank = "00" THEN                        Dq_temp := Bank0 (Row_index) (Col_index);                        IF Dqm_reg0 = "00" THEN                            Dq (15 DOWNTO 0) <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (15 DOWNTO 0)) AFTER tAC;                        ELSIF Dqm_reg0 = "01" THEN                            Dq (15 DOWNTO 8)  <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (15 DOWNTO 8)) AFTER tAC;                            Dq (7 DOWNTO 0)  <= TRANSPORT (OTHERS => 'Z') AFTER tAC;                        ELSIF Dqm_reg0 = "10" THEN                            Dq (15 DOWNTO 8)  <= TRANSPORT (OTHERS => 'Z') AFTER tAC;                            Dq (7 DOWNTO 0) <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (7 DOWNTO 0)) AFTER tAC;                        END IF;                    ELSIF Bank = "01" THEN                        Dq_temp := Bank1 (Row_index) (Col_index);                        IF Dqm_reg0 = "00" THEN                            Dq (15 DOWNTO 0) <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (15 DOWNTO 0)) AFTER tAC;                        ELSIF Dqm_reg0 = "01" THEN                            Dq (15 DOWNTO 8)  <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (15 DOWNTO 8)) AFTER tAC;                            Dq (7 DOWNTO 0)  <= TRANSPORT (OTHERS => 'Z') AFTER tAC;                        ELSIF Dqm_reg0 = "10" THEN                            Dq (15 DOWNTO 8)  <= TRANSPORT (OTHERS => 'Z') AFTER tAC;                            Dq (7 DOWNTO 0) <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (7 DOWNTO 0)) AFTER tAC;                        END IF;                    ELSIF Bank = "10" THEN                        Dq_temp := Bank2 (Row_index) (Col_index);                        IF Dqm_reg0 = "00" THEN                            Dq (15 DOWNTO 0) <= TRANSPORT TO_STDLOGICVECTOR (Dq_temp (15 DOWNTO 0)) AFTER tAC;                        ELSIF Dqm_reg0 = "01" THEN

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -