Skip to content

Commit

Permalink
Merge branch 'master' into tilk/faster-wishbone
Browse files Browse the repository at this point in the history
  • Loading branch information
tilk authored Nov 13, 2023
2 parents b0d9757 + 752b986 commit ce683bf
Show file tree
Hide file tree
Showing 53 changed files with 62 additions and 63 deletions.
2 changes: 1 addition & 1 deletion coreblocks/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
from coreblocks.frontend.icache import ICache, SimpleWBCacheRefiller, ICacheBypass
from coreblocks.peripherals.wishbone import WishboneMaster, WishboneBus
from coreblocks.frontend.fetch import Fetch, UnalignedFetch
from coreblocks.utils.fifo import BasicFifo
from transactron.utils.fifo import BasicFifo

__all__ = ["Core"]

Expand Down
2 changes: 1 addition & 1 deletion coreblocks/frontend/fetch.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
from amaranth import *
from coreblocks.utils.fifo import BasicFifo, Semaphore
from transactron.utils.fifo import BasicFifo, Semaphore
from coreblocks.frontend.icache import ICacheInterface
from coreblocks.frontend.rvc import InstrDecompress, is_instr_compressed
from transactron import def_method, Method, Transaction, TModule
Expand Down
4 changes: 2 additions & 2 deletions coreblocks/frontend/icache.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@
from transactron.core import def_method, Priority, TModule
from transactron import Method, Transaction
from coreblocks.params import ICacheLayouts, ICacheParameters
from coreblocks.utils import assign, OneHotSwitchDynamic
from coreblocks.utils._typing import HasElaborate
from transactron.utils import assign, OneHotSwitchDynamic
from transactron.utils._typing import HasElaborate
from transactron.lib import *
from coreblocks.peripherals.wishbone import WishboneMaster

Expand Down
2 changes: 1 addition & 1 deletion coreblocks/frontend/rvc.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

from transactron import TModule
from coreblocks.params import *
from coreblocks.utils import ValueLike
from transactron.utils import ValueLike


# An instruction or an instruction with the valid signal
Expand Down
4 changes: 2 additions & 2 deletions coreblocks/fu/alu.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,14 @@
from transactron.lib import FIFO

from coreblocks.params import OpType, Funct3, Funct7, GenParams, FuncUnitLayouts, FunctionalComponentParams
from coreblocks.utils import HasElaborate, OneHotSwitch
from transactron.utils import HasElaborate, OneHotSwitch

from coreblocks.fu.fu_decoder import DecoderManager
from enum import IntFlag, auto

from coreblocks.utils.protocols import FuncUnit

from coreblocks.utils.utils import popcount, count_leading_zeros
from transactron.utils.utils import popcount, count_leading_zeros

__all__ = ["AluFuncUnit", "ALUComponent"]

Expand Down
4 changes: 2 additions & 2 deletions coreblocks/fu/div_unit.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@

from coreblocks.fu.fu_decoder import DecoderManager

from coreblocks.utils import OneHotSwitch
from coreblocks.utils.fifo import BasicFifo
from transactron.utils import OneHotSwitch
from transactron.utils.fifo import BasicFifo
from coreblocks.utils.protocols import FuncUnit
from coreblocks.fu.division.long_division import LongDivider

Expand Down
2 changes: 1 addition & 1 deletion coreblocks/fu/exception.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
from transactron.lib import FIFO

from coreblocks.params import OpType, GenParams, FuncUnitLayouts, FunctionalComponentParams
from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch
from coreblocks.params.keys import ExceptionReportKey

from coreblocks.fu.fu_decoder import DecoderManager
Expand Down
4 changes: 2 additions & 2 deletions coreblocks/fu/fu_decoder.py
Original file line number Diff line number Diff line change
Expand Up @@ -81,8 +81,8 @@ def get_decoder(self, gen_params: GenParams) -> Decoder:
Returns
-------
return : set[OpType]
List of OpTypes.
return : Decoder
Instance of Decoder class.
"""
# check how many different op types are there
op_types = self.get_op_types()
Expand Down
2 changes: 1 addition & 1 deletion coreblocks/fu/jumpbranch.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
from transactron.lib import *

from coreblocks.params import *
from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch
from coreblocks.utils.protocols import FuncUnit

from coreblocks.fu.fu_decoder import DecoderManager
Expand Down
2 changes: 1 addition & 1 deletion coreblocks/fu/mul_unit.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

__all__ = ["MulUnit", "MulFn", "MulComponent", "MulType"]

from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch
from coreblocks.utils.protocols import FuncUnit


Expand Down
2 changes: 1 addition & 1 deletion coreblocks/fu/shift_unit.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from transactron.lib import FIFO

from coreblocks.params import OpType, Funct3, Funct7, GenParams, FuncUnitLayouts, FunctionalComponentParams
from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch

from coreblocks.fu.fu_decoder import DecoderManager
from enum import IntFlag, auto
Expand Down
2 changes: 1 addition & 1 deletion coreblocks/fu/zbc.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
)
from transactron import Method, def_method, TModule
from transactron.lib import FIFO
from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch
from coreblocks.utils.protocols import FuncUnit


Expand Down
2 changes: 1 addition & 1 deletion coreblocks/fu/zbs.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from coreblocks.params import Funct3, GenParams, FuncUnitLayouts, OpType, Funct7, FunctionalComponentParams
from transactron import Method, TModule, def_method
from transactron.lib import FIFO
from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch
from coreblocks.utils.protocols import FuncUnit

from coreblocks.fu.fu_decoder import DecoderManager
Expand Down
2 changes: 1 addition & 1 deletion coreblocks/lsu/dummyLsu.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
from transactron import Method, def_method, Transaction, TModule
from coreblocks.params import *
from coreblocks.peripherals.wishbone import WishboneMaster
from coreblocks.utils import assign, ModuleLike
from transactron.utils import assign, ModuleLike
from coreblocks.utils.protocols import FuncBlock


Expand Down
2 changes: 1 addition & 1 deletion coreblocks/params/instr.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
from amaranth.hdl.ast import ValueCastable
from amaranth import *

from coreblocks.utils import ValueLike
from transactron.utils import ValueLike
from coreblocks.params.isa import *


Expand Down
2 changes: 1 addition & 1 deletion coreblocks/params/layouts.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from coreblocks.params import GenParams, OpType, Funct7, Funct3
from coreblocks.params.isa import ExceptionCause
from coreblocks.utils.utils import layout_subset
from transactron.utils.utils import layout_subset

__all__ = [
"SchedulerLayouts",
Expand Down
4 changes: 2 additions & 2 deletions coreblocks/peripherals/wishbone.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@
from transactron import Method, def_method, TModule
from transactron.core import Transaction
from transactron.lib import AdapterTrans
from coreblocks.utils.utils import OneHotSwitchDynamic, assign
from coreblocks.utils.fifo import BasicFifo
from transactron.utils.utils import OneHotSwitchDynamic, assign
from transactron.utils.fifo import BasicFifo
from transactron.lib.connectors import Forwarder


Expand Down
2 changes: 1 addition & 1 deletion coreblocks/scheduler/scheduler.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from transactron import Method, Transaction, TModule
from transactron.lib import FIFO, Forwarder
from coreblocks.params import SchedulerLayouts, GenParams, OpType
from coreblocks.utils import assign, AssignType
from transactron.utils import assign, AssignType
from coreblocks.utils.protocols import FuncBlock


Expand Down
2 changes: 1 addition & 1 deletion coreblocks/scheduler/wakeup_select.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from amaranth import *

from coreblocks.params import GenParams, FuncUnitLayouts
from coreblocks.utils import assign, AssignType
from transactron.utils import assign, AssignType
from transactron.core import *

__all__ = ["WakeupSelect"]
Expand Down
2 changes: 1 addition & 1 deletion coreblocks/structs_common/csr.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
from dataclasses import dataclass

from transactron import Method, def_method, Transaction, TModule
from coreblocks.utils import assign, bits_from_int
from transactron.utils import assign, bits_from_int
from coreblocks.params.genparams import GenParams
from coreblocks.params.dependencies import DependencyManager, ListKey
from coreblocks.params.fu_params import BlockComponentParams
Expand Down
3 changes: 0 additions & 3 deletions coreblocks/utils/__init__.py
Original file line number Diff line number Diff line change
@@ -1,3 +0,0 @@
from .utils import * # noqa: F401
from ._typing import * # noqa: F401
from .debug_signals import * # noqa: F401
2 changes: 1 addition & 1 deletion coreblocks/utils/protocols.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from typing import Protocol
from transactron import Method
from ._typing import HasElaborate
from transactron.utils._typing import HasElaborate


__all__ = ["FuncUnit", "FuncBlock", "Unifier"]
Expand Down
2 changes: 1 addition & 1 deletion scripts/gen_verilog.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
from coreblocks.peripherals.wishbone import WishboneBus
from coreblocks.core import Core
from transactron import TransactionModule
from coreblocks.utils.utils import flatten_signals
from transactron.utils.utils import flatten_signals

from coreblocks.params.configurations import *

Expand Down
2 changes: 1 addition & 1 deletion scripts/synthesize.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
sys.path.insert(0, parent)


from coreblocks.utils.utils import ModuleConnector
from transactron.utils.utils import ModuleConnector
from coreblocks.params.genparams import GenParams
from coreblocks.params.fu_params import FunctionalComponentParams
from coreblocks.core import Core
Expand Down
2 changes: 1 addition & 1 deletion test/common/functions.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from amaranth.hdl.ast import Statement
from amaranth.sim.core import Command
from typing import TypeVar, Any, Generator, TypeAlias
from coreblocks.utils._typing import RecordValueDict, RecordIntDict
from transactron.utils._typing import RecordValueDict, RecordIntDict

T = TypeVar("T")
TestGen: TypeAlias = Generator[Command | Value | Statement | None, Any, T]
Expand Down
2 changes: 1 addition & 1 deletion test/common/infrastructure.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
from transactron import Method
from transactron.lib import AdapterTrans
from transactron.core import TransactionModule
from coreblocks.utils import ModuleConnector, HasElaborate, auto_debug_signals, HasDebugSignals
from transactron.utils import ModuleConnector, HasElaborate, auto_debug_signals, HasDebugSignals

T = TypeVar("T")
_T_nested_collection = T | list["_T_nested_collection[T]"] | dict[str, "_T_nested_collection[T]"]
Expand Down
2 changes: 1 addition & 1 deletion test/common/sugar.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import functools
from typing import Callable, Any, Optional
from .testbenchio import TestbenchIO, TestGen
from coreblocks.utils._typing import RecordIntDict
from transactron.utils._typing import RecordIntDict


def def_method_mock(
Expand Down
2 changes: 1 addition & 1 deletion test/common/testbenchio.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
from transactron.lib import AdapterBase
from transactron.core import ValueLike, SignalBundle
from transactron._utils import mock_def_helper
from coreblocks.utils._typing import RecordIntDictRet, RecordValueDict, RecordIntDict
from transactron.utils._typing import RecordIntDictRet, RecordValueDict, RecordIntDict
from .functions import set_inputs, get_outputs, TestGen


Expand Down
2 changes: 1 addition & 1 deletion test/frontend/test_fetch.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
from coreblocks.frontend.icache import ICacheInterface
from coreblocks.params import *
from coreblocks.params.configurations import test_core_config
from coreblocks.utils import ModuleConnector
from transactron.utils import ModuleConnector
from ..common import TestCaseWithSimulator, TestbenchIO, def_method_mock


Expand Down
4 changes: 2 additions & 2 deletions test/frontend/test_icache.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ def wishbone_slave(self):
while True:
yield from self.test_module.wb_ctrl.slave_wait()

# Wishbone is addressing words, so we need to shit it a bit to get the real address.
# Wishbone is addressing words, so we need to shift it a bit to get the real address.
addr = (yield self.test_module.wb_ctrl.wb.adr) << log2_int(self.cp.word_width_bytes)

yield
Expand Down Expand Up @@ -201,7 +201,7 @@ def wishbone_slave(self):
while True:
yield from self.m.wb_ctrl.slave_wait()

# Wishbone is addressing words, so we need to shit it a bit to get the real address.
# Wishbone is addressing words, so we need to shift it a bit to get the real address.
addr = (yield self.m.wb_ctrl.wb.adr) << log2_int(self.cp.word_width_bytes)

while random.random() < 0.5:
Expand Down
2 changes: 1 addition & 1 deletion test/frontend/test_rvc.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
from coreblocks.frontend.rvc import InstrDecompress
from coreblocks.params import *
from coreblocks.params.configurations import test_core_config
from coreblocks.utils import ValueLike
from transactron.utils import ValueLike

from ..common import TestCaseWithSimulator

Expand Down
2 changes: 1 addition & 1 deletion test/gtkw_extension.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from contextlib import contextmanager
from amaranth.sim.pysim import _VCDWriter
from amaranth import *
from coreblocks.utils.utils import flatten_signals
from transactron.utils.utils import flatten_signals


class _VCDWriterExt(_VCDWriter):
Expand Down
2 changes: 1 addition & 1 deletion test/regression/memory.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
from elftools.elf.constants import P_FLAGS
from elftools.elf.elffile import ELFFile, Segment
from coreblocks.params.configurations import CoreConfiguration
from coreblocks.utils.utils import align_to_power_of_two, align_down_to_power_of_two
from transactron.utils.utils import align_to_power_of_two, align_down_to_power_of_two

all = [
"ReplyStatus",
Expand Down
2 changes: 1 addition & 1 deletion test/structs_common/test_exception.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
from coreblocks.params.isa import ExceptionCause
from coreblocks.params.configurations import test_core_config
from transactron.lib import Adapter
from coreblocks.utils.utils import ModuleConnector
from transactron.utils.utils import ModuleConnector

from ..common import *

Expand Down
2 changes: 1 addition & 1 deletion test/test_core.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from amaranth import Elaboratable, Module

from transactron.lib import AdapterTrans
from coreblocks.utils import align_to_power_of_two
from transactron.utils import align_to_power_of_two

from .common import TestCaseWithSimulator, TestbenchIO

Expand Down
4 changes: 2 additions & 2 deletions test/transactions/test_assign.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
from amaranth.lib import data
from amaranth.hdl.ast import ArrayProxy, Slice

from coreblocks.utils._typing import LayoutLike
from coreblocks.utils.utils import AssignArg, AssignType, AssignFields, assign
from transactron.utils._typing import LayoutLike
from transactron.utils.utils import AssignArg, AssignType, AssignFields, assign

from unittest import TestCase
from parameterized import parameterized_class, parameterized
Expand Down
2 changes: 1 addition & 1 deletion test/transactions/test_simultaneous.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
from amaranth import *
from amaranth.sim import *

from coreblocks.utils.utils import ModuleConnector
from transactron.utils.utils import ModuleConnector

from ..common import SimpleTestCircuit, TestCaseWithSimulator, TestbenchIO, def_method_mock

Expand Down
4 changes: 2 additions & 2 deletions test/transactions/test_transaction_lib.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@
from transactron.core import RecordDict
from transactron.lib import *
from coreblocks.utils import *
from coreblocks.utils._typing import LayoutLike, ModuleLike
from coreblocks.utils import ModuleConnector
from transactron.utils._typing import LayoutLike, ModuleLike
from transactron.utils import ModuleConnector
from ..common import (
SimpleTestCircuit,
TestCaseWithSimulator,
Expand Down
2 changes: 1 addition & 1 deletion test/utils/test_fifo.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from amaranth import *

from coreblocks.utils.fifo import BasicFifo
from transactron.utils.fifo import BasicFifo
from transactron.lib import AdapterTrans

from test.common import TestCaseWithSimulator, TestbenchIO, data_layout
Expand Down
2 changes: 1 addition & 1 deletion test/utils/test_onehotswitch.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from amaranth import *
from amaranth.sim import *

from coreblocks.utils import OneHotSwitch
from transactron.utils import OneHotSwitch

from test.common import TestCaseWithSimulator

Expand Down
2 changes: 1 addition & 1 deletion test/utils/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

from amaranth import *
from test.common import *
from coreblocks.utils import (
from transactron.utils import (
align_to_power_of_two,
align_down_to_power_of_two,
popcount,
Expand Down
4 changes: 2 additions & 2 deletions transactron/_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@
from typing import Any, Concatenate, Optional, TypeAlias, TypeGuard, TypeVar
from collections.abc import Callable, Iterable, Mapping
from amaranth import *
from coreblocks.utils._typing import LayoutLike, ShapeLike
from coreblocks.utils import OneHotSwitchDynamic
from transactron.utils._typing import LayoutLike, ShapeLike
from transactron.utils import OneHotSwitchDynamic

__all__ = [
"Scheduler",
Expand Down
Loading

0 comments on commit ce683bf

Please sign in to comment.