tejohnson added a comment.

In D108881#2971651 <https://reviews.llvm.org/D108881#2971651>, @tbaeder wrote:

> That code has changed quite a bit since I've worked on it.
>
> The only problem I could see is that passing `-flto=thin -flto` and choosing 
> thin LTO kinda makes sense if you interpret `-flto` as just "use LTO". The 
> `-flto=thin` is more specific, so it could make sense to pick that. But 
> that's just something I wonder while looking at it. Not sure if we process 
> other options like this by just choosing the last one.

The default of -flto is documented as -flto=full, so I think the change here 
makes sense. In general the last option wins.



================
Comment at: clang/lib/Driver/ToolChains/Clang.cpp:4495-4497
+        Arg *A = Args.getLastArg(options::OPT_flto, options::OPT_flto_EQ);
+        if (A && A->getOption().matches(options::OPT_flto))
           CmdArgs.push_back("-flto");
----------------
mnadeem wrote:
> Another option would be to do the following, but i am not sure if there is 
> any code that explicitly checks for/needs "=full":
> 
> ```
> if (D.getLTOMode() == LTOK_Thin)
>     CmdArgs.push_back("-flto=thin");
> else
>     CmdArgs.push_back("-flto");
> ```
Yes, that should be fine since the default is full. But better yet, make the 
else pass the explicit -flto=full.


================
Comment at: clang/lib/Driver/ToolChains/Clang.cpp:4496
+        Arg *A = Args.getLastArg(options::OPT_flto, options::OPT_flto_EQ);
+        if (A && A->getOption().matches(options::OPT_flto))
           CmdArgs.push_back("-flto");
----------------
Can we consolidate the option handling into parseLTOMode, which does the rest 
of the -flto option handling and sets the LTOMode returned by the below call to 
getLTOMode()? The default of -flto is "full" so it can be treated there as 
such. Actually, looks like it should already be doing this?


================
Comment at: clang/lib/Driver/ToolChains/Clang.cpp:4498
           CmdArgs.push_back("-flto");
-        else {
-          if (D.getLTOMode() == LTOK_Thin)
-            CmdArgs.push_back("-flto=thin");
-          else
-            CmdArgs.push_back("-flto=full");
-        }
+        else if (D.getLTOMode() == LTOK_Thin)
+          CmdArgs.push_back("-flto=thin");
----------------
Looks like the result of getLTOMode() is already saved in the LTOMode local 
variable.


================
Comment at: clang/test/Driver/lto.c:97
+//
+// FLTO-THIN: -flto=thin
+// FLTO-FULL: -flto=full
----------------
Probably want to check that we don't have additional -flto options being passed 
too, here and on the below lines.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D108881

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to