亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mt48lc8m16a2.vhd

?? 基于VHDL編寫的SDR-SDRAM控制器的編程
?? VHD
?? 第 1 頁 / 共 5 頁
字號:
-----------------------------------------------------------------------------------------
--
--     File Name: MT48LC8M16A2.VHD
--       Version: 0.0c
--          Date: April 8th, 1999
--         Model: Behavioral
--     Simulator: Model Technology VLOG (PC version 4.7i)
--
--  Dependencies: None
--
--        Author: Son P. Huynh
--         Email: sphuynh@micron.com
--         Phone: (208) 368-3825
--       Company: Micron Technology, Inc.
--   Part Number: MT48LC8M16A2 (2Mb x 16 x 4 Banks)
--
--   Description: Micron 64Mb SDRAM
--
--    Limitation: - Doesn't check for 4096-cycle refresh
--
--          Note: - Set simulator resolution to "ps" accuracy
--
--    Disclaimer: THESE DESIGNS ARE PROVIDED "AS IS" WITH NO WARRANTY 
--                WHATSOEVER AND MICRON SPECIFICALLY DISCLAIMS ANY 
--                IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR
--                A PARTICULAR PURPOSE, OR AGAINST INFRINGEMENT.
--
--                Copyright (c) 1998 Micron Semiconductor Products, Inc.
--                All rights researved
--
--  Rev   Author          Phone         Date        Changes
--  ----  ----------------------------  ----------  -------------------------------------
--  0.0c  Son P. Huynh    208-368-3825  04/08/1999  Fix tWR + tRP in Write with AP
--        Micron Technology Inc.                    Fix tRC check in Load Mode Register
--
--  0.0b  Son P. Huynh    208-368-3825  01/06/1998  Derive from 64Mb SDRAM model
--        Micron Technology Inc.
--
-----------------------------------------------------------------------------------------

LIBRARY IEEE;
USE IEEE.std_logic_1164.ALL;
USE WORK.mti_pkg.ALL;

ENTITY mt48lc8m16a2 IS
    GENERIC (
        tAC       : TIME    :=  5.0 ns;     -- Timing parameter for -8E device
        tAH       : TIME    :=  1.0 ns;
        tAS       : TIME    :=  2.0 ns;
        tCH       : TIME    :=  3.0 ns;
        tCL       : TIME    :=  3.0 ns;
        tCK       : TIME    :=  7.5 ns;          -- 133mhz operation
--        tCK       : TIME    :=  10.0 ns;          -- 100mhz operation
        tDH       : TIME    :=  1.0 ns;
        tDS       : TIME    :=  2.0 ns;
        tCKH      : TIME    :=  1.0 ns;
        tCKS      : TIME    :=  2.0 ns;
        tCMH      : TIME    :=  1.0 ns;
        tCMS      : TIME    :=  2.0 ns;
        tHZ       : TIME    :=  6.0 ns;
        tOH       : TIME    :=  3.0 ns;
        tMRD      : INTEGER :=  2;
        tRAS      : TIME    := 50.0 ns;
        tRC       : TIME    := 70.0 ns;
        tRCD      : TIME    := 20.0 ns;
        tRP       : TIME    := 20.0 ns;
        tRRD      : TIME    := 20.0 ns;
        tWR       : INTEGER :=  2;
        addr_bits : INTEGER := 12;
        data_bits : INTEGER := 16;
        col_bits  : INTEGER :=  9
    );
    PORT (
        Dq    : INOUT STD_LOGIC_VECTOR (data_bits - 1 DOWNTO 0) := (OTHERS => 'Z');
        Addr  : IN    STD_LOGIC_VECTOR (addr_bits - 1 DOWNTO 0) := (OTHERS => '0');
        Ba    : IN    STD_LOGIC_VECTOR := "00";
        Clk   : IN    STD_LOGIC := '0';
        Cke   : IN    STD_LOGIC := '0';
        Cs_n  : IN    STD_LOGIC := '1';
        Ras_n : IN    STD_LOGIC := '0';
        Cas_n : IN    STD_LOGIC := '0';
        We_n  : IN    STD_LOGIC := '0';
        Dqm   : IN    STD_LOGIC_VECTOR (1 DOWNTO 0) := "00"
    );
END mt48lc8m16a2;

ARCHITECTURE behave OF mt48lc8m16a2 IS
    TYPE   State       IS (ACT, A_REF, BST, LMR, NOP, PRECH, READ, READ_A, WRITE, WRITE_A);
    TYPE   Array4xI    IS ARRAY (3 DOWNTO 0) OF INTEGER;
    TYPE   Array4xB    IS ARRAY (3 DOWNTO 0) OF BIT;
    TYPE   Array4x2BV  IS ARRAY (3 DOWNTO 0) OF BIT_VECTOR (1 DOWNTO 0);
    TYPE   Array4xCBV  IS ARRAY (4 DOWNTO 0) OF BIT_VECTOR (Col_bits - 1 DOWNTO 0);
    TYPE   Array_state IS ARRAY (4 DOWNTO 0) OF State;
    SIGNAL Operation : State := NOP;
    SIGNAL Mode_reg : BIT_VECTOR (addr_bits - 1 DOWNTO 0) := (OTHERS => '0');
    SIGNAL Active_enable, Aref_enable, Burst_term : BIT := '0';
    SIGNAL Mode_reg_enable, Prech_enable, Read_enable, Write_enable : BIT := '0';
    SIGNAL Burst_length_1, Burst_length_2, Burst_length_4, Burst_length_8 : BIT := '0';
    SIGNAL Cas_latency_2, Cas_latency_3 : BIT := '0';
    SIGNAL Ras_in, Cas_in, We_in : BIT := '0';
    SIGNAL Write_burst_mode : BIT := '0';
    SIGNAL Sys_clk, CkeZ : BIT := '0';

    -- Checking internal wires
    SIGNAL Pre_chk : BIT_VECTOR (3 DOWNTO 0) := "0000";
    SIGNAL Act_chk : BIT_VECTOR (3 DOWNTO 0) := "0000";
    SIGNAL Dq_in_chk, Dq_out_chk : BIT := '0';
    SIGNAL Bank_chk : BIT_VECTOR (1 DOWNTO 0) := "00";
    SIGNAL Row_chk : BIT_VECTOR (addr_bits - 1 DOWNTO 0) := (OTHERS => '0');
    SIGNAL Col_chk : BIT_VECTOR (col_bits - 1 DOWNTO 0) := (OTHERS => '0');

    BEGIN
        -- CS# Decode
        WITH Cs_n SELECT
            Cas_in <= TO_BIT (Cas_n, '1') WHEN '0',
                      '1' WHEN '1',
                      '1' WHEN OTHERS;
        WITH Cs_n SELECT
            Ras_in <= TO_BIT (Ras_n, '1') WHEN '0',
                      '1' WHEN '1',
                      '1' WHEN OTHERS;
        WITH Cs_n SELECT
            We_in  <= TO_BIT (We_n,  '1') WHEN '0',
                      '1' WHEN '1',
                      '1' WHEN OTHERS;
        
        -- Commands Decode
        Active_enable   <= NOT(Ras_in) AND     Cas_in  AND     We_in;
        Aref_enable     <= NOT(Ras_in) AND NOT(Cas_in) AND     We_in;
        Burst_term      <=     Ras_in  AND     Cas_in  AND NOT(We_in);
        Mode_reg_enable <= NOT(Ras_in) AND NOT(Cas_in) AND NOT(We_in);
        Prech_enable    <= NOT(Ras_in) AND     Cas_in  AND NOT(We_in);
        Read_enable     <=     Ras_in  AND NOT(Cas_in) AND     We_in;
        Write_enable    <=     Ras_in  AND NOT(Cas_in) AND NOT(We_in);

        -- Burst Length Decode
        Burst_length_1  <= NOT(Mode_reg(2)) AND NOT(Mode_reg(1)) AND NOT(Mode_reg(0));
        Burst_length_2  <= NOT(Mode_reg(2)) AND NOT(Mode_reg(1)) AND     Mode_reg(0);
        Burst_length_4  <= NOT(Mode_reg(2)) AND     Mode_reg(1)  AND NOT(Mode_reg(0));
        Burst_length_8  <= NOT(Mode_reg(2)) AND     Mode_reg(1)  AND     Mode_reg(0);

        -- CAS Latency Decode
        Cas_latency_2   <= NOT(Mode_reg(6)) AND     Mode_reg(5)  AND NOT(Mode_reg(4));
        Cas_latency_3   <= NOT(Mode_reg(6)) AND     Mode_reg(5)  AND     Mode_reg(4);

        -- Write Burst Mode
        Write_burst_mode <= Mode_reg(9);

        -- System Clock
        int_clk : PROCESS (Clk)
            begin
                IF Clk'LAST_VALUE = '0' AND Clk = '1' THEN
                    CkeZ <= TO_BIT(Cke, '1');
                END IF;
                Sys_clk <= CkeZ AND TO_BIT(Clk, '0');
        END PROCESS;

        state_register : PROCESS
            TYPE ram_type IS ARRAY (2**col_bits - 1 DOWNTO 0) OF BIT_VECTOR (data_bits - 1 DOWNTO 0);
            TYPE ram_pntr IS ACCESS ram_type;
            TYPE ram_stor IS ARRAY (2**addr_bits - 1 DOWNTO 0) OF ram_pntr;
            VARIABLE Bank0 : ram_stor;
            VARIABLE Bank1 : ram_stor;
            VARIABLE Bank2 : ram_stor;
            VARIABLE Bank3 : ram_stor;
            VARIABLE Row_index, Col_index : INTEGER := 0;
            VARIABLE Dq_temp : BIT_VECTOR (data_bits - 1 DOWNTO 0) := (OTHERS => '0');

            VARIABLE Col_addr : Array4xCBV;
            VARIABLE Bank_addr : Array4x2BV;
            VARIABLE Dqm_reg0, Dqm_reg1 : BIT_VECTOR (1 DOWNTO 0) := "00";

            VARIABLE Bank, Previous_bank : BIT_VECTOR (1 DOWNTO 0) := "00";
            VARIABLE B0_row_addr, B1_row_addr, B2_row_addr, B3_row_addr : BIT_VECTOR (addr_bits - 1 DOWNTO 0) := (OTHERS => '0');
            VARIABLE Col_brst : BIT_VECTOR (col_bits - 1 DOWNTO 0) := (OTHERS => '0');
            VARIABLE Row : BIT_VECTOR (addr_bits - 1 DOWNTO 0) := (OTHERS => '0');
            VARIABLE Col : BIT_VECTOR (col_bits - 1 DOWNTO 0) := (OTHERS => '0');
            VARIABLE Burst_counter : INTEGER := 0;

            VARIABLE Command : Array_state;
            VARIABLE Bank_precharge : Array4x2BV;
            VARIABLE A10_precharge : Array4xB := ('0' & '0' & '0' & '0');
            VARIABLE Auto_precharge : Array4xB := ('0' & '0' & '0' & '0');
            VARIABLE Read_precharge : Array4xB := ('0' & '0' & '0' & '0');
            VARIABLE Write_precharge : Array4xB := ('0' & '0' & '0' & '0');
            VARIABLE Count_precharge : Array4xI := (0 & 0 & 0 & 0);
            VARIABLE RW_interrupt_write : Array4xB := ('0' & '0' & '0' & '0');
            VARIABLE RW_interrupt_read : Array4xB := ('0' & '0' & '0' & '0');

            VARIABLE Data_in_enable, Data_out_enable : BIT := '0';
            VARIABLE Pc_b0, Pc_b1, Pc_b2, Pc_b3 : BIT := '0';
            VARIABLE Act_b0, Act_b1, Act_b2, Act_b3 : BIT := '0';

            -- Timing Check
            VARIABLE MRD_chk : INTEGER := 0;
            VARIABLE RC_chk, RRD_chk : TIME := 0 ns;
            VARIABLE RAS_chk0, RAS_chk1, RAS_chk2, RAS_chk3 : TIME := 0 ns;
            VARIABLE RCD_chk0, RCD_chk1, RCD_chk2, RCD_chk3 : TIME := 0 ns;
            VARIABLE RP_chk, RP_chk0, RP_chk1, RP_chk2, RP_chk3 : TIME := 0 ns;
            VARIABLE WR_chk  : Array4xI := (0 & 0 & 0 & 0);

            -- Initialize empty rows
            PROCEDURE Init_mem (Bank : BIT_VECTOR (1 DOWNTO 0); Row_index : INTEGER) IS
                VARIABLE i, j : INTEGER := 0;
                BEGIN
                    IF Bank = "00" THEN
                        IF Bank0 (Row_index) = NULL THEN                        -- Check to see if row empty
                            Bank0 (Row_index) := NEW ram_type;                  -- Open new row for access
                            FOR i IN (2**col_bits - 1) DOWNTO 0 LOOP            -- Filled row with zeros
                                FOR j IN (data_bits - 1) DOWNTO 0 LOOP
                                    Bank0 (Row_index) (i) (j) := '0';
                                END LOOP;
                            END LOOP;
                        END IF;
                    ELSIF Bank = "01" THEN
                        IF Bank1 (Row_index) = NULL THEN
                            Bank1 (Row_index) := NEW ram_type;
                            FOR i IN (2**col_bits - 1) DOWNTO 0 LOOP
                                FOR j IN (data_bits - 1) DOWNTO 0 LOOP
                                    Bank1 (Row_index) (i) (j) := '0';
                                END LOOP;
                            END LOOP;
                        END IF;
                    ELSIF Bank = "10" THEN
                        IF Bank2 (Row_index) = NULL THEN

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文无字幕一区二区三区| av男人天堂一区| 欧美视频日韩视频在线观看| 日本成人在线不卡视频| 欧美午夜片在线看| 亚洲成人黄色影院| 日韩免费观看高清完整版在线观看| 免费看欧美女人艹b| 精品91自产拍在线观看一区| 国产精品综合二区| 亚洲三级电影全部在线观看高清| 色香色香欲天天天影视综合网| 亚洲第一精品在线| 欧美videossexotv100| 成人开心网精品视频| 一区二区三区不卡在线观看| 欧美一级电影网站| 丁香五精品蜜臀久久久久99网站| 亚洲欧洲三级电影| 777久久久精品| 国产成人激情av| 亚洲国产美女搞黄色| 亚洲精品一区二区三区香蕉| proumb性欧美在线观看| 天天色 色综合| 中文字幕精品三区| 7777精品伊人久久久大香线蕉经典版下载 | 91视频在线观看免费| 视频在线观看一区| 中文字幕欧美国产| 欧美日韩国产高清一区二区| 国产一区二区女| 一区二区不卡在线播放| 欧美精品一区二区在线观看| 在线亚洲精品福利网址导航| 激情图区综合网| 亚洲一区二区美女| 欧美激情一区二区三区蜜桃视频| 在线看国产一区| 国产福利不卡视频| 亚洲成在线观看| 国产精品成人一区二区三区夜夜夜 | 日韩三级视频在线观看| fc2成人免费人成在线观看播放| 日日夜夜精品视频免费| 亚洲午夜免费福利视频| 国产亚洲精品中文字幕| 欧美另类高清zo欧美| 99精品欧美一区| 国产精品一区久久久久| 三级不卡在线观看| 一区二区欧美精品| 国产精品国产a级| 欧美精品一区二区在线播放| 欧美肥妇free| 欧美色综合久久| 99麻豆久久久国产精品免费| 国产一区91精品张津瑜| 日韩国产精品久久久久久亚洲| 亚洲男人的天堂av| 国产精品污污网站在线观看| 亚洲精品在线观| 欧美一个色资源| 欧美美女一区二区三区| 日本韩国欧美一区二区三区| 丰满白嫩尤物一区二区| 国产精品18久久久久久vr| 美女精品自拍一二三四| 免费久久精品视频| 日本大胆欧美人术艺术动态| 亚洲3atv精品一区二区三区| 一区二区三区久久久| 亚洲人成网站影音先锋播放| 亚洲图片你懂的| 国产精品久久久久婷婷二区次| 国产欧美日韩综合| 26uuu欧美日本| 久久久久高清精品| 久久久久久久网| 国产欧美日韩视频在线观看| 国产欧美精品一区二区色综合| 久久久美女艺术照精彩视频福利播放| 精品久久一区二区三区| xnxx国产精品| 国产欧美日韩在线视频| 中文字幕一区二区视频| 亚洲日本va午夜在线电影| 亚洲另类春色国产| 天堂成人国产精品一区| 婷婷国产v国产偷v亚洲高清| 日韩国产精品久久久| 麻豆精品国产传媒mv男同| 精品一区二区三区久久| 国产毛片精品一区| 成人免费的视频| 欧洲一区二区av| 欧美一区二区女人| 久久久久久久久久久久久久久99 | 91麻豆精品国产91久久久更新时间| 欧美日韩视频在线第一区| 欧美肥妇free| 国产亚洲欧美日韩日本| 最新高清无码专区| 亚洲第一在线综合网站| 精品午夜久久福利影院| 成人av在线一区二区| 欧美午夜片在线观看| 精品日韩一区二区三区 | 精品久久人人做人人爽| 亚洲国产成人一区二区三区| 亚洲精品国产精品乱码不99| 香蕉久久夜色精品国产使用方法| 久久精品国产亚洲5555| 成人一道本在线| 欧美精品一卡两卡| 国产无一区二区| 亚洲国产另类av| 精品一区二区三区在线播放| 色香蕉久久蜜桃| 精品国产一区二区精华| 日韩毛片在线免费观看| 日本vs亚洲vs韩国一区三区| 丁香啪啪综合成人亚洲小说| 欧美精品一二三区| 国产欧美一区二区三区沐欲| 亚洲18女电影在线观看| 国产成人午夜99999| 欧美日韩在线直播| 国产免费成人在线视频| 午夜精品久久久久久久久久久| 国产一区二区三区四| 欧美无人高清视频在线观看| 国产欧美日韩精品a在线观看| 亚洲第一激情av| 成人av小说网| 欧美成人欧美edvon| 亚洲国产精品综合小说图片区| 国产一区二区网址| 91精品欧美久久久久久动漫| 国产精品高潮呻吟| 国产精品一级黄| 欧美精品1区2区3区| 亚洲人成伊人成综合网小说| 国产福利一区二区三区| 日韩女优毛片在线| 亚洲第一精品在线| 在线观看日韩av先锋影音电影院| 国产欧美一区二区精品性色超碰| 蜜臀精品一区二区三区在线观看 | 国产精品美女一区二区在线观看| 青青草成人在线观看| 91福利小视频| 亚洲欧美一区二区三区久本道91 | 日韩精品成人一区二区三区| 91丨porny丨蝌蚪视频| 亚洲国产成人私人影院tom| 国产一区二区三区精品欧美日韩一区二区三区 | 男人操女人的视频在线观看欧美| 日本二三区不卡| 成人欧美一区二区三区| 国产成人自拍网| 久久久久久久久久美女| 国产一区二区三区| 久久品道一品道久久精品| 激情图区综合网| 欧美成人女星排行榜| 麻豆视频观看网址久久| 欧美一区二区三区在| 日韩高清一级片| 制服丝袜av成人在线看| 青青草视频一区| 欧美不卡在线视频| 激情综合亚洲精品| 精品99久久久久久| 欧美年轻男男videosbes| 亚洲精品菠萝久久久久久久| 欧洲激情一区二区| 婷婷开心激情综合| 日韩一区二区免费高清| 久久国产精品99久久久久久老狼| 91麻豆精品国产91| 国产一区二区三区精品欧美日韩一区二区三区| 精品入口麻豆88视频| 国产成人精品午夜视频免费| 国产欧美精品区一区二区三区| 成人av在线电影| 亚洲精品第1页| 91精品国产色综合久久ai换脸| 日韩黄色免费电影| 久久免费电影网| 99这里只有久久精品视频| 一区二区三区在线免费视频| 欧美久久久久中文字幕| 久久成人18免费观看| 国产日韩欧美一区二区三区乱码| 99在线热播精品免费| 日韩一区精品字幕| 国产亚洲人成网站| 在线日韩一区二区| 狠狠狠色丁香婷婷综合久久五月|