Josh Sharp via llvm-dev
2019-Apr-12  04:32 UTC
[llvm-dev] 'Simple Register Coalescing' pass error
Hi all,
I have an error I do not understand. My program crashes during the 'Simple
Register Coalescing' pass. All I know is that the crash happens inside
LiveRange::Query() in llvm/include/llvm/CodeGen/LiveInterval.h and is due to the
fact that EarlyVal is null and causes a crash when evaluating if
(EarlyVal->def == Idx.getBaseIndex()). What could be the reason why EarlyVal
is null? The function on which the pass is being run is:
void foo(uint8_t* input, const uint8_t* key, uint8_t *output, size_t len)
{
uint16_t np1 = (len * 8)/64;
uint16_t n = np1 - 1;
uint64_t A;
uint64_t R[n+1];
int i,j;
       memcpy(&A,input,8);
       for (i = 1; i<= n;i++)
       {
           memcpy(&R[i], input + 8*i,8);
       }
       for (j = 5; j >= 0; j--)
           for (i = n; i >= 1; i--)
           {
            uint64_t l_input[2]             {
              A ^ (((uint64_t)(n*j+i))<<56),
              R[i]
            };
               dec((uint8_t*)l_input, key, output);
               memcpy(&A,output,8);
               memcpy(&R[i],output+8,8);
           }
       memcpy(output,&A,8);
       int k;
       for(k=1;k<(n+1);k++)
       {
        memcpy(output+8*k,&R[k],8);
       }
}
Thanks.
-------------- next part --------------
An HTML attachment was scrubbed...
URL:
<http://lists.llvm.org/pipermail/llvm-dev/attachments/20190412/ca27d61e/attachment.html>
Quentin Colombet via llvm-dev
2019-Apr-12  16:41 UTC
[llvm-dev] 'Simple Register Coalescing' pass error
Hi Josh, That sounds like a bug, but I don’t have enough information to know what is going on. Could you file a public report in buzgilla and attach the IR (run clang with `-emit-llvm`) and the debug output of the coalescer (-mllvm -debug-only=regalloc)? Thanks, -Quentin> On Apr 11, 2019, at 9:32 PM, Josh Sharp via llvm-dev <llvm-dev at lists.llvm.org> wrote: > > > Hi all, > I have an error I do not understand. My program crashes during the 'Simple Register Coalescing' pass. All I know is that the crash happens inside LiveRange::Query() in llvm/include/llvm/CodeGen/LiveInterval.h and is due to the fact that EarlyVal is null and causes a crash when evaluating if (EarlyVal->def == Idx.getBaseIndex()). What could be the reason why EarlyVal is null? The function on which the pass is being run is: > > > > void foo(uint8_t* input, const uint8_t* key, uint8_t *output, size_t len) > { > > uint16_t np1 = (len * 8)/64; > uint16_t n = np1 - 1; > uint64_t A; > uint64_t R[n+1]; > int i,j; > > > memcpy(&A,input,8); > for (i = 1; i<= n;i++) > { > memcpy(&R[i], input + 8*i,8); > } > > > for (j = 5; j >= 0; j--) > for (i = n; i >= 1; i--) > { > uint64_t l_input[2] > { > A ^ (((uint64_t)(n*j+i))<<56), > R[i] > }; > > dec((uint8_t*)l_input, key, output); > memcpy(&A,output,8); > memcpy(&R[i],output+8,8); > } > > memcpy(output,&A,8); > int k; > for(k=1;k<(n+1);k++) > { > memcpy(output+8*k,&R[k],8); > } > } > > Thanks. > _______________________________________________ > LLVM Developers mailing list > llvm-dev at lists.llvm.org <mailto:llvm-dev at lists.llvm.org> > https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev <https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev>-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20190412/de10f657/attachment.html>