misc: Reorder sources in util/tlm and rewrite build scripts
[gem5.git] / util / tlm / conf / tlm_master.py
1 #
2 # Copyright (c) 2016, Dresden University of Technology (TU Dresden)
3 # All rights reserved.
4 #
5 # Redistribution and use in source and binary forms, with or without
6 # modification, are permitted provided that the following conditions are
7 # met:
8 #
9 # 1. Redistributions of source code must retain the above copyright notice,
10 # this list of conditions and the following disclaimer.
11 #
12 # 2. Redistributions in binary form must reproduce the above copyright
13 # notice, this list of conditions and the following disclaimer in the
14 # documentation and/or other materials provided with the distribution.
15 #
16 # 3. Neither the name of the copyright holder nor the names of its
17 # contributors may be used to endorse or promote products derived from
18 # this software without specific prior written permission.
19 #
20 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
22 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER
24 # OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25 # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26 # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27 # PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
28 # LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
29 # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30 # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 #
32 # Authors: Christian Menard
33 #
34
35 import m5
36 from m5.objects import *
37
38 import os
39
40 # Base System Architecture:
41 # +-----+ ^
42 # | TLM | | TLM World
43 # +--+--+ | (see main.cc)
44 # | v
45 # +----------v-----------+ External Port (see sc_master_port.*)
46 # | Membus | ^
47 # +----------+-----------+ |
48 # | | gem5 World
49 # +---v----+ |
50 # | Memory | |
51 # +--------+ v
52 #
53
54 # Create a system with a Crossbar and a simple Memory:
55 system = System()
56 system.membus = IOXBar(width = 16)
57 system.physmem = SimpleMemory(range = AddrRange('512MB'))
58 system.clk_domain = SrcClockDomain(clock = '1.5GHz',
59 voltage_domain = VoltageDomain(voltage = '1V'))
60
61 # Create a external TLM port:
62 system.tlm = ExternalMaster()
63 system.tlm.port_type = "tlm_master"
64 system.tlm.port_data = "transactor"
65
66 # Route the connections:
67 system.system_port = system.membus.slave
68 system.physmem.port = system.membus.master
69 system.tlm.port = system.membus.slave
70 system.mem_mode = 'timing'
71
72 # Start the simulation:
73 root = Root(full_system = False, system = system)
74 m5.instantiate()
75 m5.simulate()