-
Notifications
You must be signed in to change notification settings - Fork 560
/
Copy pathproject.py
54 lines (44 loc) · 1.37 KB
/
project.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/usr/bin/env python3
import vitis
import os
import time
import shutil
from datetime import datetime
print ("\n-----------------------------------------------------")
print ("HLS Design Tutorial 02: Beamformer\n")
# Create names
tmpdir = './tmp'
date = datetime.now().strftime("%Y%m%d%I%M%S")
workspace_name = 'workspace_'+date
workspace = os.path.join(tmpdir, workspace_name)
comp_name = "hls_component"
cwd = os.getcwd()
cfg_name = 'project.cfg'
cfg_path = os.path.join(cwd, cfg_name)
# Delete the workspace if already exists
if (os.path.isdir(tmpdir)):
shutil.rmtree(tmpdir, ignore_errors=True)
print(f"Deleted workspaces in {tmpdir}")
# Print names
print(f"CWD is {cwd}")
print(f"Workspace path is {workspace}")
print(f"Creating component {comp_name}")
print(f"Using config file {cfg_path}")
# Create a client object
client = vitis.create_client()
# Set Workspace
client.set_workspace(workspace)
# Create HLS Component
comp = client.create_hls_component(name=comp_name, cfg_file = cfg_path)
# Execute the desired steps:
comp.run('C_SIMULATION')
comp.run('SYNTHESIS')
#comp.execute('CO_SIMULATION')
#comp.execute('PACKAGE')
#comp.execute('IMPLEMENTATION')
# Clean up, delete the workspace
if (os.path.isdir(tmpdir)):
shutil.rmtree(tmpdir, ignore_errors=True)
print(f"Deleted workspaces in {tmpdir}")
# Close the client connection and terminate the vitis server
vitis.dispose()