(sbb-af-spec16 dst src cf) → *
Function:
(defun sbb-af-spec16$inline (dst src cf) (declare (type (unsigned-byte 16) dst) (type (unsigned-byte 16) src) (type (unsigned-byte 1) cf)) (b* (((the (unsigned-byte 4) dst-3-0) (mbe :logic (part-select dst :low 0 :width 4) :exec (logand 15 dst))) ((the (unsigned-byte 4) src-3-0) (mbe :logic (part-select src :low 0 :width 4) :exec (logand 15 src))) (sbb (- (the (unsigned-byte 4) dst-3-0) (+ (the (unsigned-byte 4) src-3-0) (the (unsigned-byte 4) cf)))) (af (the (unsigned-byte 1) (bool->bit (< sbb 0))))) af))
Theorem:
(defthm n01p-sbb-af-spec16 (unsigned-byte-p 1 (sbb-af-spec16 dst src cf)) :rule-classes (:rewrite (:type-prescription :corollary (natp (sbb-af-spec16 dst src cf)) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p natp)))) (:linear :corollary (and (<= 0 (sbb-af-spec16 dst src cf)) (< (sbb-af-spec16 dst src cf) 2)) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p (:e expt)))))))