mirror of
https://github.com/amd/blis.git
synced 2026-05-11 17:50:00 +00:00
Inadvertantly hidden xerbla_() in blastest (#313).
Details: - Attempted a fix to issue #313, which reports that when building only a shared library (ie: static library build is disabled), running the BLAS test drivers can fail because those drivers provide their own local version of xerbla_() as a clever (albeit still rather hackish) way of checking the error codes that result from the individual tests. This local xerbla_() function is never found at link-time because the BLAS test drivers' Makefile imports BLIS compilation flags via the get-user-cflags-for() function, which currently conveys the -fvisibility=hidden flag, which hides symbols unless they are explicitly annotated for export. The -fvisibility=hidden flag was only ever intended for use when building BLIS (not for applications), and so the attempted solution here is to omit the symbol export flag(s) from get-user-cflags-for() by storing the symbol export flag(s) to a new BULID_SYMFLAGS variable instead of appending it to the subconfigurations' CMISCFLAGS variable (which is returned by every get-*-cflags-for() function). Thanks to M. Zhou for reporting this issue and also to Isuru Fernando for suggesting the fix. - Renamed BUILD_FLAGS to BUILD_CPPFLAGS to harmonize with the newly created BUILD_SYMFLAGS. - Fixed typo in entry for --export-shared flag in 'configure --help' text.
This commit is contained in:
committed by
Devrajegowda, Kiran
parent
defe789b8c
commit
c90a1a8dca
58
common.mk
58
common.mk
@@ -118,7 +118,8 @@ get-noopt-cxxflags-for = $(strip $(CFLAGS_PRESET) \
|
||||
get-refinit-cflags-for = $(strip $(call load-var-for,COPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
-DBLIS_CNAME=$(1) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
|
||||
get-refkern-cflags-for = $(strip $(call load-var-for,CROPTFLAGS,$(1)) \
|
||||
@@ -126,23 +127,27 @@ get-refkern-cflags-for = $(strip $(call load-var-for,CROPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
$(COMPSIMDFLAGS) \
|
||||
-DBLIS_CNAME=$(1) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
|
||||
get-config-cflags-for = $(strip $(call load-var-for,COPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
|
||||
get-frame-cflags-for = $(strip $(call load-var-for,COPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
|
||||
get-kernel-cflags-for = $(strip $(call load-var-for,CKOPTFLAGS,$(1)) \
|
||||
$(call load-var-for,CKVECFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
|
||||
# When compiling sandboxes, we use flags similar to those of general framework
|
||||
@@ -153,19 +158,24 @@ get-kernel-cflags-for = $(strip $(call load-var-for,CKOPTFLAGS,$(1)) \
|
||||
get-sandbox-c99flags-for = $(strip $(call load-var-for,COPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
$(CSBOXINCFLAGS) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
get-sandbox-cxxflags-for = $(strip $(call load-var-for,COPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cxxflags-for,$(1)) \
|
||||
$(CSBOXINCFLAGS) \
|
||||
$(BUILD_FLAGS) \
|
||||
$(BUILD_CPPFLAGS) \
|
||||
$(BUILD_SYMFLAGS) \
|
||||
)
|
||||
|
||||
# Define a separate function that will return appropriate flags for use by
|
||||
# applications that want to use the same basic flags as those used when BLIS
|
||||
# was compiled. (This is the same as get-frame-cflags-for(), except that it
|
||||
# omits the BUILD_FLAGS, which are exclusively for use when BLIS is being
|
||||
# compiled.)
|
||||
# was compiled. (NOTE: This is the same as the $(get-frame-cflags-for ...)
|
||||
# function, except that it omits two variables that contain flags exclusively
|
||||
# for use when BLIS is being compiled/built: BUILD_CPPFLAGS, which contains a
|
||||
# cpp macro that confirms that BLIS is being built; and BUILD_SYMFLAGS, which
|
||||
# contains symbol export flags that are only needed when a shared library is
|
||||
# being compiled/linked.)
|
||||
get-user-cflags-for = $(strip $(call load-var-for,COPTFLAGS,$(1)) \
|
||||
$(call get-noopt-cflags-for,$(1)) \
|
||||
)
|
||||
@@ -627,22 +637,26 @@ $(foreach c, $(CONFIG_LIST_FAM), $(eval $(call append-var-for,CPICFLAGS,$(c))))
|
||||
|
||||
# --- Symbol exporting flags (shared libraries only) ---
|
||||
|
||||
# NOTE: These flags are only applied when building BLIS and not used by
|
||||
# applications that import BLIS compilation flags via the
|
||||
# $(get-user-cflags-for ...) function.
|
||||
|
||||
# Determine default export behavior / visibility of symbols for gcc.
|
||||
ifeq ($(CC_VENDOR),gcc)
|
||||
ifeq ($(IS_WIN),yes)
|
||||
ifeq ($(EXPORT_SHARED),all)
|
||||
CMISCFLAGS := -Wl,--export-all-symbols, -Wl,--enable-auto-import
|
||||
BUILD_SYMFLAGS := -Wl,--export-all-symbols, -Wl,--enable-auto-import
|
||||
else # ifeq ($(EXPORT_SHARED),public)
|
||||
CMISCFLAGS := -Wl,--exclude-all-symbols
|
||||
BUILD_SYMFLAGS := -Wl,--exclude-all-symbols
|
||||
endif
|
||||
else # ifeq ($(IS_WIN),no)
|
||||
ifeq ($(EXPORT_SHARED),all)
|
||||
# Export all symbols by default.
|
||||
CMISCFLAGS := -fvisibility=default
|
||||
BUILD_SYMFLAGS := -fvisibility=default
|
||||
else # ifeq ($(EXPORT_SHARED),public)
|
||||
# Hide all symbols by default and export only those that have been annotated
|
||||
# as needing to be exported.
|
||||
CMISCFLAGS := -fvisibility=hidden
|
||||
BUILD_SYMFLAGS := -fvisibility=hidden
|
||||
endif
|
||||
endif
|
||||
endif
|
||||
@@ -653,11 +667,11 @@ endif
|
||||
ifeq ($(CC_VENDOR),icc)
|
||||
ifeq ($(EXPORT_SHARED),all)
|
||||
# Export all symbols by default.
|
||||
CMISCFLAGS := -fvisibility=default
|
||||
BUILD_SYMFLAGS := -fvisibility=default
|
||||
else # ifeq ($(EXPORT_SHARED),public)
|
||||
# Hide all symbols by default and export only those that have been annotated
|
||||
# as needing to be exported.
|
||||
CMISCFLAGS := -fvisibility=hidden
|
||||
BUILD_SYMFLAGS := -fvisibility=hidden
|
||||
endif
|
||||
endif
|
||||
|
||||
@@ -667,27 +681,25 @@ ifeq ($(IS_WIN),yes)
|
||||
ifeq ($(EXPORT_SHARED),all)
|
||||
# NOTE: clang on Windows does not appear to support exporting all symbols
|
||||
# by default, and therefore we ignore the value of EXPORT_SHARED.
|
||||
CMISCFLAGS :=
|
||||
BUILD_SYMFLAGS :=
|
||||
else # ifeq ($(EXPORT_SHARED),public)
|
||||
# NOTE: The default behavior of clang on Windows is to hide all symbols
|
||||
# and only export functions and other declarations that have beenannotated
|
||||
# as needing to be exported.
|
||||
CMISCFLAGS :=
|
||||
BUILD_SYMFLAGS :=
|
||||
endif
|
||||
else # ifeq ($(IS_WIN),no)
|
||||
ifeq ($(EXPORT_SHARED),all)
|
||||
# Export all symbols by default.
|
||||
CMISCFLAGS := -fvisibility=default
|
||||
BUILD_SYMFLAGS := -fvisibility=default
|
||||
else # ifeq ($(EXPORT_SHARED),public)
|
||||
# Hide all symbols by default and export only those that have been annotated
|
||||
# as needing to be exported.
|
||||
CMISCFLAGS := -fvisibility=hidden
|
||||
BUILD_SYMFLAGS := -fvisibility=hidden
|
||||
endif
|
||||
endif
|
||||
endif
|
||||
|
||||
$(foreach c, $(CONFIG_LIST_FAM), $(eval $(call append-var-for,CMISCFLAGS,$(c))))
|
||||
|
||||
# --- Language flags ---
|
||||
|
||||
# Enable C99.
|
||||
@@ -1026,7 +1038,7 @@ VERS_DEF := -DBLIS_VERSION_STRING=\"$(VERSION)\"
|
||||
# Define a C preprocessor flag that is *only* defined when BLIS is being
|
||||
# compiled. (In other words, an application that #includes blis.h will not
|
||||
# get this cpp macro.)
|
||||
BUILD_FLAGS := -DBLIS_IS_BUILDING_LIBRARY
|
||||
BUILD_CPPFLAGS := -DBLIS_IS_BUILDING_LIBRARY
|
||||
|
||||
|
||||
|
||||
|
||||
14
configure
vendored
14
configure
vendored
@@ -152,13 +152,13 @@ print_usage()
|
||||
echo " functions and variables that belong to public APIs are"
|
||||
echo " exported in shared libraries. However, the user may"
|
||||
echo " instead export all symbols in BLIS, even those that were"
|
||||
echo " intended for internal use only. Note Note that the public"
|
||||
echo " APIs encompass all functions that almost any user would"
|
||||
echo " ever want to call, including the BLAS/CBLAS compatibility"
|
||||
echo " APIs as well as the basic and expert interfaces to the"
|
||||
echo " typed and object APIs that are unique to BLIS. Also note"
|
||||
echo " that changing this option to 'all' will have no effect in"
|
||||
echo " some environments, such as when compiling with clang on"
|
||||
echo " intended for internal use only. Note that the public APIs"
|
||||
echo " encompass all functions that almost any user would ever"
|
||||
echo " want to call, including the BLAS/CBLAS compatibility APIs"
|
||||
echo " as well as the basic and expert interfaces to the typed"
|
||||
echo " and object APIs that are unique to BLIS. Also note that"
|
||||
echo " changing this option to 'all' will have no effect in some"
|
||||
echo " environments, such as when compiling with clang on"
|
||||
echo " Windows."
|
||||
echo " "
|
||||
echo " -t MODEL, --enable-threading[=MODEL], --disable-threading"
|
||||
|
||||
Reference in New Issue
Block a user