peakrdl-python 3.0.0rc8__tar.gz → 3.1.0rc1__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/.github/workflows/action.yaml +19 -19
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/PKG-INFO +21 -5
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/README.md +20 -4
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/generated_package.rst +12 -3
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/generate_and_test.py +1 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/__about__.py +1 -1
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/base.py +29 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/base_field.py +1 -1
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/systemrdl_node_hashes.py +6 -1
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_tb.py.jinja +3 -1
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_udp_property.py.jinja +2 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python.egg-info/PKG-INFO +21 -5
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python.egg-info/SOURCES.txt +1 -0
- peakrdl_python-3.1.0rc1/tests/testcases/udp_with_referencing.rdl +31 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/.gitignore +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/.readthedocs.yaml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/LICENSE +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/MANIFEST.in +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/api.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/api_components.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/command_line.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/conf.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/customisation.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/design_decisions.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/design_tools.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/genindex.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/index.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/installation.rst +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/docs/requirements.txt +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/array_access/array_access.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/array_access/demo_array_access.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/enumerated_fields/demo_enumerated_fields.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/enumerated_fields/enumerated_fields.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/optimised_access/demo_optimised_access.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/optimised_access/demo_optimised_array_access.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/optimised_access/optimised_access.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/optimised_access/optimised_array_access.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/overridden_names/demo_over_ridden_names.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/overridden_names/overridden_names.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/simulating_callbacks/chip_with_a_GPIO.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/simulating_callbacks/flashing_the_LED.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/tranversing_address_map/chip_with_registers.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/tranversing_address_map/dumping_register_state_to_json_file.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/tranversing_address_map/reg_dump.json +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/tranversing_address_map/reseting_registers.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/tranversing_address_map/writing_register_state_from_json_file.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/user_defined_properties/demo_user_defined_properties.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/user_defined_properties/user_defined_properties.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/why_ral/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/why_ral/gpio.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/why_ral/with_hal.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/why_ral/with_ral.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/why_ral/without_ral.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/generate_testcases.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/pyproject.toml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/setup.cfg +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/.coveragerc +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/__peakrdl__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/_deploy_package.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/_node_walkers.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/class_names.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/compiler_udp.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/exporter.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/async_memory.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/async_register_and_field.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/base_register.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/callbacks.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/field_encoding.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/memory.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/py.typed +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/register_and_field.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/sections.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/utility_functions.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/_async_base_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/_base_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/_common_base_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/async_field_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/async_mem_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/async_reg_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/async_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/field_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/mem_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/reg_test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/test_class.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib_test/utilities.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/py.typed +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/safe_name_utility.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/_callbacks.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/base.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/dummy_callbacks.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/field.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/memory.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/py.typed +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/register.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/sim_lib/simulator.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/systemrdl_node_utility_functions.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_field.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_memory.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_register.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_simulation.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_simulation_tb.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_system_rdl_name_mapping.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_universal_property.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/baseclass_simulation_tb.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/baseclass_tb.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/child_definitions.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/example.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/field_enums.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/header.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/header_tb.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/property_enums.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/reg_definitions.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/template_ultilities.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/unique_component_iterator.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python.egg-info/dependency_links.txt +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python.egg-info/entry_points.txt +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python.egg-info/requires.txt +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python.egg-info/top_level.txt +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates/header.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates/header_tb.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates_dynamic/header.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates_dynamic/header_tb.py.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates_dynamic_toml/header_check.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates_dynamic_toml/peakrdl.toml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates_toml/header_check.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/alternative_templates_toml/peakrdl.toml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/pathological_register_maps/pathological_rdl_builder.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/pathological_register_maps/templates/pathological_template.rdl.jinja +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/RDLFormatCode_example.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/addr_map.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/aliases.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/all_register_access_types.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/basic.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/block_a.xml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/block_b.xml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/deduplicated_field.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/different_array_types.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/enum_example.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/example_issue_106.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/extended_memories.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/extended_sizes_registers_array.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/field_scope.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/field_with_overridden_reset.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/fields_with_HW_write.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/fields_with_reset_values.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/hidden_property.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/large_field_combinations.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/memories.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/memories_with_registers.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/msb0_and_lsb0.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/multi_block.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/multifile.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/name_clash.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/name_desc_all_levels.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/name_desc_option_deduplicate.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/name_desc_stress_test.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/overlapping_registers_and_fields.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/overridden_python_name.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/parametrised_readonly_and_readwrite.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/parametrised_top.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/reg_name_stress.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/regfile_and_arrays.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/reserved_elements.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/same_but_different_enum.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/signals_definitions_at_various_levels.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/simple.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/simple.xml +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/simulator_test.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/sizes_registers.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/sizes_registers_array.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/sparse_enum_issue_200.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/user_defined_properties.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/testcases/write_only_enum_with_undefined_reset.rdl +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/__init__.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/simple_components.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_array_indexing.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_building_inner_addrmap.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_export.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_field.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_name_desc_export.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_optimised_reg_array.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_reg.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_sim.py +0 -0
- {peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/tests/unit_tests/test_system_rdl_enum.py +0 -0
|
@@ -27,9 +27,9 @@ jobs:
|
|
|
27
27
|
lint:
|
|
28
28
|
runs-on: ubuntu-latest
|
|
29
29
|
steps:
|
|
30
|
-
- uses: actions/checkout@
|
|
30
|
+
- uses: actions/checkout@v5
|
|
31
31
|
- name: Set up Python
|
|
32
|
-
uses: actions/setup-python@
|
|
32
|
+
uses: actions/setup-python@v6
|
|
33
33
|
with:
|
|
34
34
|
python-version: "3.13"
|
|
35
35
|
|
|
@@ -52,9 +52,9 @@ jobs:
|
|
|
52
52
|
mypy:
|
|
53
53
|
runs-on: ubuntu-latest
|
|
54
54
|
steps:
|
|
55
|
-
- uses: actions/checkout@
|
|
55
|
+
- uses: actions/checkout@v5
|
|
56
56
|
- name: Set up Python
|
|
57
|
-
uses: actions/setup-python@
|
|
57
|
+
uses: actions/setup-python@v6
|
|
58
58
|
with:
|
|
59
59
|
python-version: "3.13"
|
|
60
60
|
|
|
@@ -77,10 +77,10 @@ jobs:
|
|
|
77
77
|
python-version: [ 3.9, "3.10", "3.11", "3.12", "3.13", "3.14" ]
|
|
78
78
|
|
|
79
79
|
steps:
|
|
80
|
-
- uses: actions/checkout@
|
|
80
|
+
- uses: actions/checkout@v5
|
|
81
81
|
|
|
82
82
|
- name: Set up Python ${{ matrix.python-version }}
|
|
83
|
-
uses: actions/setup-python@
|
|
83
|
+
uses: actions/setup-python@v6
|
|
84
84
|
with:
|
|
85
85
|
python-version: ${{ matrix.python-version }}
|
|
86
86
|
|
|
@@ -107,10 +107,10 @@ jobs:
|
|
|
107
107
|
python-version: [ 3.9, "3.10", "3.11", "3.12", "3.13", "3.14" ]
|
|
108
108
|
|
|
109
109
|
steps:
|
|
110
|
-
- uses: actions/checkout@
|
|
110
|
+
- uses: actions/checkout@v5
|
|
111
111
|
|
|
112
112
|
- name: Set up Python ${{ matrix.python-version }}
|
|
113
|
-
uses: actions/setup-python@
|
|
113
|
+
uses: actions/setup-python@v6
|
|
114
114
|
with:
|
|
115
115
|
python-version: ${{ matrix.python-version }}
|
|
116
116
|
|
|
@@ -183,10 +183,10 @@ jobs:
|
|
|
183
183
|
python-version: [ 3.9, "3.10", "3.11", "3.12", "3.13", "3.14" ]
|
|
184
184
|
|
|
185
185
|
steps:
|
|
186
|
-
- uses: actions/checkout@
|
|
186
|
+
- uses: actions/checkout@v5
|
|
187
187
|
|
|
188
188
|
- name: Set up Python ${{ matrix.python-version }}
|
|
189
|
-
uses: actions/setup-python@
|
|
189
|
+
uses: actions/setup-python@v6
|
|
190
190
|
with:
|
|
191
191
|
python-version: ${{ matrix.python-version }}
|
|
192
192
|
|
|
@@ -306,7 +306,7 @@ jobs:
|
|
|
306
306
|
python-version: [ 3.9, "3.10", "3.11", "3.12", "3.13", "3.14" ]
|
|
307
307
|
|
|
308
308
|
steps:
|
|
309
|
-
- uses: actions/checkout@
|
|
309
|
+
- uses: actions/checkout@v5
|
|
310
310
|
|
|
311
311
|
- name: Install dependencies
|
|
312
312
|
run: |
|
|
@@ -341,10 +341,10 @@ jobs:
|
|
|
341
341
|
lib_copy: [true, false]
|
|
342
342
|
|
|
343
343
|
steps:
|
|
344
|
-
- uses: actions/checkout@
|
|
344
|
+
- uses: actions/checkout@v5
|
|
345
345
|
|
|
346
346
|
- name: Set up Python ${{ matrix.python-version }}
|
|
347
|
-
uses: actions/setup-python@
|
|
347
|
+
uses: actions/setup-python@v6
|
|
348
348
|
with:
|
|
349
349
|
python-version: ${{ matrix.python-version }}
|
|
350
350
|
|
|
@@ -390,10 +390,10 @@ jobs:
|
|
|
390
390
|
python-version: [3.9, "3.10", "3.11", "3.12", "3.13", "3.14"]
|
|
391
391
|
|
|
392
392
|
steps:
|
|
393
|
-
- uses: actions/checkout@
|
|
393
|
+
- uses: actions/checkout@v5
|
|
394
394
|
|
|
395
395
|
- name: Set up Python ${{ matrix.python-version }}
|
|
396
|
-
uses: actions/setup-python@
|
|
396
|
+
uses: actions/setup-python@v6
|
|
397
397
|
with:
|
|
398
398
|
python-version: ${{ matrix.python-version }}
|
|
399
399
|
|
|
@@ -433,9 +433,9 @@ jobs:
|
|
|
433
433
|
runs-on: ubuntu-latest
|
|
434
434
|
|
|
435
435
|
steps:
|
|
436
|
-
- uses: actions/checkout@
|
|
436
|
+
- uses: actions/checkout@v5
|
|
437
437
|
- name: Set up Python
|
|
438
|
-
uses: actions/setup-python@
|
|
438
|
+
uses: actions/setup-python@v6
|
|
439
439
|
with:
|
|
440
440
|
python-version: "3.13"
|
|
441
441
|
|
|
@@ -470,9 +470,9 @@ jobs:
|
|
|
470
470
|
name: Build source distribution
|
|
471
471
|
runs-on: ubuntu-latest
|
|
472
472
|
steps:
|
|
473
|
-
- uses: actions/checkout@
|
|
473
|
+
- uses: actions/checkout@v5
|
|
474
474
|
|
|
475
|
-
- uses: actions/setup-python@
|
|
475
|
+
- uses: actions/setup-python@v6
|
|
476
476
|
name: Install Python
|
|
477
477
|
with:
|
|
478
478
|
python-version: "3.13"
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: peakrdl-python
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.1.0rc1
|
|
4
4
|
Summary: Generate Python Register Access Layer (RAL) from SystemRDL
|
|
5
5
|
Author: Keith Brady
|
|
6
6
|
License: GNU LESSER GENERAL PUBLIC LICENSE
|
|
@@ -286,9 +286,9 @@ assumes that peakrdl has been installed.
|
|
|
286
286
|
To make use of the RAL with real hardware or a different simulation, the callbacks will need to be
|
|
287
287
|
connected to the appropriate access function in order to perform an address space reads and writes
|
|
288
288
|
|
|
289
|
-
#
|
|
289
|
+
# Some important changes
|
|
290
290
|
|
|
291
|
-
##
|
|
291
|
+
## 0.9.0
|
|
292
292
|
|
|
293
293
|
In order to address a major limitation of peakrdl-python that prevented it from implementing the
|
|
294
294
|
full systemRDL specification, a breaking API change was needed for handling blocks:
|
|
@@ -299,7 +299,7 @@ Users are encouraged to upgrade in order to avoid this limitation. However, ther
|
|
|
299
299
|
to support users with existing designs, see: _Legacy Block Callback and Block Access_ in the
|
|
300
300
|
documentation
|
|
301
301
|
|
|
302
|
-
##
|
|
302
|
+
## 1.2.0
|
|
303
303
|
|
|
304
304
|
Version 1.2 introduced a new way to define the enumerations for the field encoding. This allows
|
|
305
305
|
metadata from the systemRDL to propagate through to the generated code. This may break advanced
|
|
@@ -307,7 +307,7 @@ usage of the python enumerations. User are encouraged to use the new feature, ho
|
|
|
307
307
|
are problems with the old enumeration types (based on `IntEnum`) can be used, see
|
|
308
308
|
_Legacy Enumeration Types_ in the documentation
|
|
309
309
|
|
|
310
|
-
##
|
|
310
|
+
## 2.0.0
|
|
311
311
|
|
|
312
312
|
Version 2.0.0 introduced a significant change to the process for building the register model python
|
|
313
313
|
code. This change was intended to reduce the size of the generated code by only generating
|
|
@@ -325,4 +325,20 @@ changing each time it was regenerated, version 2.1.0 introduces a option to eith
|
|
|
325
325
|
of large register models but will be consistent, therefore is useful if the resultant code is being
|
|
326
326
|
checked into a version control system (such as GIT) and the differences are being reviewed
|
|
327
327
|
|
|
328
|
+
## 3.0.0
|
|
329
|
+
|
|
330
|
+
Version 3.0.0 has included a significant refactoring of the generated test cases, moving functions out
|
|
331
|
+
of the templates (generated code) in favour of an enhanced test library. On some cases, this
|
|
332
|
+
reduced the size of the test case generated code by 90%, significantly improved the time to generate
|
|
333
|
+
the code and also improved the time to run the tests by a 30% reduction.
|
|
334
|
+
|
|
335
|
+
In preparation for the removal of some legacy features from the early versions in release 4.0.0,
|
|
336
|
+
the following options were changed:
|
|
337
|
+
- Version 1.2 introduced a new custom enumeration type (rather than using `IntEnum`) in order to allow
|
|
338
|
+
the content to `name` and `desc` systemRDL properties in be accessible. Until version 3.0.0 the new
|
|
339
|
+
type was not the default, it now is. The old enumeration types can still be used by setting `legacy_enum_type`.
|
|
340
|
+
- The first versions of PeakRDL Python used the built-in `Array` type for accessing blocks of data efficiently.
|
|
341
|
+
This had some restrictions, so the a new methodology based on the `list` type was introduced in version 0.9.
|
|
342
|
+
The old array based behaviour is no longer the default but can be turned on using the `legacy_block_access`
|
|
343
|
+
|
|
328
344
|
|
|
@@ -75,9 +75,9 @@ assumes that peakrdl has been installed.
|
|
|
75
75
|
To make use of the RAL with real hardware or a different simulation, the callbacks will need to be
|
|
76
76
|
connected to the appropriate access function in order to perform an address space reads and writes
|
|
77
77
|
|
|
78
|
-
#
|
|
78
|
+
# Some important changes
|
|
79
79
|
|
|
80
|
-
##
|
|
80
|
+
## 0.9.0
|
|
81
81
|
|
|
82
82
|
In order to address a major limitation of peakrdl-python that prevented it from implementing the
|
|
83
83
|
full systemRDL specification, a breaking API change was needed for handling blocks:
|
|
@@ -88,7 +88,7 @@ Users are encouraged to upgrade in order to avoid this limitation. However, ther
|
|
|
88
88
|
to support users with existing designs, see: _Legacy Block Callback and Block Access_ in the
|
|
89
89
|
documentation
|
|
90
90
|
|
|
91
|
-
##
|
|
91
|
+
## 1.2.0
|
|
92
92
|
|
|
93
93
|
Version 1.2 introduced a new way to define the enumerations for the field encoding. This allows
|
|
94
94
|
metadata from the systemRDL to propagate through to the generated code. This may break advanced
|
|
@@ -96,7 +96,7 @@ usage of the python enumerations. User are encouraged to use the new feature, ho
|
|
|
96
96
|
are problems with the old enumeration types (based on `IntEnum`) can be used, see
|
|
97
97
|
_Legacy Enumeration Types_ in the documentation
|
|
98
98
|
|
|
99
|
-
##
|
|
99
|
+
## 2.0.0
|
|
100
100
|
|
|
101
101
|
Version 2.0.0 introduced a significant change to the process for building the register model python
|
|
102
102
|
code. This change was intended to reduce the size of the generated code by only generating
|
|
@@ -114,4 +114,20 @@ changing each time it was regenerated, version 2.1.0 introduces a option to eith
|
|
|
114
114
|
of large register models but will be consistent, therefore is useful if the resultant code is being
|
|
115
115
|
checked into a version control system (such as GIT) and the differences are being reviewed
|
|
116
116
|
|
|
117
|
+
## 3.0.0
|
|
118
|
+
|
|
119
|
+
Version 3.0.0 has included a significant refactoring of the generated test cases, moving functions out
|
|
120
|
+
of the templates (generated code) in favour of an enhanced test library. On some cases, this
|
|
121
|
+
reduced the size of the test case generated code by 90%, significantly improved the time to generate
|
|
122
|
+
the code and also improved the time to run the tests by a 30% reduction.
|
|
123
|
+
|
|
124
|
+
In preparation for the removal of some legacy features from the early versions in release 4.0.0,
|
|
125
|
+
the following options were changed:
|
|
126
|
+
- Version 1.2 introduced a new custom enumeration type (rather than using `IntEnum`) in order to allow
|
|
127
|
+
the content to `name` and `desc` systemRDL properties in be accessible. Until version 3.0.0 the new
|
|
128
|
+
type was not the default, it now is. The old enumeration types can still be used by setting `legacy_enum_type`.
|
|
129
|
+
- The first versions of PeakRDL Python used the built-in `Array` type for accessing blocks of data efficiently.
|
|
130
|
+
This had some restrictions, so the a new methodology based on the `list` type was introduced in version 0.9.
|
|
131
|
+
The old array based behaviour is no longer the default but can be turned on using the `legacy_block_access`
|
|
132
|
+
|
|
117
133
|
|
|
@@ -9,6 +9,7 @@ will be based on the top level address map name with the package was generated
|
|
|
9
9
|
|
|
10
10
|
| ``<root_name>``
|
|
11
11
|
| ├── ``lib``
|
|
12
|
+
| ├── ``lib_test``
|
|
12
13
|
| ├── ``sim_lib``
|
|
13
14
|
| ├── ``reg_model``
|
|
14
15
|
| │ └── ``<root_name>.py``
|
|
@@ -20,8 +21,9 @@ will be based on the top level address map name with the package was generated
|
|
|
20
21
|
In the folder structure above:
|
|
21
22
|
|
|
22
23
|
- ``<root_name>.py`` - This is the register access layer code for the design
|
|
23
|
-
- ``test_<root_name>.py`` - This is a set of autogenerated unittests to verify the register access layer
|
|
24
|
+
- ``test_<root_name>.py`` - This is a set of autogenerated unittests to verify the register access layer (The unit test generation can be skipped, see ``skip_test_case_generation``)
|
|
24
25
|
- ``lib`` - This is a package of base classes used by the register access layer (The copy of this can be skipped, see :ref:`skipping-lib-copy`)
|
|
26
|
+
- ``lib_test`` - This is a package of base classes autogenerated unit tests (The copy of this can be skipped, see :ref:`skipping-lib-copy`)
|
|
25
27
|
- ``sim_lib`` - This is a package of base classes used by the register access layer simulator (The copy of this can be skipped, see :ref:`skipping-lib-copy`)
|
|
26
28
|
|
|
27
29
|
.. versionchanged:: 2.0.0
|
|
@@ -30,6 +32,11 @@ In the folder structure above:
|
|
|
30
32
|
than building the whole register model in a single python module. This helps avoid
|
|
31
33
|
excessively large files which helps speed up the generation and loading time.
|
|
32
34
|
|
|
35
|
+
.. versionchanged:: 3.0.0
|
|
36
|
+
|
|
37
|
+
The auto-generated unit tests were changed in version 3.0.0 to split to make use
|
|
38
|
+
of a test library, which significantly reduced the size of the generated code.
|
|
39
|
+
|
|
33
40
|
Top Level Classes
|
|
34
41
|
-----------------
|
|
35
42
|
|
|
@@ -74,8 +81,10 @@ Callbacks
|
|
|
74
81
|
=========
|
|
75
82
|
|
|
76
83
|
The Register Access Layer will typically interfaced to a driver that
|
|
77
|
-
allows accesses the chip.
|
|
78
|
-
|
|
84
|
+
allows accesses the chip.
|
|
85
|
+
|
|
86
|
+
.. tip:: The simulator generated with the register model can be used as an alternative to
|
|
87
|
+
a hardware connection
|
|
79
88
|
|
|
80
89
|
In order to operate the register access layer typically requires the following:
|
|
81
90
|
|
|
@@ -222,6 +222,7 @@ if __name__ == '__main__':
|
|
|
222
222
|
skip_library_copy=not CommandLineArgs.copy_libraries,
|
|
223
223
|
legacy_block_access=CommandLineArgs.legacy_block_access,
|
|
224
224
|
user_defined_properties_to_include=CommandLineArgs.udp,
|
|
225
|
+
user_defined_properties_to_include_regex=CommandLineArgs.udp_regex,
|
|
225
226
|
hidden_inst_name_regex=CommandLineArgs.hide_regex,
|
|
226
227
|
legacy_enum_type=CommandLineArgs.legacy_enum_type,
|
|
227
228
|
skip_systemrdl_name_and_desc_properties=
|
|
@@ -97,6 +97,35 @@ class Base(ABC):
|
|
|
97
97
|
"""
|
|
98
98
|
return {}
|
|
99
99
|
|
|
100
|
+
def _traverse_from_fully_qualified_name(self, fully_qualified_name: list[str]) -> 'Base':
|
|
101
|
+
"""
|
|
102
|
+
This method allows another node in the structure to located based on a list of string
|
|
103
|
+
which represented the systemRDL path.
|
|
104
|
+
|
|
105
|
+
This function is intended for use with UDPs which reference other UDPs
|
|
106
|
+
"""
|
|
107
|
+
|
|
108
|
+
# 1) location the root node by walking backwards up the tree until the parent is
|
|
109
|
+
# found
|
|
110
|
+
def locate_root(node: 'Base') -> 'Base':
|
|
111
|
+
if node.parent is None:
|
|
112
|
+
return node
|
|
113
|
+
return locate_root(node.parent)
|
|
114
|
+
root_node = locate_root(self)
|
|
115
|
+
# 2) check the 1st entry in the list matches the name of the root
|
|
116
|
+
if root_node.inst_name != fully_qualified_name[0]:
|
|
117
|
+
raise RuntimeError('root node name mismatch')
|
|
118
|
+
# 3) start walking down the tree matching the nodes
|
|
119
|
+
walking_node = root_node
|
|
120
|
+
for node_name in fully_qualified_name[1:]:
|
|
121
|
+
if not isinstance(walking_node, Node):
|
|
122
|
+
# the current node being traversed must be a Node type i.e. not a field
|
|
123
|
+
raise RuntimeError('node traversal has failed as type:{type(walking_node)} was'
|
|
124
|
+
' unexpectedly encountered')
|
|
125
|
+
walking_node = walking_node.get_child_by_system_rdl_name(node_name)
|
|
126
|
+
|
|
127
|
+
return walking_node
|
|
128
|
+
|
|
100
129
|
@property
|
|
101
130
|
def rdl_name(self) -> Optional[str]:
|
|
102
131
|
"""
|
|
@@ -404,7 +404,7 @@ class _FieldReadOnlyFramework(Field[FieldType], ABC):
|
|
|
404
404
|
'than or equal to 0')
|
|
405
405
|
|
|
406
406
|
if value > self.__parent_register.max_value:
|
|
407
|
-
raise ValueError(f'value to
|
|
407
|
+
raise ValueError(f'value to be decoded must be less than or equal '
|
|
408
408
|
f'to {self.__parent_register.max_value:d}')
|
|
409
409
|
|
|
410
410
|
if self.msb0 is False:
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/systemrdl_node_hashes.py
RENAMED
|
@@ -168,7 +168,12 @@ def __node_hash_components(node: Node,
|
|
|
168
168
|
value_to_hash.append(desc)
|
|
169
169
|
|
|
170
170
|
for udp in get_properties_to_include(node, udp_include_func):
|
|
171
|
-
|
|
171
|
+
udp_value = node.get_property(udp)
|
|
172
|
+
# systemRDL supports UDPs that cross-reference other parts of the register model
|
|
173
|
+
if isinstance(udp_value, Node):
|
|
174
|
+
value_to_hash.append('.'.join(udp_value.get_path_segments()))
|
|
175
|
+
else:
|
|
176
|
+
value_to_hash.append(node.get_property(udp))
|
|
172
177
|
|
|
173
178
|
return value_to_hash
|
|
174
179
|
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/templates/addrmap_tb.py.jinja
RENAMED
|
@@ -102,8 +102,10 @@ class {{fq_block_name}}_single_access({{top_node.inst_name}}_TestCase): # type:
|
|
|
102
102
|
} )
|
|
103
103
|
{% elif isinstance(property_value, systemrdlUserEnum) %}
|
|
104
104
|
self.assertEqual(self.dut.{{'.'.join(get_python_path_segments(node))}}.udp['{{property_name}}'], {{ type(property_value).type_name }}_property_enumcls.{{ property_value.name.upper() }} )
|
|
105
|
-
|
|
105
|
+
{% elif isinstance(property_value, str) %}
|
|
106
106
|
self.assertEqual(self.dut.{{'.'.join(get_python_path_segments(node))}}.udp['{{property_name}}'], "{{ property_value }}" )
|
|
107
|
+
{% elif isinstance(property_value, systemrdlFieldNode) %}
|
|
108
|
+
self.assertEqual(self.dut.{{'.'.join(get_python_path_segments(node))}}.udp['{{property_name}}'], self.dut.{{'.'.join(get_python_path_segments(property_value))}} )
|
|
107
109
|
{% else %}
|
|
108
110
|
self.assertEqual(self.dut.{{'.'.join(get_python_path_segments(node))}}.udp['{{property_name}}'], {{ property_value }} )
|
|
109
111
|
{% endif %}
|
|
@@ -27,6 +27,8 @@ along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
27
27
|
'{{name}}' : {{ type(value).type_name + '_property_enumcls.' + value.name.upper() }} ,
|
|
28
28
|
{% elif isinstance(value, str) %}
|
|
29
29
|
'{{name}}' : "{{ value }}" ,
|
|
30
|
+
{% elif isinstance(value, systemrdlFieldNode) %}
|
|
31
|
+
'{{name}}' : self._traverse_from_fully_qualified_name({{ value.get_path_segments() }}) ,
|
|
30
32
|
{% else %}
|
|
31
33
|
'{{name}}' : {{ value }} ,
|
|
32
34
|
{% endif %}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: peakrdl-python
|
|
3
|
-
Version: 3.
|
|
3
|
+
Version: 3.1.0rc1
|
|
4
4
|
Summary: Generate Python Register Access Layer (RAL) from SystemRDL
|
|
5
5
|
Author: Keith Brady
|
|
6
6
|
License: GNU LESSER GENERAL PUBLIC LICENSE
|
|
@@ -286,9 +286,9 @@ assumes that peakrdl has been installed.
|
|
|
286
286
|
To make use of the RAL with real hardware or a different simulation, the callbacks will need to be
|
|
287
287
|
connected to the appropriate access function in order to perform an address space reads and writes
|
|
288
288
|
|
|
289
|
-
#
|
|
289
|
+
# Some important changes
|
|
290
290
|
|
|
291
|
-
##
|
|
291
|
+
## 0.9.0
|
|
292
292
|
|
|
293
293
|
In order to address a major limitation of peakrdl-python that prevented it from implementing the
|
|
294
294
|
full systemRDL specification, a breaking API change was needed for handling blocks:
|
|
@@ -299,7 +299,7 @@ Users are encouraged to upgrade in order to avoid this limitation. However, ther
|
|
|
299
299
|
to support users with existing designs, see: _Legacy Block Callback and Block Access_ in the
|
|
300
300
|
documentation
|
|
301
301
|
|
|
302
|
-
##
|
|
302
|
+
## 1.2.0
|
|
303
303
|
|
|
304
304
|
Version 1.2 introduced a new way to define the enumerations for the field encoding. This allows
|
|
305
305
|
metadata from the systemRDL to propagate through to the generated code. This may break advanced
|
|
@@ -307,7 +307,7 @@ usage of the python enumerations. User are encouraged to use the new feature, ho
|
|
|
307
307
|
are problems with the old enumeration types (based on `IntEnum`) can be used, see
|
|
308
308
|
_Legacy Enumeration Types_ in the documentation
|
|
309
309
|
|
|
310
|
-
##
|
|
310
|
+
## 2.0.0
|
|
311
311
|
|
|
312
312
|
Version 2.0.0 introduced a significant change to the process for building the register model python
|
|
313
313
|
code. This change was intended to reduce the size of the generated code by only generating
|
|
@@ -325,4 +325,20 @@ changing each time it was regenerated, version 2.1.0 introduces a option to eith
|
|
|
325
325
|
of large register models but will be consistent, therefore is useful if the resultant code is being
|
|
326
326
|
checked into a version control system (such as GIT) and the differences are being reviewed
|
|
327
327
|
|
|
328
|
+
## 3.0.0
|
|
329
|
+
|
|
330
|
+
Version 3.0.0 has included a significant refactoring of the generated test cases, moving functions out
|
|
331
|
+
of the templates (generated code) in favour of an enhanced test library. On some cases, this
|
|
332
|
+
reduced the size of the test case generated code by 90%, significantly improved the time to generate
|
|
333
|
+
the code and also improved the time to run the tests by a 30% reduction.
|
|
334
|
+
|
|
335
|
+
In preparation for the removal of some legacy features from the early versions in release 4.0.0,
|
|
336
|
+
the following options were changed:
|
|
337
|
+
- Version 1.2 introduced a new custom enumeration type (rather than using `IntEnum`) in order to allow
|
|
338
|
+
the content to `name` and `desc` systemRDL properties in be accessible. Until version 3.0.0 the new
|
|
339
|
+
type was not the default, it now is. The old enumeration types can still be used by setting `legacy_enum_type`.
|
|
340
|
+
- The first versions of PeakRDL Python used the built-in `Array` type for accessing blocks of data efficiently.
|
|
341
|
+
This had some restrictions, so the a new methodology based on the `list` type was introduced in version 0.9.
|
|
342
|
+
The old array based behaviour is no longer the default but can be turned on using the `legacy_block_access`
|
|
343
|
+
|
|
328
344
|
|
|
@@ -172,6 +172,7 @@ tests/testcases/simulator_test.rdl
|
|
|
172
172
|
tests/testcases/sizes_registers.rdl
|
|
173
173
|
tests/testcases/sizes_registers_array.rdl
|
|
174
174
|
tests/testcases/sparse_enum_issue_200.rdl
|
|
175
|
+
tests/testcases/udp_with_referencing.rdl
|
|
175
176
|
tests/testcases/user_defined_properties.rdl
|
|
176
177
|
tests/testcases/write_only_enum_with_undefined_reset.rdl
|
|
177
178
|
tests/unit_tests/__init__.py
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Testcase the #292 bug
|
|
3
|
+
with a UDP that cross-references another
|
|
4
|
+
*/
|
|
5
|
+
property field_pointer {
|
|
6
|
+
type = field;
|
|
7
|
+
component = field;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
property register_pointer {
|
|
11
|
+
type = reg;
|
|
12
|
+
component = reg;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
addrmap udp_with_referencing {
|
|
16
|
+
reg {
|
|
17
|
+
field {
|
|
18
|
+
hw = rw;
|
|
19
|
+
sw = rw;
|
|
20
|
+
} value;
|
|
21
|
+
} view;
|
|
22
|
+
|
|
23
|
+
reg {
|
|
24
|
+
field {
|
|
25
|
+
hw = rw;
|
|
26
|
+
sw = rw;
|
|
27
|
+
} value;
|
|
28
|
+
} pointer;
|
|
29
|
+
|
|
30
|
+
view.value->field_pointer = pointer.value;
|
|
31
|
+
};
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/array_access/demo_array_access.py
RENAMED
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/enumerated_fields/enumerated_fields.rdl
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/optimised_access/optimised_access.rdl
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/overridden_names/overridden_names.rdl
RENAMED
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/simulating_callbacks/flashing_the_LED.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/example/tranversing_address_map/reg_dump.json
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/field_encoding.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/register_and_field.py
RENAMED
|
File without changes
|
|
File without changes
|
{peakrdl_python-3.0.0rc8 → peakrdl_python-3.1.0rc1}/src/peakrdl_python/lib/utility_functions.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|