Previously if getSetccResultType returned an illegal type we just fell back to using the default promoted type. This appears to have been to handle the case where for vectors getSetccResultType returns the input type, but the input type itself isn't legal and will need to be promoted. Without the legality check we would never reach a legal type.
But just picking the promoted type to be the setcc type can create strange setccs where the result type is 128 bits and the operand type is 256 bits. If for example the result type was promoted to v8i16 from v8i1, but the input type was promoted from v8i23 to v8i32. We currently handle this with custom lowering code in X86.
This legality check also caused us reject the getSetccResultType when the input type needed to be widened or split. Even though that result wouldn't have caused legalization to get stuck.
This patch tries to fix this situation by detecting that the input type needs to be promoted and using the promoted input type to make the setcc call. This should prevent getting stuck always picking the same illegal type.
I tried legalizing the operands of the setcc at the same time as the result for this case, but that caused some test changes solely due to the next DAG combine running in a different order.
The x86 test changes look to be regressions. Previously we were rejecting this because the result type being returned was v8i64 but we were rejecting it in favor of v8i16. Then we split the operands to v4i64, created a setcc with v4i1 result type. Promoted that v4i1 to v4i32. Then split the setcc operands again to v2i64, created setcc with v2i1 result type. Then finally promoted that v2i1 result to v2i64. Each time we promote the result a truncate node gets introduced. Somehow those intermediate truncates helped us legalize this well. Now we keep v8i64 and always have vXi1 or vXi64 results for the setccs. We are able to split these setccs without introducing any new truncates.
Please explicitly note this is a heuristic.