[LLVMdev] Question about lowering clamp function to bic/usat on ARM
Zhao, Weiming
weimingz at quicinc.com
Fri Nov 16 18:43:55 PST 2012
Hi,
Given a function like x < 0 ? 0 : x
We can lower it to bic x, x, asr 31 because we can test if CC==LT && RHS==TrueVal==0 && LHS==FalseVal
Further, give a function x > 255 ? 255 : (x < 0 ? 0 :x), we should lower it to: usat x, #8
However, things become more complicated if we have
((x < 0 ? 0 :x) << n ) & mask ...
Because it will first be converted to
x < 0 ? 0 : ((x << n) & mask)
Now, it's hard to match the pattern. (Doable but nasty)
Any suggestions?
Thanks in advance.
Weiming
Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20121117/968cfd3b/attachment.html>
More information about the llvm-dev
mailing list