Skip to content

Commit

Permalink
Build FABulous package with setuptools
Browse files Browse the repository at this point in the history
Update pyproject.toml to build FABulous package with setuptools.
Use setuptools-scm for autoamtic project version generation.
Add FABulous as package script to make it callable directlty from shell.
Add bit_gen as package script and add main function to it.

Update "fabric_gen" github workflow:
  - Use new FABulous structure
  - Update external actions

Update import statements in all python modules to absolue imports of
FABulous modules and and remove unused imports.

Update gitignore.

Signed-off-by: Jonas K. <[email protected]>
  • Loading branch information
EverythingElseWasAlreadyTaken committed May 7, 2024
1 parent 1539ec3 commit 8da78dd
Show file tree
Hide file tree
Showing 23 changed files with 221 additions and 155 deletions.
19 changes: 10 additions & 9 deletions .github/workflows/fabric_gen.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,15 @@ jobs:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v4
with:
submodules: recursive
- name: Set up Python 3.9
uses: actions/setup-python@v2
uses: actions/setup-python@v4
with:
python-version: 3.9
- name: Set up OSS CAD suite
uses: YosysHQ/setup-oss-cad-suite@v1
uses: YosysHQ/setup-oss-cad-suite@v2
- name: Install dependencies
run: |
python3 -m pip install --upgrade pip
Expand All @@ -31,15 +31,16 @@ jobs:
- name: Lint with flake8
run: |
# stop the build if there are Python syntax errors or undefined names
flake8 FABulous/fabric_generator/ --count --select=E9,F63,F7,F82 --show-source --statistics
flake8 FABulous/**/*.py --count --select=E9,F63,F7,F82 --show-source --statistics
# exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
flake8 FABulous/fabric_generator --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics
flake8 FABulous/**/*.py --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics
- name: Install FABulous
run: |
pip3 install -e .
- name: Run fabric generator flow
run: |
export FAB_ROOT=.
python3.9 FABulous/FABulous.py -c demo
python3.9 FABulous/FABulous.py demo --script ./demo/FABulous.tcl
FABulous -c demo
FABulous demo --script ./demo/FABulous.tcl
- name: Run simulation smoketest
run: |
cd ./demo/Test
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
demo/
**/__pycache__
*.egg-info/
53 changes: 30 additions & 23 deletions FABulous/FABulous.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,30 +16,31 @@
#
# SPDX-License-Identifier: Apache-2.0

from contextlib import redirect_stdout
from fabric_generator.utilities import genFabricObject, GetFabric
import fabric_generator.model_generation_npnr as model_gen_npnr
from fabric_generator.code_generation_VHDL import VHDLWriter
from fabric_generator.code_generation_Verilog import VerilogWriter
from FABulous_API import FABulous
import argparse
import cmd
import csv
from glob import glob
import logging
import os
import argparse
import pickle
import platform
import re
import sys
import subprocess as sp
import shutil
from typing import List, Literal
import docker
import cmd
import readline
import logging
import shutil
import subprocess as sp
import sys
import tkinter as tk
from pathlib import PurePosixPath, PureWindowsPath
import platform
import traceback
from contextlib import redirect_stdout
from glob import glob
from pathlib import PurePosixPath, PureWindowsPath
from typing import List, Literal

import docker
import FABulous.fabric_generator.model_generation_npnr as model_gen_npnr
from FABulous.fabric_generator.code_generation_Verilog import VerilogWriter
from FABulous.fabric_generator.code_generation_VHDL import VHDLWriter
from FABulous.fabric_generator.utilities import GetFabric, genFabricObject
from FABulous.FABulous_API import FABulous

readline.set_completer_delims(" \t\n")
histfile = ""
Expand All @@ -54,15 +55,16 @@

metaDataDir = ".FABulous"

fabulousRoot = os.getenv('FAB_ROOT')
fabulousRoot = os.getenv("FAB_ROOT")
if fabulousRoot is None:
fabulousRoot = os.path.dirname(os.path.realpath(__file__))
logger.warning("FAB_ROOT environment variable not set!")
logger.warning(f"Using {fabulousRoot} as FAB_ROOT")
else:
if not os.path.exists(fabulousRoot):
logger.error(
f"FAB_ROOT environment variable set to {fabulousRoot} but the directory does not exist")
f"FAB_ROOT environment variable set to {fabulousRoot} but the directory does not exist"
)
sys.exit()
else:
if os.path.exists(f"{fabulousRoot}/FABulous"):
Expand All @@ -86,6 +88,11 @@ def create_project(project_dir, type: Literal["verilog", "vhdl"] = "verilog"):
f"{project_dir}/",
dirs_exist_ok=True,
)
shutil.copytree(
f"{fabulousRoot}/fabric_cad/synth",
f"{project_dir}/Test/synth",
dirs_exist_ok=True,
)

adjust_directory_in_verilog_tb(project_dir)

Expand Down Expand Up @@ -129,7 +136,7 @@ def adjust_directory_in_verilog_tb(project_dir):
"rt",
) as fin:
with open(
f"{fabulousRoot}/{project_dir}/Test/sequential_16bit_en_tb.v", "wt"
f"{project_dir}/Test/sequential_16bit_en_tb.v", "wt"
) as fout:
for line in fin:
fout.write(line.replace("PROJECT_DIR", f"{project_dir}"))
Expand Down Expand Up @@ -244,7 +251,8 @@ def inter(*args, **varargs):
if fun.startswith("do_"):
name = fun.strip("do_")
tcl.createcommand(
name, wrap_with_except_handling(getattr(self, fun)))
name, wrap_with_except_handling(getattr(self, fun))
)

# os.chdir(args.project_dir)
tcl.eval(script)
Expand Down Expand Up @@ -987,8 +995,7 @@ def do_gen_bitStream_binary(self, args):
logger.info(f"Generating Bitstream for design {self.projectDir}/{path}")
logger.info(f"Outputting to {self.projectDir}/{parent}/{bitstream_file}")
runCmd = [
"python3",
f"{fabulousRoot}/fabric_cad/bit_gen.py",
"bit_gen",
"-genBitstream",
f"{self.projectDir}/{parent}/{fasm_file}",
f"{self.projectDir}/.FABulous/bitStreamSpec.bin",
Expand Down
18 changes: 9 additions & 9 deletions FABulous/FABulous_API.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
import fabric_generator.model_generation_vpr as model_gen_vpr
import fabric_generator.model_generation_npnr as model_gen_npnr
from fabric_generator.code_generation_VHDL import VHDLWriter
import fabric_generator.code_generator as codeGen
import fabric_generator.file_parser as fileParser
from fabric_generator.fabric import Fabric, Tile
from fabric_generator.fabric_gen import FabricGenerator
from geometry_generator.geometry_gen import GeometryGenerator

import logging

import FABulous.fabric_generator.code_generator as codeGen
import FABulous.fabric_generator.file_parser as fileParser
import FABulous.fabric_generator.model_generation_npnr as model_gen_npnr
import FABulous.fabric_generator.model_generation_vpr as model_gen_vpr
from FABulous.fabric_generator.code_generation_VHDL import VHDLWriter
from FABulous.fabric_generator.fabric import Fabric, Tile
from FABulous.fabric_generator.fabric_gen import FabricGenerator
from FABulous.geometry_generator.geometry_gen import GeometryGenerator

logger = logging.getLogger(__name__)
logging.basicConfig(
format="[%(levelname)s]-%(asctime)s - %(message)s", level=logging.INFO
Expand Down
Empty file added FABulous/fabric_cad/__init__.py
Empty file.
80 changes: 38 additions & 42 deletions FABulous/fabric_cad/bit_gen.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,9 @@
# Python 3
from array import array
#!/usr/bin/env python

import pickle
import re
import sys
from contextlib import redirect_stdout
from io import StringIO
import math
import os
import numpy
import pickle
import csv

from fasm import * # Remove this line if you do not have the fasm library installed and will not be generating a bitstream


Expand Down Expand Up @@ -260,39 +255,40 @@ def getTileAndWireByWireDest(self, loc: str, dest: str, jumps: bool = True):
#####################################################################################
# Main
#####################################################################################

# Strip arguments
caseProcessedArguments = list(map(lambda x: x.strip(), sys.argv))
processedArguments = list(map(lambda x: x.lower(), caseProcessedArguments))
flagRE = re.compile("-\S*")

if "-genBitstream".lower() in str(sys.argv).lower():
argIndex = processedArguments.index("-genBitstream".lower())

if len(processedArguments) <= argIndex + 3:
raise ValueError(
"\nError: -genBitstream expect three file names - the fasm file, the spec file and the output file"
)
elif (
flagRE.match(caseProcessedArguments[argIndex + 1])
or flagRE.match(caseProcessedArguments[argIndex + 2])
or flagRE.match(caseProcessedArguments[argIndex + 3])
):
raise ValueError(
"\nError: -genBitstream expect three file names, but found a flag in the arguments:"
f" {caseProcessedArguments[argIndex + 1]}, {caseProcessedArguments[argIndex + 2]}, {caseProcessedArguments[argIndex + 3]}\n"
def bit_gen():
# Strip arguments
caseProcessedArguments = list(map(lambda x: x.strip(), sys.argv))
processedArguments = list(map(lambda x: x.lower(), caseProcessedArguments))
flagRE = re.compile("-\S*")
if "-genBitstream".lower() in str(sys.argv).lower():
argIndex = processedArguments.index("-genBitstream".lower())
if len(processedArguments) <= argIndex + 3:
raise ValueError(
"\nError: -genBitstream expect three file names - the fasm file, the spec file and the output file"
)
elif (
flagRE.match(caseProcessedArguments[argIndex + 1])
or flagRE.match(caseProcessedArguments[argIndex + 2])
or flagRE.match(caseProcessedArguments[argIndex + 3])
):
raise ValueError(
"\nError: -genBitstream expect three file names, but found a flag in the arguments:"
f" {caseProcessedArguments[argIndex + 1]}, {caseProcessedArguments[argIndex + 2]}, {caseProcessedArguments[argIndex + 3]}\n"
)

FasmFileName = caseProcessedArguments[argIndex + 1]
SpecFileName = caseProcessedArguments[argIndex + 2]
OutFileName = caseProcessedArguments[argIndex + 3]

genBitstream(FasmFileName, SpecFileName, OutFileName)

if ("-help".lower() in str(sys.argv).lower()) or ("-h" in str(sys.argv).lower()):
print("")
print("Options/Switches")
print(
" -genBitstream foo.fasm spec.txt bitstream.txt - generates a bitstream - the first file is the fasm file, the second is the bitstream spec and the third is the fasm file to write to"
)

FasmFileName = caseProcessedArguments[argIndex + 1]
SpecFileName = caseProcessedArguments[argIndex + 2]
OutFileName = caseProcessedArguments[argIndex + 3]

genBitstream(FasmFileName, SpecFileName, OutFileName)


if ("-help".lower() in str(sys.argv).lower()) or ("-h" in str(sys.argv).lower()):
print("")
print("Options/Switches")
print(
" -genBitstream foo.fasm spec.txt bitstream.txt - generates a bitstream - the first file is the fasm file, the second is the bitstream spec and the third is the fasm file to write to"
)
if __name__ == "__main__":
bit_gen()
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
#!/usr/bin/env bash
SYNTH_TCL=../../FABulous/fabric_cad/synth/synth_fabulous.tcl
BIT_GEN=../../FABulous/fabric_cad/bit_gen.py
SYNTH_TCL=./synth/synth_fabulous.tcl
BIT_GEN=bit_gen

DESIGN=counter

set -ex
yosys -qp "tcl $SYNTH_TCL 4 top_wrapper test_design/${DESIGN}.json" test_design/${DESIGN}.v test_design/top_wrapper.v

FAB_ROOT=.. nextpnr-generic --uarch fabulous --json test_design/${DESIGN}.json -o fasm=test_design/${DESIGN}_des.fasm
python3 ${BIT_GEN} -genBitstream test_design/${DESIGN}_des.fasm ../.FABulous/bitStreamSpec.bin test_design/${DESIGN}.bin
${BIT_GEN} -genBitstream test_design/${DESIGN}_des.fasm ../.FABulous/bitStreamSpec.bin test_design/${DESIGN}.bin
9 changes: 4 additions & 5 deletions FABulous/fabric_generator/code_generation_VHDL.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
from typing import Literal, Tuple
import os
import math
import os
import re
from typing import Literal, Tuple

from fabric_generator.fabric import Fabric, Tile, Port, Bel, IO
from fabric_generator.code_generator import codeGenerator
from fabric_generator.fabric import ConfigBitMode
from FABulous.fabric_generator.code_generator import codeGenerator
from FABulous.fabric_generator.fabric import IO, Bel, ConfigBitMode, Fabric, Port, Tile


class VHDLWriter(codeGenerator):
Expand Down
6 changes: 3 additions & 3 deletions FABulous/fabric_generator/code_generation_Verilog.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
from typing import Literal
import math
import re
from typing import Literal

from fabric_generator.fabric import Tile, Bel, ConfigBitMode, IO
from fabric_generator.code_generator import codeGenerator
from FABulous.fabric_generator.code_generator import codeGenerator
from FABulous.fabric_generator.fabric import IO, Bel, ConfigBitMode, Tile


class VerilogWriter(codeGenerator):
Expand Down
3 changes: 2 additions & 1 deletion FABulous/fabric_generator/code_generator.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import abc
from typing import List, Tuple
from fabric_generator.fabric import Bel, IO, ConfigBitMode

from FABulous.fabric_generator.fabric import IO, Bel, ConfigBitMode


class codeGenerator(abc.ABC):
Expand Down
6 changes: 3 additions & 3 deletions FABulous/fabric_generator/fabric.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
from dataclasses import dataclass, field
from typing import Any, Literal, List, Dict, Tuple
import math
from enum import Enum
import os
from dataclasses import dataclass, field
from enum import Enum
from typing import Any, Dict, List, Literal, Tuple


class IO(Enum):
Expand Down
32 changes: 19 additions & 13 deletions FABulous/fabric_generator/fabric_gen.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,26 +16,32 @@
# SPDX-License-Identifier: Apache-2.0


import re
import csv
import logging
import math
import os
import re
import string
import csv
from typing import Dict, List, Tuple
import logging
from pathlib import Path
from typing import Dict, List, Tuple


from FABulous.fabric_generator.code_generation_Verilog import VerilogWriter
from FABulous.fabric_generator.code_generation_VHDL import VHDLWriter
from FABulous.fabric_generator.code_generator import codeGenerator
from FABulous.fabric_generator.fabric import (
IO,
ConfigBitMode,
ConfigMem,
Direction,
Fabric,
MultiplexerStyle,
Port,
SuperTile,
Tile,
)
from FABulous.fabric_generator.file_parser import parseConfigMem, parseList, parseMatrix
from fasm import * # Remove this line if you do not have the fasm library installed and will not be generating a bitstream


from fabric_generator.file_parser import parseMatrix, parseConfigMem, parseList
from fabric_generator.fabric import IO, Direction, MultiplexerStyle, ConfigBitMode
from fabric_generator.fabric import Fabric, Tile, Port, SuperTile, ConfigMem
from fabric_generator.code_generation_VHDL import VHDLWriter
from fabric_generator.code_generation_Verilog import VerilogWriter
from fabric_generator.code_generator import codeGenerator

SWITCH_MATRIX_DEBUG_SIGNAL = True
logger = logging.getLogger(__name__)

Expand Down
Loading

0 comments on commit 8da78dd

Please sign in to comment.