[Mesa-dev] [PATCH 1/3] scons: Enable building through Clang Static Analyzer.
Brian Paul
brianp at vmware.com
Mon Apr 14 08:38:19 PDT 2014
On 04/14/2014 07:32 AM, jfonseca at vmware.com wrote:
> From: José Fonseca <jfonseca at vmware.com>
>
> By accurately detecting gcc/clang through --version option instead
> of executable name.
>
> Clang Static Analyzer reports many issues, most false positives, but it
> found at least one real and subtle use-after-free issue
> in st_texture_get_sampler_view():
>
> http://people.freedesktop.org/~jrfonseca/scan-build-2014-04-14-1/report-869047.html#EndPath
> ---
> scons/gallium.py | 31 +++++++++++++++++++++++--------
> 1 file changed, 23 insertions(+), 8 deletions(-)
>
> diff --git a/scons/gallium.py b/scons/gallium.py
> index e11d4db..42e8f7c 100755
> --- a/scons/gallium.py
> +++ b/scons/gallium.py
> @@ -104,6 +104,19 @@ def num_jobs():
> return 1
>
>
> +def get_cc_version(env):
> + # Get the first line of `$CC --version`
> + pipe = SCons.Action._subproc(env, [env['CC'], '--version'],
> + stdin = 'devnull',
> + stderr = 'devnull',
> + stdout = subprocess.PIPE)
> + if pipe.wait() != 0:
> + return ''
> +
> + line = pipe.stdout.readline()
> + return line
> +
> +
> def generate(env):
> """Common environment generation code"""
>
> @@ -119,12 +132,8 @@ def generate(env):
> if os.environ.has_key('CC'):
> env['CC'] = os.environ['CC']
> # Update CCVERSION to match
> - pipe = SCons.Action._subproc(env, [env['CC'], '--version'],
> - stdin = 'devnull',
> - stderr = 'devnull',
> - stdout = subprocess.PIPE)
> - if pipe.wait() == 0:
> - line = pipe.stdout.readline()
> + line = get_cc_version(env)
> + if line:
> match = re.search(r'[0-9]+(\.[0-9]+)+', line)
> if match:
> env['CCVERSION'] = match.group(0)
> @@ -137,10 +146,16 @@ def generate(env):
> if os.environ.has_key('LDFLAGS'):
> env['LINKFLAGS'] += SCons.Util.CLVar(os.environ['LDFLAGS'])
>
> - env['gcc'] = 'gcc' in os.path.basename(env['CC']).split('-')
> + # Detect gcc/clang not by executable name, but through `--version` option,
> + # to avoid drawing wrong conclusions when using tools that overrice CC/CXX
> + # like scan-build.
> + cc_version = get_cc_version(env)
> + cc_version_words = cc_version.split()
> +
> + env['gcc'] = 'gcc' in cc_version_words
> env['msvc'] = env['CC'] == 'cl'
> env['suncc'] = env['platform'] == 'sunos' and os.path.basename(env['CC']) == 'cc'
> - env['clang'] = env['CC'] == 'clang'
> + env['clang'] = 'clang' in cc_version_words
> env['icc'] = 'icc' == os.path.basename(env['CC'])
>
> if env['msvc'] and env['toolchain'] == 'default' and env['machine'] == 'x86_64':
>
Series looks good to me.
Reviewed-by: Brian Paul <brianp at vmware.com>
More information about the mesa-dev
mailing list