Skip to content

Commit 8f65697

Browse files
committed
sby: core: backported changes from #212 for sby-stages integration
1 parent 6e952ce commit 8f65697

File tree

1 file changed

+33
-2
lines changed

1 file changed

+33
-2
lines changed

sbysrc/sby_core.py

+33-2
Original file line numberDiff line numberDiff line change
@@ -636,7 +636,7 @@ def run(self):
636636
self.tasks = []
637637
for task in tasks:
638638
task.check_timeout()
639-
if task.procs_pending or task.procs_running:
639+
if task.procs_pending or task.procs_running or task.stage_running:
640640
self.tasks.append(task)
641641
else:
642642
task.exit_callback()
@@ -677,6 +677,9 @@ def __init__(self, sbyconfig, workdir, early_logs, reusedir, taskloop=None, logf
677677
self.taskloop = taskloop or SbyTaskloop()
678678
self.taskloop.tasks.append(self)
679679

680+
self.base_dependencies = []
681+
self.stages_running = []
682+
680683
self.procs_running = []
681684
self.procs_pending = []
682685

@@ -867,7 +870,7 @@ def make_model(self, model_name):
867870
proc = SbyProc(
868871
self,
869872
model_name,
870-
[],
873+
self.base_dependencies,
871874
"cd {}/src; {} -ql ../model/design.log ../model/design.ys".format(self.workdir, self.exe_paths["yosys"])
872875
)
873876
proc.checkretcode = True
@@ -1098,6 +1101,8 @@ def setup_procs(self, setupmode):
10981101
self.retcode = 0
10991102
return
11001103

1104+
# TODO: Stage stuff
1105+
11011106
if self.opt_make_model is not None:
11021107
for name in self.opt_make_model.split(","):
11031108
self.model(name.strip())
@@ -1128,6 +1133,12 @@ def setup_procs(self, setupmode):
11281133
if opt not in self.used_options:
11291134
self.error(f"Unused option: {opt}")
11301135

1136+
def setup_stage(self, setupmode, config, name, depends):
1137+
stage = SbyStage(config, self, name)
1138+
stage.base_dependencies.extend(depends)
1139+
self.stages_running.append(stage)
1140+
stage.setup_procs(setupmode)
1141+
11311142
def summarize(self):
11321143
total_clock_time = int(monotonic() - self.start_clock_time)
11331144

@@ -1261,3 +1272,23 @@ def print_junit_result(self, f, junit_ts_name, junit_tc_name, junit_format_stric
12611272
print('</system-err>', file=f)
12621273
print(f'</testsuite>', file=f)
12631274
print(f'</testsuites>', file=f)
1275+
1276+
class SbyStage(SbyTask):
1277+
def __init__(self, sbyconfig, main_task, name):
1278+
self.main_task = main_task
1279+
self.name = name
1280+
workdir = f'{main_task.workdir}/stage_{name}'
1281+
os.mkdir(workdir)
1282+
1283+
super().__init__(
1284+
sbyconfig, workdir,
1285+
early_logs = [], reusedir = False,
1286+
taskloop = main_task.taskloop, logfile = main_task.logfile
1287+
)
1288+
1289+
self.exit_callback = self.handle_stage_exit
1290+
1291+
def handle_stage_exit(self):
1292+
self.main_task.stages_running.remove(self)
1293+
1294+
# TODO pass the status back to the main task

0 commit comments

Comments
 (0)