Install fields from a vl-genblob into a module.
(vl-genblob->module x orig) → new-mod
See vl-module->genblob. This is the companion operation which takes the fields from the genblob and sticks them back into a module.
Certain fields of the module, like its warnings, name, and location information, aren't affected. But the real fields like modinsts, assigns, etc., are overwritten with whatever is in the genblob.
Function:
(defun vl-genblob->module (x orig) (declare (xargs :guard (and (vl-genblob-p x) (vl-module-p orig)))) (let ((__function__ 'vl-genblob->module)) (declare (ignorable __function__)) (b* (((vl-genblob x))) (change-vl-module orig :generates x.generates :ports x.ports :portdecls x.portdecls :assigns x.assigns :aliases x.aliases :vardecls x.vardecls :paramdecls x.paramdecls :fundecls x.fundecls :taskdecls x.taskdecls :modinsts x.modinsts :gateinsts x.gateinsts :alwayses x.alwayses :initials x.initials :finals x.finals :typedefs x.typedefs :imports x.imports :genvars x.genvars :assertions x.assertions :cassertions x.cassertions :properties x.properties :sequences x.sequences :clkdecls x.clkdecls :gclkdecls x.gclkdecls :defaultdisables x.defaultdisables :dpiimports x.dpiimports :dpiexports x.dpiexports :binds x.binds :classes x.classes :covergroups x.covergroups :elabtasks x.elabtasks))))
Theorem:
(defthm vl-module-p-of-vl-genblob->module (b* ((new-mod (vl-genblob->module x orig))) (vl-module-p new-mod)) :rule-classes :rewrite)
Theorem:
(defthm vl-genblob->module-of-vl-genblob-fix-x (equal (vl-genblob->module (vl-genblob-fix x) orig) (vl-genblob->module x orig)))
Theorem:
(defthm vl-genblob->module-vl-genblob-equiv-congruence-on-x (implies (vl-genblob-equiv x x-equiv) (equal (vl-genblob->module x orig) (vl-genblob->module x-equiv orig))) :rule-classes :congruence)
Theorem:
(defthm vl-genblob->module-of-vl-module-fix-orig (equal (vl-genblob->module x (vl-module-fix orig)) (vl-genblob->module x orig)))
Theorem:
(defthm vl-genblob->module-vl-module-equiv-congruence-on-orig (implies (vl-module-equiv orig orig-equiv) (equal (vl-genblob->module x orig) (vl-genblob->module x orig-equiv))) :rule-classes :congruence)