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

📄 mt46v32m8.vhd

📁 vhdl cod for ram.For sp3e
💻 VHD
📖 第 1 页 / 共 5 页
字号:
                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_Address_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_Address_CLK );                VitalSetupHoldCheck (                    TestSignal      => WENegIn,                    TestSignalName  => "WENeg",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_A0_CLK,                    SetupLow        => tsetup_A0_CLK,                    HoldHigh        => thold_A0_CLK,                    HoldLow         => thold_A0_CLK,                    CheckEnabled    => chip_en,                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_WENeg_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_WENeg_CLK );                VitalSetupHoldCheck (                    TestSignal      => RASNegIn,                    TestSignalName  => "RASNeg",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_A0_CLK,                    SetupLow        => tsetup_A0_CLK,                    HoldHigh        => thold_A0_CLK,                    HoldLow         => thold_A0_CLK,                    CheckEnabled    => chip_en,                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_RASNeg_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_RASNeg_CLK );                VitalSetupHoldCheck (                    TestSignal      => CSNegIn,                    TestSignalName  => "CSNeg",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_A0_CLK,                    SetupLow        => tsetup_A0_CLK,                    HoldHigh        => thold_A0_CLK,                    HoldLow         => thold_A0_CLK,                    CheckEnabled    => chip_en,                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CSNeg_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CSNeg_CLK );                VitalSetupHoldCheck (                    TestSignal      => CASNegIn,                    TestSignalName  => "CASNeg",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_A0_CLK,                    SetupLow        => tsetup_A0_CLK,                    HoldHigh        => thold_A0_CLK,                    HoldLow         => thold_A0_CLK,                    CheckEnabled    => chip_en,                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CASNeg_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CASNeg_CLK );                VitalPeriodPulseCheck (                    TestSignal      =>  CLKIn,                    TestSignalName  =>  "CLK",                    Period          =>  tperiod_CLK_posedge,                    PulseWidthLow   =>  tpw_CLK_negedge,                    PulseWidthHigh  =>  tpw_CLK_posedge,                    PeriodData      =>  PD_CLK,                    XOn             =>  XOn,                    MsgOn           =>  MsgOn,                    Violation       =>  Pviol_CLK,                    HeaderMsg       =>  InstancePath & PartID,                    CheckEnabled    =>  TRUE );                VitalPeriodPulseCheck (                    TestSignal      =>  DQSIn,                    TestSignalName  =>  "DQSIn",                    PulseWidthLow   =>  tpw_DQS_posedge,                    PulseWidthHigh  =>  tpw_DQS_posedge,                    PeriodData      =>  PD_DQS,                    XOn             =>  XOn,                    MsgOn           =>  MsgOn,                    Violation       =>  Pviol_DQS,                    HeaderMsg       =>  InstancePath & PartID,                    CheckEnabled    =>  TRUE );                Violation := Pviol_DQS OR                             Pviol_CLK OR                             Tviol_BA_CLK OR                             Tviol_DM_DQS OR                             Tviol_DQS_CLK OR                             Tviol_D0_DQS OR                             Tviol_CKE_CLK OR                             Tviol_Address_CLK OR                             Tviol_WENeg_CLK OR                             Tviol_RASNeg_CLK OR                             Tviol_CSNeg_CLK OR                             Tviol_CASNeg_CLK;                ASSERT Violation = '0'                    REPORT InstancePath & partID & ": simulation may be" &                           " inaccurate due to timing violations"                    SEVERITY SeverityMode;            END IF; -- Timing Check Section    --------------------------------------------------------------------    -- Functional Section    --------------------------------------------------------------------    IF (rising_edge(CLKIn)) THEN        CKEreg <= CKE_nwv;        IF (NOW > Next_Ref AND PoweredUp AND Ref_Cnt > 0) THEN            Ref_Cnt := Ref_Cnt - 1;            Next_Ref := NOW + tdevice_REF;        END IF;        IF CKEreg = '1' THEN            IF CSNegIn = '0' THEN                chip_en := true;            ELSE                chip_en := false;            END IF;        END IF;    END IF;    IF  (rising_edge(DQSin) OR falling_edge(DQSIn)) AND            (DM_nwv = '0') AND   NOT(DQSin=DQS_zd) THEN        InputReg := to_nat(DataIn);        DQS_event_reg := TRUE;    END IF;    IF (rising_edge(CLKIn) AND CKEreg = '1' AND to_X01(CSNegIn) = '1') THEN        command := nop;    ELSIF (rising_edge(CLKIn) AND CKEreg = '1' AND to_X01(CSNegIn) = '0') THEN        ASSERT (not(Is_X(WENegIn)))            REPORT InstancePath & partID & ": Unusable value for WENeg"            SEVERITY SeverityMode;        ASSERT (not(Is_X(RASNegIn)))            REPORT InstancePath & partID & ": Unusable value for RASNeg"            SEVERITY SeverityMode;        ASSERT (not(Is_X(CASNegIn)))            REPORT InstancePath & partID & ": Unusable value for CASNeg"            SEVERITY SeverityMode;        -- Command Decode        IF ((RASNegIn = '1') AND (CASNegIn = '1') AND (WENegIn = '1')) THEN            command := nop;        ELSIF ((RASNegIn = '0') AND (CASNegIn = '1') AND (WENegIn = '1')) THEN            command := act;        ELSIF ((RASNegIn = '1') AND (CASNegIn = '0') AND (WENegIn = '1')) THEN            command := read;        ELSIF ((RASNegIn = '1') AND (CASNegIn = '0') AND (WENegIn = '0')) THEN            command := writ;        ELSIF ((RASNegIn = '1') AND (CASNegIn = '1') AND (WENegIn = '0')) THEN            command := bst;        ELSIF ((RASNegIn = '0') AND (CASNegIn = '1') AND (WENegIn = '0')) THEN            command := pre;        ELSIF ((RASNegIn = '0') AND (CASNegIn = '0') AND (WENegIn = '1')) THEN            command := ref;        ELSIF ((RASNegIn = '0') AND (CASNegIn = '0') AND (WENegIn = '0')) THEN            command := mrs;        END IF;        -- PowerUp Check        IF (NOT(PoweredUp) AND command /= nop) THEN            ASSERT false                REPORT InstancePath & partID & ": Incorrect power up. Command"                      & " issued before power up complete."                SEVERITY SeverityMode;        END IF;        -- Bank Decode        CASE BAIn IS            WHEN "00" => cur_bank := 0; BankString := " Bank-0 ";            WHEN "01" => cur_bank := 1; BankString := " Bank-1 ";            WHEN "10" => cur_bank := 2; BankString := " Bank-2 ";            WHEN "11" => cur_bank := 3; BankString := " Bank-3 ";            WHEN others =>                ASSERT false                    REPORT InstancePath & partID & ": Could not decode bank"                           & " selection - results may be incorrect."                    SEVERITY SeverityMode;        END CASE;    END IF;    IF (rising_edge(CLKIn) AND CKEreg = '1') THEN        ASSERT (not(Is_X(CSNegIn)))            REPORT InstancePath & partID & ": Unusable value for CSNeg"            SEVERITY SeverityMode;        IF (CSNegIn = '1') THEN            command := nop;        END IF;        -- DM pipeline        DM_reg2 := DM_reg1;        DM_reg1 := DM_reg0;        DM_reg0 := DMIn;        -- by default data drive is Z, might get over written in one        -- of the passes below        DataDrive := (OTHERS => 'Z');        DQSDrive:='Z';    END IF;    -- The Big State Machine    IF (rising_edge(CLKIn) AND CKEreg = '1') THEN        banks : FOR bank IN 0 TO hi_bank LOOP        CASE statebank(bank) IS            WHEN pwron =>                IF (PoweredUp = false) THEN                    ASSERT (command = nop)                        REPORT InstancePath & partID & BankString                               &": Only NOPs allowed"                               & " during power up."                        SEVERITY SeverityMode;                    DataDrive := (OTHERS => 'Z');                ELSIF (command = pre) AND ((cur_bank = bank) OR                              (AddressIn(10) = '1')) THEN                    statebank(bank) <= precharge, idle AFTER tdevice_TRP;                END IF;            WHEN precharge =>                IF cur_bank = bank THEN                    -- It is only an error if this bank is selected                    ASSERT (command = nop OR command = pre)                        REPORT InstancePath & partID & BankString                               &": Illegal command received"                               & " during precharge."                        SEVERITY SeverityMode;                END IF;            WHEN idle =>                IF (command = nop OR command = bst OR command = pre) OR                                 (cur_bank /= bank) THEN                    null;                ELSIF (command = mrs) THEN                    IF (statebank = idle & idle & idle & idle) THEN                        IF BAIn = "01" THEN                            mode_set_ind:= extended;                            ExtModeReg := AddressIn;                        ELSE                            mode_set_ind:= standard;                            ModeReg := AddressIn;                        END IF;                        statebank <= mode_set & mode_set & mode_set & mode_set;                    END IF;                ELSIF (command = ref) THEN                    IF (statebank = idle & idle & idle & idle) THEN                        IF (CKEIn = '1') THEN                            statebank(bank) <= auto_refresh, idle                                 AFTER tdevice_TRFC;                        ELSE                            statebank(bank) <= self_refresh;                        END IF;                    END IF;                ELSIF (command = act) THEN                    statebank(bank) <= bank_act;                    ras_in(bank)  <= '1', '0' AFTER 70 ns;                    rct_in  <= '1', '0' AFTER 10 ps;                    rcdt_in(bank) <= '1', '0' AFTER 10 ps;                    MemAddr(bank)(HiAddrBit+HiColBit+1 downto HiColBit +1) :=                                                     AddressIn; -- latch row addr                ELSE                    ASSERT false                        REPORT InstancePath & partID & ": Illegal command"                               & " received in idle state."                        SEVERITY SeverityMode;                END IF;            WHEN mode_set =>                statebank <= idle & idle & idle & idle;               IF mode_set_ind=standard THEN                   ASSERT (ModeReg(7) = '0')                       REPORT InstancePath & partID & BankString                              &": Illegal operating mode set."                       SEVERITY SeverityMode;                   ASSERT command = nop                       REPORT InstancePath & partID & BankString                              & ": Illegal command received during mode_set."                       SEVERITY SeverityMode;

⌨️ 快捷键说明

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