[flang-commits] [PATCH] D104290: [flang] Check there's no dependency on C++ libs

Diana Picus via Phabricator via flang-commits flang-commits at lists.llvm.org
Wed Jun 16 01:24:38 PDT 2021


This revision was automatically updated to reflect the committed changes.
Closed by commit rG7ddbf2633911: [flang] Check there's no dependency on C++ libs (authored by rovka).

Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D104290/new/

https://reviews.llvm.org/D104290

Files:
  flang/test/Runtime/no-cpp-dep.c
  flang/test/lit.cfg.py
  flang/test/lit.site.cfg.py.in


Index: flang/test/lit.site.cfg.py.in
===================================================================
--- flang/test/lit.site.cfg.py.in
+++ flang/test/lit.site.cfg.py.in
@@ -9,8 +9,10 @@
 config.flang_tools_dir = "@FLANG_TOOLS_DIR@"
 config.flang_intrinsic_modules_dir = "@FLANG_INTRINSIC_MODULES_DIR@"
 config.flang_llvm_tools_dir = "@CMAKE_BINARY_DIR@/bin"
+config.flang_lib_dir = "@CMAKE_BINARY_DIR@/lib"
 config.python_executable = "@PYTHON_EXECUTABLE@"
 config.flang_standalone_build = @FLANG_STANDALONE_BUILD@
+config.cc = "@CMAKE_C_COMPILER@"
 
 # Control the regression test for flang-new driver
 import lit.util
Index: flang/test/lit.cfg.py
===================================================================
--- flang/test/lit.cfg.py
+++ flang/test/lit.cfg.py
@@ -75,6 +75,19 @@
    tools.append(ToolSubst('%flang_fc1', command=FindTool('f18'),
     unresolved='fatal'))
 
+# Define some variables to help us test that the flang runtime doesn't depend on
+# the C++ runtime libraries. For this we need a C compiler. If for some reason
+# we don't have one, we can just disable the test.
+if config.cc:
+    config.available_features.add('c-compiler')
+    tools.append(ToolSubst('%cc', command=config.cc, unresolved='ignore'))
+    tools.append(ToolSubst('%libruntime',
+        command=os.path.join(config.flang_lib_dir, 'libFortranRuntime.a'),
+        unresolved='warn'))
+    tools.append(ToolSubst('%runtimeincludes',
+        command=os.path.join(config.flang_src_dir, 'runtime'),
+        unresolved='warn'))
+
 if config.flang_standalone_build:
     llvm_config.add_tool_substitutions(tools, [config.flang_llvm_tools_dir])
 else:
Index: flang/test/Runtime/no-cpp-dep.c
===================================================================
--- /dev/null
+++ flang/test/Runtime/no-cpp-dep.c
@@ -0,0 +1,19 @@
+// This test makes sure that flang's runtime does not depend on the C++ runtime
+// library. It tries to link this simple file against libFortranRuntime.a with
+// a C compiler.
+//
+// REQUIRES: c-compiler
+//
+// RUN: %cc -std=c90 %s -I%runtimeincludes %libruntime -o /dev/null
+
+#include "entry-names.h"
+
+// Manually add declarations for the runtime functions that we want to make sure
+// we're testing. We can't include any headers directly since they likely
+// contain C++ code that would explode here.
+double RTNAME(CpuTime)();
+
+int main() {
+  double x = RTNAME(CpuTime)();
+  return x;
+}


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D104290.352369.patch
Type: text/x-patch
Size: 2431 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/flang-commits/attachments/20210616/411fcf1b/attachment.bin>


More information about the flang-commits mailing list