mirror of
https://github.com/amd/blis.git
synced 2026-05-11 17:50:00 +00:00
Details: - Historically, the compiler selection has happened statically in the various make_defs.mk and would only be overriden by setting CC (either prior to running configure or as a configure argument). However, in the last couple months, configure has evolved to contain rather sophisticated compiler detection logic for the purposes of blacklisting sub-configurations. It only makes sense that configure now fully take over the responsibility of selecting a compiler from the GNU make side of the build system. Thanks to Alex Arslan for his help exposing this issue. - Substitute found_cc into CC in config.mk via configure. - Set a new variable, CC_VENDOR, in config.mk via substitution from configure, and disable the corresponding CC_VENDOR code in common.mk. - Disabled default compiler selection (usually gcc) in the sub-configs' various make_def.mk files.
122 lines
5.0 KiB
Makefile
122 lines
5.0 KiB
Makefile
#
|
|
#
|
|
# BLIS
|
|
# An object-based framework for developing high-performance BLAS-like
|
|
# libraries.
|
|
#
|
|
# Copyright (C) 2014, The University of Texas at Austin
|
|
#
|
|
# 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 University of Texas at Austin 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
|
|
# HOLDER 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.
|
|
#
|
|
#
|
|
|
|
# Only include this block of code once
|
|
ifndef CONFIG_MK_INCLUDED
|
|
CONFIG_MK_INCLUDED := yes
|
|
|
|
# The version string. This could be the official string or a custom
|
|
# string forced at configure-time.
|
|
VERSION := @version@
|
|
|
|
# The shared library .so major and minor.build version numbers.
|
|
SO_MAJOR := @so_version_major@
|
|
SO_MINORB := @so_version_minorbuild@
|
|
SO_MMB := $(SO_MAJOR).$(SO_MINORB)
|
|
|
|
# The name of the configuration family.
|
|
CONFIG_NAME := @config_name@
|
|
|
|
# The list of sub-configurations associated with CONFIG_NAME. Each
|
|
# sub-configuration in CONFIG_LIST corresponds to a configuration
|
|
# sub-directory in the 'config' directory. See the 'config_registry'
|
|
# file for the full list of registered configurations.
|
|
CONFIG_LIST := @config_list@
|
|
|
|
# This list of kernels needed for the configurations in CONFIG_LIST.
|
|
# Each item in this list corresponds to a sub-directory in the top-level
|
|
# 'kernels' directory. Oftentimes, this list is identical to CONFIG_LIST,
|
|
# but not always. For example, if configuration X and Y use the same
|
|
# kernel set X, and configuration W uses kernel set Q, and the CONFIG_LIST
|
|
# might contained "X Y Z W", then the KERNEL_LIST would contain "X Z Q".
|
|
KERNEL_LIST := @kernel_list@
|
|
|
|
# This list contains some number of "kernel:config" pairs, where "config"
|
|
# specifies which configuration's compilation flags (CFLAGS) should be
|
|
# used to compile the source code for the kernel set named "kernel".
|
|
KCONFIG_MAP := @kconfig_map@
|
|
|
|
# The operating system name, which should be either 'Linux' or 'Darwin'.
|
|
OS_NAME := @os_name@
|
|
|
|
# The directory path to the top level of the source distribution.
|
|
# NOTE: We allow the includer to override this value by setting DIST_PATH
|
|
# prior to including this file. This is employed, for example, when
|
|
# common.mk (and therefore config.mk) is included by the Makefile local
|
|
# to the 'testsuite' directory, or the 'test' directory containing
|
|
# individual test drivers.
|
|
ifeq ($(strip $(DIST_PATH)),)
|
|
DIST_PATH := @dist_path@
|
|
endif
|
|
|
|
# The C compiler.
|
|
CC := @CC@
|
|
CC_VENDOR := @CC_VENDOR@
|
|
RANLIB := @RANLIB@
|
|
|
|
# The level of debugging info to generate.
|
|
DEBUG_TYPE := @debug_type@
|
|
|
|
# The requested threading model.
|
|
THREADING_MODEL := @threading_model@
|
|
|
|
# The install libdir and includedir values from configure tell us where to
|
|
# install the libraries and header files, respectively. Notice that we
|
|
# support the use of DESTDIR so that advanced users may install to a
|
|
# temporary location.
|
|
INSTALL_LIBDIR := $(DESTDIR)@install_libdir@
|
|
INSTALL_INCDIR := $(DESTDIR)@install_incdir@
|
|
|
|
# Whether to output verbose command-line feedback as the Makefile is processed.
|
|
ENABLE_VERBOSE := @enable_verbose@
|
|
|
|
# Whether we are building out-of-tree.
|
|
BUILDING_OOT := @configured_oot@
|
|
|
|
# Whether to build the static and shared libraries.
|
|
# Note the "MK_" prefix, which helps differentiate these variables from
|
|
# their corresonding cpp macros that use the BLIS_ prefix.
|
|
MK_ENABLE_STATIC := @enable_static@
|
|
MK_ENABLE_SHARED := @enable_shared@
|
|
|
|
# Whether to enable either the BLAS or CBLAS compatibility layers.
|
|
MK_ENABLE_BLAS := @enable_blas@
|
|
MK_ENABLE_CBLAS := @enable_cblas@
|
|
|
|
# Whether libblis will depend on libmemkind for certain memory allocations.
|
|
MK_ENABLE_MEMKIND := @enable_memkind@
|
|
|
|
# end of ifndef CONFIG_MK_INCLUDED conditional block
|
|
endif
|