(set (match_dup 0) (match_op_dup 1
[(and:SI (match_dup 3) (match_dup 2))
(const_int 0)]))])
+
+;; Variant 1 of 4: Split ((A | B) ^ A) ^ C as (B & ~A) ^ C.
+(define_split
+ [(set (match_operand:SWI48 0 "register_operand")
+ (xor:SWI48
+ (xor:SWI48
+ (ior:SWI48 (match_operand:SWI48 1 "register_operand")
+ (match_operand:SWI48 2 "nonimmediate_operand"))
+ (match_dup 1))
+ (match_operand:SWI48 3 "nonimmediate_operand")))
+ (clobber (reg:CC FLAGS_REG))]
+ "TARGET_BMI"
+ [(parallel
+ [(set (match_dup 4) (and:SWI48 (not:SWI48 (match_dup 1)) (match_dup 2)))
+ (clobber (reg:CC FLAGS_REG))])
+ (parallel
+ [(set (match_dup 0) (xor:SWI48 (match_dup 4) (match_dup 3)))
+ (clobber (reg:CC FLAGS_REG))])]
+ "operands[4] = gen_reg_rtx (<MODE>mode);")
+
+;; Variant 2 of 4: Split ((A | B) ^ B) ^ C as (A & ~B) ^ C.
+(define_split
+ [(set (match_operand:SWI48 0 "register_operand")
+ (xor:SWI48
+ (xor:SWI48
+ (ior:SWI48 (match_operand:SWI48 1 "register_operand")
+ (match_operand:SWI48 2 "register_operand"))
+ (match_dup 2))
+ (match_operand:SWI48 3 "nonimmediate_operand")))
+ (clobber (reg:CC FLAGS_REG))]
+ "TARGET_BMI"
+ [(parallel
+ [(set (match_dup 4) (and:SWI48 (not:SWI48 (match_dup 2)) (match_dup 1)))
+ (clobber (reg:CC FLAGS_REG))])
+ (parallel
+ [(set (match_dup 0) (xor:SWI48 (match_dup 4) (match_dup 3)))
+ (clobber (reg:CC FLAGS_REG))])]
+ "operands[4] = gen_reg_rtx (<MODE>mode);")
+
+;; Variant 3 of 4: Split ((A | B) ^ C) ^ A as (B & ~A) ^ C.
+(define_split
+ [(set (match_operand:SWI48 0 "register_operand")
+ (xor:SWI48
+ (xor:SWI48
+ (ior:SWI48 (match_operand:SWI48 1 "register_operand")
+ (match_operand:SWI48 2 "nonimmediate_operand"))
+ (match_operand:SWI48 3 "nonimmediate_operand"))
+ (match_dup 1)))
+ (clobber (reg:CC FLAGS_REG))]
+ "TARGET_BMI"
+ [(parallel
+ [(set (match_dup 4) (and:SWI48 (not:SWI48 (match_dup 1)) (match_dup 2)))
+ (clobber (reg:CC FLAGS_REG))])
+ (parallel
+ [(set (match_dup 0) (xor:SWI48 (match_dup 4) (match_dup 3)))
+ (clobber (reg:CC FLAGS_REG))])]
+ "operands[4] = gen_reg_rtx (<MODE>mode);")
+
+;; Variant 4 of 4: Split ((A | B) ^ C) ^ B as (A & ~B) ^ C.
+(define_split
+ [(set (match_operand:SWI48 0 "register_operand")
+ (xor:SWI48
+ (xor:SWI48
+ (ior:SWI48 (match_operand:SWI48 1 "register_operand")
+ (match_operand:SWI48 2 "register_operand"))
+ (match_operand:SWI48 3 "nonimmediate_operand"))
+ (match_dup 2)))
+ (clobber (reg:CC FLAGS_REG))]
+ "TARGET_BMI"
+ [(parallel
+ [(set (match_dup 4) (and:SWI48 (not:SWI48 (match_dup 2)) (match_dup 1)))
+ (clobber (reg:CC FLAGS_REG))])
+ (parallel
+ [(set (match_dup 0) (xor:SWI48 (match_dup 4) (match_dup 3)))
+ (clobber (reg:CC FLAGS_REG))])]
+ "operands[4] = gen_reg_rtx (<MODE>mode);")
\f
;; Logical inclusive and exclusive OR instructions