ChampSim
environment.h
Go to the documentation of this file.
1 /*
2  * Copyright 2023 The ChampSim Contributors
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef ENVIRONMENT_H
18 #define ENVIRONMENT_H
19 
20 #include <functional>
21 #include <vector>
22 
23 #include "cache.h"
24 #include "dram_controller.h"
25 #include "ooo_cpu.h"
26 #include "operable.h"
27 #include "ptw.h"
28 
29 namespace champsim
30 {
31 struct environment {
32  virtual std::vector<std::reference_wrapper<O3_CPU>> cpu_view() = 0;
33  virtual std::vector<std::reference_wrapper<CACHE>> cache_view() = 0;
34  virtual std::vector<std::reference_wrapper<PageTableWalker>> ptw_view() = 0;
35  virtual MEMORY_CONTROLLER& dram_view() = 0;
36  virtual std::vector<std::reference_wrapper<operable>> operable_view() = 0;
37 };
38 } // namespace champsim
39 
40 #endif
Definition: dram_controller.h:86
Definition: champsim.h:24
Definition: environment.h:31
virtual std::vector< std::reference_wrapper< CACHE > > cache_view()=0
virtual std::vector< std::reference_wrapper< PageTableWalker > > ptw_view()=0
virtual MEMORY_CONTROLLER & dram_view()=0
virtual std::vector< std::reference_wrapper< O3_CPU > > cpu_view()=0
virtual std::vector< std::reference_wrapper< operable > > operable_view()=0