6cb07302e895e77731b2fe18210e379176783b69
1 #######################################################################
9 #######################################################################
10 # Configuration options
12 # For example, invoke scons as
14 # scons debug=1 dri=0 machine=x86
16 # to set configuration variables. Or you can write those options to a file
28 # to get the full list of options. See scons manpage for more info.
31 # TODO: auto-detect defaults
32 opts
= Options('config.py')
33 opts
.Add(BoolOption('debug', 'build debug version', False))
34 opts
.Add(BoolOption('dri', 'build dri drivers', False))
35 opts
.Add(BoolOption('llvm', 'use llvm', False))
36 opts
.Add(EnumOption('machine', 'use machine-specific assembly code', 'x86',
37 allowed_values
=('generic', 'x86', 'x86-64')))
42 Help(opts
.GenerateHelpText(env
))
48 # platform will be typically 'posix' or 'win32'
49 platform
= env
['PLATFORM']
51 # platform will be one of 'linux', 'freebsd', 'win32', 'darwin', etc.
52 platform
= sys
.platform
53 if platform
== 'linux2':
56 # replicate options values in local variables
60 machine
= env
['machine']
63 x86
= machine
== 'x86'
64 gcc
= platform
in ('posix', 'linux', 'freebsd', 'darwin')
65 msvc
= platform
== 'win32'
78 #######################################################################
81 # TODO: put the compiler specific settings in seperate files
82 # TODO: auto-detect as much as possible
88 env
.Append(CFLAGS
= '-O0 -g3')
89 env
.Append(CXXFLAGS
= '-O0 -g3')
91 env
.Append(CFLAGS
= '-O3 -g3')
92 env
.Append(CXXFLAGS
= '-O3 -g3')
94 env
.Append(CFLAGS
= '-Wall -Wmissing-prototypes -std=c99 -ffast-math -pedantic')
95 env
.Append(CXXFLAGS
= '-Wall -pedantic')
98 env
.Append(CFLAGS
= '-fmessage-length=0')
99 env
.Append(CXXFLAGS
= '-fmessage-length=0')
104 env
.Append(CPPDEFINES
= ['DEBUG'])
106 env
.Append(CPPDEFINES
= ['NDEBUG'])
110 env
.Append(CPPPATH
= [
112 '#/src/gallium/include',
113 '#/src/gallium/auxiliary',
114 '#/src/gallium/drivers',
120 env
.Append(CPPDEFINES
= [
127 env
.Append(CFLAGS
= '-m32')
128 env
.Append(CXXFLAGS
= '-m32')
132 if platform
in ('posix', 'linux', 'freebsd', 'darwin'):
133 env
.Append(CPPDEFINES
= [
135 ('_POSIX_C_SOURCE', '199309L'),
141 'HAVE_POSIX_MEMALIGN',
143 env
.Append(CPPPATH
= ['/usr/X11R6/include'])
144 env
.Append(LIBPATH
= ['/usr/X11R6/lib'])
155 env
.ParseConfig('pkg-config --cflags --libs libdrm')
156 env
.Append(CPPDEFINES
= [
157 ('USE_EXTERNAL_DXTN_LIB', '1'),
159 'GLX_DIRECT_RENDERING',
160 'GLX_INDIRECT_RENDERING',
165 # See also http://www.scons.org/wiki/UsingPkgConfig
166 env
.ParseConfig('llvm-config --cflags --ldflags --libs')
167 env
.Append(CPPDEFINES
= ['MESA_LLVM'])
168 env
.Append(CXXFLAGS
= ['-Wno-long-long'])
184 #######################################################################
185 # Convenience Library Builder
186 # based on the stock StaticLibrary and SharedLibrary builders
188 def createConvenienceLibBuilder(env
):
189 """This is a utility function that creates the ConvenienceLibrary
190 Builder in an Environment if it is not there already.
192 If it is already there, we return the existing one.
196 convenience_lib
= env
['BUILDERS']['ConvenienceLibrary']
198 action_list
= [ Action("$ARCOM", "$ARCOMSTR") ]
199 if env
.Detect('ranlib'):
200 ranlib_action
= Action("$RANLIBCOM", "$RANLIBCOMSTR")
201 action_list
.append(ranlib_action
)
203 convenience_lib
= Builder(action
= action_list
,
204 emitter
= '$LIBEMITTER',
205 prefix
= '$LIBPREFIX',
206 suffix
= '$LIBSUFFIX',
207 src_suffix
= '$SHOBJSUFFIX',
208 src_builder
= 'SharedObject')
209 env
['BUILDERS']['ConvenienceLibrary'] = convenience_lib
210 env
['BUILDERS']['Library'] = convenience_lib
212 return convenience_lib
214 createConvenienceLibBuilder(env
)
217 #######################################################################
220 # Put build output in a separate dir, which depends on the current configuration
221 # See also http://www.scons.org/wiki/AdvancedBuildExample
222 build_topdir
= 'build'
223 build_subdir
= platform
225 build_subdir
+= "-dri"
227 build_subdir
+= "-llvm"
229 build_subdir
+= "-x86"
231 build_subdir
+= "-debug"
232 build_dir
= os
.path
.join(build_topdir
, build_subdir
)
234 # TODO: Build several variants at the same time?
235 # http://www.scons.org/wiki/SimultaneousVariantBuilds
239 build_dir
= build_dir
,
240 duplicate
= 0 # http://www.scons.org/doc/0.97/HTML/scons-user/x2261.html