# Copyright 2020 Google, Inc.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met: redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer;
# redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution;
# neither the name of the copyright holders nor the names of its
# contributors may be used to endorse or promote products derived from
# this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Import('*')

from gem5_scons import warning

import gem5_scons
host_isa = None
try:
    import platform
    host_isa = platform.machine()
except:
    pass

with gem5_scons.Configure(main) as conf:
    # Check if we should enable KVM-based hardware virtualization. The API
    # we rely on exists since version 2.6.36 of the kernel, but somehow
    # the KVM_API_VERSION does not reflect the change. We test for one of
    # the types as a fall back.
    conf.env['KVM_ISA'] = None
    if not conf.CheckHeader('linux/kvm.h', '<>'):
        print("Info: Compatible header file <linux/kvm.h> not found, "
              "disabling KVM support.")
    elif not conf.CheckLibWithHeader([None, 'rt'], [ 'time.h', 'signal.h' ],
            'C', 'timer_create(CLOCK_MONOTONIC, NULL, NULL);'):
        warning("Cannot enable KVM, host doesn't support POSIX timers")
    elif host_isa == 'x86_64':
        if conf.CheckTypeSize('struct kvm_xsave',
                '#include <linux/kvm.h>') != 0:
            conf.env['KVM_ISA'] = 'x86'
        else:
            warning("KVM on x86 requires xsave support in kernel headers.")
    elif host_isa in ('armv7l', 'aarch64'):
        conf.env['KVM_ISA'] = 'arm'
    else:
        warning("Failed to determine host ISA.")

    if conf.env['KVM_ISA']:
        # Check if the exclude_host attribute is available. We want this to
        # get accurate instruction counts in KVM.
        conf.env['HAVE_PERF_ATTR_EXCLUDE_HOST'] = conf.CheckMember(
            'linux/perf_event.h', 'struct perf_event_attr', 'exclude_host')

        # Warn about missing optional functionality
        if not conf.env['HAVE_PERF_ATTR_EXCLUDE_HOST']:
            warning("perf_event headers lack support for the exclude_host "
                    "attribute. KVM instruction counts will be inaccurate.")

        export_vars.append('HAVE_PERF_ATTR_EXCLUDE_HOST')

if main['KVM_ISA']:
    sticky_vars.Add(BoolVariable('USE_KVM',
                'Enable hardware virtualized (KVM) CPU models', True))
else:
    main['USE_KVM'] = False
    warning("Can not enable KVM, host seems to lack KVM support")

export_vars.append('USE_KVM')
