SConscript revision 11692
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('GPUStaticInstFlags.py')
45SimObject('LdsState.py')
46SimObject('X86GPUTLB.py')
47
48if env['TARGET_GPU_ISA'] == 'hsail':
49    Source('brig_object.cc')
50    Source('hsail_code.cc')
51
52Source('cl_driver.cc')
53Source('compute_unit.cc')
54Source('condition_register_state.cc')
55Source('dispatcher.cc')
56Source('exec_stage.cc')
57Source('fetch_stage.cc')
58Source('fetch_unit.cc')
59Source('global_memory_pipeline.cc')
60Source('gpu_dyn_inst.cc')
61Source('gpu_exec_context.cc')
62Source('gpu_static_inst.cc')
63Source('gpu_tlb.cc')
64Source('hsa_object.cc')
65Source('kernel_cfg.cc')
66Source('lds_state.cc')
67Source('local_memory_pipeline.cc')
68Source('of_scheduling_policy.cc')
69Source('pool_manager.cc')
70Source('rr_scheduling_policy.cc')
71Source('schedule_stage.cc')
72Source('scheduler.cc')
73Source('scoreboard_check_stage.cc')
74Source('shader.cc')
75Source('simple_pool_manager.cc')
76Source('tlb_coalescer.cc')
77Source('vector_register_file.cc')
78Source('vector_register_state.cc')
79Source('wavefront.cc')
80
81DebugFlag('BRIG')
82DebugFlag('GPUCoalescer')
83DebugFlag('GPUDisp')
84DebugFlag('GPUExec')
85DebugFlag('GPUFetch')
86DebugFlag('GPUHsailCFInfo')
87DebugFlag('GPUMem')
88DebugFlag('GPUPort')
89DebugFlag('GPUPrefetch')
90DebugFlag('GPUReg')
91DebugFlag('GPUSync')
92DebugFlag('GPUTLB')
93DebugFlag('GPUVRF')
94DebugFlag('HSALoader')
95DebugFlag('HSAIL')
96DebugFlag('HSAILObject')
97DebugFlag('Predictor')
98DebugFlag('WavefrontStack')
99
100CompoundFlag('GPUALL', ['GPUCoalescer', 'GPUDisp', 'GPUExec', 'GPUFetch',
101                        'GPUMem', 'GPUPort', 'GPUSync', 'GPUTLB', 'HSAIL',
102                        'GPUVRF'])
103