[PATCH] D153281: [flang] add -flang-experimental-polymorphism flag to flang-new
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 {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= 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/front
[PATCH] D153281: [flang] add -flang-experimental-polymorphism flag to flang-new
clementval added a comment. Looks ok to me. Note that some of the polymorphic TODOs will only be removed when HLFIR is in place. Looks like you have a clang-format issue. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153281/new/ https://reviews.llvm.org/D153281 ___ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
[PATCH] D153281: [flang] add -flang-experimental-polymorphism flag to flang-new
awarzynski accepted this revision. awarzynski added a comment. LGTM, thanks David! Could you also add a test in https://github.com/llvm/llvm-project/blob/main/flang/test/Driver/frontend-forwarding.f90? Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153281/new/ https://reviews.llvm.org/D153281 ___ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
[PATCH] D153281: [flang] add -flang-experimental-polymorphism flag to flang-new
tblah accepted this revision. tblah added a comment. This revision is now accepted and ready to land. Looks good to me, thanks! Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153281/new/ https://reviews.llvm.org/D153281 ___ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
[PATCH] D153281: [flang] add -flang-experimental-polymorphism flag to flang-new
DavidTruby created this revision. DavidTruby added reviewers: tblah, vzakhari, awarzynski. Herald added a reviewer: sscalpone. Herald added a subscriber: sunshaoce. Herald added projects: Flang, All. DavidTruby requested review of this revision. Herald added subscribers: cfe-commits, jdoerfert, MaskRay. Herald added a project: clang. This flag enables Fortran 2003 polymorphism. It is marked experimental and not included in --help. Repository: rG LLVM Github Monorepo 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 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 {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 @@ -43,6 +43,8 @@ ! CHECK-NEXT:Enable support for generating executables (experimental) ! 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= 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 @@ -5289,6 +5289,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/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 {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-hi