sifive-7-series can predicate ALU instructions in the shadow of a
branch not just move instruction instructions.
This patch implements analyzeSelect/optimizeSelect to predicate
these operations. This is based on ARM's implementation.
I've restricted it to just the instructions we have test cases for,
but it can be extended in the future.
Can you rename this into something like canFoldIntoPredicateOp? CCMOV doesn't seem to be quite right here.