source: trunk/IPs/systemC/processor/Morpheo/Behavioural/Generic/RegisterFile/RegisterFile_Multi_Banked/src/RegisterFile_Multi_Banked.cpp @ 15

Last change on this file since 15 was 15, checked in by rosiere, 17 years ago

Interface normalisé
Début du banc de registres multi niveaux

File size: 3.1 KB
Line 
1/*
2 * $Id$
3 *
4 * [ Description ]
5 *
6 */
7
8#include "Behavioural/Generic/RegisterFile/RegisterFile_Multi_Banked/include/RegisterFile_Multi_Banked.h"
9
10namespace morpheo                    {
11namespace behavioural {
12namespace generic {
13namespace registerfile {
14namespace registerfile_multi_banked {
15
16
17#ifdef SYSTEMC
18  RegisterFile_Multi_Banked::RegisterFile_Multi_Banked (sc_module_name name,
19#else
20  RegisterFile_Multi_Banked::RegisterFile_Multi_Banked (string name,
21#endif
22#ifdef STATISTICS
23                              morpheo::behavioural::Parameters_Statistics             param_statistics,
24#endif
25                              morpheo::behavioural::generic::registerfile::registerfile_multi_banked::Parameters param ):
26                              _name              (name)
27                              ,_param            (param)
28// #ifdef STATISTICS
29//                            ,_param_statistics (param_statistics)
30// #endif
31  {
32    log_printf(FUNC,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","Begin");
33
34#ifdef STATISTICS
35    log_printf(INFO,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","Allocation of statistics");
36
37    // Allocation of statistics
38    _stat = new Statistics (static_cast<string>(_name),
39                            param_statistics          ,
40                            param);
41#endif
42
43#ifdef VHDL_TESTBENCH
44    log_printf(INFO,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","Creation of a testbench");
45
46    // Creation of a testbench
47    //  -> port
48    //  -> clock's signals
49    _vhdl_testbench = new Vhdl_Testbench (_name);
50    //vhdl_testbench_port           ();
51    _vhdl_testbench->set_clock    ("in_CLOCK",true);
52#endif
53
54#ifdef VHDL
55    // generate the vhdl
56    log_printf(INFO,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","Generate the vhdl");
57
58    vhdl();
59#endif
60
61#ifdef SYSTEMC
62    log_printf(INFO,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","Allocation");
63
64    allocation ();
65
66//#if defined(STATISTICS) or defined(VHDL_TESTBENCH)
67    log_printf(INFO,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","Method - transition");
68
69    SC_METHOD (transition);
70    dont_initialize ();
71    sensitive_pos << *(in_CLOCK);
72//#endif
73
74#ifdef SYSTEMCASS_SPECIFIC
75    // List dependency information
76#endif   
77
78#endif
79    log_printf(FUNC,RegisterFile_Multi_Banked,"RegisterFile_Multi_Banked","End");
80  };
81 
82  RegisterFile_Multi_Banked::~RegisterFile_Multi_Banked (void)
83  {
84    log_printf(FUNC,RegisterFile_Multi_Banked,"~RegisterFile_Multi_Banked","Begin");
85
86#ifdef VHDL_TESTBENCH
87    log_printf(INFO,RegisterFile_Multi_Banked,"~RegisterFile_Multi_Banked","Generate Testbench  file");
88
89    // generate the test bench
90    _vhdl_testbench->generate_file();
91    delete _vhdl_testbench;
92#endif
93
94#ifdef STATISTICS
95    log_printf(INFO,RegisterFile_Multi_Banked,"~RegisterFile_Multi_Banked","Generate Statistics file");
96
97    _stat->generate_file(statistics(0));
98   
99    delete _stat;
100#endif
101
102#ifdef SYSTEMC
103    log_printf(INFO,RegisterFile_Multi_Banked,"~RegisterFile_Multi_Banked","Deallocation");
104
105    deallocation ();
106#endif
107
108    log_printf(FUNC,RegisterFile_Multi_Banked,"~RegisterFile_Multi_Banked","End");
109  };
110
111}; // end namespace registerfile_multi_banked
112}; // end namespace registerfile
113}; // end namespace generic
114
115}; // end namespace behavioural
116}; // end namespace morpheo             
Note: See TracBrowser for help on using the repository browser.