亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产曰批免费观看久久久| 91.com在线观看| 国产亚洲短视频| 麻豆精品精品国产自在97香蕉| 高清在线不卡av| 国产成人免费视频| 日韩小视频在线观看专区| 午夜激情一区二区| 欧美日韩精品电影| 肉色丝袜一区二区| 欧美一区二区三区性视频| 亚洲午夜成aⅴ人片| 欧美色爱综合网| 亚洲成年人网站在线观看| 欧美日韩视频专区在线播放| 亚洲综合清纯丝袜自拍| 欧美日韩视频专区在线播放| 日韩av不卡在线观看| 日韩一区二区三区在线观看| 美女看a上一区| 精品国产一区二区三区av性色| 久久激五月天综合精品| 久久久天堂av| jvid福利写真一区二区三区| 一区二区中文视频| 欧美日韩一区二区三区四区五区| 秋霞午夜鲁丝一区二区老狼| 日韩欧美一区电影| 国产.精品.日韩.另类.中文.在线.播放| 国产亚洲福利社区一区| 91香蕉国产在线观看软件| 《视频一区视频二区| 91久久线看在观草草青青 | 欧美乱妇15p| 麻豆一区二区99久久久久| 精品毛片乱码1区2区3区| 精品一区中文字幕| 国产精品麻豆网站| 欧美精品日韩一本| 国产精品99久| 亚洲资源中文字幕| 日韩精品一区二区三区老鸭窝 | 欧美亚洲综合在线| 日韩av网站免费在线| 亚洲精品乱码久久久久久| 在线看日韩精品电影| 久久99蜜桃精品| 国产欧美精品一区aⅴ影院| 欧洲在线/亚洲| 精品在线免费观看| 亚洲男人电影天堂| 精品成a人在线观看| 色婷婷精品大在线视频| 久久精品国产免费看久久精品| 国产精品高潮久久久久无| eeuss鲁片一区二区三区在线看| √…a在线天堂一区| 日韩一区二区三区视频在线观看| gogogo免费视频观看亚洲一| 日韩av电影天堂| 亚洲日穴在线视频| 久久久久青草大香线综合精品| 欧美系列日韩一区| 精品亚洲免费视频| 亚洲人成网站精品片在线观看 | 91网站在线播放| 国产一区二区美女| 视频一区二区三区入口| 日韩三级.com| 欧美日韩在线三区| 99久久精品免费精品国产| 蜜桃一区二区三区在线| 亚洲精品老司机| 欧美国产乱子伦| 精品盗摄一区二区三区| 91麻豆免费视频| 麻豆精品一区二区三区| 亚洲午夜在线电影| 亚洲日韩欧美一区二区在线| 久久精品人人爽人人爽| 精品国产麻豆免费人成网站| 欧美一级淫片007| 欧美三级电影网| 成人黄色小视频| 毛片一区二区三区| 五月激情综合网| 亚洲国产精品人人做人人爽| 亚洲男人的天堂网| 国产精品电影院| 欧美国产精品一区二区| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美情侣在线播放| 欧美系列在线观看| 欧美日韩视频专区在线播放| 欧美午夜免费电影| 欧美日本一区二区| 欧美日韩第一区日日骚| 欧美日韩日日摸| 欧美高清www午色夜在线视频| 成人理论电影网| 不卡大黄网站免费看| jvid福利写真一区二区三区| 国产毛片精品视频| 国产精品一区二区免费不卡| 成人午夜碰碰视频| 北岛玲一区二区三区四区| 99视频精品在线| 97超碰欧美中文字幕| www.欧美日韩| jiyouzz国产精品久久| 一本一道波多野结衣一区二区| 91麻豆国产福利在线观看| 在线观看国产91| 欧美日韩国产综合草草| 91麻豆精品国产无毒不卡在线观看 | 麻豆国产欧美一区二区三区| 美女精品一区二区| 国产黄人亚洲片| 91丨porny丨最新| 欧美视频三区在线播放| 日韩免费电影一区| 欧美激情一区二区三区四区| 久久人人97超碰com| 2017欧美狠狠色| 国产精品色婷婷| 亚洲自拍偷拍欧美| 日韩福利视频导航| 风间由美一区二区三区在线观看 | 欧美精品久久久久久久久老牛影院 | 亚洲观看高清完整版在线观看 | 午夜欧美大尺度福利影院在线看| 老司机午夜精品| 不卡欧美aaaaa| 欧美性猛交xxxx乱大交退制版| 日韩亚洲欧美一区| 亚洲欧洲av色图| 久久丁香综合五月国产三级网站| 欧美天堂亚洲电影院在线播放| 国产女同互慰高潮91漫画| 免费成人结看片| 欧美日韩中文国产| 成人欧美一区二区三区黑人麻豆 | kk眼镜猥琐国模调教系列一区二区| 91精品免费在线观看| 亚洲精品日韩综合观看成人91| 国产不卡视频一区| 亚洲精品一区二区三区99| 天天做天天摸天天爽国产一区| 色婷婷国产精品久久包臀| 中文字幕乱码一区二区免费| 精品一区二区在线播放| 日韩一本二本av| 图片区小说区国产精品视频| 一本色道久久综合狠狠躁的推荐| 国产亚洲精品aa| 国产精品一级黄| 久久久久久久久久看片| 看片网站欧美日韩| 日韩亚洲欧美在线| 久久狠狠亚洲综合| 精品三级在线观看| 日本亚洲欧美天堂免费| 欧美二区三区91| 日韩有码一区二区三区| 欧美巨大另类极品videosbest | 国产精品综合网| 久久久久久久精| 国产乱妇无码大片在线观看| 久久精品这里都是精品| 国产成人av电影在线| 国产欧美日韩另类一区| 不卡在线观看av| 亚洲黄色小视频| 在线观看一区二区精品视频| 亚洲成a人片综合在线| 欧美日韩久久不卡| 免费在线视频一区| 精品国产乱码久久久久久免费 | 亚洲日本乱码在线观看| 欧美视频在线一区二区三区| 亚洲成人激情综合网| 91精品国产一区二区人妖| 精品一区二区免费在线观看| 久久女同精品一区二区| 不卡一区中文字幕| 亚洲一区电影777| 日韩女优av电影在线观看| 国产河南妇女毛片精品久久久| 中文字幕在线不卡一区| 欧美色图一区二区三区| 奇米色一区二区三区四区| 国产午夜精品一区二区三区嫩草| 99re视频精品| 午夜不卡av免费| 国产清纯在线一区二区www| caoporm超碰国产精品| 丝袜诱惑制服诱惑色一区在线观看 | 裸体健美xxxx欧美裸体表演| 国产欧美va欧美不卡在线| 欧美午夜片在线观看|