联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> C/C++编程C/C++编程

日期:2018-11-23 10:48

Lab 2: Cache Simulator

In this lab assignment, you will implement a two-level (L1 and L2) cache simulator in C++. The

cache simulator will take several parameters describing the cache (block size, associativity, etc)

along with a memory access trace file for an input program.

Cache Design

Read Miss: on a read miss, the cache issues a read request for the data

from the lower level of the cache. Once the data is returned, it is placed in

an empty way, if one exists, or data in one of the ways is evicted to create

room for the new data.

The ways of the cache are numbered from {0,1,2..W-1} for a W-way

cache. If an empty way exists, data is placed in lowest numbered

empty way.

Eviction is performed based on LRU policy. [Note, in this lab you are

expected to emulate the exact LRU policy, not hierarchical LRU]

Write Hit: both the L1 and L2 caches are write-through caches.

Write Miss: both the L1 and L2 caches are write no-allocate caches. On a

write miss, the write request is forwarded to the lower level of the cache.

Non-Inclusive: the L1 and L2 caches are non-inclusive.

Configuration File (config.txt):

The parameters of the L1 and L2 caches are specified in a configuration file. The format of the

configuration file is as follows.

Block size: Specifies the block size for the cache in bytes. This should always be a nonnegative

power of 2 (i.e., 1, 2, 4, 8, etc).

Associativity: Specifies the associativity of the cache. A value of "1" implies a directmapped

cache, while a "0" value implies fully-associative. Should always be a nonnegative

power of 2.

Cache size: Specifies the total size of the cache data array in KB.

An example config file is provided below. It specifies a 16KB direct-mapped L1 cache with 8 byte

blocks, and a 32KB 4-way set associative L2 cache with 16 byte blocks

Sample configuration file for L1 and L2 Cache:

L1:

8

1

16

L2:

16

4

32

The skeleton code provided reads the config file and initializes variables for the L1 and L2 cache

parameters.

Trace File (trace.txt):

Your simulator will need to take as input a trace file that will be used to compute the output

statistics. The trace file will specify all the data memory accesses that occur in the sample

program. Each line in the trace file will specify a new memory reference. Each line in the trace

cache will therefore have the following two fields:

Access Type: A single character indicating whether the access is a read (‘R') or a write

('W').

Address: A 32-bit integer (in unsigned hexidecimal format) specifying the memory

address that is being accessed.

Fields on the same line are separated by a single space.

The skeleton code provided reads the trace file one line at a time in order. After each access,

your code should emulate the impact of the access on the cache hierarchy.

Simulator Output:

For each cache access, your simulator must output whether the access caused a read or write

hit or miss in the L1 and L2 caches, or, in the L2 cache, it it was not accessed. Each event is

coded with a number, as shown below.

0: No Access

1: Read Hit

2: Read Miss

3: Write Hit

4: Write Miss

For example, if a read access Misses in the L1 cache but hits in the L2 cache, your simulator

would output:

2 1

where the first number corresponds to the L1 cache event and the second to the L2 cache

event.

(Note: when there is a read miss in L1 and read hit in L2, the L1 cache might have to evict some

data to make room for the data returned by the L2 cache.)

What you need to submit:

Your source code

A readme.txt with instructions on how to compile your code


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp