(mul-spec-32 dst src) → (mv * * *)
Function:
(defun mul-spec-32 (dst src) (declare (type (unsigned-byte 32) dst) (type (unsigned-byte 32) src)) (let ((__function__ 'mul-spec-32)) (declare (ignorable __function__)) (b* ((dst (mbe :logic (n-size 32 dst) :exec dst)) (src (mbe :logic (n-size 32 src) :exec src)) (product (the (unsigned-byte 64) (* dst src))) (product-high (mbe :logic (part-select product :low 32 :width 32) :exec (the (unsigned-byte 32) (ash (the (unsigned-byte 64) product) -32)))) (product-low (mbe :logic (part-select product :low 0 :width 32) :exec (the (unsigned-byte 32) (logand 4294967295 product))))) (mv product-high product-low product))))
Theorem:
(defthm n32-mv-nth-0-mul-spec-32 (unsigned-byte-p 32 (mv-nth 0 (mul-spec-32 dst src))) :rule-classes (:rewrite (:type-prescription :corollary (natp (mv-nth 0 (mul-spec-32 dst src))) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p natp)))) (:linear :corollary (and (<= 0 (mv-nth 0 (mul-spec-32 dst src))) (< (mv-nth 0 (mul-spec-32 dst src)) 4294967296)) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p (:e expt)))))))
Theorem:
(defthm mv-nth-1-mul-spec-32 (unsigned-byte-p 32 (mv-nth 1 (mul-spec-32 dst src))) :rule-classes (:rewrite (:type-prescription :corollary (natp (mv-nth 1 (mul-spec-32 dst src))) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p natp)))) (:linear :corollary (and (<= 0 (mv-nth 1 (mul-spec-32 dst src))) (< (mv-nth 1 (mul-spec-32 dst src)) 4294967296)) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p (:e expt)))))))
Theorem:
(defthm mv-nth-2-mul-spec-32 (unsigned-byte-p 64 (mv-nth 2 (mul-spec-32 dst src))) :rule-classes (:rewrite (:type-prescription :corollary (natp (mv-nth 2 (mul-spec-32 dst src))) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p natp)))) (:linear :corollary (and (<= 0 (mv-nth 2 (mul-spec-32 dst src))) (< (mv-nth 2 (mul-spec-32 dst src)) 18446744073709551616)) :hints (("Goal" :in-theory '(unsigned-byte-p integer-range-p (:e expt)))))))