This revision was landed with ongoing or failed builds. This revision was automatically updated to reflect the committed changes. Closed by commit rGb81c5070d545: [flang] add -flang-experimental-polymorphism flag to flang-new (authored by DavidTruby).
Changed prior to commit: https://reviews.llvm.org/D153281?vs=532658&id=533622#toc Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153281/new/ https://reviews.llvm.org/D153281 Files: clang/include/clang/Driver/Options.td clang/lib/Driver/ToolChains/Flang.cpp flang/lib/Frontend/CompilerInvocation.cpp flang/test/Driver/driver-help-hidden.f90 flang/test/Driver/flang-experimental-polymorphism-flag.f90 flang/test/Driver/frontend-forwarding.f90 Index: flang/test/Driver/frontend-forwarding.f90 =================================================================== --- flang/test/Driver/frontend-forwarding.f90 +++ flang/test/Driver/frontend-forwarding.f90 @@ -16,7 +16,7 @@ ! RUN: -freciprocal-math \ ! RUN: -fpass-plugin=Bye%pluginext \ ! RUN: -fversion-loops-for-stride \ -! RUN: -mllvm -print-before-all\ +! RUN: -flang-experimental-polymorphism \ ! RUN: -mllvm -print-before-all \ ! RUN: -save-temps=obj \ ! RUN: -P \ @@ -36,6 +36,7 @@ ! CHECK: "-freciprocal-math" ! CHECK: "-fconvert=little-endian" ! CHECK: "-fpass-plugin=Bye -! CHECK: "-fversion-loops-for-stride" +! CHECK: "-flang-experimental-polymorphism" +! CHECK: "-fversion-loops-for-stride" ! CHECK: "-mllvm" "-print-before-all" ! CHECK: "-save-temps=obj" Index: flang/test/Driver/flang-experimental-polymorphism-flag.f90 =================================================================== --- /dev/null +++ flang/test/Driver/flang-experimental-polymorphism-flag.f90 @@ -0,0 +1,10 @@ +! Test -flang-experimental-hlfir flag +! RUN: %flang_fc1 -flang-experimental-polymorphism -emit-fir -o - %s | FileCheck %s +! RUN: not %flang_fc1 -emit-fir -o - %s 2>&1 | FileCheck %s --check-prefix NO-POLYMORPHISM + +! CHECK: func.func @_QPtest(%{{.*}}: !fir.class<none> {fir.bindc_name = "poly"}) +subroutine test(poly) + class(*) :: poly +end subroutine test + +! NO-POLYMORPHISM: not yet implemented: support for polymorphic types Index: flang/test/Driver/driver-help-hidden.f90 =================================================================== --- flang/test/Driver/driver-help-hidden.f90 +++ flang/test/Driver/driver-help-hidden.f90 @@ -41,6 +41,8 @@ ! CHECK-NEXT: Specify where to find the compiled intrinsic modules ! CHECK-NEXT: -flang-experimental-hlfir ! CHECK-NEXT: Use HLFIR lowering (experimental) +! CHECK-NEXT: -flang-experimental-polymorphism +! CHECK-NEXT: Enable Fortran 2003 polymorphism (experimental) ! CHECK-NEXT: -flarge-sizes Use INTEGER(KIND=8) for the result type in size-related intrinsics ! CHECK-NEXT: -flogical-abbreviations Enable logical abbreviations ! CHECK-NEXT: -flto=<value> Set LTO mode Index: flang/lib/Frontend/CompilerInvocation.cpp =================================================================== --- flang/lib/Frontend/CompilerInvocation.cpp +++ flang/lib/Frontend/CompilerInvocation.cpp @@ -920,6 +920,10 @@ res.loweringOpts.setLowerToHighLevelFIR(true); } + if (args.hasArg(clang::driver::options::OPT_flang_experimental_polymorphism)) { + res.loweringOpts.setPolymorphicTypeImpl(true); + } + success &= parseFrontendArgs(res.getFrontendOpts(), args, diags); parseTargetArgs(res.getTargetOpts(), args); parsePreprocessorArgs(res.getPreprocessorOpts(), args); Index: clang/lib/Driver/ToolChains/Flang.cpp =================================================================== --- clang/lib/Driver/ToolChains/Flang.cpp +++ clang/lib/Driver/ToolChains/Flang.cpp @@ -140,6 +140,8 @@ if (Args.hasArg(options::OPT_flang_experimental_hlfir)) CmdArgs.push_back("-flang-experimental-hlfir"); + if (Args.hasArg(options::OPT_flang_experimental_polymorphism)) + CmdArgs.push_back("-flang-experimental-polymorphism"); if (shouldLoopVersion(Args)) CmdArgs.push_back("-fversion-loops-for-stride"); } Index: clang/include/clang/Driver/Options.td =================================================================== --- clang/include/clang/Driver/Options.td +++ clang/include/clang/Driver/Options.td @@ -5283,6 +5283,11 @@ Flags<[FlangOption, FC1Option, FlangOnlyOption, NoXarchOption, HelpHidden]>, HelpText<"Use HLFIR lowering (experimental)">; +def flang_experimental_polymorphism : Flag<["-"], "flang-experimental-polymorphism">, + Flags<[FlangOption, FC1Option, FlangOnlyOption, NoXarchOption, HelpHidden]>, + HelpText<"Enable Fortran 2003 polymorphism (experimental)">; + + //===----------------------------------------------------------------------===// // FLangOption + CoreOption + NoXarchOption //===----------------------------------------------------------------------===//
Index: flang/test/Driver/frontend-forwarding.f90 =================================================================== --- flang/test/Driver/frontend-forwarding.f90 +++ flang/test/Driver/frontend-forwarding.f90 @@ -16,7 +16,7 @@ ! RUN: -freciprocal-math \ ! RUN: -fpass-plugin=Bye%pluginext \ ! RUN: -fversion-loops-for-stride \ -! RUN: -mllvm -print-before-all\ +! RUN: -flang-experimental-polymorphism \ ! RUN: -mllvm -print-before-all \ ! RUN: -save-temps=obj \ ! RUN: -P \ @@ -36,6 +36,7 @@ ! CHECK: "-freciprocal-math" ! CHECK: "-fconvert=little-endian" ! CHECK: "-fpass-plugin=Bye -! CHECK: "-fversion-loops-for-stride" +! CHECK: "-flang-experimental-polymorphism" +! CHECK: "-fversion-loops-for-stride" ! CHECK: "-mllvm" "-print-before-all" ! CHECK: "-save-temps=obj" Index: flang/test/Driver/flang-experimental-polymorphism-flag.f90 =================================================================== --- /dev/null +++ flang/test/Driver/flang-experimental-polymorphism-flag.f90 @@ -0,0 +1,10 @@ +! Test -flang-experimental-hlfir flag +! RUN: %flang_fc1 -flang-experimental-polymorphism -emit-fir -o - %s | FileCheck %s +! RUN: not %flang_fc1 -emit-fir -o - %s 2>&1 | FileCheck %s --check-prefix NO-POLYMORPHISM + +! CHECK: func.func @_QPtest(%{{.*}}: !fir.class<none> {fir.bindc_name = "poly"}) +subroutine test(poly) + class(*) :: poly +end subroutine test + +! NO-POLYMORPHISM: not yet implemented: support for polymorphic types Index: flang/test/Driver/driver-help-hidden.f90 =================================================================== --- flang/test/Driver/driver-help-hidden.f90 +++ flang/test/Driver/driver-help-hidden.f90 @@ -41,6 +41,8 @@ ! CHECK-NEXT: Specify where to find the compiled intrinsic modules ! CHECK-NEXT: -flang-experimental-hlfir ! CHECK-NEXT: Use HLFIR lowering (experimental) +! CHECK-NEXT: -flang-experimental-polymorphism +! CHECK-NEXT: Enable Fortran 2003 polymorphism (experimental) ! CHECK-NEXT: -flarge-sizes Use INTEGER(KIND=8) for the result type in size-related intrinsics ! CHECK-NEXT: -flogical-abbreviations Enable logical abbreviations ! CHECK-NEXT: -flto=<value> Set LTO mode Index: flang/lib/Frontend/CompilerInvocation.cpp =================================================================== --- flang/lib/Frontend/CompilerInvocation.cpp +++ flang/lib/Frontend/CompilerInvocation.cpp @@ -920,6 +920,10 @@ res.loweringOpts.setLowerToHighLevelFIR(true); } + if (args.hasArg(clang::driver::options::OPT_flang_experimental_polymorphism)) { + res.loweringOpts.setPolymorphicTypeImpl(true); + } + success &= parseFrontendArgs(res.getFrontendOpts(), args, diags); parseTargetArgs(res.getTargetOpts(), args); parsePreprocessorArgs(res.getPreprocessorOpts(), args); Index: clang/lib/Driver/ToolChains/Flang.cpp =================================================================== --- clang/lib/Driver/ToolChains/Flang.cpp +++ clang/lib/Driver/ToolChains/Flang.cpp @@ -140,6 +140,8 @@ if (Args.hasArg(options::OPT_flang_experimental_hlfir)) CmdArgs.push_back("-flang-experimental-hlfir"); + if (Args.hasArg(options::OPT_flang_experimental_polymorphism)) + CmdArgs.push_back("-flang-experimental-polymorphism"); if (shouldLoopVersion(Args)) CmdArgs.push_back("-fversion-loops-for-stride"); } Index: clang/include/clang/Driver/Options.td =================================================================== --- clang/include/clang/Driver/Options.td +++ clang/include/clang/Driver/Options.td @@ -5283,6 +5283,11 @@ Flags<[FlangOption, FC1Option, FlangOnlyOption, NoXarchOption, HelpHidden]>, HelpText<"Use HLFIR lowering (experimental)">; +def flang_experimental_polymorphism : Flag<["-"], "flang-experimental-polymorphism">, + Flags<[FlangOption, FC1Option, FlangOnlyOption, NoXarchOption, HelpHidden]>, + HelpText<"Enable Fortran 2003 polymorphism (experimental)">; + + //===----------------------------------------------------------------------===// // FLangOption + CoreOption + NoXarchOption //===----------------------------------------------------------------------===//
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits