[PATCH] Added InstCombine transform for pattern " ((X % Z) + (Y % Z)) % Z -> (X + Y) % Z ".

Nuno Lopes nunoplopes at sapo.pt
Mon Sep 15 04:50:21 PDT 2014


This patch is incorrect:

$ ./alive.py < a.opt
----------------------------------------
Optimization: 1
Precondition: true
%1 = srem %x, %z
%2 = srem %y, %z
%3 = add %1, %2
%r = srem %3, %z
   =>
%6 = add %x, %y
%r = srem %6, %z

Done: 1
ERROR: Domain of definedness of Target is smaller than Source's for i2 %r

Example:
%x i2 = 1 (0x1)
%z i2 = 3 (0x3)
%1 i2 = 0 (0x0)
%y i2 = 1 (0x1)
%2 i2 = 0 (0x0)
%3 i2 = 0 (0x0)
%6 i2 = 2 (0x2)
Source value: 0 (0x0)
Target value: undef


Meaning that the optimized code is introducing undefined behaviour  
where the original code didn't have.

Nuno



Citando Ankur Garg <ankur29.garg at samsung.com>:

> Hi majnemer, suyog, dexonsmith,
>
> Hi Eveyone,
>
> This patch implements the following transformation
>
>  " ((X % Z) + (Y % Z)) % Z -> (X + Y) % Z "
>
> Please help in reviewing it.
>
> Regards,
> Ankur.
>
> http://reviews.llvm.org/D5351
>
> Files:
>   lib/Transforms/InstCombine/InstCombineMulDivRem.cpp
>   test/Transforms/InstCombine/rem.ll



More information about the llvm-commits mailing list