SConscript revision 11642
1# -*- mode:python -*-
2
3#
4#  Copyright (c) 2015 Advanced Micro Devices, Inc.
5#  All rights reserved.
6#
7#  For use for simulation and test purposes only
8#
9#  Redistribution and use in source and binary forms, with or without
10#  modification, are permitted provided that the following conditions are met:
11#
12#  1. Redistributions of source code must retain the above copyright notice,
13#  this list of conditions and the following disclaimer.
14#
15#  2. Redistributions in binary form must reproduce the above copyright notice,
16#  this list of conditions and the following disclaimer in the documentation
17#  and/or other materials provided with the distribution.
18#
19#  3. Neither the name of the copyright holder nor the names of its contributors
20#  may be used to endorse or promote products derived from this software
21#  without specific prior written permission.
22#
23#  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
24#  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25#  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26#  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
27#  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28#  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29#  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30#  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31#  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32#  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33#  POSSIBILITY OF SUCH DAMAGE.
34#
35#  Author: Anthony Gutierrez
36#
37
38Import('*')
39
40if not env['BUILD_GPU']:
41    Return()
42
43SimObject('GPU.py')
44SimObject('LdsState.py')
45SimObject('X86GPUTLB.py')
46
47if env['TARGET_GPU_ISA'] == 'hsail':
48    Source('brig_object.cc')
49    Source('hsail_code.cc')
50
51Source('cl_driver.cc')
52Source('compute_unit.cc')
53Source('condition_register_state.cc')
54Source('dispatcher.cc')
55Source('exec_stage.cc')
56Source('fetch_stage.cc')
57Source('fetch_unit.cc')
58Source('global_memory_pipeline.cc')
59Source('gpu_dyn_inst.cc')
60Source('gpu_exec_context.cc')
61Source('gpu_static_inst.cc')
62Source('gpu_tlb.cc')
63Source('hsa_object.cc')
64Source('kernel_cfg.cc')
65Source('lds_state.cc')
66Source('local_memory_pipeline.cc')
67Source('of_scheduling_policy.cc')
68Source('pool_manager.cc')
69Source('rr_scheduling_policy.cc')
70Source('schedule_stage.cc')
71Source('scheduler.cc')
72Source('scoreboard_check_stage.cc')
73Source('shader.cc')
74Source('simple_pool_manager.cc')
75Source('tlb_coalescer.cc')
76Source('vector_register_file.cc')
77Source('vector_register_state.cc')
78Source('wavefront.cc')
79
80DebugFlag('BRIG')
81DebugFlag('GPUCoalescer')
82DebugFlag('GPUDisp')
83DebugFlag('GPUExec')
84DebugFlag('GPUFetch')
85DebugFlag('GPUHsailCFInfo')
86DebugFlag('GPUMem')
87DebugFlag('GPUPort')
88DebugFlag('GPUPrefetch')
89DebugFlag('GPUReg')
90DebugFlag('GPUSync')
91DebugFlag('GPUTLB')
92DebugFlag('GPUVRF')
93DebugFlag('HSALoader')
94DebugFlag('HSAIL')
95DebugFlag('HSAILObject')
96DebugFlag('Predictor')
97DebugFlag('WavefrontStack')
98
99CompoundFlag('GPUALL', ['GPUCoalescer', 'GPUDisp', 'GPUExec', 'GPUFetch',
100                        'GPUMem', 'GPUPort', 'GPUSync', 'GPUTLB', 'HSAIL',
101                        'GPUVRF'])
102