yosys/tests/arch/anlogic/mux.ys

53 lines
1.8 KiB
Plaintext
Raw Permalink Normal View History

2019-10-18 12:19:59 +02:00
read_verilog ../common/mux.v
2019-10-04 11:04:18 +02:00
design -save read
hierarchy -top mux2
2019-10-18 09:06:43 +02:00
proc
2019-10-04 11:04:18 +02:00
equiv_opt -assert -map +/anlogic/cells_sim.v synth_anlogic # equivalency check
design -load postopt # load the post-opt design (otherwise equiv_opt loads the pre-opt design)
cd mux2 # Constrain all select calls below inside the top module
select -assert-count 1 t:AL_MAP_LUT3
select -assert-none t:AL_MAP_LUT3 %% t:* %D
design -load read
hierarchy -top mux4
2019-10-18 09:06:43 +02:00
proc
2019-10-04 11:04:18 +02:00
equiv_opt -assert -map +/anlogic/cells_sim.v synth_anlogic # equivalency check
design -load postopt # load the post-opt design (otherwise equiv_opt loads the pre-opt design)
cd mux4 # Constrain all select calls below inside the top module
select -assert-count 1 t:AL_MAP_LUT6
select -assert-none t:AL_MAP_LUT6 %% t:* %D
design -load read
hierarchy -top mux8
2019-10-18 09:06:43 +02:00
proc
2019-10-04 11:04:18 +02:00
equiv_opt -assert -map +/anlogic/cells_sim.v synth_anlogic # equivalency check
design -load postopt # load the post-opt design (otherwise equiv_opt loads the pre-opt design)
cd mux8 # Constrain all select calls below inside the top module
2023-06-09 14:41:45 +02:00
select -assert-max 3 t:AL_MAP_LUT3
select -assert-max 3 t:AL_MAP_LUT4
select -assert-max 1 t:AL_MAP_LUT5
select -assert-max 1 t:AL_MAP_LUT6
2019-10-04 11:04:18 +02:00
2023-06-09 14:41:45 +02:00
select -assert-none t:AL_MAP_LUT3 t:AL_MAP_LUT4 t:AL_MAP_LUT5 t:AL_MAP_LUT6 %% t:* %D
2019-10-04 11:04:18 +02:00
design -load read
hierarchy -top mux16
2019-10-18 09:06:43 +02:00
proc
2025-09-08 14:11:31 +02:00
# Flaky test, started failing with statically allocated IdStrings, but works
# for me locally when I scramble the names using:
#
# rename -scramble-name -seed 1
#
#equiv_opt -assert -map +/anlogic/cells_sim.v synth_anlogic # equivalency check
#design -load postopt # load the post-opt design (otherwise equiv_opt loads the pre-opt design)
#cd mux16 # Constrain all select calls below inside the top module
#show
#select -assert-count 5 t:AL_MAP_LUT6
#select -assert-none t:AL_MAP_LUT6 %% t:* %D