From d5a636f52a3c506c86201d34f00a3ce7093ef2c6 Mon Sep 17 00:00:00 2001 From: "Matthias J. Kannwischer" Date: Mon, 16 Dec 2024 13:50:20 +0800 Subject: [PATCH] selftest: skip selftest if preamble/postamble contain symbolic registers --- slothy/core/core.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/slothy/core/core.py b/slothy/core/core.py index 53c447fc..49470d89 100644 --- a/slothy/core/core.py +++ b/slothy/core/core.py @@ -870,6 +870,21 @@ def selftest(self, log): iterations = 7 if self.config.sw_pipelining.enabled is True: old_source, new_source = self.get_fully_unrolled_loop(iterations) + + dfgc_preamble = DFGConfig(self.config, outputs=self.kernel_input_output) + dfgc_preamble.inputs_are_outputs = False + preamble_dfg = DFG(self.preamble, log, dfgc_preamble) + + if preamble_dfg.has_symbolic_registers(): + log.info("Skipping selftest as preamble contains symbolic registers.") + return + + dfgc_postamble = DFGConfig(self.config, outputs=self.orig_outputs) + postamble_dfg = DFG(self.postamble, log.getChild("new_postamble"), dfgc_postamble) + + if postamble_dfg.has_symbolic_registers(): + log.info("Skipping selftest as postamble contains symbolic registers.") + return else: old_source, new_source = self.orig_code, self.code