[llvm-dev] Use case of undef

Mehdi Amini via llvm-dev llvm-dev at lists.llvm.org
Sun Dec 4 18:10:48 PST 2016


> On Dec 4, 2016, at 3:22 PM, LYU YH via llvm-dev <llvm-dev at lists.llvm.org> wrote:
> 
> Hello Sean,
> 
> I read several LLVM undef materials[1][2][3] but still have some questions of it. I can understand "add %X, undef -> undef". But why the equation "and %X, undef -> 0" is valid? In LLVM Language Reference Manual, the explanation of such equation is that it is safe to assume that all bits of the ‘undef‘ could be 0. If so, why can't we assume all bits of the 'undef' is 0 in the former equation. Therefore we can get "add %X, 0 -> %X" instead?

For integer I believe you’re allowed to fold add %X, 0 -> %X

AFAIK you can use any valid bit pattern for the type when replacing an undef.

— 
Mehdi



> 
> By the way, is there any document that describe how 'undef' should be handled with other LLVM value? Is the 'undef' in LLVM the same as the UNDEF[4] (the top element in lattice) in constant propagation?
> 
> [1] http://www.nondot.org/sabre/LLVMNotes/UndefinedValue.txt <http://www.nondot.org/sabre/LLVMNotes/UndefinedValue.txt>
> [2] https://www.cs.utah.edu/~regehr/llvm-ub.pdf <https://www.cs.utah.edu/~regehr/llvm-ub.pdf>
> [3] http://sunfishcode.github.io/blog/2014/07/14/undef-introduction.html <http://sunfishcode.github.io/blog/2014/07/14/undef-introduction.html>
> [4] http://infolab.stanford.edu/~ullman/dragon/w06/lectures/cp.pdf <http://infolab.stanford.edu/~ullman/dragon/w06/lectures/cp.pdf>
> 
> Thanks for your reply
> _______________________________________________
> LLVM Developers mailing list
> llvm-dev at lists.llvm.org
> http://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/20161204/de32eef6/attachment.html>


More information about the llvm-dev mailing list