1/*****************************************************************************
2 *                                McPAT
3 *                      SOFTWARE LICENSE AGREEMENT
4 *            Copyright (c) 2010-2013 Advanced Micro Devices, Inc.
5 *                          All Rights Reserved
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
9 * met: redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer;
11 * redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution;
14 * neither the name of the copyright holders nor the names of its
15 * contributors may be used to endorse or promote products derived from
16 * this software without specific prior written permission.
17
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 *
30 * Authors: Joel Hestness
31 *          Yasuko Eckert
32 *
33 ***************************************************************************/
34
35#ifndef SYSTEM_H_
36#define SYSTEM_H_
37
38#include "arbiter.h"
39#include "area.h"
40#include "array.h"
41#include "basic_components.h"
42#include "bus_interconnect.h"
43#include "cachecontroller.h"
44#include "cacheunit.h"
45#include "core.h"
46#include "decoder.h"
47#include "iocontrollers.h"
48#include "memoryctrl.h"
49#include "noc.h"
50#include "parameter.h"
51#include "router.h"
52
53class System : public McPATComponent {
54public:
55    InputParameter interface_ip;
56
57    int device_type;
58    double core_tech_node;
59    int interconnect_projection_type;
60    int temperature;
61
62    System(XMLNode* _xml_data);
63    void set_proc_param();
64    // TODO: make this recursively compute energy on subcomponents
65    void displayData(uint32_t indent = 0, int plevel = 100);
66    void displayDeviceType(int device_type_, uint32_t indent = 0);
67    void displayInterconnectType(int interconnect_type_, uint32_t indent = 0);
68    ~System();
69};
70
71#endif /* SYSTEM_H_ */
72