scons: Enable mesa state tracker in all platforms by default.
But only actually build it on some. This results in a better default scons experience.
This commit is contained in:
@@ -30,14 +30,15 @@ import common
|
|||||||
# Configuration options
|
# Configuration options
|
||||||
|
|
||||||
if common.default_platform in ('linux', 'freebsd', 'darwin'):
|
if common.default_platform in ('linux', 'freebsd', 'darwin'):
|
||||||
default_statetrackers = 'mesa'
|
default_statetrackers = 'all'
|
||||||
default_drivers = 'softpipe,failover,i915simple,i965simple'
|
default_drivers = 'softpipe,failover,i915simple,i965simple'
|
||||||
default_winsys = 'xlib'
|
default_winsys = 'xlib'
|
||||||
elif common.default_platform in ('winddk',):
|
elif common.default_platform in ('winddk',):
|
||||||
default_statetrackers = 'none'
|
default_statetrackers = 'all'
|
||||||
default_drivers = 'softpipe,i915simple'
|
default_drivers = 'softpipe,i915simple'
|
||||||
default_winsys = 'none'
|
default_winsys = 'none'
|
||||||
else:
|
else:
|
||||||
|
default_statetrackers = 'all'
|
||||||
default_drivers = 'all'
|
default_drivers = 'all'
|
||||||
default_winsys = 'all'
|
default_winsys = 'all'
|
||||||
|
|
||||||
|
@@ -4,307 +4,309 @@
|
|||||||
|
|
||||||
Import('*')
|
Import('*')
|
||||||
|
|
||||||
env = env.Clone()
|
if env['platform'] != 'winddk':
|
||||||
|
|
||||||
# Includes
|
env = env.Clone()
|
||||||
env.Append(CPPPATH = [
|
|
||||||
'#/src/mesa',
|
# Includes
|
||||||
'#/src/mesa/main',
|
env.Append(CPPPATH = [
|
||||||
])
|
'#/src/mesa',
|
||||||
|
'#/src/mesa/main',
|
||||||
if gcc:
|
|
||||||
env.Append(CFLAGS = [
|
|
||||||
'-std=c99',
|
|
||||||
])
|
])
|
||||||
|
|
||||||
# x86 assembly
|
if gcc:
|
||||||
if x86 and gcc:
|
env.Append(CFLAGS = [
|
||||||
env.Append(CPPDEFINES = [
|
'-std=c99',
|
||||||
'USE_X86_ASM',
|
])
|
||||||
'USE_MMX_ASM',
|
|
||||||
'USE_3DNOW_ASM',
|
# x86 assembly
|
||||||
'USE_SSE_ASM',
|
if x86 and gcc:
|
||||||
])
|
env.Append(CPPDEFINES = [
|
||||||
|
'USE_X86_ASM',
|
||||||
|
'USE_MMX_ASM',
|
||||||
#######################################################################
|
'USE_3DNOW_ASM',
|
||||||
# Core sources
|
'USE_SSE_ASM',
|
||||||
|
])
|
||||||
MAIN_SOURCES = [
|
|
||||||
'main/api_arrayelt.c',
|
|
||||||
'main/api_loopback.c',
|
#######################################################################
|
||||||
'main/api_noop.c',
|
# Core sources
|
||||||
'main/api_validate.c',
|
|
||||||
'main/accum.c',
|
MAIN_SOURCES = [
|
||||||
'main/attrib.c',
|
'main/api_arrayelt.c',
|
||||||
'main/arrayobj.c',
|
'main/api_loopback.c',
|
||||||
'main/blend.c',
|
'main/api_noop.c',
|
||||||
'main/bufferobj.c',
|
'main/api_validate.c',
|
||||||
'main/buffers.c',
|
'main/accum.c',
|
||||||
'main/clip.c',
|
'main/attrib.c',
|
||||||
'main/colortab.c',
|
'main/arrayobj.c',
|
||||||
'main/context.c',
|
'main/blend.c',
|
||||||
'main/convolve.c',
|
'main/bufferobj.c',
|
||||||
'main/debug.c',
|
'main/buffers.c',
|
||||||
'main/depth.c',
|
'main/clip.c',
|
||||||
'main/depthstencil.c',
|
'main/colortab.c',
|
||||||
'main/dlist.c',
|
'main/context.c',
|
||||||
'main/drawpix.c',
|
'main/convolve.c',
|
||||||
'main/enable.c',
|
'main/debug.c',
|
||||||
'main/enums.c',
|
'main/depth.c',
|
||||||
'main/eval.c',
|
'main/depthstencil.c',
|
||||||
'main/execmem.c',
|
'main/dlist.c',
|
||||||
'main/extensions.c',
|
'main/drawpix.c',
|
||||||
'main/fbobject.c',
|
'main/enable.c',
|
||||||
'main/feedback.c',
|
'main/enums.c',
|
||||||
'main/ffvertex_prog.c',
|
'main/eval.c',
|
||||||
'main/fog.c',
|
'main/execmem.c',
|
||||||
'main/framebuffer.c',
|
'main/extensions.c',
|
||||||
'main/get.c',
|
'main/fbobject.c',
|
||||||
'main/getstring.c',
|
'main/feedback.c',
|
||||||
'main/hash.c',
|
'main/ffvertex_prog.c',
|
||||||
'main/hint.c',
|
'main/fog.c',
|
||||||
'main/histogram.c',
|
'main/framebuffer.c',
|
||||||
'main/image.c',
|
'main/get.c',
|
||||||
'main/imports.c',
|
'main/getstring.c',
|
||||||
'main/light.c',
|
'main/hash.c',
|
||||||
'main/lines.c',
|
'main/hint.c',
|
||||||
'main/matrix.c',
|
'main/histogram.c',
|
||||||
'main/mipmap.c',
|
'main/image.c',
|
||||||
'main/mm.c',
|
'main/imports.c',
|
||||||
'main/pixel.c',
|
'main/light.c',
|
||||||
'main/points.c',
|
'main/lines.c',
|
||||||
'main/polygon.c',
|
'main/matrix.c',
|
||||||
'main/queryobj.c',
|
'main/mipmap.c',
|
||||||
'main/rastpos.c',
|
'main/mm.c',
|
||||||
'main/rbadaptors.c',
|
'main/pixel.c',
|
||||||
'main/renderbuffer.c',
|
'main/points.c',
|
||||||
'main/shaders.c',
|
'main/polygon.c',
|
||||||
'main/state.c',
|
'main/queryobj.c',
|
||||||
'main/stencil.c',
|
'main/rastpos.c',
|
||||||
'main/texcompress.c',
|
'main/rbadaptors.c',
|
||||||
'main/texcompress_s3tc.c',
|
'main/renderbuffer.c',
|
||||||
'main/texcompress_fxt1.c',
|
'main/shaders.c',
|
||||||
'main/texenvprogram.c',
|
'main/state.c',
|
||||||
'main/texformat.c',
|
'main/stencil.c',
|
||||||
'main/teximage.c',
|
'main/texcompress.c',
|
||||||
'main/texobj.c',
|
'main/texcompress_s3tc.c',
|
||||||
'main/texrender.c',
|
'main/texcompress_fxt1.c',
|
||||||
'main/texstate.c',
|
'main/texenvprogram.c',
|
||||||
'main/texstore.c',
|
'main/texformat.c',
|
||||||
'main/varray.c',
|
'main/teximage.c',
|
||||||
'main/vtxfmt.c',
|
'main/texobj.c',
|
||||||
]
|
'main/texrender.c',
|
||||||
|
'main/texstate.c',
|
||||||
GLAPI_SOURCES = [
|
'main/texstore.c',
|
||||||
'main/dispatch.c',
|
'main/varray.c',
|
||||||
'glapi/glapi.c',
|
'main/vtxfmt.c',
|
||||||
'glapi/glthread.c',
|
]
|
||||||
]
|
|
||||||
|
GLAPI_SOURCES = [
|
||||||
MATH_SOURCES = [
|
'main/dispatch.c',
|
||||||
'math/m_debug_clip.c',
|
'glapi/glapi.c',
|
||||||
'math/m_debug_norm.c',
|
'glapi/glthread.c',
|
||||||
'math/m_debug_xform.c',
|
]
|
||||||
'math/m_eval.c',
|
|
||||||
'math/m_matrix.c',
|
MATH_SOURCES = [
|
||||||
'math/m_translate.c',
|
'math/m_debug_clip.c',
|
||||||
'math/m_vector.c',
|
'math/m_debug_norm.c',
|
||||||
'math/m_xform.c',
|
'math/m_debug_xform.c',
|
||||||
]
|
'math/m_eval.c',
|
||||||
|
'math/m_matrix.c',
|
||||||
VBO_SOURCES = [
|
'math/m_translate.c',
|
||||||
'vbo/vbo_context.c',
|
'math/m_vector.c',
|
||||||
'vbo/vbo_exec.c',
|
'math/m_xform.c',
|
||||||
'vbo/vbo_exec_api.c',
|
]
|
||||||
'vbo/vbo_exec_array.c',
|
|
||||||
'vbo/vbo_exec_draw.c',
|
VBO_SOURCES = [
|
||||||
'vbo/vbo_exec_eval.c',
|
'vbo/vbo_context.c',
|
||||||
'vbo/vbo_rebase.c',
|
'vbo/vbo_exec.c',
|
||||||
'vbo/vbo_split.c',
|
'vbo/vbo_exec_api.c',
|
||||||
'vbo/vbo_split_copy.c',
|
'vbo/vbo_exec_array.c',
|
||||||
'vbo/vbo_split_inplace.c',
|
'vbo/vbo_exec_draw.c',
|
||||||
'vbo/vbo_save.c',
|
'vbo/vbo_exec_eval.c',
|
||||||
'vbo/vbo_save_api.c',
|
'vbo/vbo_rebase.c',
|
||||||
'vbo/vbo_save_draw.c',
|
'vbo/vbo_split.c',
|
||||||
'vbo/vbo_save_loopback.c',
|
'vbo/vbo_split_copy.c',
|
||||||
]
|
'vbo/vbo_split_inplace.c',
|
||||||
|
'vbo/vbo_save.c',
|
||||||
VF_SOURCES = [
|
'vbo/vbo_save_api.c',
|
||||||
'vf/vf.c',
|
'vbo/vbo_save_draw.c',
|
||||||
'vf/vf_generic.c',
|
'vbo/vbo_save_loopback.c',
|
||||||
'vf/vf_sse.c',
|
]
|
||||||
]
|
|
||||||
|
VF_SOURCES = [
|
||||||
STATETRACKER_SOURCES = [
|
'vf/vf.c',
|
||||||
'state_tracker/st_atom.c',
|
'vf/vf_generic.c',
|
||||||
'state_tracker/st_atom_blend.c',
|
'vf/vf_sse.c',
|
||||||
'state_tracker/st_atom_clip.c',
|
]
|
||||||
'state_tracker/st_atom_constbuf.c',
|
|
||||||
'state_tracker/st_atom_depth.c',
|
STATETRACKER_SOURCES = [
|
||||||
'state_tracker/st_atom_framebuffer.c',
|
'state_tracker/st_atom.c',
|
||||||
'state_tracker/st_atom_pixeltransfer.c',
|
'state_tracker/st_atom_blend.c',
|
||||||
'state_tracker/st_atom_sampler.c',
|
'state_tracker/st_atom_clip.c',
|
||||||
'state_tracker/st_atom_scissor.c',
|
'state_tracker/st_atom_constbuf.c',
|
||||||
'state_tracker/st_atom_shader.c',
|
'state_tracker/st_atom_depth.c',
|
||||||
'state_tracker/st_atom_rasterizer.c',
|
'state_tracker/st_atom_framebuffer.c',
|
||||||
'state_tracker/st_atom_stipple.c',
|
'state_tracker/st_atom_pixeltransfer.c',
|
||||||
'state_tracker/st_atom_texture.c',
|
'state_tracker/st_atom_sampler.c',
|
||||||
'state_tracker/st_atom_viewport.c',
|
'state_tracker/st_atom_scissor.c',
|
||||||
'state_tracker/st_cb_accum.c',
|
'state_tracker/st_atom_shader.c',
|
||||||
'state_tracker/st_cb_bitmap.c',
|
'state_tracker/st_atom_rasterizer.c',
|
||||||
'state_tracker/st_cb_blit.c',
|
'state_tracker/st_atom_stipple.c',
|
||||||
'state_tracker/st_cb_bufferobjects.c',
|
'state_tracker/st_atom_texture.c',
|
||||||
'state_tracker/st_cb_clear.c',
|
'state_tracker/st_atom_viewport.c',
|
||||||
'state_tracker/st_cb_flush.c',
|
'state_tracker/st_cb_accum.c',
|
||||||
'state_tracker/st_cb_drawpixels.c',
|
'state_tracker/st_cb_bitmap.c',
|
||||||
'state_tracker/st_cb_fbo.c',
|
'state_tracker/st_cb_blit.c',
|
||||||
'state_tracker/st_cb_feedback.c',
|
'state_tracker/st_cb_bufferobjects.c',
|
||||||
'state_tracker/st_cb_program.c',
|
'state_tracker/st_cb_clear.c',
|
||||||
'state_tracker/st_cb_queryobj.c',
|
'state_tracker/st_cb_flush.c',
|
||||||
'state_tracker/st_cb_rasterpos.c',
|
'state_tracker/st_cb_drawpixels.c',
|
||||||
'state_tracker/st_cb_readpixels.c',
|
'state_tracker/st_cb_fbo.c',
|
||||||
'state_tracker/st_cb_strings.c',
|
'state_tracker/st_cb_feedback.c',
|
||||||
'state_tracker/st_cb_texture.c',
|
'state_tracker/st_cb_program.c',
|
||||||
'state_tracker/st_context.c',
|
'state_tracker/st_cb_queryobj.c',
|
||||||
'state_tracker/st_debug.c',
|
'state_tracker/st_cb_rasterpos.c',
|
||||||
'state_tracker/st_draw.c',
|
'state_tracker/st_cb_readpixels.c',
|
||||||
'state_tracker/st_extensions.c',
|
'state_tracker/st_cb_strings.c',
|
||||||
'state_tracker/st_format.c',
|
'state_tracker/st_cb_texture.c',
|
||||||
'state_tracker/st_framebuffer.c',
|
'state_tracker/st_context.c',
|
||||||
'state_tracker/st_gen_mipmap.c',
|
'state_tracker/st_debug.c',
|
||||||
'state_tracker/st_mesa_to_tgsi.c',
|
'state_tracker/st_draw.c',
|
||||||
'state_tracker/st_program.c',
|
'state_tracker/st_extensions.c',
|
||||||
'state_tracker/st_texture.c',
|
'state_tracker/st_format.c',
|
||||||
]
|
'state_tracker/st_framebuffer.c',
|
||||||
|
'state_tracker/st_gen_mipmap.c',
|
||||||
SHADER_SOURCES = [
|
'state_tracker/st_mesa_to_tgsi.c',
|
||||||
'shader/arbprogparse.c',
|
'state_tracker/st_program.c',
|
||||||
'shader/arbprogram.c',
|
'state_tracker/st_texture.c',
|
||||||
'shader/atifragshader.c',
|
]
|
||||||
'shader/grammar/grammar_mesa.c',
|
|
||||||
'shader/nvfragparse.c',
|
SHADER_SOURCES = [
|
||||||
'shader/nvprogram.c',
|
'shader/arbprogparse.c',
|
||||||
'shader/nvvertparse.c',
|
'shader/arbprogram.c',
|
||||||
'shader/program.c',
|
'shader/atifragshader.c',
|
||||||
'shader/prog_cache.c',
|
'shader/grammar/grammar_mesa.c',
|
||||||
'shader/prog_debug.c',
|
'shader/nvfragparse.c',
|
||||||
'shader/prog_execute.c',
|
'shader/nvprogram.c',
|
||||||
'shader/prog_instruction.c',
|
'shader/nvvertparse.c',
|
||||||
'shader/prog_parameter.c',
|
'shader/program.c',
|
||||||
'shader/prog_print.c',
|
'shader/prog_cache.c',
|
||||||
'shader/prog_statevars.c',
|
'shader/prog_debug.c',
|
||||||
'shader/prog_uniform.c',
|
'shader/prog_execute.c',
|
||||||
'shader/programopt.c',
|
'shader/prog_instruction.c',
|
||||||
'shader/shader_api.c',
|
'shader/prog_parameter.c',
|
||||||
]
|
'shader/prog_print.c',
|
||||||
|
'shader/prog_statevars.c',
|
||||||
SLANG_SOURCES = [
|
'shader/prog_uniform.c',
|
||||||
'shader/slang/slang_builtin.c',
|
'shader/programopt.c',
|
||||||
'shader/slang/slang_codegen.c',
|
'shader/shader_api.c',
|
||||||
'shader/slang/slang_compile.c',
|
]
|
||||||
'shader/slang/slang_compile_function.c',
|
|
||||||
'shader/slang/slang_compile_operation.c',
|
SLANG_SOURCES = [
|
||||||
'shader/slang/slang_compile_struct.c',
|
'shader/slang/slang_builtin.c',
|
||||||
'shader/slang/slang_compile_variable.c',
|
'shader/slang/slang_codegen.c',
|
||||||
'shader/slang/slang_emit.c',
|
'shader/slang/slang_compile.c',
|
||||||
'shader/slang/slang_ir.c',
|
'shader/slang/slang_compile_function.c',
|
||||||
'shader/slang/slang_label.c',
|
'shader/slang/slang_compile_operation.c',
|
||||||
'shader/slang/slang_library_noise.c',
|
'shader/slang/slang_compile_struct.c',
|
||||||
'shader/slang/slang_link.c',
|
'shader/slang/slang_compile_variable.c',
|
||||||
'shader/slang/slang_log.c',
|
'shader/slang/slang_emit.c',
|
||||||
'shader/slang/slang_mem.c',
|
'shader/slang/slang_ir.c',
|
||||||
'shader/slang/slang_preprocess.c',
|
'shader/slang/slang_label.c',
|
||||||
'shader/slang/slang_print.c',
|
'shader/slang/slang_library_noise.c',
|
||||||
'shader/slang/slang_simplify.c',
|
'shader/slang/slang_link.c',
|
||||||
'shader/slang/slang_storage.c',
|
'shader/slang/slang_log.c',
|
||||||
'shader/slang/slang_typeinfo.c',
|
'shader/slang/slang_mem.c',
|
||||||
'shader/slang/slang_vartable.c',
|
'shader/slang/slang_preprocess.c',
|
||||||
'shader/slang/slang_utility.c',
|
'shader/slang/slang_print.c',
|
||||||
]
|
'shader/slang/slang_simplify.c',
|
||||||
|
'shader/slang/slang_storage.c',
|
||||||
|
'shader/slang/slang_typeinfo.c',
|
||||||
#######################################################################
|
'shader/slang/slang_vartable.c',
|
||||||
# Assembly sources
|
'shader/slang/slang_utility.c',
|
||||||
|
]
|
||||||
ASM_C_SOURCES = [
|
|
||||||
'x86/common_x86.c',
|
|
||||||
'x86/x86.c',
|
#######################################################################
|
||||||
'x86/3dnow.c',
|
# Assembly sources
|
||||||
'x86/sse.c',
|
|
||||||
'sparc/sparc.c',
|
ASM_C_SOURCES = [
|
||||||
'ppc/common_ppc.c',
|
'x86/common_x86.c',
|
||||||
'x86-64/x86-64.c',
|
'x86/x86.c',
|
||||||
]
|
'x86/3dnow.c',
|
||||||
|
'x86/sse.c',
|
||||||
X86_SOURCES = [
|
'sparc/sparc.c',
|
||||||
'x86/common_x86_asm.S',
|
'ppc/common_ppc.c',
|
||||||
'x86/x86_xform2.S',
|
'x86-64/x86-64.c',
|
||||||
'x86/x86_xform3.S',
|
]
|
||||||
'x86/x86_xform4.S',
|
|
||||||
'x86/x86_cliptest.S',
|
X86_SOURCES = [
|
||||||
'x86/mmx_blend.S',
|
'x86/common_x86_asm.S',
|
||||||
'x86/3dnow_xform1.S',
|
'x86/x86_xform2.S',
|
||||||
'x86/3dnow_xform2.S',
|
'x86/x86_xform3.S',
|
||||||
'x86/3dnow_xform3.S',
|
'x86/x86_xform4.S',
|
||||||
'x86/3dnow_xform4.S',
|
'x86/x86_cliptest.S',
|
||||||
'x86/3dnow_normal.S',
|
'x86/mmx_blend.S',
|
||||||
'x86/sse_xform1.S',
|
'x86/3dnow_xform1.S',
|
||||||
'x86/sse_xform2.S',
|
'x86/3dnow_xform2.S',
|
||||||
'x86/sse_xform3.S',
|
'x86/3dnow_xform3.S',
|
||||||
'x86/sse_xform4.S',
|
'x86/3dnow_xform4.S',
|
||||||
'x86/sse_normal.S',
|
'x86/3dnow_normal.S',
|
||||||
'x86/read_rgba_span_x86.S',
|
'x86/sse_xform1.S',
|
||||||
]
|
'x86/sse_xform2.S',
|
||||||
|
'x86/sse_xform3.S',
|
||||||
X86_API = [
|
'x86/sse_xform4.S',
|
||||||
'x86/glapi_x86.S',
|
'x86/sse_normal.S',
|
||||||
]
|
'x86/read_rgba_span_x86.S',
|
||||||
|
]
|
||||||
X86_64_SOURCES = [
|
|
||||||
'x86-64/xform4.S',
|
X86_API = [
|
||||||
]
|
'x86/glapi_x86.S',
|
||||||
|
]
|
||||||
X86_64_API = [
|
|
||||||
'x86-64/glapi_x86-64.S',
|
X86_64_SOURCES = [
|
||||||
]
|
'x86-64/xform4.S',
|
||||||
|
]
|
||||||
SPARC_SOURCES = [
|
|
||||||
'sparc/clip.S',
|
X86_64_API = [
|
||||||
'sparc/norm.S',
|
'x86-64/glapi_x86-64.S',
|
||||||
'sparc/xform.S',
|
]
|
||||||
]
|
|
||||||
|
SPARC_SOURCES = [
|
||||||
SPARC_API = [
|
'sparc/clip.S',
|
||||||
'sparc/glapi_sparc.S',
|
'sparc/norm.S',
|
||||||
]
|
'sparc/xform.S',
|
||||||
|
]
|
||||||
if x86 and gcc:
|
|
||||||
ASM_SOURCES = ASM_C_SOURCES + X86_SOURCES
|
SPARC_API = [
|
||||||
API_SOURCES = X86_API
|
'sparc/glapi_sparc.S',
|
||||||
else:
|
]
|
||||||
ASM_SOURCES = []
|
|
||||||
API_SOURCES = []
|
if x86 and gcc:
|
||||||
|
ASM_SOURCES = ASM_C_SOURCES + X86_SOURCES
|
||||||
SOLO_SOURCES = \
|
API_SOURCES = X86_API
|
||||||
MAIN_SOURCES + \
|
else:
|
||||||
MATH_SOURCES + \
|
ASM_SOURCES = []
|
||||||
VBO_SOURCES + \
|
API_SOURCES = []
|
||||||
VF_SOURCES + \
|
|
||||||
STATETRACKER_SOURCES + \
|
SOLO_SOURCES = \
|
||||||
SHADER_SOURCES + \
|
MAIN_SOURCES + \
|
||||||
ASM_SOURCES + \
|
MATH_SOURCES + \
|
||||||
SLANG_SOURCES
|
VBO_SOURCES + \
|
||||||
|
VF_SOURCES + \
|
||||||
mesa = env.ConvenienceLibrary(
|
STATETRACKER_SOURCES + \
|
||||||
target = 'mesa',
|
SHADER_SOURCES + \
|
||||||
source = SOLO_SOURCES,
|
ASM_SOURCES + \
|
||||||
)
|
SLANG_SOURCES
|
||||||
Export('mesa')
|
|
||||||
|
mesa = env.ConvenienceLibrary(
|
||||||
if not dri:
|
target = 'mesa',
|
||||||
glapi = env.ConvenienceLibrary(
|
source = SOLO_SOURCES,
|
||||||
target = 'glapi',
|
|
||||||
source = GLAPI_SOURCES + API_SOURCES,
|
|
||||||
)
|
)
|
||||||
Export('glapi')
|
Export('mesa')
|
||||||
|
|
||||||
|
if not dri:
|
||||||
|
glapi = env.ConvenienceLibrary(
|
||||||
|
target = 'glapi',
|
||||||
|
source = GLAPI_SOURCES + API_SOURCES,
|
||||||
|
)
|
||||||
|
Export('glapi')
|
||||||
|
Reference in New Issue
Block a user