Expand function calls throughout a vl-modinst-p
(vl-modinst-expand-function-calls x ss nf vardecls assigns warnings) → (mv successp warnings nf x-prime vardecls assigns)
Function:
(defun vl-modinst-expand-function-calls (x ss nf vardecls assigns warnings) (declare (xargs :guard (and (vl-modinst-p x) (vl-scopestack-p ss) (vl-namefactory-p nf) (vl-vardecllist-p vardecls) (vl-assignlist-p assigns) (vl-warninglist-p warnings)))) (let ((__function__ 'vl-modinst-expand-function-calls)) (declare (ignorable __function__)) (b* ((nf (vl-namefactory-fix nf)) (assigns (vl-assignlist-fix assigns)) (vardecls (vl-vardecllist-fix vardecls))) (b* (((vl-modinst x) x) ((mv okp1 warnings) (vl-check-bad-funcalls x (vl-maybe-range-allexprs x.range) "module instance array ranges" warnings)) ((mv okp2 warnings) (vl-check-bad-funcalls x (vl-maybe-gatedelay-allexprs x.delay) "delay expressions" warnings)) ((mv okp3 warnings) (vl-check-bad-funcalls x (vl-paramargs-allexprs x.paramargs) "module instance parameter-lists" warnings)) ((mv okp4 warnings nf portargs-prime vardecls assigns) (vl-arguments-expand-function-calls x.portargs ss nf vardecls assigns warnings x x.loc)) (okp (and okp1 okp2 okp3 okp4)) (x-prime (change-vl-modinst x :portargs portargs-prime))) (mv okp warnings nf x-prime vardecls assigns)))))
Theorem:
(defthm booleanp-of-vl-modinst-expand-function-calls.successp (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-modinst-expand-function-calls x ss nf vardecls assigns warnings))) (booleanp successp)) :rule-classes :type-prescription)
Theorem:
(defthm vl-warninglist-p-of-vl-modinst-expand-function-calls.warnings (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-modinst-expand-function-calls x ss nf vardecls assigns warnings))) (vl-warninglist-p warnings)) :rule-classes :rewrite)
Theorem:
(defthm vl-namefactory-p-of-vl-modinst-expand-function-calls.nf (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-modinst-expand-function-calls x ss nf vardecls assigns warnings))) (vl-namefactory-p nf)) :rule-classes :rewrite)
Theorem:
(defthm vl-modinst-p-of-vl-modinst-expand-function-calls.x-prime (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-modinst-expand-function-calls x ss nf vardecls assigns warnings))) (vl-modinst-p x-prime)) :rule-classes :rewrite)
Theorem:
(defthm vl-vardecllist-p-of-vl-modinst-expand-function-calls.vardecls (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-modinst-expand-function-calls x ss nf vardecls assigns warnings))) (vl-vardecllist-p vardecls)) :rule-classes :rewrite)
Theorem:
(defthm vl-assignlist-p-of-vl-modinst-expand-function-calls.assigns (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-modinst-expand-function-calls x ss nf vardecls assigns warnings))) (vl-assignlist-p assigns)) :rule-classes :rewrite)