source: trunk/IPs/systemC/Environment/Cache/include/Cache_OneLevel.h @ 80

Last change on this file since 80 was 80, checked in by rosiere, 16 years ago

Oups, Environnement is french :P

File size: 2.4 KB
Line 
1#ifndef ENVIRONMENT_CACHE_CACHE_ONELEVEL_H
2#define ENVIRONMENT_CACHE_CACHE_ONELEVEL_H
3
4#include "Cache_OneLevel_Access_Port.h"
5#include "Cache_OneLevel_Address.h"
6#include "Cache_OneLevel_Tag.h"
7#include "Cache_OneLevel_Write_Buffer.h"
8#include "Cache_OneLevel_Parameters.h"
9#include "../../Queue/include/Sort_Queue_Dynamic.h"
10
11namespace environment {
12namespace cache {
13namespace cache_onelevel {
14
15  class Cache_OneLevel
16  {
17  protected : std::string    name;
18  protected : Parameters   * param;
19  private   : Tag         ** tag;
20  private   : Access_Port  * access_port;
21  private   : Address        size_address;
22  private   : queue::Sort_Queue_Dynamic<Write_Buffer> * write_buffer;
23
24  protected : queue::Parameters * param_write_buffer;
25
26  public    :  Cache_OneLevel (std::string name,
27                            Parameters * param);
28
29  public    : ~Cache_OneLevel (void);
30
31
32
33  public    : void             reset             (void);
34  public    : void             transition        (void);
35  private   : void             update_lru        (uint32_t familly, uint32_t num_associativity);
36  private   : uint32_t         index_victim      (uint32_t familly);
37  private   : Address          translate_address (uint32_t address);
38  public    : type_rsp_cache_t access            (uint32_t num_port, uint32_t address, uint32_t trdid, type_req_cache_t type, direction_req_cache_t dir);
39  private   : type_rsp_cache_t access_cached     (uint32_t num_port, uint32_t address, uint32_t trdid,                        direction_req_cache_t dir);
40  private   : type_rsp_cache_t access_uncached   (uint32_t num_port, uint32_t address, uint32_t trdid);
41  private   : type_rsp_cache_t access_invalidate (uint32_t num_port, uint32_t address, uint32_t trdid);
42  private   : type_rsp_cache_t access_flush      (uint32_t num_port, uint32_t address, uint32_t trdid);
43  private   : uint32_t         hit_write_buffer  (uint32_t trdid, Address address);
44  private   : uint32_t         hit_cache         (uint32_t trdid, Address address);
45  private   : uint32_t         hit_access_port   (uint32_t trdid, Address address);
46  public    : uint32_t         need_slot         (void);
47  public    : uint32_t         latence           (uint32_t num_port);
48  public    : uint32_t         update_latence    (uint32_t num_port, uint32_t latence);
49  public    : std::string      information       (uint32_t depth);
50
51  public    : friend std::ostream& operator<< (std::ostream& output, Cache_OneLevel & x);
52    };
53
54};
55};
56};
57#endif
Note: See TracBrowser for help on using the repository browser.