1#!python
2
3# Copyright (c) 2016, Dresden University of Technology (TU Dresden)
4# All rights reserved.
5#
6# Redistribution and use in source and binary forms, with or without
7# modification, are permitted provided that the following conditions are
8# met:
9#
10# 1. Redistributions of source code must retain the above copyright notice,
11#    this list of conditions and the following disclaimer.
12#
13# 2. Redistributions in binary form must reproduce the above copyright
14#    notice, this list of conditions and the following disclaimer in the
15#    documentation and/or other materials provided with the distribution.
16#
17# 3. Neither the name of the copyright holder nor the names of its
18#    contributors may be used to endorse or promote products derived from
19#    this software without specific prior written permission.
20#
21# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
23# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
24# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER
25# OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
26# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
28# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
29# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
30# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
31# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32#
33# Authors: Christian Menard
34
35Import('env')
36
37env = env.Clone()
38
39gem5_root = env['GEM5_ROOT']
40
41systemc_util_dir = gem5_root + '/util/systemc/gem5_within_systemc'
42
43systemc_src = []
44systemc_src += Install('.', systemc_util_dir + '/sc_gem5_control.cc'),
45systemc_src += Install('.', systemc_util_dir + '/sc_logger.cc'),
46systemc_src += Install('.', systemc_util_dir + '/sc_module.cc'),
47systemc_src += Install('.', systemc_util_dir + '/stats.cc'),
48
49tlm_src = []
50tlm_src += [File('master_transactor.cc')]
51tlm_src += [File('sc_ext.cc')]
52tlm_src += [File('sc_master_port.cc')]
53tlm_src += [File('sc_mm.cc')]
54tlm_src += [File('sc_slave_port.cc')]
55tlm_src += [File('sim_control.cc')]
56tlm_src += [File('slave_transactor.cc')]
57
58tlm = env.Library('gem5_tlm', tlm_src + systemc_src)
59
60Return('tlm')
61