#!/bin/bash set -e source openfpga.sh PYTHON_EXEC=python3.8 ############################################### # OpenFPGA Shell with VPR8 ############################################## echo -e "Basic regression tests"; echo -e "Testing configuration chain of a K4N4 FPGA"; run-task basic_tests/full_testbench/configuration_chain $@ run-task basic_tests/full_testbench/configuration_chain_no_time_stamp $@ run-task basic_tests/full_testbench/configuration_chain_use_reset $@ run-task basic_tests/full_testbench/configuration_chain_use_resetb $@ run-task basic_tests/full_testbench/configuration_chain_use_set $@ run-task basic_tests/full_testbench/configuration_chain_use_setb $@ run-task basic_tests/full_testbench/configuration_chain_use_set_reset $@ run-task basic_tests/full_testbench/configuration_chain_config_enable_scff $@ run-task basic_tests/full_testbench/multi_region_configuration_chain $@ run-task basic_tests/full_testbench/fast_configuration_chain $@ run-task basic_tests/full_testbench/fast_configuration_chain_use_set $@ run-task basic_tests/full_testbench/smart_fast_configuration_chain $@ run-task basic_tests/full_testbench/smart_fast_multi_region_configuration_chain $@ run-task basic_tests/preconfig_testbench/configuration_chain $@ run-task basic_tests/preconfig_testbench/configuration_chain_config_done_io $@ run-task basic_tests/preconfig_testbench/configuration_chain_no_time_stamp $@ echo -e "Testing fram-based configuration protocol of a K4N4 FPGA"; run-task basic_tests/full_testbench/configuration_frame $@ run-task basic_tests/full_testbench/smart_fast_configuration_frame $@ run-task basic_tests/full_testbench/fast_configuration_frame $@ run-task basic_tests/full_testbench/fast_configuration_frame_use_set $@ run-task basic_tests/full_testbench/configuration_frame_ccff $@ run-task basic_tests/full_testbench/configuration_frame_scff $@ run-task basic_tests/full_testbench/configuration_frame_use_reset $@ run-task basic_tests/full_testbench/configuration_frame_use_resetb $@ run-task basic_tests/full_testbench/configuration_frame_use_set $@ run-task basic_tests/full_testbench/configuration_frame_use_setb $@ run-task basic_tests/full_testbench/configuration_frame_use_set_reset $@ run-task basic_tests/full_testbench/multi_region_configuration_frame $@ run-task basic_tests/full_testbench/smart_fast_multi_region_configuration_frame $@ run-task basic_tests/preconfig_testbench/configuration_frame $@ echo -e "Testing memory bank configuration protocol of a K4N4 FPGA"; run-task basic_tests/full_testbench/memory_bank $@ run-task basic_tests/full_testbench/memory_bank_use_reset $@ run-task basic_tests/full_testbench/memory_bank_use_resetb $@ run-task basic_tests/full_testbench/memory_bank_use_set $@ run-task basic_tests/full_testbench/memory_bank_use_setb $@ run-task basic_tests/full_testbench/memory_bank_use_set_reset $@ run-task basic_tests/full_testbench/multi_region_memory_bank $@ run-task basic_tests/full_testbench/fast_memory_bank $@ run-task basic_tests/full_testbench/fast_memory_bank_use_set $@ run-task basic_tests/full_testbench/smart_fast_memory_bank $@ run-task basic_tests/full_testbench/smart_fast_multi_region_memory_bank $@ run-task basic_tests/preconfig_testbench/memory_bank $@ echo -e "Testing physical design friendly memory bank configuration protocol of a K4N4 FPGA"; run-task basic_tests/full_testbench/ql_memory_bank $@ run-task basic_tests/full_testbench/ql_memory_bank_use_wlr $@ run-task basic_tests/full_testbench/multi_region_ql_memory_bank $@ run-task basic_tests/full_testbench/ql_memory_bank_flatten $@ run-task basic_tests/full_testbench/ql_memory_bank_flatten_use_wlr $@ run-task basic_tests/full_testbench/ql_memory_bank_shift_register $@ run-task basic_tests/full_testbench/ql_memory_bank_shift_register_use_wlr $@ run-task basic_tests/full_testbench/ql_memory_bank_shift_register_multi_chain $@ echo -e "Testing testbenches without self checking features"; run-task basic_tests/full_testbench/full_testbench_without_self_checking $@ run-task basic_tests/preconfig_testbench/preconfigured_testbench_without_self_checking $@ echo -e "Testing standalone (flatten memory) configuration protocol of a K4N4 FPGA"; run-task basic_tests/full_testbench/flatten_memory $@ run-task basic_tests/preconfig_testbench/flatten_memory $@ echo -e "Testing fixed device layout and routing channel width"; run-task basic_tests/fixed_device_support $@ echo -e "Testing fabric Verilog generation only"; run-task basic_tests/generate_fabric $@ echo -e "Testing Verilog testbench generation only"; run-task basic_tests/generate_testbench $@ echo -e "Testing separated Verilog fabric netlists and testbench locations"; run-task basic_tests/custom_fabric_netlist_location $@ echo -e "Testing user-defined simulation settings: clock frequency and number of cycles"; run-task basic_tests/fixed_simulation_settings/fixed_operating_clock_freq $@ run-task basic_tests/fixed_simulation_settings/fixed_operating_clock_freq_no_ace $@ # TODO: This feature is temporarily out of test due to the emergency in delivering netlists for multi-chain shift-register memory bank #run-task basic_tests/fixed_simulation_settings/fixed_shift_register_clock_freq $@ echo -e "Testing Secured FPGA fabrics"; run-task basic_tests/fabric_key/generate_vanilla_key $@ run-task basic_tests/fabric_key/generate_multi_region_vanilla_key $@ run-task basic_tests/fabric_key/generate_random_key $@ run-task basic_tests/fabric_key/generate_random_key_ql_memory_bank $@ run-task basic_tests/fabric_key/load_external_key $@ run-task basic_tests/fabric_key/load_external_key_cc_fpga $@ run-task basic_tests/fabric_key/load_external_key_multi_region_cc_fpga $@ run-task basic_tests/fabric_key/load_external_key_qlbank_fpga $@ run-task basic_tests/fabric_key/load_external_key_multi_region_qlbank_fpga $@ run-task basic_tests/fabric_key/load_external_key_qlbanksr_multi_chain_fpga $@ # TODO: This feature is temporarily out of test due to the emergency in delivering netlists for multi-chain shift-register memory bank #run-task basic_tests/fabric_key/load_external_key_multi_region_qlbanksr_fpga $@ echo -e "Testing K4 series FPGA"; echo -e "Testing K4N4 with facturable LUTs"; run-task basic_tests/k4_series/k4n4_frac_lut $@ echo -e "Testing K4N4 with asynchronous reset"; run-task basic_tests/k4_series/k4n4_fracff $@ echo -e "Testing K4N4 with negative edge clocks"; run-task basic_tests/k4_series/k4n4_fracff2edge $@ echo -e "Testing K4N4 with hard adders"; run-task basic_tests/k4_series/k4n4_adder $@ echo -e "Testing K4N4 without local routing architecture"; run-task basic_tests/k4_series/k4n4_no_local_routing $@ echo -e "Testing K4N4 with block RAM"; run-task basic_tests/k4_series/k4n4_bram $@ echo -e "Testing K4N4 with LUTRAM"; run-task basic_tests/k4_series/k4n4_lutram $@ echo -e "Testing K4N4 with multiple lengths of routing segments"; run-task basic_tests/k4_series/k4n4_L124 $@ echo -e "Testing K4N4 with 32-bit fracturable multiplier"; run-task basic_tests/k4_series/k4n4_frac_mult $@ echo -e "Testing K4N5 with pattern based local routing"; run-task basic_tests/k4_series/k4n5_pattern_local_routing $@ echo -e "Testing different tile organizations"; echo -e "Testing tiles with pins only on top and left sides"; run-task basic_tests/tile_organization/top_left_custom_pins $@ echo -e "Testing tiles with pins only on top and right sides"; run-task basic_tests/tile_organization/top_right_custom_pins $@ echo -e "Testing tiles with pins only on bottom and right sides"; run-task basic_tests/tile_organization/bottom_right_custom_pins $@ echo -e "Testing tiles with I/O in center grid"; run-task basic_tests/tile_organization/tileable_io $@ echo -e "Testing global port definition from tiles"; run-task basic_tests/global_tile_ports/global_tile_clock $@ run-task basic_tests/global_tile_ports/global_tile_reset $@ run-task basic_tests/global_tile_ports/global_tile_4clock $@ run-task basic_tests/global_tile_ports/global_tile_4clock_pin $@ echo -e "Testing configuration chain of a K4N4 FPGA using .blif generated by yosys+verific"; run-task basic_tests/verific_test $@ echo -e "Testing explicit multi verilog files"; run-task basic_tests/explicit_multi_verilog_files $@ echo -e "Test the remove of runtime directories" clear-task-run basic_tests/explicit_multi_verilog_files $@ echo -e "Testing write GSB to files"; run-task basic_tests/write_gsb/write_gsb_to_xml $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_rr_info $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_cbx $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_cby $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_cbx_cby $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_sb $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_sb_cbx $@ run-task basic_tests/write_gsb/write_gsb_to_xml_exclude_sb_cby $@ run-task basic_tests/write_gsb/write_gsb_to_xml_include_sb_cbx_cby $@ run-task basic_tests/write_gsb/write_gsb_to_xml_include_single_cbx $@ run-task basic_tests/write_gsb/write_gsb_to_xml_include_single_cby $@ run-task basic_tests/write_gsb/write_gsb_to_xml_include_single_sb $@ run-task basic_tests/write_gsb/write_gsb_to_xml_compress_routing $@ run-task basic_tests/write_gsb/write_unique_gsb_to_xml $@ run-task basic_tests/write_gsb/write_unique_gsb_to_xml_compress_routing $@ echo -e "Testing bus group features"; run-task basic_tests/bus_group/preconfig_testbench_explicit_mapping $@ run-task basic_tests/bus_group/preconfig_testbench_implicit_mapping $@ run-task basic_tests/bus_group/full_testbench_explicit_mapping $@ run-task basic_tests/bus_group/full_testbench_implicit_mapping $@ echo -e "Testing fix pins features"; run-task basic_tests/fix_pins $@ run-task basic_tests/constrain_pin_location $@ echo -e "Testing project templates"; run-task template_tasks/vpr_blif_template $@ run-task template_tasks/yosys_vpr_template $@ run-task template_tasks/vtr_benchmarks_template $@ echo -e "Testing create tsk from template and run task" create-task _task_copy basic_tests/generate_fabric run-task _task_copy $@ echo -e "Testing output files without time stamp"; run-task basic_tests/no_time_stamp $@ # Run git-diff to ensure no changes on the golden netlists # Switch to root path in case users are running the tests in another location cd ${OPENFPGA_PATH} pwd git config --global --add safe.directory ${OPENFPGA_PATH} git log git diff --name-status -- ':${OPENFPGA_PATH}/openfpga_flow/tasks/basic_tests/no_time_stamp/golden_outputs_no_time_stamp/**' if git diff --name-status --exit-code -- ':${OPENFPGA_PATH}/openfpga_flow/tasks/basic_tests/no_time_stamp/golden_outputs_no_time_stamp/**'; then echo -e "Golden netlist remain unchanged" else echo -e "Detect changes in golden netlists"; exit 1; fi cd - # Repgression test to test multi-user enviroment # Note: Keep this task as the last one!!! cp -r */*/basic_tests/full_testbench/configuration_chain /tmp/ cd /tmp/ && run-task configuration_chain $@ cd -