Skip to content

Commit

Permalink
Added stencil valid scheduling
Browse files Browse the repository at this point in the history
  • Loading branch information
jack-melchert committed May 29, 2024
1 parent 3322ce3 commit 8a41143
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 10 deletions.
29 changes: 20 additions & 9 deletions apps/hardware_benchmarks/hw_support/copy_clockwork_schedules.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import sys, json, re, os

fsource = open(sys.argv[1], "r")
fdest = open(sys.argv[2], "r")
flush_file = open(sys.argv[3], "r")
pond_file = open(sys.argv[4], "r")
stencil_valid_file = open(sys.argv[5], "r")

source_lines = fsource.readlines()
dest_lines = source_lines

new_mem_schedules = {}
new_pond_schedules = {}
Expand All @@ -21,16 +21,23 @@

flush_latencies = json.load(flush_file)
pond_latencies = json.load(pond_file)
stencil_valid_latencies = json.load(stencil_valid_file)

for idx, line in enumerate(dest_lines):
for idx, line in enumerate(source_lines):
new_line = ""
if line in new_mem_schedules:
new_line = new_mem_schedules[line]
mem_name = line.split('"')[1]
if mem_name in flush_latencies:
def replace_func(matchobj):
return str(int(matchobj.group(1)) + flush_latencies[mem_name])
new_line = re.sub(r'(?<=cycle_starting_addr":\[)(\d*)(?=],"cycle_stride)', replace_func, new_line)
dest_lines[idx+4] = new_line

if mem_name in stencil_valid_latencies:
def replace_func(matchobj):
return str(int(matchobj.group(1)) + stencil_valid_latencies[mem_name])
new_line = re.sub(r'(?<=cycle_starting_addr":\[)(\d*)(?=],"cycle_stride)', replace_func, new_line)
source_lines[idx+4] = new_line

if line in new_pond_schedules:
new_line = new_pond_schedules[line]
Expand All @@ -39,7 +46,7 @@ def replace_func(matchobj):
def replace_func(matchobj):
return str(int(matchobj.group(1)) + flush_latencies[mem_name])
new_line = re.sub(r'(?<=cycle_starting_addr":\[)(\d*)(?=],"cycle_stride)', replace_func, new_line)
dest_lines[idx+4] = new_line
source_lines[idx+4] = new_line

if line in new_pond_pipe_schedules:
new_line = new_pond_pipe_schedules[line]
Expand All @@ -48,13 +55,17 @@ def replace_func(matchobj):
def replace_func(matchobj):
return str(pond_latencies[pond_name])
new_line = re.sub(r'(?<="regfile2out_0":{"cycle_starting_addr":\[)(\d*)(?=],"cycle_stride)', replace_func, new_line)
dest_lines[idx+2] = new_line
source_lines[idx+2] = new_line
FAIL = '\033[91m'
ENDC = '\033[0m'
if "-" in new_line:
print(f"{FAIL}design_top.json has a schedule with a negative number:\n{new_line}\nThis application will probably fail{ENDC}")


fsource.close()
fdest.close()

fout = open(sys.argv[2], "w")
for line in dest_lines:
for line in source_lines:
fout.write(line)

fout.close()
fout.close()
2 changes: 1 addition & 1 deletion apps/hardware_benchmarks/hw_support/hardware_targets.mk
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ reschedule_mem:
CLKWRK_PATH=$(CLOCKWORK_PATH) LD_LIBRARY_PATH=$(CLOCKWORK_PATH)/lib:$(COREIR_DIR)/lib LAKE_PATH=$(LAKE_PATH) LAKE_CONTROLLERS=$(abspath $(BIN)) LAKE_STREAM=$(BIN) COREIR_PATH=$(COREIR_DIR) \
./clockwork_codegen compile_mem_use_metamapper 1>mem_cout 2> >(tee -a mem_cout >&2); \
EXIT_CODE=$$?; rm unoptimized_$(TESTNAME)*; cd ..; exit $$EXIT_CODE
python $(HWSUPPORT)/copy_clockwork_schedules.py $(BIN)/map_result/$(TESTNAME)/$(TESTNAME)_to_metamapper.json $(BIN)/design_top.json $(BIN)/$(TESTNAME)_flush_latencies.json $(BIN)/$(TESTNAME)_pond_latencies.json
python $(HWSUPPORT)/copy_clockwork_schedules.py $(BIN)/map_result/$(TESTNAME)/$(TESTNAME)_to_metamapper.json $(BIN)/design_top.json $(BIN)/$(TESTNAME)_flush_latencies.json $(BIN)/$(TESTNAME)_pond_latencies.json $(BIN)/$(TESTNAME)_stencil_valid_latencies.json

mem design_top design_top.json $(BIN)/design_top.json: $(BIN)/map_result/$(TESTNAME)/$(TESTNAME).json
cp $(BIN)/map_result/$(TESTNAME)/$(TESTNAME)_garnet.json $(BIN)/design_top.json
Expand Down

0 comments on commit 8a41143

Please sign in to comment.