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

📄 idt71v546.vhd

📁 vhdl cod for ram.For sp3e
💻 VHD
📖 第 1 页 / 共 5 页
字号:
                    TimingData      => TD_DatDIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_DatDIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => DatCIn,                    TestSignalName  => "DatC",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_DQA0_CLK,                    SetupLow        => tsetup_DQA0_CLK,                    HoldHigh        => thold_DQA0_CLK,                    HoldLow         => thold_DQA0_CLK,                    CheckEnabled    => (CKENIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_DatCIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_DatCIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => DatBIn,                    TestSignalName  => "DatB",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_DQA0_CLK,                    SetupLow        => tsetup_DQA0_CLK,                    HoldHigh        => thold_DQA0_CLK,                    HoldLow         => thold_DQA0_CLK,                    CheckEnabled    => (CKENIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_DatBIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_DatBIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => DatAIn,                    TestSignalName  => "DatA",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_DQA0_CLK,                    SetupLow        => tsetup_DQA0_CLK,                    HoldHigh        => thold_DQA0_CLK,                    HoldLow         => thold_DQA0_CLK,                    CheckEnabled    => (CKENIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_DatAIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_DatAIn_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    =>  (CKENIn ='0') );                Violation := Pviol_CLK OR Tviol_DatAIn_CLK OR Tviol_DatBIn_CLK                             OR Tviol_DatCIn_CLK OR Tviol_DatDIn_CLK OR                             Tviol_AddressIn_CLK OR Tviol_RIn_CLK OR                              Tviol_CE2In_CLK OR Tviol_CE2NegIn_CLK OR                             Tviol_CE1NegIn_CLK OR Tviol_ADVIn_CLK OR                             Tviol_CKENIn_CLK OR Tviol_BWAN_CLK OR                             Tviol_BWBN_CLK OR Tviol_BWCN_CLK OR                             Tviol_BWDN_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) AND CKENIn = '0') THEN        ASSERT (not(Is_X(BWDNIn)))            REPORT InstancePath & partID & ": Unusable value for BWDN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWCNIn)))            REPORT InstancePath & partID & ": Unusable value for BWCN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWBNIn)))            REPORT InstancePath & partID & ": Unusable value for BWBN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWANIn)))            REPORT InstancePath & partID & ": Unusable value for BWAN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(RIn)))            REPORT InstancePath & partID & ": Unusable value for R"            SEVERITY SeverityMode;        ASSERT (not(Is_X(ADVIn)))            REPORT InstancePath & partID & ": Unusable value for ADV"            SEVERITY SeverityMode;        ASSERT (not(Is_X(CE2In)))            REPORT InstancePath & partID & ": Unusable value for CE2"            SEVERITY SeverityMode;        ASSERT (not(Is_X(CE1NegIn)))            REPORT InstancePath & partID & ": Unusable value for CE1Neg"            SEVERITY SeverityMode;        ASSERT (not(Is_X(CE2NegIn)))            REPORT InstancePath & partID & ": Unusable value for CE2Neg"            SEVERITY SeverityMode;        -- Command Decode        IF ((ADVIn = '0') AND (CE1NegIn = '1' OR CE2NegIn = '1' OR                CE2In = '0')) THEN            command := ds;        ELSIF (CE1NegIn = '0' AND CE2NegIn = '0' AND CE2In = '1' AND                ADVIn = '0') THEN            IF (RIn = '1') THEN                command := read;            ELSE                command := write;            END IF;        ELSIF (ADVIn = '1') AND (CE1NegIn = '0' AND CE2NegIn = '0' AND                  CE2In = '1') THEN            command := burst;        ELSE            ASSERT false                REPORT InstancePath & partID & ": Could not decode "                       & "command."                SEVERITY SeverityMode;        END IF;        wr3 := wr2;        wr2 := wr1;        wr1 := false;        IF (wr3) THEN            IF (BWA2 = '0') THEN                IF Violation = 'X' THEN                    MemDataA(MemAddr1) := -1;                ELSE                    MemDataA(MemAddr1) := to_nat(DatAIn);                END IF;            END IF;            IF (BWB2 = '0') THEN                IF Violation = 'X' THEN                    MemDataB(MemAddr1) := -1;                ELSE                    MemDataB(MemAddr1) := to_nat(DatBIn);                END IF;            END IF;            IF (BWC2 = '0') THEN                IF Violation = 'X' THEN                    MemDataC(MemAddr1) := -1;                ELSE                    MemDataC(MemAddr1) := to_nat(DatCIn);                END IF;            END IF;            IF (BWD2 = '0') THEN                IF Violation = 'X' THEN                    MemDataD(MemAddr1) := -1;                ELSE                    MemDataD(MemAddr1) := to_nat(DatDIn);                END IF;            END IF;        END IF;        MemAddr1 := MemAddr;        OBuf2 := OBuf1;        -- The State Machine        CASE state IS            WHEN desel =>                CASE command IS                    WHEN ds =>                        OBuf1 := (others => 'Z');                    WHEN read =>                        state <= begin_rd;                        MemAddr := to_nat(AddressIn);                        startaddr := MemAddr;                        memstart := to_nat(AddressIn(1 downto 0));                        IF MemDataA(MemAddr) = -2 THEN                            OBuf1(8 downto 0) := (others => 'U');                        ELSIF MemDataA(MemAddr) = -1 THEN                            OBuf1(8 downto 0) := (others => 'X');                        ELSE                            OBuf1(8 downto 0) := to_slv(MemDataA(MemAddr),9);                        END IF;                        IF MemDataB(MemAddr) = -2 THEN                            OBuf1(17 downto 9) := (others => 'U');                        ELSIF MemDataB(MemAddr) = -1 THEN                            OBuf1(17 downto 9) := (others => 'X');                        ELSE                            OBuf1(17 downto 9) := to_slv(MemDataB(MemAddr),9);                        END IF;                        IF MemDataC(MemAddr) = -2 THEN                            OBuf1(26 downto 18) := (others => 'U');                        ELSIF MemDataC(MemAddr) = -1 THEN                            OBuf1(26 downto 18) := (others => 'X');                        ELSE                            OBuf1(26 downto 18) := to_slv(MemDataC(MemAddr),9);                        END IF;                        IF MemDataD(MemAddr) = -2 THEN                            OBuf1(35 downto 27) := (others => 'U');                        ELSIF MemDataD(MemAddr) = -1 THEN                            OBuf1(35 downto 27) := (others => 'X');                        ELSE                            OBuf1(35 downto 27) := to_slv(MemDataD(MemAddr),9);                        END IF;                    WHEN write =>                        state <= begin_wr;                        MemAddr := to_nat(AddressIn);                        startaddr := MemAddr;                        memstart := to_nat(AddressIn(1 downto 0));                        OBuf1 := (others => 'Z');                        BWA1 := BWANIn;                        BWB1 := BWBNIn;                        BWC1 := BWCNIn;                        BWD1 := BWDNIn;                        wr1  := true;                    WHEN burst =>                        OBuf1 := (others => 'Z');                 END CASE;            WHEN begin_rd =>                Burst_Cnt := 0;                CASE command IS                    WHEN ds =>                        state <= desel;                        OBuf1 := (others => 'Z');                    WHEN read =>                        state <= begin_rd;                        MemAddr := to_nat(AddressIn);                        startaddr := MemAddr;                        memstart := to_nat(AddressIn(1 downto 0));                        IF MemDataA(MemAddr) = -2 THEN                            OBuf1(8 downto 0) := (others => 'U');                        ELSIF MemDataA(MemAddr) = -1 THEN                            OBuf1(8 downto 0) := (others => 'X');                        ELSE                            OBuf1(8 downto 0) := to_slv(MemDataA(MemAddr),9);                        END IF;                        IF MemDataB(MemAddr) = -2 THEN                            OBuf1(17 downto 9) := (others => 'U');                        ELSIF MemDataB(MemAddr) = -1 THEN                            OBuf1(17 downto 9) := (others => 'X');                        ELSE                            OBuf1(17 downto 9) := to_slv(MemDataB(MemAddr),9);                        END IF;                        IF MemDataC(MemAddr) = -2 THEN                            OBuf1(26 downto 18) := (others => 'U');                        ELSIF MemDataC(MemAddr) = -1 THEN                            OBuf1(26 downto 18) := (others => 'X');                        ELSE                            OBuf1(26 downto 18) := to_slv(MemDataC(MemAddr),9);                        END IF;                        IF MemDataD(MemAddr) = -2 THEN                            OBuf1(35 downto 27) := (others => 'U');                        ELSIF MemDataD(MemAddr) = -1 THEN                            OBuf1(35 downto 27) := (others => 'X');                        ELSE                            OBuf1(35 downto 27) := to_slv(MemDataD(MemAddr),9);                        END IF;                    WHEN write =>                        state <= begin_wr;                        MemAddr := to_nat(AddressIn);                        startaddr := MemAddr;                        memstart := to_nat(AddressIn(1 downto 0));                        OBuf1 := (others => 'Z');                        BWA1 := BWANIn;                        BWB1 := BWBNIn;                        BWC1 := BWCNIn;                        BWD1 := BWDNIn;                        wr1  := true;                    WHEN burst =>

⌨️ 快捷键说明

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