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

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

?? ram_control.vhd

?? fpga實現OFDM的源代碼 并且配有各個部分的詳細說明
?? VHD
字號:
library IEEE;use IEEE.STD_LOGIC_1164.all;use IEEE.STD_LOGIC_ARITH.all;use IEEE.STD_LOGIC_SIGNED.all;entity ram_control is  generic (    Tx_nRX : natural := 0;    stage  : natural := 3);  port (    clk          : in  std_logic;    rst          : in  std_logic;    Gen_state    : in  std_logic_vector(2*stage+2 downto 0);    mem_bk       : in  std_logic;    addrout_in   : out std_logic_vector(stage*2-Tx_nRX downto 0);    wen_proc     : out std_logic;    addrin_proc  : out std_logic_vector(stage*2-1 downto 0);    addrout_proc : out std_logic_vector(stage*2-1 downto 0);    wen_out      : out std_logic;    addrin_out   : out std_logic_vector(stage*2-1 downto 0));end ram_control;architecture ram_control of ram_control is  function counter2addr(    counter : std_logic_vector;    mask1   : std_logic_vector;    mask2   : std_logic_vector    ) return std_logic_vector is    variable result : std_logic_vector(counter'range);  begin    for n in mask1'range loop      if mask1(n) = '1' then        result( 2*n+1 downto 2*n ) := counter( 1 downto 0 );      elsif mask2(n) = '1' and n /= STAGE-1 then        result( 2*n+1 downto 2*n ) := counter( 2*n+3 downto 2*n+2 );      else        result( 2*n+1 downto 2*n ) := counter( 2*n+1 downto 2*n );      end if;    end loop;    return result;  end counter2addr;  function outcounter2addr(counter : std_logic_vector) return std_logic_vector is    variable result : std_logic_vector(counter'range);  begin    for n in 0 to STAGE-1 loop      result( 2*n+1 downto 2*n ) := counter( counter'high-2*n downto counter'high-2*n-1 );    end loop;    return result;  end outcounter2addr;  alias state   : std_logic_vector(2 downto 0) is Gen_state(2*stage+2 downto 2*stage);  alias counter : std_logic_vector(2*stage-1 downto 0) is Gen_state(2*stage-1 downto 0);  constant FFTDELAY    : integer := 13+2*STAGE;  constant FACTORDELAY : integer := 6;  constant OUTDELAY    : integer := 9;-- read    signal rmask1, rmask2 : std_logic_vector( STAGE-1 downto 0 );-- proc  signal wmask1, wmask2 : std_logic_vector( STAGE-1 downto 0 );  signal wcounter       : std_logic_vector( STAGE*2-1 downto 0 );-- out  signal outcounter     : std_logic_vector( STAGE*2-1 downto 0 );begin-- Read  Tx_read : if Tx_nRx = 1 generate    readaddr : process( clk, rst )      variable aux_addrout     : std_logic_vector(stage*2-1 downto 0);      variable aux_addrout_abs : std_logic_vector(stage*2-1 downto 0);    begin      if rst = '1' then        addrout_in      <= ( others => '0' );        addrout_proc    <= ( others => '0' );        aux_addrout     := ( others => '0' );        aux_addrout_abs := ( others => '0' );        rmask1          <= ( others => '0' );        rmask2          <= ( others => '0' );      elsif clk'event and clk = '1' then        if unsigned(state) = 0 and signed(counter) = 0 then          rmask1(STAGE-1)          <= '1';          rmask1(STAGE-2 downto 0) <= (others => '0');          rmask2(STAGE-1)          <= '0';          rmask2(STAGE-2 downto 0) <= (others => '1');        elsif signed(counter) = -1 then          rmask1 <= '0'&rmask1( STAGE-1 downto 1 );          rmask2 <= '0'&rmask2( STAGE-1 downto 1 );        end if;        aux_addrout     := counter2addr(counter, rmask1, rmask2);        aux_addrout_abs := abs(aux_addrout);        if unsigned(state) = 0 then          if mem_bk = '0' then            addrout_in <= aux_addrout_abs;          else            addrout_in <= aux_addrout_abs+32;          end if;        end if;        addrout_proc <= aux_addrout;      end if;    end process readaddr;  end generate;  Rx_read : if Tx_nRx = 0 generate    readaddr : process( clk, rst )      variable aux_addrout : std_logic_vector(stage*2 downto 0);    begin      if rst = '1' then        addrout_in   <= ( others => '0' );        addrout_proc <= ( others => '0' );        aux_addrout  := ( others => '0' );        rmask1       <= ( others => '0' );        rmask2       <= ( others => '0' );      elsif clk'event and clk = '1' then        if unsigned(state) = 0 and signed(counter) = 0 then          rmask1(STAGE-1)          <= '1';          rmask1(STAGE-2 downto 0) <= (others => '0');          rmask2(STAGE-1)          <= '0';          rmask2(STAGE-2 downto 0) <= (others => '1');        elsif signed(counter) = -1 then          rmask1 <= '0'&rmask1( STAGE-1 downto 1 );          rmask2 <= '0'&rmask2( STAGE-1 downto 1 );        end if;        aux_addrout := '0'&counter2addr(counter, rmask1, rmask2);        if unsigned(state) = 0 and mem_bk = '1' then          addrout_in <= aux_addrout+64;        else          addrout_in <= aux_addrout;        end if;        addrout_proc <= aux_addrout(stage*2-1 downto 0);      end if;    end process readaddr;  end generate;-- Escrita em proc  writeaddr_proc : process( clk, rst )  begin    if rst = '1' then      addrin_proc <= ( others => '0' );      wcounter    <= ( others => '0' );      wmask1      <= ( others => '0' );      wmask2      <= ( others => '0' );    elsif clk'event and clk = '1' then      if unsigned(state) = 0 and unsigned(counter) = FFTDELAY-1 then        wmask1(STAGE-1)          <= '1';        wmask1(STAGE-2 downto 0) <= (others => '0');        wmask2(STAGE-1)          <= '0';        wmask2(STAGE-2 downto 0) <= (others => '1');      elsif unsigned(counter) = FFTDELAY-1 then        wmask1 <= '0'&wmask1( STAGE-1 downto 1 );        wmask2 <= '0'&wmask2( STAGE-1 downto 1 );      end if;      if unsigned(state) < STAGE and unsigned(counter) = FFTDELAY-1 then        wcounter <= ( others => '0' );      else        wcounter <= unsigned(wcounter)+1;      end if;      addrin_proc <= counter2addr(wcounter, wmask1, wmask2 );    end if;  end process writeaddr_proc;  writeen_proc : process( clk, rst )  begin    if rst = '1' then      wen_proc <= '0';    elsif clk'event and clk = '1' then      if unsigned(state) = 0 and unsigned(counter) = FFTDELAY then        wen_proc <= '1';      elsif unsigned(state) = STAGE-1 and unsigned(counter) = FFTDELAY then        wen_proc <= '0';      end if;    end if;  end process writeen_proc;-- Escrite em OutRam  writeaddr_out : process( clk, rst )  begin    if rst = '1' then      outcounter <= (others => '0');    elsif clk'event and clk = '1' then      if unsigned(state) = stage-1 and unsigned(counter) = OUTDELAY then        outcounter <= (others => '0');      else        outcounter <= unsigned(outcounter)+1;      end if;    end if;  end process writeaddr_out;  addrin_out <= outcounter2addr(outcounter);  writeen_out : process( clk, rst )  begin    if rst = '1' then      wen_out <= '0';    elsif clk'event and clk = '1' then      if unsigned(state) = STAGE-1 and unsigned(counter) = OUTDELAY then        wen_out <= '1';      elsif unsigned(outcounter) = 63 then        wen_out <= '0';      end if;    end if;  end process writeen_out;end ram_control;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久一区二区三区四区| 91久久久免费一区二区| 亚瑟在线精品视频| 亚洲成人午夜电影| 天天爽夜夜爽夜夜爽精品视频| 亚洲欧美激情插 | 成人性生交大片免费看视频在线 | 91视视频在线直接观看在线看网页在线看| 国产大片一区二区| 国产成人精品三级| www.亚洲免费av| 91精品1区2区| 欧美一区二区观看视频| 欧美精品一区二区精品网| 精品黑人一区二区三区久久| 久久久久国产免费免费| 亚洲图片激情小说| 亚洲成人动漫av| 国产一区二区三区在线看麻豆| 国产麻豆视频一区二区| gogo大胆日本视频一区| 欧美亚洲愉拍一区二区| 日韩视频免费观看高清完整版在线观看| 日韩一区二区精品| 国产精品家庭影院| 亚洲国产综合色| 国产精品99久久久久久宅男| 91同城在线观看| 欧美一级精品在线| 国产精品精品国产色婷婷| 亚洲一区二区三区四区不卡| 日本不卡不码高清免费观看| 成人18视频日本| 日韩免费一区二区| 亚洲老妇xxxxxx| 国产一区不卡视频| 欧美日韩高清一区| 中文av一区二区| 美女诱惑一区二区| 一本久道久久综合中文字幕 | 国产·精品毛片| 欧美日韩精品一区视频| 国产精品女主播av| 麻豆精品视频在线观看视频| 99精品欧美一区二区三区小说 | 欧美日韩久久一区二区| 久久综合久久综合久久| 亚洲一区在线免费观看| 国产成人免费视| 91精品国产欧美一区二区18| 亚洲欧洲制服丝袜| 处破女av一区二区| 精品久久人人做人人爰| 日本亚洲天堂网| 欧美日韩美少妇| 亚洲国产精品嫩草影院| 91在线视频观看| 国产日韩欧美麻豆| 国产一区二区导航在线播放| 日韩午夜激情av| 日本在线观看不卡视频| 欧美亚一区二区| 亚洲小少妇裸体bbw| 91蝌蚪国产九色| 国产精品色在线观看| 国产精品一级片在线观看| 日韩精品一区二| 久久aⅴ国产欧美74aaa| 欧美一级搡bbbb搡bbbb| 日本欧美一区二区| 制服丝袜国产精品| 日韩成人伦理电影在线观看| 欧美日韩国产一级二级| 亚洲成人动漫av| 91麻豆精品国产91久久久更新时间| 亚洲欧美一区二区三区久本道91 | 亚洲国产精品久久人人爱| 9l国产精品久久久久麻豆| 国产精品成人免费精品自在线观看| 国产电影一区二区三区| 亚洲国产成人自拍| 91蝌蚪porny| 亚洲国产欧美一区二区三区丁香婷| 欧美在线|欧美| 蜜桃视频在线观看一区二区| 精品日韩99亚洲| 国产精品亚洲视频| 综合久久给合久久狠狠狠97色| 91在线观看污| 三级一区在线视频先锋| 欧美成人vr18sexvr| 国产不卡视频在线观看| 亚洲丝袜精品丝袜在线| 欧美日韩一区二区三区在线| 美腿丝袜亚洲一区| 国产精品美女一区二区| 欧美三级电影精品| 久久电影国产免费久久电影| 欧美国产欧美亚州国产日韩mv天天看完整 | 91成人免费在线| 韩国v欧美v日本v亚洲v| 亚洲男人的天堂在线aⅴ视频| 欧美性猛片xxxx免费看久爱| 美女网站在线免费欧美精品| 欧美激情中文不卡| 欧美撒尿777hd撒尿| 激情图片小说一区| 亚洲人成影院在线观看| 欧美电影在哪看比较好| 国产不卡免费视频| 婷婷一区二区三区| 久久综合av免费| 欧美亚洲综合在线| 国产成人综合自拍| 日韩一区欧美二区| 欧美国产乱子伦 | 五月综合激情日本mⅴ| 国产欧美一区二区精品秋霞影院| 在线一区二区视频| 国产成人av一区| 欧美a级理论片| 亚洲一区自拍偷拍| 国产精品久久久久7777按摩| 欧美大片拔萝卜| 欧美日韩一二三| 99re热视频这里只精品| 国产综合色视频| 奇米一区二区三区av| 自拍偷拍国产精品| 国产精品欧美极品| 久久精品欧美日韩精品| 日韩写真欧美这视频| 欧美自拍丝袜亚洲| bt欧美亚洲午夜电影天堂| 韩日精品视频一区| 久草在线在线精品观看| 三级精品在线观看| 亚洲成人你懂的| 天天色图综合网| 一区二区三区日本| 一级女性全黄久久生活片免费| 国产精品女主播av| 国产精品女主播av| 国产精品传媒入口麻豆| 欧美激情资源网| 国产精品狼人久久影院观看方式| 久久久99精品久久| 久久久高清一区二区三区| 精品福利二区三区| 久久亚洲私人国产精品va媚药| 精品日韩欧美在线| 日韩欧美的一区二区| 欧美大片在线观看一区| 日韩色视频在线观看| 日韩午夜av一区| 久久一夜天堂av一区二区三区| 精品久久久三级丝袜| 精品少妇一区二区三区在线视频| 日韩一级二级三级| 国产日韩精品视频一区| 中文字幕免费不卡| 伊人婷婷欧美激情| 亚洲成人av电影| 久久91精品久久久久久秒播| 久久99久久久久久久久久久| 国产麻豆精品theporn| 国产91精品免费| 91精品办公室少妇高潮对白| 欧美久久一二区| 久久一区二区三区四区| 国产精品不卡在线观看| 亚洲一区二区三区四区在线| 日本女人一区二区三区| 国产精品18久久久久久vr| 菠萝蜜视频在线观看一区| 在线观看免费视频综合| 欧美一级在线免费| 中文字幕欧美区| 日韩精品一二三四| 成人一区二区三区中文字幕| 91日韩一区二区三区| 欧美乱妇20p| 中文字幕第一区二区| 亚洲国产你懂的| 国产一区二区剧情av在线| 色噜噜狠狠成人中文综合| 日韩一区二区免费视频| 国产精品的网站| 久久国产精品99久久久久久老狼| 成人av综合在线| 91麻豆精品国产综合久久久久久| 久久久久久久久久久久久女国产乱| 亚洲天堂a在线| 久久99久久99| 欧美日韩成人在线| 欧美激情中文不卡| 久久www免费人成看片高清| 色播五月激情综合网| 国产亚洲一区二区在线观看| 亚洲成人资源在线|