rovka accepted this revision.
rovka added a comment.
This revision is now accepted and ready to land.

In D123211#3433059 <https://reviews.llvm.org/D123211#3433059>, @awarzynski 
wrote:

> Thanks for taking a look Diana!
>
>> Why not use the BackendAction for this?
>
> This action only requires the middle-end in LLVM :) The `BackendAction` will 
> use the backend, but that's not needed here.

Is there actually a significant difference, besides the naming (which is easy 
to change)? AFAICT the BackendAction isn't initializing anything 
backend-related except very close to where it's using it, so that can happen 
inside a switch/if branch.

>> There seems to be a lot of shared code, up until the point where you create 
>> and use the pass manager
>
> This is the bit that's shared:
>
>   CompilerInstance &ci = this->instance();
>   // Generate an LLVM module if it's not already present (it will already be
>   // present if the input file is an LLVM IR/BC file).
>   if (!llvmModule)
>     GenerateLLVMIR();
>   
>   // Create and configure `Target`
>   std::string error;
>   std::string theTriple = llvmModule->getTargetTriple();
>   const llvm::Target *theTarget =
>       llvm::TargetRegistry::lookupTarget(theTriple, error);
>   assert(theTarget && "Failed to create Target");
>   
>   // Create and configure `TargetMachine`
>   std::unique_ptr<llvm::TargetMachine> TM;
>   
>   TM.reset(theTarget->createTargetMachine(theTriple, /*CPU=*/"",
>       /*Features=*/"", llvm::TargetOptions(), llvm::None));
>   assert(TM && "Failed to create TargetMachine");
>   llvmModule->setDataLayout(TM->createDataLayout());
>
> I wouldn't say it's "a lot", but probably enough for a dedicated method. I've 
> been conservative with regard to sharing code as I anticipate things to 
> change in the future (I expect `-O{0|1|2|3|s|z}` to complicate the logic a 
> bit).

I was thinking also about the code for generating the output file, which can be 
folded into the switch from BackendAction. If you consider that too, it becomes 
a very large percentage of EmitLLVMBitcodeAction::ExecuteAction that can be 
shared.

>> (and in the future, when the backend switches to the new pass manager, there 
>> will be even more shared code).
>
> I'm not sure about the timelines for this. And even then, the logic might be 
> quite different (again, middle-end vs back-end).

Ok. IMO the template method pattern would work well here (or less formally, 
just a simple switch to the same effect), but I can understand if you think 
it's premature to go that route. 
No other objections from my side, thanks :)


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D123211

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

Reply via email to