1Import('*') 2 3from sys import executable as python_cmd 4import os.path 5import distutils.version 6 7if not env['swr']: 8 Return() 9 10if not env['llvm']: 11 print('warning: LLVM disabled: not building swr') 12 env['swr'] = False 13 Return() 14 15if env['LLVM_VERSION'] < distutils.version.LooseVersion('3.9'): 16 print("warning: swr requires LLVM >= 3.9: not building swr") 17 env['swr'] = False 18 Return() 19 20env.MSVC2013Compat() 21 22env = env.Clone() 23 24# construct llvm include dir 25if env['platform'] == 'windows': 26 # on windows there is no llvm-config, so LLVM is defined 27 llvm_includedir = os.path.join(os.environ['LLVM'], 'include') 28else: 29 llvm_config = os.environ.get('LLVM_CONFIG', 'llvm-config') 30 llvm_includedir = env.backtick('%s --includedir' % llvm_config).rstrip() 31 print("llvm include dir %s" % llvm_includedir) 32 33if not env['msvc'] : 34 env.Append(CCFLAGS = [ 35 '-std=c++11', 36 ]) 37 38swrroot = '#src/gallium/drivers/swr/' 39bldroot = Dir('.').abspath 40 41env.CodeGenerate( 42 target = 'rasterizer/codegen/gen_knobs.cpp', 43 script = swrroot + 'rasterizer/codegen/gen_knobs.py', 44 source = '', 45 command = python_cmd + ' $SCRIPT --output $TARGET --gen_cpp' 46) 47Depends('rasterizer/codegen/gen_knobs.cpp', 48 swrroot + 'rasterizer/codegen/templates/gen_knobs.cpp') 49 50env.CodeGenerate( 51 target = 'rasterizer/codegen/gen_knobs.h', 52 script = swrroot + 'rasterizer/codegen/gen_knobs.py', 53 source = '', 54 command = python_cmd + ' $SCRIPT --output $TARGET --gen_h' 55) 56Depends('rasterizer/codegen/gen_knobs.h', 57 swrroot + 'rasterizer/codegen/templates/gen_knobs.h') 58 59env.CodeGenerate( 60 target = 'rasterizer/jitter/gen_state_llvm.h', 61 script = swrroot + 'rasterizer/codegen/gen_llvm_types.py', 62 source = 'rasterizer/core/state.h', 63 command = python_cmd + ' $SCRIPT --input $SOURCE --output $TARGET' 64) 65Depends('rasterizer/jitter/gen_state_llvm.h', 66 swrroot + 'rasterizer/codegen/templates/gen_llvm.hpp') 67 68env.CodeGenerate( 69 target = 'rasterizer/jitter/gen_builder.hpp', 70 script = swrroot + 'rasterizer/codegen/gen_llvm_ir_macros.py', 71 source = os.path.join(llvm_includedir, 'llvm/IR/IRBuilder.h'), 72 command = python_cmd + ' $SCRIPT --input $SOURCE --output ' + bldroot + '/rasterizer/jitter --gen_h' 73) 74Depends('rasterizer/jitter/gen_builder.hpp', 75 swrroot + 'rasterizer/codegen/templates/gen_builder.hpp') 76 77env.CodeGenerate( 78 target = 'rasterizer/jitter/gen_builder_x86.hpp', 79 script = swrroot + 'rasterizer/codegen/gen_llvm_ir_macros.py', 80 source = '', 81 command = python_cmd + ' $SCRIPT --output ' + bldroot + '/rasterizer/jitter --gen_x86_h' 82) 83Depends('rasterizer/jitter/gen_builder.hpp', 84 swrroot + 'rasterizer/codegen/templates/gen_builder.hpp') 85 86env.CodeGenerate( 87 target = './gen_swr_context_llvm.h', 88 script = swrroot + 'rasterizer/codegen/gen_llvm_types.py', 89 source = 'swr_context.h', 90 command = python_cmd + ' $SCRIPT --input $SOURCE --output $TARGET' 91) 92Depends('rasterizer/jitter/gen_state_llvm.h', 93 swrroot + 'rasterizer/codegen/templates/gen_llvm.hpp') 94 95env.CodeGenerate( 96 target = 'rasterizer/archrast/gen_ar_event.hpp', 97 script = swrroot + 'rasterizer/codegen/gen_archrast.py', 98 source = 'rasterizer/archrast/events.proto', 99 command = python_cmd + ' $SCRIPT --proto $SOURCE --output $TARGET --gen_event_h' 100) 101Depends('rasterizer/jitter/gen_state_llvm.h', 102 swrroot + 'rasterizer/codegen/templates/gen_ar_event.hpp') 103 104env.CodeGenerate( 105 target = 'rasterizer/archrast/gen_ar_event.cpp', 106 script = swrroot + 'rasterizer/codegen/gen_archrast.py', 107 source = 'rasterizer/archrast/events.proto', 108 command = python_cmd + ' $SCRIPT --proto $SOURCE --output $TARGET --gen_event_cpp' 109) 110Depends('rasterizer/jitter/gen_state_llvm.h', 111 swrroot + 'rasterizer/codegen/templates/gen_ar_event.cpp') 112 113env.CodeGenerate( 114 target = 'rasterizer/archrast/gen_ar_eventhandler.hpp', 115 script = swrroot + 'rasterizer/codegen/gen_archrast.py', 116 source = 'rasterizer/archrast/events.proto', 117 command = python_cmd + ' $SCRIPT --proto $SOURCE --output $TARGET --gen_eventhandler_h' 118) 119Depends('rasterizer/jitter/gen_state_llvm.h', 120 swrroot + 'rasterizer/codegen/templates/gen_ar_eventhandler.hpp') 121 122env.CodeGenerate( 123 target = 'rasterizer/archrast/gen_ar_eventhandlerfile.hpp', 124 script = swrroot + 'rasterizer/codegen/gen_archrast.py', 125 source = 'rasterizer/archrast/events.proto', 126 command = python_cmd + ' $SCRIPT --proto $SOURCE --output $TARGET --gen_eventhandlerfile_h' 127) 128Depends('rasterizer/jitter/gen_state_llvm.h', 129 swrroot + 'rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp') 130 131# 5 SWR_MULTISAMPLE_TYPE_COUNT 132# 2 SWR_MSAA_SAMPLE_PATTERN_COUNT 133# 3 SWR_INPUT_COVERAGE_COUNT 134# 2 centroid 135# 2 forcedSampleCount 136# 2 canEarlyZ 137backendPixelRateFileCount = 4 138backendPixelRateFilePat = "rasterizer/core/backends/gen_BackendPixelRate%s.cpp" 139backendPixelRateFiles = list(backendPixelRateFilePat % x for x in range(0, backendPixelRateFileCount)) 140env.CodeGenerate( 141 target = 'rasterizer/core/backends/gen_BackendPixelRate.hpp', 142 script = swrroot + 'rasterizer/codegen/gen_backends.py', 143 source = '', 144 command = python_cmd + ' $SCRIPT --outdir ' + bldroot + '/rasterizer/core/backends --dim 5 2 3 2 2 2 --numfiles ' + str(backendPixelRateFileCount) + ' --cpp --hpp' 145 ) 146Depends(backendPixelRateFiles, 147 ['rasterizer/core/backends/gen_BackendPixelRate.hpp', 148 'rasterizer/archrast/gen_ar_event.hpp', 149 'rasterizer/archrast/gen_ar_eventhandler.hpp', 150 'rasterizer/codegen/gen_knobs.h'] 151 ) 152 153# 5 SWR_MULTISAMPLE_TYPE_COUNT 154# 2 CenterPattern 155# 2 Conservative 156# 3 SWR_INPUT_COVERAGE_COUNT 157# 5 STATE_VALID_TRI_EDGE_COUNT 158# 2 RasterScissorEdges 159genRasterizerFileCount = 4 160genRasterizerFilePat = "rasterizer/core/backends/gen_rasterizer%s.cpp" 161genRasterizerFiles = list(genRasterizerFilePat % x for x in range(0, genRasterizerFileCount)) 162env.CodeGenerate( 163 target = 'rasterizer/core/backends/gen_rasterizer.hpp', 164 script = swrroot + 'rasterizer/codegen/gen_backends.py', 165 source = '', 166 command = python_cmd + ' $SCRIPT --outdir ' + bldroot + '/rasterizer/core/backends --rast --dim 5 2 2 3 5 2 --numfiles ' + str(genRasterizerFileCount) + ' --cpp --hpp' 167 ) 168Depends(genRasterizerFiles, 169 ['rasterizer/core/backends/gen_rasterizer.hpp', 170 'rasterizer/archrast/gen_ar_event.hpp', 171 'rasterizer/archrast/gen_ar_eventhandler.hpp', 172 'rasterizer/codegen/gen_knobs.h'] 173 ) 174 175Depends('rasterizer/jitter/gen_state_llvm.h', 176 swrroot + 'rasterizer/codegen/templates/gen_backend.cpp') 177 178# Auto-generated .cpp files (that need to generate object files) 179built_sources = [ 180 'rasterizer/codegen/gen_knobs.cpp', 181 'rasterizer/archrast/gen_ar_event.cpp', 182 ] 183 184built_sources += [backendPixelRateFiles, genRasterizerFiles] 185 186source = built_sources 187source += env.ParseSourceList(swrroot + 'Makefile.sources', [ 188 'ARCHRAST_CXX_SOURCES', 189 'COMMON_CXX_SOURCES', 190 'CORE_CXX_SOURCES', 191 'MEMORY_CXX_SOURCES' 192]) 193 194env.Prepend(CPPPATH = [ 195 '.', 196 'rasterizer', 197 'rasterizer/codegen', 198 'rasterizer/core', 199 'rasterizer/jitter', 200 'rasterizer/archrast', 201 ]) 202 203# AVX lib 204envavx = env.Clone() 205 206envavx.Append(CPPDEFINES = ['KNOB_ARCH=KNOB_ARCH_AVX']) 207if env['platform'] == 'windows': 208 envavx.Append(CCFLAGS = ['/arch:AVX']) 209else: 210 envavx.Append(CCFLAGS = ['-mavx']) 211 212swrAVX = envavx.SharedLibrary( 213 target = 'swrAVX', 214 source = source, 215 OBJPREFIX = 'avx_' 216 ) 217env.Alias('swrAVX', swrAVX) 218 219# AVX2 lib 220envavx2 = env.Clone() 221 222envavx2.Append(CPPDEFINES = ['KNOB_ARCH=KNOB_ARCH_AVX2']) 223if env['platform'] == 'windows': 224 envavx2.Append(CCFLAGS = ['/arch:AVX2']) 225else: 226 envavx2.Append(CCFLAGS = ['-mavx2', '-mfma', '-mbmi2', '-mf16c']) 227 228swrAVX2 = envavx2.SharedLibrary( 229 target = 'swrAVX2', 230 source = source, 231 OBJPREFIX = 'avx2_' 232 ) 233env.Alias('swrAVX2', swrAVX2) 234 235source = env.ParseSourceList(swrroot + 'Makefile.sources', [ 236 'CXX_SOURCES', 237 'COMMON_CXX_SOURCES', 238 'JITTER_CXX_SOURCES', 239 'LOADER_SOURCES' 240]) 241source += [ 242 'rasterizer/codegen/gen_knobs.cpp', 243 'rasterizer/archrast/gen_ar_event.cpp', 244 ] 245 246# main SWR lib 247envSWR = envavx.Clone() # pick up the arch flag for intrinsic usage 248envSWR.Append(CPPDEFINES = ['HAVE_SWR_AVX', 'HAVE_SWR_AVX2']) 249swr = envSWR.ConvenienceLibrary( 250 target = 'swr', 251 source = source, 252 ) 253 254# treat arch libs as dependencies, even though they are not linked 255# into swr, so we don't have to build them separately 256Depends(swr, ['swrAVX', 'swrAVX2']) 257 258env.Alias('swr', swr) 259 260env.Prepend(LIBS = [swr]) 261 262Export('swr') 263