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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? gendc.vhd

?? core_arm_latest.tar.gz源代碼
?? VHD
?? 第 1 頁 / 共 3 頁
字號:
-- $(help_generic)-- $(help_local)library ieee;use ieee.std_logic_1164.all;use IEEE.std_logic_unsigned.conv_integer;use IEEE.std_logic_arith.conv_unsigned;use work.config.all;use work.int.all;use work.memdef.all;use work.corelib.all;use work.cache_comp.all;use work.cache_config.all;use work.genic_lib.all;use work.gendc_lib.all;use work.genwb_lib.all;use work.gencmem_lib.all;use work.setrepl_lib.all;use work.arith_cnt_comp.all;use work.bus_comp.all;entity gendc is  port (     rst     : in  std_logic;     clk     : in  std_logic;    hold : in cli_hold;    i  : in  gendc_type_in;    o  : out gendc_type_out;    ctrl : in gdcl_ctrl;    dcmo : in gencmem_type_dc_out;    dcmi : out gencmem_type_dc_in;    wbi  : out genwb_type_in;    wbo  : in genwb_type_out    );end gendc;architecture rtl of gendc is    type gendc_dirty_a is array (natural range <>) of std_logic_vector(GCML_DC_TADDR_BSZ-1 downto 0);    type gendc_cmaddrsrc is (gdca_no, gdca_in,  gdca_re,  gdca_lo);  type gendc_meaddrsrc is (gdcma_no, gdcma_in, gdcma_re, gdcma_lo );  type gendc_datainsrc is (gdcdi_no, gdcdi_in, gdcdi_re, gdcdi_lo, gdcdi_me );  type gendc_datapisrc is (gdcdp_cm, gdcdp_me, gdcdp_no );  type gendc_dbsrc is (gdcdb_mem, gdcdb_cm );    type gendc_validsrc is (gdcvalid_old, gdcvalid_clr, gdcvalid_new, gdcvalid_add );  type gendc_dirtysrc is (gdcdirty_old, gdcdirty_clr, gdcdirty_new, gdcdirty_add );  constant GCML_DC_DLINE_BSZ_X : integer := lin_log2x(CFG_DC_DLINE_SZ);   constant GCML_DC_SETS_X  : integer := lin_log2x(CFG_DC_SETS);   type gendc_tmp_type is record    hit, valid, dirty  : std_logic;     -- cache line attr     set, setrep  : integer;                     -- hit set    pos  : integer;                     -- line pos    ehold, req, reqread, reqwrite : std_logic;    sethit  : std_logic_vector(CFG_DC_SETS-1 downto 0);    setvalid   : std_logic_vector(CFG_DC_SETS-1 downto 0);    newvalid, newdirty : std_logic_vector(CFG_DC_TLINE_SZ-1 downto 0);    twrite, dwrite : std_logic;    mexc : std_logic;        setpos : std_logic_vector(lin_log2x(CFG_DC_SETS)-1 downto 0);        cmaddr : std_logic_vector(31 downto 0);    datain : std_logic_vector(31 downto 0);    meaddr : std_logic_vector(31 downto 0);    datapi : std_logic_vector(31 downto 0);    tvalid_src : gendc_validsrc;    tdirty_src : gendc_dirtysrc;    cmaddr_src : gendc_cmaddrsrc;    datain_src : gendc_datainsrc;    meaddr_src : gendc_meaddrsrc;    datapi_src : gendc_datapisrc;    db_src : gendc_dbsrc;        sign, read, lock, burst : std_logic;    size : lmd_memsize;           linepos : std_logic_vector(GCML_DC_TLINE_BSZ-1 downto 0);    linepos_lastbit : std_logic_vector(CFG_DC_TLINE_SZ-1 downto 0);        cmset : integer;        si : arith_cnt8_in;    dcmi : gencmem_type_dc_in;    wbi  : genwb_type_in;    o  : gendc_type_out;        sr_setfree : std_logic_vector(CFG_DC_SETS-1 downto 0);    sr_setlock : std_logic_vector(CFG_DC_SETS-1 downto 0);    sr_useset : std_logic;  end record;  type gendc_state is (gendc_hit,                        gendc_wtwb_readdata,                       gendc_wb_writedata, gendc_wt_writedata,                       gendc_wb_wbline, gendc_wb_fillline,                        gendc_reloadtaddr );  type gendc_reg_type is record    setrep : std_logic_vector(lin_log2x(CFG_DC_SETS)-1 downto 0);    state, state_wbline_next : gendc_state;    hit, hold : std_logic;    p_address : std_logic_vector(31 downto 0);    p_data : std_logic_vector(31 downto 0);    p_sign, p_read, p_lock : std_logic;    p_size : lmd_memsize;         stored, wbready, wbnext : std_logic;    setrep_locked, setrep_free : std_logic;    o_wr_data : std_logic_vector(31 downto 0);    addrlo : std_logic_vector(1 downto 0);    dirty : std_logic_vector(CFG_DC_TLINE_SZ-1 downto 0);    fill_linepos, linepos : std_logic_vector(GCML_DC_TLINE_BSZ-1 downto 0);    doaddr : std_logic_vector(1 downto 0);    mexc : std_logic;  end record;  type gendc_dbg_type is record     dummy : std_logic;     -- pragma translate_off     cmaddr : std_logic_vector(31 downto 0);     dbg : gendc_tmp_type;     -- pragma translate_on  end record;  signal r, c       : gendc_reg_type;  signal rdbg, cdbg : gendc_dbg_type;  signal si : arith_cnt8_in;  signal so : arith_cnt8_out;    signal sr_setfree : std_logic_vector(CFG_DC_SETS-1 downto 0);  signal sr_setlock : std_logic_vector(CFG_DC_SETS-1 downto 0);  signal sr_useset : std_logic;  signal sr_locked : std_logic;  signal sr_free   : std_logic;  signal sr_setrep_free : std_logic_vector(GCML_DC_SETS_X-1 downto 0);  signal sr_setrep_repl : std_logic_vector(GCML_DC_SETS_X-1 downto 0);    begin        p0: process (clk, rst, r, hold, i, dcmo, wbo, so,               sr_locked, sr_free, sr_setrep_free, sr_setrep_repl )    variable v    : gendc_reg_type;    variable t    : gendc_tmp_type;    variable vdbg : gendc_dbg_type;  begin        -- todo: locking on atomic load store does not work yet    -- until no multiprocessor system is implemented it's defered to the future        -- $(init(t:gendc_tmp_type))    v := r;        t.meaddr := i.addr_in;    t.cmaddr := i.addr_in;    t.datain := i.data_in;        t.wbi.fifo_write := '0';    v.stored := r.stored or wbo.fifo_stored_v;        -- write back address    t.si.data := (others => '0');    t.si.data(arith_cnt8_SZ-1 downto arith_cnt8_SZ-CFG_DC_TLINE_SZ) := r.dirty;    t.linepos := so.res(GCML_DC_TLINE_BSZ-1 downto 0);    t.linepos_lastbit := (others => '0');    t.mexc := '0';        t.datapi_src := gdcdp_no;    t.db_src := gdcdb_cm;        t.ehold := hold.ihold;    t.req := (not (t.ehold or i.annul)) and i.addrin_re ;    t.reqread := i.param_r.read and t.req;    t.reqwrite := (not i.param_r.read) and t.req;    t.twrite := '0';    t.dwrite := '0';        if r.hit = '1' then      t.tvalid_src := gdcvalid_add;      t.tdirty_src := gdcdirty_add;    else      t.tvalid_src := gdcvalid_new;      t.tdirty_src := gdcdirty_new;    end if;    t.burst := '0';    if (r.hold or t.ehold) = '1' then      t.cmaddr_src := gdca_re;      t.meaddr_src := gdcma_lo;      t.datain_src := gdcdi_lo;      t.sign := r.p_sign;      t.size := r.p_size;      t.read := r.p_read;      t.lock := r.p_lock;    else      t.cmaddr_src := gdca_in;      t.meaddr_src := gdcma_re;      t.datain_src := gdcdi_in;      t.sign := i.param_r.signed;      t.size := i.param_r.size;      t.read := i.param_r.read;      t.lock := i.param_r.lock;    end if;        if t.read = '1' then      t.size := lmd_word;    end if;            -- cmp    t.hit := '0';    t.set := 0;    for j in CFG_DC_SETS-1 downto 0 loop      -- (note: multiset does not recognice valid zero tags)      if gdcl_is_taghit(i.addr_re,dcmo.tag_line(j)) then        t.hit := '1';        t.sethit(j) := '1';        t.set := j;      end if;    end loop;             t.sr_setfree := (others => '0');    for j in CFG_DC_SETS-1 downto 0 loop      if gdcl_is_free(dcmo.tag_line(j)) then        t.sr_setfree(j) := '1';      end if;    end loop;         t.sr_setlock := (others => '0');    for j in CFG_DC_SETS-1 downto 0 loop      t.sr_setlock(j) := dcmo.tag_line(j).lock;    end loop;     t.sr_useset := '0';        t.valid := '0';    if gdcl_is_linevalid(i.addr_re,dcmo.tag_line(t.set)) then      t.valid := '1';    end if;    t.dirty := '0';    t.setrep := lin_convint(sr_setrep_repl);    if (sr_free = '1') or (sr_locked = '1') then      t.dirty := '0';      if (sr_free = '1') then        t.setrep := lin_convint(sr_setrep_free);      end if;    else      if gdcl_is_linedirty(i.addr_re,dcmo.tag_line(t.setrep)) then        t.dirty := '1';      end if;    end if;          -- $(del)    --                read                               write                                                    --   Writeback     |   Writethrough     Writeback     |   Writethrough                                            --        +--------+--------+                +--------+--------+                                                      --    hit | miss        hit | miss       hit | miss        hit | miss                                          --   +----+----+       +----+----+      +----+----+       +----+----+                                   --   |     free|dirty  |         |      |     free|dirty  |         |                       --   O1     +--+--+    O1        O3    O5      +--+--+   O4/O6     O6                                  --          |     |              |             |     |                                                --          O3<---O2             O4            O5<---O2                                                --          |                                                                                                         --          O4                                                                                         --                                                                                                            --  O1: cacheread                                                                                                      --  O2: writeback line                                                                                                  --  O3: memload                                                                                                         --  O4: cachewrite clean                                                                                                  --  O5: cachewrite dirty                                                                                                 --  O6: writeback single                                                                                                -- $(/del)            case r.state is            when gendc_hit =>        if t.hit = '1' then          t.tvalid_src := gdcvalid_add;          t.tdirty_src := gdcdirty_add;        else          t.tvalid_src := gdcvalid_new;          t.tdirty_src := gdcdirty_new;        end if;        v.mexc := '0';        v.wbready := '0';        v.wbnext := '0';        v.stored := wbo.fifo_stored_v;        v.hold := '0';                v.setrep_locked := sr_locked;        v.setrep_free := sr_free;                v.hit := t.hit;                v.p_address := i.addr_re;        v.p_data := i.data_in;        v.p_sign := i.param_r.signed;        v.p_size := i.param_r.size;        v.p_read := i.param_r.read;        v.p_lock := i.param_r.lock;          if t.req = '1' then                    t.sr_useset := '1';              if i.param_r.read = '1' then            if ctrl.writeback = '0' then              if (not (t.hit and t.valid)) = '1' or (i.forceread = '1') then                                -- $(del)                --                read                               --   Writeback     |   Writethrough                  --        +--------+--------+                        --    hit | miss        hit |<MISS>                                   --   +----+----+       +----+----+                   --   |     free|dirty  |         |                   --   O1     +--+--+    O1        O3                  --          |     |              |                   --          O3<---O2             O4                  --          |                                        --          O4                -- $(/del)                                -- $(del)                -- $(/del)                t.cmaddr_src := gdca_re;                v.hold := '1';                                t.wbi.fifo_write := '1';                v.state := gendc_wtwb_readdata;                              else                                                                                          -- $(del)                --                read                               --   Writeback     |   Writethrough                  --        +--------+--------+                        --    hit | miss       <HIT>| miss                                   --   +----+----+       +----+----+                   --   |     free|dirty  |         |   

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线成人午夜影院| 亚洲综合久久久久| 一区二区三区在线免费| 丝袜诱惑制服诱惑色一区在线观看 | 激情深爱一区二区| 色8久久精品久久久久久蜜| 欧美成人女星排行榜| 一区二区三区四区中文字幕| 久久精品国产99国产| 91久久精品国产91性色tv | 国精品**一区二区三区在线蜜桃| 色素色在线综合| 国产欧美精品一区二区色综合朱莉| 亚洲综合一区二区| 大胆欧美人体老妇| www国产精品av| 日韩激情视频在线观看| 一本大道久久a久久综合婷婷| www一区二区| 精品在线你懂的| 欧美剧情片在线观看| 亚洲精品乱码久久久久久黑人 | 色爱区综合激月婷婷| 国产精品丝袜黑色高跟| 精品一区二区在线观看| 欧美久久久久免费| 午夜在线电影亚洲一区| 色婷婷亚洲一区二区三区| 国产精品久久久久久久久免费桃花| 国内精品不卡在线| 久久伊99综合婷婷久久伊| 青青草成人在线观看| 欧美一区日韩一区| 日韩精品国产欧美| 欧美一二三区在线观看| 日韩高清不卡一区| 日韩欧美二区三区| 久久99精品久久久久婷婷| 欧美一区二区日韩| 国产综合色产在线精品 | 欧美久久久影院| 亚洲成人自拍网| 69av一区二区三区| 美女性感视频久久| 久久众筹精品私拍模特| 国产精品一线二线三线精华| 久久精品欧美日韩| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 国产成人精品免费在线| 国产精品福利电影一区二区三区四区| www.亚洲免费av| 亚洲一区二区三区免费视频| 欧美日韩精品一区二区三区| 美女视频网站久久| 国产日韩欧美麻豆| 色88888久久久久久影院按摩| 亚洲大片精品永久免费| 精品黑人一区二区三区久久| 国产乱码精品一区二区三区忘忧草 | 香蕉久久夜色精品国产使用方法| 北条麻妃一区二区三区| 国产精品区一区二区三| 大尺度一区二区| 亚洲色图视频免费播放| 色又黄又爽网站www久久| 亚洲免费观看视频| 欧美综合在线视频| 午夜精品免费在线| 精品人伦一区二区色婷婷| 久久精品国产一区二区三| 日韩色视频在线观看| 国产在线看一区| 国产精品午夜春色av| av一二三不卡影片| 亚洲夂夂婷婷色拍ww47| 91精品国产欧美一区二区成人| 国产一区二区三区在线观看精品 | 欧美videos大乳护士334| 国产馆精品极品| 亚洲男人的天堂在线aⅴ视频 | 亚洲精品免费看| 国产精品一级片| 亚洲欧美日韩精品久久久久| 在线区一区二视频| 麻豆精品新av中文字幕| 国产欧美精品一区| 欧美在线制服丝袜| 精品伊人久久久久7777人| 国产欧美日韩精品一区| av电影在线观看一区| 亚洲三级小视频| 久久精品免费在线观看| 欧美性大战久久久久久久| 久久国产免费看| 中文字幕五月欧美| 日韩一级片网站| 99精品国产91久久久久久| 首页国产欧美久久| 国产精品蜜臀av| 欧美日韩国产a| 久久国产精品免费| 亚洲国产日韩精品| 欧美亚一区二区| 高清shemale亚洲人妖| 亚洲成人精品在线观看| 国产色一区二区| 欧美日韩免费电影| 成人免费毛片高清视频| 青青草91视频| 亚洲午夜免费福利视频| 日韩一区二区三区三四区视频在线观看| 99久久综合精品| 久久国产乱子精品免费女| 亚洲午夜精品网| 亚洲卡通动漫在线| 国产欧美一区二区精品性| 日韩手机在线导航| 欧美私人免费视频| 99久久精品99国产精品| 久久精品国产亚洲a| 激情欧美一区二区| 日韩av在线播放中文字幕| 亚洲精品欧美专区| 亚洲欧洲国产日本综合| 国产亚洲成av人在线观看导航| 日韩欧美一级二级三级久久久| 欧美亚洲动漫另类| 在线日韩av片| 色噜噜狠狠色综合欧洲selulu| 国产精品亚洲视频| 国产不卡视频在线观看| 国产尤物一区二区在线| 日本成人在线不卡视频| 蜜臀久久99精品久久久久久9 | 91精品国产免费久久综合| 欧美无砖专区一中文字| 欧美在线视频不卡| 色8久久人人97超碰香蕉987| 色综合久久综合网| 在线国产电影不卡| 欧美日韩亚洲综合在线 | 日韩精品一区在线观看| 日韩一区二区视频在线观看| 欧美一区二区不卡视频| 欧美大片顶级少妇| 日韩欧美黄色影院| 国产精品国产三级国产a| 国产精品二区一区二区aⅴ污介绍| 中文字幕在线不卡| 亚洲国产日韩av| 天天亚洲美女在线视频| 美日韩一区二区三区| 国内精品免费**视频| 国产xxx精品视频大全| 国产91精品在线观看| 91一区二区三区在线观看| 91高清视频在线| 91精品国产色综合久久ai换脸 | 国产电影精品久久禁18| 成人av在线观| 欧美伊人精品成人久久综合97| 欧美日韩一区小说| 精品欧美乱码久久久久久1区2区| 日韩欧美视频在线| 久久久精品日韩欧美| 亚洲精品亚洲人成人网| 亚洲444eee在线观看| 国产剧情一区在线| 91免费观看在线| 日韩视频免费观看高清在线视频| 久久久不卡影院| 亚洲黄色小说网站| 国产精品18久久久久| 色婷婷综合五月| 日韩欧美一区在线| 日韩伦理电影网| 六月丁香综合在线视频| 99精品偷自拍| 欧美va亚洲va香蕉在线| 国产精品乱码人人做人人爱| 亚洲小说欧美激情另类| 国产成人av电影在线| 欧美三日本三级三级在线播放| 欧美精品一区男女天堂| 亚洲视频在线观看一区| 久久精品99久久久| 国产激情精品久久久第一区二区| 成人动漫av在线| 精品欧美乱码久久久久久1区2区| 亚洲精品国产第一综合99久久| 麻豆91精品视频| 91电影在线观看| 国产精品视频yy9299一区| 蜜乳av一区二区| 97久久超碰精品国产| 亚洲视频中文字幕| 国产高清成人在线| 日韩亚洲欧美高清| 性久久久久久久久久久久| 99久久国产免费看|