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

📄 cy7c1380.vhd

📁 vhdl cod for ram.For sp3e
💻 VHD
📖 第 1 页 / 共 5 页
字号:
                    TestSignalName  => "BWC",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_BWANeg_CLK,                    SetupLow        => tsetup_BWANeg_CLK,                    HoldHigh        => thold_BWANeg_CLK,                    HoldLow         => thold_BWANeg_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_BWCN_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_BWCN_CLK );                VitalSetupHoldCheck (                    TestSignal      => BWBNIn,                    TestSignalName  => "BWB",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_BWANeg_CLK,                    SetupLow        => tsetup_BWANeg_CLK,                    HoldHigh        => thold_BWANeg_CLK,                    HoldLow         => thold_BWANeg_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_BWBN_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_BWBN_CLK );                VitalSetupHoldCheck (                    TestSignal      => BWANIn,                    TestSignalName  => "BWA",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_BWANeg_CLK,                    SetupLow        => tsetup_BWANeg_CLK,                    HoldHigh        => thold_BWANeg_CLK,                    HoldLow         => thold_BWANeg_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_BWAN_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_BWAN_CLK );                VitalSetupHoldCheck (                    TestSignal      => ADVNIn,                    TestSignalName  => "ADV",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_ADVNeg_CLK,                    SetupLow        => tsetup_ADVNeg_CLK,                    HoldHigh        => thold_ADVNeg_CLK,                    HoldLow         => thold_ADVNeg_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_ADVNIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_ADVNIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => ADSPNIn,                    TestSignalName  => "ADSP",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_ADSCNeg_CLK,                    SetupLow        => tsetup_ADSCNeg_CLK,                    HoldHigh        => thold_ADSCNeg_CLK,                    HoldLow         => thold_ADSCNeg_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_ADSPNIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_ADSPNIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => ADSPNIn,                    TestSignalName  => "ADSP",                    RefSignal       => ZZIn,                    RefSignalName   => "ZZ",                    HoldHigh        => thold_ADSCNeg_ZZ,                    CheckEnabled    => true,                    RefTransition   => '\',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_ADSPNIn_ZZ,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_ADSPNIn_ZZ );                VitalSetupHoldCheck (                    TestSignal      => ADSCNIn,                    TestSignalName  => "ADSC",                    RefSignal       => ZZIn,                    RefSignalName   => "ZZ",                    HoldHigh        => thold_ADSCNeg_ZZ,                    CheckEnabled    => true,                    RefTransition   => '\',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_ADSCNIn_ZZ,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_ADSCNIn_ZZ );                VitalSetupHoldCheck (                    TestSignal      => ADSCNIn,                    TestSignalName  => "ADSC",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_ADSCNeg_CLK,                    SetupLow        => tsetup_ADSCNeg_CLK,                    HoldHigh        => thold_ADSCNeg_CLK,                    HoldLow         => thold_ADSCNeg_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_ADSCNIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_ADSCNIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => CE1NegIn,                    TestSignalName  => "CE1Neg",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_CE2_CLK,                    SetupLow        => tsetup_CE2_CLK,                    HoldHigh        => thold_CE2_CLK,                    HoldLow         => thold_CE2_CLK,                    CheckEnabled    => (zzIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CE1NegIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CE1NegIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => CE1NegIn,                    TestSignalName  => "CE1Neg",                    RefSignal       => ZZIn,                    RefSignalName   => "ZZ",                    HoldHigh        => thold_ADSCNeg_ZZ,                    CheckEnabled    => true,                    RefTransition   => '\',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CE1NegIn_ZZ,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CE1NegIn_ZZ );                VitalSetupHoldCheck (                    TestSignal      => CE3NegIn,                    TestSignalName  => "CE3Neg",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_CE2_CLK,                    SetupLow        => tsetup_CE2_CLK,                    HoldHigh        => thold_CE2_CLK,                    HoldLow         => thold_CE2_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CE3NegIn_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CE3NegIn_CLK );                VitalSetupHoldCheck (                    TestSignal      => CE3NegIn,                    TestSignalName  => "CE3Neg",                    RefSignal       => ZZIn,                    RefSignalName   => "ZZ",                    HoldHigh        => thold_ADSCNeg_ZZ,                    CheckEnabled    => true,                    RefTransition   => '\',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CE3NegIn_ZZ,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CE3NegIn_ZZ );                VitalSetupHoldCheck (                    TestSignal      => CE2In,                    TestSignalName  => "CE2",                    RefSignal       => CLKIn,                    RefSignalName   => "CLK",                    SetupHigh       => tsetup_CE2_CLK,                    SetupLow        => tsetup_CE2_CLK,                    HoldHigh        => thold_CE2_CLK,                    HoldLow         => thold_CE2_CLK,                    CheckEnabled    => (ZZIn ='0'),                    RefTransition   => '/',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CE2In_CLK,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CE2In_CLK );                VitalSetupHoldCheck (                    TestSignal      => CE2In,                    TestSignalName  => "CE2",                    RefSignal       => ZZIn,                    RefSignalName   => "ZZ",                    HoldLow         => thold_ADSCNeg_ZZ,                    CheckEnabled    => true,                    RefTransition   => '\',                    HeaderMsg       => InstancePath & PartID,                    TimingData      => TD_CE2In_ZZ,                    XOn             => XOn,                    MsgOn           => MsgOn,                    Violation       => Tviol_CE2In_ZZ );                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    =>  (ZZIn ='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_ADSCNIn_CLK OR                             Tviol_CE2In_CLK OR Tviol_CE3NegIn_CLK OR                             Tviol_CE1NegIn_CLK OR Tviol_ADVNIn_CLK OR                             Tviol_ADSPNIn_CLK OR Tviol_BWAN_CLK OR                             Tviol_BWBN_CLK OR Tviol_BWCN_CLK OR                             Tviol_BWDN_CLK OR Tviol_BWEN_CLK OR                             Tviol_GWN_CLK OR Tviol_ADSCNIn_ZZ OR                             Tviol_ADSPNIn_ZZ OR Tviol_CE1NegIn_ZZ                             OR Tviol_CE2In_ZZ OR Tviol_CE3NegIn_ZZ;                ASSERT Violation = '0'                    REPORT InstancePath & partID & ": simulation may be" &                           " inaccurate due to timing violations"                    SEVERITY SeverityMode;            END IF;    ----------------------------------------------------------------------------    -- Functional Section    ----------------------------------------------------------------------------    IF rising_edge(CLKIn) AND ZZIn = '0' THEN        ASSERT (not(Is_X(BWANIn)))            REPORT InstancePath & partID & ": Unusable value for BWAN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWBNIn)))            REPORT InstancePath & partID & ": Unusable value for BWBN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWCNIn)))            REPORT InstancePath & partID & ": Unusable value for BWCN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWDNIn)))            REPORT InstancePath & partID & ": Unusable value for BWDN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(GWNIn)))            REPORT InstancePath & partID & ": Unusable value for GWN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(BWENIn)))            REPORT InstancePath & partID & ": Unusable value for BWEN"            SEVERITY SeverityMode;        ASSERT (not(Is_X(ADVNIn)))            REPORT InstancePath & partID & ": Unusable value for ADVN"

⌨️ 快捷键说明

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