Access the |X86ISA|::|OSXSAVE| field of a cr4bits bit structure.
Function:
(defun cr4bits->osxsave$inline (x) (declare (xargs :guard (cr4bits-p x))) (mbe :logic (let ((x (cr4bits-fix x))) (part-select x :low 18 :width 1)) :exec (the (unsigned-byte 1) (logand (the (unsigned-byte 1) 1) (the (unsigned-byte 8) (ash (the (unsigned-byte 26) x) -18))))))
Theorem:
(defthm bitp-of-cr4bits->osxsave (b* ((osxsave (cr4bits->osxsave$inline x))) (bitp osxsave)) :rule-classes :rewrite)
Theorem:
(defthm cr4bits->osxsave$inline-of-cr4bits-fix-x (equal (cr4bits->osxsave$inline (cr4bits-fix x)) (cr4bits->osxsave$inline x)))
Theorem:
(defthm cr4bits->osxsave$inline-cr4bits-equiv-congruence-on-x (implies (cr4bits-equiv x x-equiv) (equal (cr4bits->osxsave$inline x) (cr4bits->osxsave$inline x-equiv))) :rule-classes :congruence)
Theorem:
(defthm cr4bits->osxsave-of-cr4bits (equal (cr4bits->osxsave (cr4bits vme pvi tsd de pse pae mce pge pce osfxsr osxmmexcpt umip la57 vmxe smxe res1 fsgsbase pcide osxsave kl smep smap pke cet pks uintr)) (bfix osxsave)))
Theorem:
(defthm cr4bits->osxsave-of-write-with-mask (implies (and (fty::bitstruct-read-over-write-hyps x cr4bits-equiv-under-mask) (cr4bits-equiv-under-mask x y fty::mask) (equal (logand (lognot fty::mask) 262144) 0)) (equal (cr4bits->osxsave x) (cr4bits->osxsave y))))