- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第四章‐实验2
基本Cache的实现
班级:1303101
姓名:李明远
学号:1130310126
一、 实验要求:
在实现存储芯片的基础上,按照P112,图4.50实现cache的基本功能,其中替换机构和地址映射的方式可以自定。
二、 实验原理
P112,图4.50 Cache基本结构如下:
三、实验设计
主存采用长度为256的向量数组实现(向量长度为4,表示字长为4);
Cache采用长度为16的向量数组实现。
Cache-主存地址映射采用直接映射方式:
设置act变量表示读或写操作,hit变量表示cpu进行读操作时是否命中,并设置大小和Cache一致的标记数组表示标记块。
进行读操作时,通过主存高位地址和标记数组进行比较判断是否命中,若命中则直接读取;否则将字块调入Cache。
进行写操作时,将数据写入Cache,标记为存入高位地址,然后将字块调入主存。
四、 程序设计框图
五、 程序代码
library IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_ARITH.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
-- Uncomment the following library declaration if using
-- arithmetic functions with Signed or Unsigned values
--use IEEE.NUMERIC_STD.ALL;
-- Uncomment the following library declaration if instantiating
-- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;
entity code is
Port (
clk : in STD_LOGIC;
Initial : in STD_LOGIC;
act : in STD_LOGIC;
hit : out STD_LOGIC;
high_order : in STD_LOGIC_VECTOR (3 downto 0);
low_order : in STD_LOGIC_VECTOR (3 downto 0);
input : in STD_LOGIC_VECTOR (3 downto 0);
output : out STD_LOGIC_VECTOR (3 downto 0);
);
end code;
architecture Behavioral of code is
type M_mem is array(255 downto 0) of std_logic_vector(3 downto 0);
type Cache is array(15 downto 0) of std_logic_vector(3 downto 0);
shared variable MainMem: M_mem;
shared variable CacheMem: Cache;
shared variable Mark: Cache;
signal flag: std_logic;
signal data_show:std_logic_vector(3 downto 0);
begin
hit=flag;
output=data_show;
process(Initial)
begin
for i in 0 to 225 loop
MainMem(i):=0000;
if i16 then
CacheMem(i):=0000;
Mark(i):=0000;
end if;
end loop;
end process;
process(clk)
begin
if rising_edge(clk) then
if act=0 then
if Mark(conv_integer(low_order))=high_order then
flag=1;
else
flag=0;
CacheMem(conv_integer(low_order)):=MainMem(cont_integer(high_order)*16+conv_integer(low_order));
Mark(conv_integer(low_order)):=high_order;
end if;
data_show=CacheMem(conv_integer(low_order));
else
if Mark(conv_integer(low_order))=high_order t
您可能关注的文档
- 联络通道施工方案(7.1按专家意见改)研讨.doc
- 锅炉炉管泄漏监测系统用户使用手册研讨.doc
- 《陈情表》拓展课正式解答.ppt
- 电子电气元器件说明大全研讨.doc
- 电子高新技术产品逆向物流模式论文附属研讨.doc
- 廉租房施工方案研讨.doc
- 《陈涉世家》第二课时4解答.ppt
- 练习含成本(确认稿)研讨.doc
- 电子工艺实训研讨.doc
- 第三章风力发电机组的特性范例.pptx
- 金融产品2024年投资策略报告:积极适应市场风格,行为金融+机器学习新发现.pdf
- 交运物流2024年度投资策略:转型十字路,峰回路又转(2023120317).pdf
- 建材行业2024年投资策略报告:板块持续磨底,重点关注需求侧复苏.pdf
- 宏观2024年投资策略报告:复苏之路.pdf
- 光储氢2024年投资策略报告:复苏在春季,需求的非线性增长曙光初现.pdf
- 公用环保2024年投资策略报告:电改持续推进,火电盈利稳定性有望进一步提升.pdf
- 房地产2024年投资策略报告:聚焦三大工程,静待需求修复.pdf
- 保险2024年投资策略报告:资产负债匹配穿越利率周期.pdf
- 政策研究2024年宏观政策与经济形势展望:共识与分歧.pdf
- 有色金属行业2024年投资策略报告:新旧需求共振&工业原料受限,构筑有色大海星辰.pdf
文档评论(0)