-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathebrick_demo_fpga.py
executable file
·55 lines (35 loc) · 1.38 KB
/
ebrick_demo_fpga.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
55
#!/usr/bin/env python3
# Copyright 2024 Zero ASIC Corporation
# Licensed under the MIT License (see LICENSE for details)
import os
from ebrick_demo import ebrick
from siliconcompiler import Chip
from logik.targets import logik_target
def main(part_name='logik_demo'):
chip = Chip('ebrick_demo_fpga')
if __name__ == '__main__':
chip.create_cmdline(switchlist=['-fpga_partname'])
# Set default part name
chip.set('fpga', 'partname', part_name, clobber=False)
set_part_name = chip.get('fpga', 'partname')
# 1. Project setup
ebrick.setup_core_design(chip)
# Add this repository as a package source to pick up a top level wrapper
chip.register_source(
name='logik_demo',
path=os.path.abspath(os.path.dirname(__file__)))
# Add the wrapper around ebrick_core to map it to a valid logik_demo pinout
chip.input(os.path.join('rtl', 'ebrick_core_fpga_wrapper.v'), package='logik_demo')
# Set the top module to ebrick_core
chip.set('option', 'entrypoint', 'ebrick_core_fpga_wrapper')
# 3. Define constraints
chip.input(os.path.join('constraints', f'pin_constraints_{set_part_name}.pcf'),
package='logik_demo')
# 3. Load target
chip.use(logik_target)
# 4. Customize steps for this design
chip.set('option', 'quiet', True)
chip.run()
chip.summary()
if __name__ == "__main__":
main()