[PATCH] D112961: [fir] Add fir.extract_value and fir.insert_value conversion
    Mehdi AMINI via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Fri Nov  5 15:41:13 PDT 2021
    
    
  
mehdi_amini added inline comments.
================
Comment at: flang/lib/Optimizer/CodeGen/DescriptorModel.h:90
+template <>
+TypeBuilderFunc getModel<Fortran::ISO::CFI_index_t>() {
+  return [](mlir::MLIRContext *context) -> mlir::Type {
----------------
Meinersbur wrote:
> clementval wrote:
> > Meinersbur wrote:
> > > clementval wrote:
> > > > Meinersbur wrote:
> > > > > This breaks the [[ https://lab.llvm.org/buildbot/#/builders/172/builds/5299 | windows build ]]:
> > > > > ```
> > > > > C:\Users\buildbot-worker\minipc-ryzen-win\flang-x86_64-windows\llvm-project\flang\lib\Optimizer\CodeGen\DescriptorModel.h(95): error C2766: explicit specialization; 'fir::TypeBuilderFunc (__cdecl *fir::getModel<__int64>(void))(mlir::MLIRContext *)' has already been defined
> > > > > C:\Users\buildbot-worker\minipc-ryzen-win\flang-x86_64-windows\llvm-project\flang\lib\Optimizer\CodeGen\DescriptorModel.h(70): note: see previous definition of 'getModel'
> > > > > ```
> > > > > 
> > > > > `CFI_index_t` is a typedef of `ptrdiff_t` which is a 64 bit signed integer. That is, the same as `getModel<long long>` template specialization. Don't know why it works under Linux or why the Windows pre-merge check didn't run.
> > > > > 
> > > > https://github.com/llvm/llvm-project/commit/d75ab7d548c020f37ed3391a0002b206336fe46e should fix the buildbot for the time being. 
> > > Thanks, it successfully fixed the build: https://lab.llvm.org/buildbot/#/builders/172/builds/5311
> > @Meinersbur Removing this is actually making all other buildbots to fail. I reverted this patch until we can figure out what's happening. 
> Which one failed? I cannot find one at e.g. https://lab.llvm.org/buildbot/#/builders/175
> 
> By [[ https://llvm.org/docs/DeveloperPolicy.html#patch-reversion-policy | LLVM policy ]], this should have been mentioned in the reverting commit.
On Linux ptrdiff  is `long` : https://godbolt.org/z/fdacb8f7v
What if you replace this specialization with a specialization for `long` instead? This seems to be the one missing?
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D112961/new/
https://reviews.llvm.org/D112961
    
    
More information about the llvm-commits
mailing list