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

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

?? sd_cnfg.vhd

?? lattice sdram 控制器VHDL源代碼
?? VHD
字號:
-- --------------------------------------------------------------------
-- >>>>>>>>>>>>>>>>>>>>>>>>> COPYRIGHT NOTICE <<<<<<<<<<<<<<<<<<<<<<<<<
-- --------------------------------------------------------------------
-- Copyright (c) 2001 by Lattice Semiconductor Corporation
-- --------------------------------------------------------------------
--
-- Permission:
--
--   Lattice Semiconductor grants permission to use this code for use
--   in synthesis for any Lattice programmable logic product.  Other
--   use of this code, including the selling or duplication of any
--   portion is strictly prohibited.
--
-- Disclaimer:
--
--   This VHDL or Verilog source code is intended as a design reference
--   which illustrates how these types of functions can be implemented.
--   It is the user's responsibility to verify their design for
--   consistency and functionality through the use of formal
--   verification methods.  Lattice Semiconductor provides no warranty
--   regarding the use or functionality of this code.
--
-- --------------------------------------------------------------------
--           
--                     Lattice Semiconductor Corporation
--                     5555 NE Moore Court
--                     Hillsboro, OR 97214
--                     U.S.A
--
--                     TEL: 1-800-Lattice (USA and Canada)
--                          408-826-6000 (other locations)
--
--                     web: http://www.latticesemi.com/
--                     email: techsupport@latticesemi.com
--
-- --------------------------------------------------------------------
-- Revision History :
-----------------------------------------------------------------------
-- Ver  | Author    | Mod. Date | Changes Made:
-----------------------------------------------------------------------
-- 0.1  | kam       | 9/3/99    | birth
-- 1.0  | kam       | ------    | Release
-----------------------------------------------------------------------

-- This module provides an alternative to having an internal register to
-- load the sdram command mode values and to initiate the sdram startup
-- procedure.  Upon receiving the sdram_enable signal, which is assumed 
-- to be asynchronous to the clock, the state machine starts initiating 3
-- commands to the sdrams.  The first will be a precharge, the second will
-- be an auto refresh, the last will be the load mode register command.
-- After performing these threee commands, the sdram will be functional.

library IEEE;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;

entity sd_cnfg is
     port (
           sdram_en:       in  std_logic;
           clk:            in  std_logic;
           rst_l:          in  std_logic;
           sdram_cycle:    in  std_logic_vector(3 downto 0);
           state_cntr:     in  std_logic_vector(3 downto 0);
           sdram_mode_reg: out std_logic_vector(11 downto 0);
           sdram_cmnd:     out std_logic_vector(1 downto 0);
           cmnd_cycle_req: out  std_logic;
           sdram_setup:    out std_logic);
end sd_cnfg;


architecture RTL of sd_cnfg is

  -- write mode set to single or programmed burst length -- mode bit[9]
  constant prog_brst: std_logic := '0';
  constant single:    std_logic := '1';

  -- cas latency set to 2 or 3 -- mode bits[6:4]
  constant cas_lat_2:      std_logic_vector(2 downto 0) := "010";
  constant cas_lat_3:      std_logic_vector(2 downto 0) := "011";

  -- burst type sequential or interleaved -- mode bit[3]
  constant seq: std_logic := '0';
  constant int: std_logic := '1';

  -- burst length -- mode bits(2 downto 0)
  constant brst1:      std_logic_vector(2 downto 0) := "000";  -- 1
  constant brst2:      std_logic_vector(2 downto 0) := "001";  -- 2
  constant brst4:      std_logic_vector(2 downto 0) := "010";  -- 4
  constant brst8:      std_logic_vector(2 downto 0) := "011";  -- 8
  constant brstf:      std_logic_vector(2 downto 0) := "111";  -- full page

  -- state assignments
  constant idle:      std_logic_vector(3 downto 0) := "0000";
  constant precharge: std_logic_vector(3 downto 0) := "0001";
  constant nop1:      std_logic_vector(3 downto 0) := "0010";
  constant refresh1:  std_logic_vector(3 downto 0) := "0011";
  constant nop2:      std_logic_vector(3 downto 0) := "0100";
  constant refresh2:  std_logic_vector(3 downto 0) := "0101";
  constant nop3:      std_logic_vector(3 downto 0) := "0110";
  constant load_mode: std_logic_vector(3 downto 0) := "0111";
  constant all_done:  std_logic_vector(3 downto 0) := "1000";

  signal  sdram_en1: std_logic;
  signal  sdram_en2: std_logic;	                       -- enable sync'd twice
  signal  state: std_logic_vector(3 downto 0);            -- state bits
  signal  sdram_mode_regs: std_logic_vector(11 downto 0); -- mode register

  begin

  ---------------------------------------------------------------------
  -- sdram mode register assignment
  -- change values to whatever you need

  sdram_mode_regs(11 downto 10) <= "00";       -- reserved
  sdram_mode_regs(9)            <= prog_brst;  -- write mode
  sdram_mode_regs(8 downto 7)   <= "00";       -- reserved
  sdram_mode_regs(6 downto 4)   <= cas_lat_2;  -- cas latency 2 clocks
  sdram_mode_regs(3)            <= seq;        -- sequential access
  sdram_mode_regs(2 downto 0)   <= brst8;      -- burst of 8
  sdram_mode_reg <= sdram_mode_regs;
  -----------------------------------------------------------------------
  -- synchronize enable

  sdram_enable: process(clk, rst_l)
    begin
      if(rst_l = '0') then
        sdram_en1 <= '0' after 1 ns;
        sdram_en2 <= '0' after 1 ns;
      elsif rising_edge(clk) then
        sdram_en1 <= sdram_en after 1 ns;
        sdram_en2 <= sdram_en1 after 1 ns;
      end if;
  end process sdram_enable;
			
  -- ---------------------------------------------------------------------
  -- state machine

  state_machine: process (clk, rst_l)
    begin
      if(rst_l = '0') then
        state <= idle after 1 ns;
        sdram_cmnd <= "00" after 1 ns;
        cmnd_cycle_req <= '0' after 1 ns;
        sdram_setup <= '0' after 1 ns;
      elsif rising_edge(clk) then
         case state is
            when idle => if(sdram_en2 = '1') then
                            state          <= precharge after 1 ns;
                            sdram_cmnd     <= "01" after 1 ns;
                            cmnd_cycle_req <= '1' after 1 ns;
                            sdram_setup    <= '0' after 1 ns;
                         end if;

            when precharge => if(sdram_cycle(1) = '1' and state_cntr(3) = '1') then
                                state          <= nop1 after 1 ns;
                                sdram_cmnd     <= "00" after 1 ns;
                                cmnd_cycle_req <= '0' after 1 ns;
                                sdram_setup    <= '0' after 1 ns;
                              end if;

            when nop1 => state <= refresh1 after 1 ns;
                           sdram_cmnd     <= "10" after 1 ns;
                           cmnd_cycle_req <= '1' after 1 ns;
                           sdram_setup    <= '0' after 1 ns;

            when refresh1 => if(sdram_cycle(1) = '1' and state_cntr(3) = '1') then
                               state          <= nop2 after 1 ns;
                               sdram_cmnd     <= "00" after 1 ns;
                               cmnd_cycle_req <= '0' after 1 ns;
                               sdram_setup    <= '0' after 1 ns;
                             end if;

            when nop2 => state <= refresh2 after 1 ns;
                           sdram_cmnd     <= "10" after 1 ns;
                           cmnd_cycle_req <= '1' after 1 ns;
                           sdram_setup    <= '0' after 1 ns;

            when refresh2 => if(sdram_cycle(1) = '1' and state_cntr(3) = '1') then
                               state          <= nop3 after 1 ns;
                               sdram_cmnd     <= "00" after 1 ns;
                               cmnd_cycle_req <= '0' after 1 ns;
                               sdram_setup    <= '0' after 1 ns;
                             end if;

            when nop3 => state <= load_mode after 1 ns;
                           sdram_cmnd     <= "11" after 1 ns;
                           cmnd_cycle_req <= '1' after 1 ns;
                           sdram_setup    <= '0' after 1 ns;

            when load_mode => if(sdram_cycle(1) = '1' and state_cntr(2) = '1') then
                                state          <= all_done after 1 ns;
                                sdram_cmnd     <= "00" after 1 ns;
                                cmnd_cycle_req <= '0' after 1 ns;
                                sdram_setup    <= '1' after 1 ns;
                              end if;

            when all_done => state <= all_done after 1 ns;
                               sdram_cmnd     <= "00" after 1 ns;
                               cmnd_cycle_req <= '0' after 1 ns;
                               sdram_setup    <= '1' after 1 ns;

            when others => state <= idle after 1 ns; 
                             sdram_cmnd     <= "00" after 1 ns;
                             cmnd_cycle_req <= '0' after 1 ns;
                             sdram_setup    <= '0' after 1 ns;
         end case;
      end if;
  end process state_machine;
end architecture RTL;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产91乱码一区二区三区 | 一区二区三区资源| 成人激情免费网站| 亚洲国产精品高清| caoporen国产精品视频| 亚洲免费在线电影| 欧美少妇xxx| 美女视频一区在线观看| 久久你懂得1024| www.久久久久久久久| 亚洲一级二级三级在线免费观看| 欧美三级蜜桃2在线观看| 三级亚洲高清视频| www日韩大片| 色综合天天综合网国产成人综合天| 亚洲天堂免费在线观看视频| 欧美日韩日日摸| 久久精品久久精品| 国产精品免费看片| 欧美性感一区二区三区| 久久aⅴ国产欧美74aaa| 国产精品日日摸夜夜摸av| 日本道在线观看一区二区| 秋霞影院一区二区| 日本一区二区三区电影| 欧美日精品一区视频| 麻豆精品久久久| 综合久久综合久久| 日韩一区二区三区免费观看| 国产精品一区二区久激情瑜伽| 国产精品国产三级国产aⅴ入口 | 午夜免费久久看| 国产欧美一区二区三区鸳鸯浴 | 不卡一区在线观看| 亚洲成av人片一区二区三区| 久久夜色精品国产噜噜av| 一本到一区二区三区| 久久国产夜色精品鲁鲁99| 亚洲人成在线播放网站岛国| 日韩欧美国产不卡| 色哟哟一区二区三区| 九九九精品视频| 亚洲永久精品大片| 中文天堂在线一区| 欧美成人一区二区| 欧美四级电影在线观看| 国产91丝袜在线播放0| 午夜精品在线看| 一区精品在线播放| 久久精品欧美一区二区三区不卡| 欧美日韩性生活| 懂色av一区二区在线播放| 午夜成人免费电影| 亚洲另类在线制服丝袜| 亚洲国产精品国自产拍av| 日韩久久免费av| 欧美精选午夜久久久乱码6080| 99久精品国产| 成人黄色一级视频| 国产精品综合二区| 久久99精品网久久| 免费高清在线一区| 日韩一区精品字幕| 亚洲国产精品久久久久秋霞影院| 亚洲人精品午夜| 亚洲黄一区二区三区| 国产精品免费丝袜| 国产精品国产成人国产三级| 国产日韩视频一区二区三区| 精品国产乱码久久久久久影片| 7777精品伊人久久久大香线蕉的| 欧洲精品在线观看| 日本高清不卡视频| 欧美日韩色一区| 欧美老女人在线| 7777精品伊人久久久大香线蕉| 欧美日韩一区三区| 欧美一区二区三区免费视频| 欧美肥妇bbw| 日韩一区二区不卡| 久久久久国产精品人| 久久久777精品电影网影网| 久久亚洲二区三区| 欧美激情一区二区三区蜜桃视频| 国产色产综合色产在线视频 | 精品剧情在线观看| 欧美一区二区三区在线电影| 777午夜精品视频在线播放| 91精品国产色综合久久不卡蜜臀 | 国产精品亲子乱子伦xxxx裸| 国产精品网曝门| 亚洲欧美另类小说视频| 亚洲综合色自拍一区| 午夜免费欧美电影| 狠狠色综合色综合网络| 国产一二三精品| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 欧美性一级生活| 欧美精品精品一区| 亚洲精品一区二区三区精华液 | 亚洲欧洲综合另类| 午夜免费久久看| 国产麻豆一精品一av一免费| 波多野结衣在线一区| 欧美午夜不卡在线观看免费| 日韩免费在线观看| 国产精品久久久久久久久搜平片 | 日韩精品专区在线影院重磅| 国产偷国产偷亚洲高清人白洁| 国产精品女人毛片| 亚洲香肠在线观看| 国产精品自拍在线| 欧美最猛性xxxxx直播| 精品国产在天天线2019| 亚洲欧美一区二区在线观看| 午夜久久久影院| 国产成人高清在线| 3d成人h动漫网站入口| 国产日产亚洲精品系列| 亚洲一区二区五区| 国产白丝精品91爽爽久久| 91久久精品一区二区二区| 欧美大片在线观看一区二区| 一区二区中文视频| 精品一区二区三区免费播放| 99久久777色| 久久综合九色综合欧美就去吻| 亚洲欧美色图小说| 激情综合亚洲精品| 欧美日韩综合在线| 亚洲国产精品成人久久综合一区| 午夜精品影院在线观看| 成人高清视频在线| 日韩女优电影在线观看| 一区二区三区成人在线视频| 国产suv一区二区三区88区| 7777精品伊人久久久大香线蕉| 国产精品美女www爽爽爽| 另类调教123区| 在线不卡中文字幕| 一区二区三区在线观看视频| 高清av一区二区| 日韩欧美成人一区| 一区二区三区国产| 91丨porny丨户外露出| 欧美国产精品专区| 精品无人码麻豆乱码1区2区| 欧美日韩国产在线播放网站| 亚洲视频 欧洲视频| 菠萝蜜视频在线观看一区| 久久久久久久久伊人| 日本成人在线视频网站| 欧美日韩大陆在线| 一区二区三区日韩| 色伊人久久综合中文字幕| 国产精品超碰97尤物18| 国产精品资源在线看| 日韩免费视频一区二区| 美女www一区二区| 欧美精品免费视频| 五月天久久比比资源色| 欧美视频在线一区| 亚洲国产一区视频| 欧美色成人综合| 亚洲综合一区二区三区| 色婷婷激情综合| 亚洲男人电影天堂| 91久久一区二区| 亚洲国产精品久久一线不卡| 欧美午夜一区二区三区 | 日韩精品电影在线| 欧美日本在线视频| 日韩高清不卡在线| 欧美一区2区视频在线观看| 秋霞成人午夜伦在线观看| 欧美一区二区三区小说| 久久成人免费网| 久久久久亚洲综合| 成人app网站| 亚洲一区欧美一区| 欧美日韩成人在线一区| 五月婷婷激情综合网| 日韩欧美自拍偷拍| 国产精品主播直播| 亚洲欧美另类在线| 91精品国产91热久久久做人人| 美女视频一区二区| 国产精品久久久久精k8| 欧美综合一区二区三区| 日本vs亚洲vs韩国一区三区二区| 日韩欧美卡一卡二| 成人一区二区三区中文字幕| 亚洲另类一区二区| 欧美夫妻性生活| 国产最新精品精品你懂的| 国产精品系列在线| 欧美三级电影网| 国产ts人妖一区二区| 亚洲自拍偷拍综合| 欧美一卡2卡3卡4卡|