The following fails with the same error:
;;;;;;;;;;;;;;;;;;;;;;;;;;;

(defmacro many-forms ()
  (let ((body '()))
    (dotimes (i 20000)
      (setq body (cons '(message "more") body)))
    `(progn ,@body)))

(many-forms)

(if (eq 1 a)
    (message "dude")
  (message "else"))

;;;;;;;;;;;;;;;;;;;;;;;