Skip to content

Commit 613a077

Browse files
authored
[flang] Generate quadmath_wrapper.h for Flang Evaluate. (llvm#132817)
When building Flang with Clang, we need to do the same quadmath.h wrapping as we do for flang-rt. I extracted the CMake code into FlangCommon.cmake, and cleaned up the arguments passing to execute_process (note that `-###` was treated as `-` in the original code, because `#` starts a comment). I believe the Clang command does not require the input source file, so I removed it as well.
1 parent 011a95c commit 613a077

File tree

9 files changed

+75
-47
lines changed

9 files changed

+75
-47
lines changed

flang-rt/CMakeLists.txt

Lines changed: 1 addition & 39 deletions
Original file line numberDiff line numberDiff line change
@@ -290,44 +290,6 @@ set(HAVE_BACKTRACE ${Backtrace_FOUND})
290290
set(BACKTRACE_HEADER ${Backtrace_HEADER})
291291

292292

293-
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
294-
if (NOT DEFINED FLANG_RT_GCC_RESOURCE_DIR)
295-
set(FLANG_RT_GCC_RESOURCE_DIR "FLANG_RT_GCC_RESOURCE_DIR-NOTFOUND")
296-
execute_process(
297-
COMMAND "${CMAKE_CXX_COMPILER}" -v -c "${FLANG_RT_SOURCE_DIR}/cmake/clang_gcc_root.cpp" ${CMAKE_CXX_FLAGS} -###
298-
ERROR_FILE "${CMAKE_CURRENT_BINARY_DIR}/clang_gcc_root_result"
299-
)
300-
file(STRINGS "${CMAKE_CURRENT_BINARY_DIR}/clang_gcc_root_result" _errorresult)
301-
foreach (_line IN LISTS _errorresult)
302-
string(REGEX MATCH
303-
"^Selected GCC installation: (.+)$"
304-
_match
305-
"${_line}")
306-
if (CMAKE_MATCH_1)
307-
set(FLANG_RT_GCC_RESOURCE_DIR "${CMAKE_MATCH_1}")
308-
message(STATUS "Found GCC installation selected by Clang: ${FLANG_RT_GCC_RESOURCE_DIR}")
309-
break()
310-
endif ()
311-
endforeach ()
312-
set(FLANG_RT_GCC_RESOURCE_DIR "${FLANG_RT_GCC_RESOURCE_DIR}" CACHE INTERNAL "Path to GCC's resource dir selected by Clang" FORCE)
313-
endif ()
314-
endif ()
315-
316-
check_include_file("quadmath.h" FOUND_QUADMATH_H)
317-
if (FOUND_QUADMATH_H)
318-
message(STATUS "quadmath.h found without additional include paths")
319-
set(FLANG_RT_INCLUDE_QUADMATH_H "<quadmath.h>")
320-
elseif (FLANG_RT_GCC_RESOURCE_DIR)
321-
cmake_push_check_state()
322-
list(APPEND CMAKE_REQUIRED_INCLUDES "${FLANG_RT_GCC_RESOURCE_DIR}/include")
323-
check_include_file("quadmath.h" FOUND_GCC_QUADMATH_H)
324-
cmake_pop_check_state()
325-
if (FOUND_GCC_QUADMATH_H)
326-
message(STATUS "quadmath.h found in Clang's selected GCC installation")
327-
set(FLANG_RT_INCLUDE_QUADMATH_H "\"${FLANG_RT_GCC_RESOURCE_DIR}/include/quadmath.h\"")
328-
endif ()
329-
endif ()
330-
331293
#####################
332294
# Build Preparation #
333295
#####################
@@ -351,7 +313,7 @@ set(CMAKE_CXX_STANDARD_REQUIRED YES)
351313

352314

353315
configure_file(cmake/config.h.cmake.in config.h)
354-
if (FLANG_RT_INCLUDE_QUADMATH_H)
316+
if (FLANG_INCLUDE_QUADMATH_H)
355317
configure_file("cmake/quadmath_wrapper.h.in" "${FLANG_RT_BINARY_DIR}/quadmath_wrapper.h")
356318
endif ()
357319

flang-rt/cmake/clang_gcc_root.cpp

Lines changed: 0 additions & 1 deletion
This file was deleted.

flang-rt/cmake/quadmath_wrapper.h.in

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,4 +6,4 @@
66
*
77
*===----------------------------------------------------------------------===*/
88

9-
#include ${FLANG_RT_INCLUDE_QUADMATH_H}
9+
#include ${FLANG_INCLUDE_QUADMATH_H}

flang-rt/lib/quadmath/CMakeLists.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -78,7 +78,7 @@ target_include_directories(FortranFloat128MathILib INTERFACE
7878

7979
if (FLANG_RUNTIME_F128_MATH_LIB)
8080
if (${FLANG_RUNTIME_F128_MATH_LIB} STREQUAL "libquadmath")
81-
if(FLANG_RT_INCLUDE_QUADMATH_H)
81+
if(FLANG_INCLUDE_QUADMATH_H)
8282
add_compile_definitions(HAS_QUADMATHLIB)
8383
else()
8484
message(FATAL_ERROR

flang/cmake/modules/FlangCommon.cmake

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,3 +37,47 @@ check_c_source_compiles(
3737
int main() { return 0; }
3838
"
3939
HAVE_LDBL_MANT_DIG_113)
40+
41+
# Discover the GCC installation, when the build compiler is Clang,
42+
# and try to find quadmath.h there. Set FLANG_INCLUDE_QUADMATH_H
43+
# to the path to quadmath.h, if found.
44+
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
45+
if (NOT DEFINED FLANG_GCC_RESOURCE_DIR)
46+
set(FLANG_GCC_RESOURCE_DIR "FLANG_GCC_RESOURCE_DIR-NOTFOUND")
47+
# Prepare CMAKE_CXX_FLAGS so that they can be passed to execute_process
48+
# as separate flags.
49+
separate_arguments(flags UNIX_COMMAND "${CMAKE_CXX_FLAGS}")
50+
execute_process(
51+
COMMAND "${CMAKE_CXX_COMPILER}" ${flags} -v "-###"
52+
ERROR_FILE "${CMAKE_CURRENT_BINARY_DIR}/clang_gcc_root_result"
53+
)
54+
file(STRINGS "${CMAKE_CURRENT_BINARY_DIR}/clang_gcc_root_result" _errorresult)
55+
foreach (_line IN LISTS _errorresult)
56+
string(REGEX MATCH
57+
"^Selected GCC installation: (.+)$"
58+
_match
59+
"${_line}")
60+
if (CMAKE_MATCH_1)
61+
set(FLANG_GCC_RESOURCE_DIR "${CMAKE_MATCH_1}")
62+
message(STATUS "Found GCC installation selected by Clang: ${FLANG_GCC_RESOURCE_DIR}")
63+
break()
64+
endif ()
65+
endforeach ()
66+
set(FLANG_GCC_RESOURCE_DIR "${FLANG_GCC_RESOURCE_DIR}" CACHE INTERNAL "Path to GCC's resource dir selected by Clang" FORCE)
67+
endif ()
68+
endif ()
69+
70+
check_include_file("quadmath.h" FOUND_QUADMATH_H)
71+
if (FOUND_QUADMATH_H)
72+
message(STATUS "quadmath.h found without additional include paths")
73+
set(FLANG_INCLUDE_QUADMATH_H "<quadmath.h>")
74+
elseif (FLANG_GCC_RESOURCE_DIR)
75+
cmake_push_check_state()
76+
list(APPEND CMAKE_REQUIRED_INCLUDES "${FLANG_GCC_RESOURCE_DIR}/include")
77+
check_include_file("quadmath.h" FOUND_GCC_QUADMATH_H)
78+
cmake_pop_check_state()
79+
if (FOUND_GCC_QUADMATH_H)
80+
message(STATUS "quadmath.h found in Clang's selected GCC installation")
81+
set(FLANG_INCLUDE_QUADMATH_H "\"${FLANG_GCC_RESOURCE_DIR}/include/quadmath.h\"")
82+
endif ()
83+
endif ()

flang/cmake/quadmath_wrapper.h.in

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
/*===-- cmake/quadmath_wrapper.h.in ---------------------=-----------*- C -*-===
2+
*
3+
* Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4+
* See https://llvm.org/LICENSE.txt for license information.
5+
* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6+
*
7+
*===----------------------------------------------------------------------===*/
8+
9+
#ifdef __clang_major__
10+
/*
11+
* _Complex inside quadmath.h triggers c99-extension warnings,
12+
* when this header file is included into a C++ file.
13+
* Disable them just during the inclusion of quadmath.h.
14+
*/
15+
#pragma clang diagnostic push
16+
#pragma clang diagnostic ignored "-Wc99-extensions"
17+
#endif
18+
19+
#include ${FLANG_INCLUDE_QUADMATH_H}
20+
21+
#ifdef __clang_major__
22+
#pragma clang diagnostic pop
23+
#endif

flang/lib/Evaluate/CMakeLists.txt

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -21,12 +21,12 @@ if (LIBPGMATH_DIR)
2121
endif()
2222
endif()
2323

24-
check_include_file(quadmath.h FOUND_QUADMATH_HEADER)
2524
check_library_exists(quadmath sinq "" FOUND_QUADMATH_LIB)
26-
if(FOUND_QUADMATH_HEADER AND FOUND_QUADMATH_LIB)
25+
if (FLANG_INCLUDE_QUADMATH_H AND FOUND_QUADMATH_LIB)
26+
configure_file("${FLANG_SOURCE_DIR}/cmake/quadmath_wrapper.h.in" "${CMAKE_CURRENT_BINARY_DIR}/quadmath_wrapper.h")
2727
add_compile_definitions(HAS_QUADMATHLIB)
2828
set(QUADMATHLIB quadmath)
29-
endif()
29+
endif ()
3030

3131
add_flang_library(FortranEvaluate
3232
call.cpp

flang/lib/Evaluate/host.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@
1818
// to safely refer to this hardware type.
1919

2020
#if HAS_QUADMATHLIB
21-
#include "quadmath.h"
21+
#include "quadmath_wrapper.h"
2222
#include "flang/Common/float128.h"
2323
#endif
2424
#include "flang/Evaluate/type.h"

flang/lib/Evaluate/intrinsics-library.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@
2323
#include <complex>
2424
#include <functional>
2525
#if HAS_QUADMATHLIB
26-
#include "quadmath.h"
26+
#include "quadmath_wrapper.h"
2727
#endif
2828
#include "flang/Common/float128.h"
2929
#include "flang/Common/float80.h"

0 commit comments

Comments
 (0)