Apply
(bitxor-values val1 val2) → resval
It is an error if the values are not integers. If they are integers, we perform the usual arithmetic conversions and then we call the operation on integer values.
Function:
(defun bitxor-values (val1 val2) (declare (xargs :guard (and (valuep val1) (valuep val2)))) (let ((__function__ 'bitxor-values)) (declare (ignorable __function__)) (if (and (value-integerp val1) (value-integerp val2)) (b* (((mv val1 val2) (uaconvert-values val1 val2))) (bitxor-integer-values val1 val2)) (error (list :bitand-mistype :required :integer :integer :supplied (value-fix val1) (value-fix val2))))))
Theorem:
(defthm value-resultp-of-bitxor-values (b* ((resval (bitxor-values val1 val2))) (value-resultp resval)) :rule-classes :rewrite)
Theorem:
(defthm bitxor-values-of-value-fix-val1 (equal (bitxor-values (value-fix val1) val2) (bitxor-values val1 val2)))
Theorem:
(defthm bitxor-values-value-equiv-congruence-on-val1 (implies (value-equiv val1 val1-equiv) (equal (bitxor-values val1 val2) (bitxor-values val1-equiv val2))) :rule-classes :congruence)
Theorem:
(defthm bitxor-values-of-value-fix-val2 (equal (bitxor-values val1 (value-fix val2)) (bitxor-values val1 val2)))
Theorem:
(defthm bitxor-values-value-equiv-congruence-on-val2 (implies (value-equiv val2 val2-equiv) (equal (bitxor-values val1 val2) (bitxor-values val1 val2-equiv))) :rule-classes :congruence)