On November 7, 2014 5:03:19 AM CET, Andrew Pinski <pins...@gmail.com> wrote:
>On Thu, Nov 6, 2014 at 2:40 AM, Richard Biener <rguent...@suse.de>
>wrote:
>> On Thu, 6 Nov 2014, Richard Biener wrote:
>>
>>> On Wed, 5 Nov 2014, Andrew Pinski wrote:
>>>
>>> > Hi,
>>> >   I was trying to hook up tree-ssa-phiopt to match-and-simplify
>using
>>> > either gimple_build (or rather using gimple_simplify depending on
>if
>>> > we want to produce cond_expr for conditional move).  I ran into a
>>> > problem.
>>> > With the pattern below:
>>> > /* a ? 0 : 1 -> a if 0 and 1 are integral types. */
>>> > (simplify
>>> >   (cond_expr @0 integer_zerop integer_onep)
>>> >   (if (INTEGRAL_TYPE_P (type))
>>> >     (convert @0)))
>>>
>>> Ok, so you are capturing a GENERIC expr here but nothing knows that.
>>> It would work if you'd do (ugh)
>>>
>>> (for op (lt le eq ne ge gt)
>>>  (simplify
>>>   (cond_expr (op @0 @1) integer_zerop integer_onep)
>>>   (if (INTEGRAL_TYPE_P (type))
>>>    (convert (op @0 @1)))))
>>> (simplify
>>>  (cond_expr SSA_NAME@0 integer_zerop integer_onep)
>>>   (if (INTEGRAL_TYPE_P (type))
>>>    (convert @0))))
>>>
>>> as a workaround.  To make your version work will require (quite)
>>> some special-casing in the code generator or maybe the resimplify
>>> helper.  Let me see if I can cook up a "simple" fix.
>>
>> Sth like below (for the real fix this has to be replicated in
>> all gimple_resimplifyN functions).  I'm missing a testcase
>> where the pattern would apply (and not be already folded by fold),
>> so I didn't check if it actually works.
>
>You do need to check if seq is NULL though as gimple_build depends on
>seq not being NULL.  But otherwise yes this works for me.
>
>>
>> Bah, of course we should fix COND_EXPRs to not embed a GENERIC
>> expr...
>
>Yes totally agree.  For my changes to tree-ssa-phiopt, I no longer
>embed it.  Though we need to change loop ifconvert still.

Istr expansion or code quality does not like us to cse the condition of two 
cobd_exprs either.  After all I had a patch set at some point doing that 
conversion (though as well for gimple_conds).

Richard.

>Thanks,
>Andrew
>
>>
>> Richard.
>>
>> Index: gcc/gimple-match-head.c
>> ===================================================================
>> --- gcc/gimple-match-head.c     (revision 217035)
>> +++ gcc/gimple-match-head.c     (working copy)
>> @@ -90,6 +90,13 @@ gimple_resimplify1 (gimple_seq *seq,
>>                     code_helper *res_code, tree type, tree *res_ops,
>>                     tree (*valueize)(tree))
>>  {
>> +  /* ???  Stupid tcc_comparison GENERIC trees in COND_EXPRs.  */
>> +  if (COMPARISON_CLASS_P (res_ops[0]))
>> +    res_ops[0] = gimple_build (seq,
>> +                              TREE_CODE (res_ops[0]), TREE_TYPE
>(res_ops[0]),
>> +                              TREE_OPERAND (res_ops[0], 0),
>> +                              TREE_OPERAND (res_ops[0], 1));
>> +
>>    if (constant_for_folding (res_ops[0]))
>>      {
>>        tree tem = NULL_TREE;
>>


Reply via email to