Get the rs1 field from a instr-op-imms32.
This is an ordinary field accessor created by fty::defprod.
Function:
(defun instr-op-imms32->rs1$inline (x) (declare (xargs :guard (instrp x))) (declare (xargs :guard (equal (instr-kind x) :op-imms32))) (mbe :logic (b* ((x (and (equal (instr-kind x) :op-imms32) x))) (ubyte5-fix (std::da-nth 2 (cdr x)))) :exec (std::da-nth 2 (cdr x))))
Theorem:
(defthm ubyte5p-of-instr-op-imms32->rs1 (b* ((rs1 (instr-op-imms32->rs1$inline x))) (ubyte5p rs1)) :rule-classes :rewrite)
Theorem:
(defthm instr-op-imms32->rs1$inline-of-instr-fix-x (equal (instr-op-imms32->rs1$inline (instr-fix x)) (instr-op-imms32->rs1$inline x)))
Theorem:
(defthm instr-op-imms32->rs1$inline-instr-equiv-congruence-on-x (implies (instr-equiv x x-equiv) (equal (instr-op-imms32->rs1$inline x) (instr-op-imms32->rs1$inline x-equiv))) :rule-classes :congruence)
Theorem:
(defthm instr-op-imms32->rs1-when-wrong-kind (implies (not (equal (instr-kind x) :op-imms32)) (equal (instr-op-imms32->rs1 x) (ubyte5-fix nil))))