Coverage for tsfpga/examples/example_env.py: 0%
19 statements
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-28 20:52 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-28 20:52 +0000
1# --------------------------------------------------------------------------------------------------
2# Copyright (c) Lukas Vik. All rights reserved.
3#
4# This file is part of the tsfpga project, a project platform for modern FPGA development.
5# https://tsfpga.com
6# https://github.com/tsfpga/tsfpga
7# --------------------------------------------------------------------------------------------------
9"""
10Common functions and definitions in the example build environment.
11"""
13# Standard libraries
14from typing import TYPE_CHECKING, Optional
16if TYPE_CHECKING:
17 from tsfpga.module_list import ModuleList
19# Import before others since it modifies PYTHONPATH. pylint: disable=unused-import
20import tsfpga.examples.example_pythonpath # noqa: F401
22# Third party libraries
23from hdl_registers.register import Register
24from hdl_registers.register_modes import REGISTER_MODES
26# First party libraries
27import tsfpga
28from tsfpga.module import get_modules
30TSFPGA_EXAMPLES_TEMP_DIR = tsfpga.TSFPGA_GENERATED
33def get_default_registers() -> list[Register]:
34 """
35 Default registers for tsfpga examples.
36 """
37 registers = [
38 Register("config", 0, REGISTER_MODES["r_w"], "Configuration register."),
39 Register(
40 "command",
41 1,
42 REGISTER_MODES["wpulse"],
43 "When this register is written, all '1's in the written word will be asserted for one "
44 "clock cycle in the FPGA logic.",
45 ),
46 Register("status", 2, REGISTER_MODES["r"], "Status register."),
47 Register(
48 "irq_status",
49 3,
50 REGISTER_MODES["r_wpulse"],
51 "Reading a '1' in this register means the corresponding interrupt has triggered.\n"
52 "Writing to this register will clear the interrupts where there is a '1' in the "
53 "written word.",
54 ),
55 Register(
56 "irq_mask",
57 4,
58 REGISTER_MODES["r_w"],
59 "A '1' in this register means that the corresponding interrupt is enabled.",
60 ),
61 ]
62 return registers
65def get_tsfpga_example_modules(
66 names_include: Optional[set[str]] = None, names_avoid: Optional[set[str]] = None
67) -> "ModuleList":
68 """
69 Wrapper of the regular :func:`.get_modules`. call with correct settings for tsfpga
70 example modules.
71 This will include the example tsfpga modules, but not the "real" modules.
73 Arguments will be passed on to :func:`.get_modules`.
74 """
75 return get_modules(
76 modules_folders=[tsfpga.TSFPGA_EXAMPLE_MODULES],
77 names_include=names_include,
78 names_avoid=names_avoid,
79 library_name_has_lib_suffix=False,
80 default_registers=get_default_registers(),
81 )
84def get_hdl_modules(
85 names_include: Optional[set[str]] = None, names_avoid: Optional[set[str]] = None
86) -> "ModuleList":
87 """
88 Wrapper of :func:`.get_modules` which returns the ``hdl-modules`` module objects
89 (https://hdl-modules.com), if available.
91 If ``hdl-modules`` can not be found in the default repo checkout location,
92 the function will assert False.
94 Arguments will be passed on to :func:`.get_modules`.
96 Return:
97 :class:`.ModuleList`: The module objects.
98 """
99 # Presumed location of the hdl-modules repo
100 hdl_modules_repo_root = tsfpga.REPO_ROOT.parent.parent.resolve() / "hdl-modules" / "hdl-modules"
101 if (hdl_modules_repo_root / "modules").exists():
102 return get_modules(
103 modules_folders=[hdl_modules_repo_root / "modules"],
104 names_include=names_include,
105 names_avoid=names_avoid,
106 library_name_has_lib_suffix=False,
107 )
109 raise FileNotFoundError(
110 f"The hdl-modules modules could not be found. Searched in {hdl_modules_repo_root}"
111 )