aboutsummaryrefslogtreecommitdiffstats
path: root/tests/arch/common/memory_attributes/attributes_test.ys
diff options
context:
space:
mode:
authorDiego H <diego@symbioticeda.com>2019-12-15 23:33:09 -0600
committerDiego H <diego@symbioticeda.com>2019-12-15 23:33:09 -0600
commitb35559fc335181d7c8f8046fa17bf05550c21ba7 (patch)
tree6293cb01ff8137aad0fee27aa575a080b2c2d206 /tests/arch/common/memory_attributes/attributes_test.ys
parent266993408a2b926ffefcf536feb92b36b11e398e (diff)
downloadyosys-b35559fc335181d7c8f8046fa17bf05550c21ba7.tar.gz
yosys-b35559fc335181d7c8f8046fa17bf05550c21ba7.tar.bz2
yosys-b35559fc335181d7c8f8046fa17bf05550c21ba7.zip
Merging attribute rules into a single match block; Adding tests
Diffstat (limited to 'tests/arch/common/memory_attributes/attributes_test.ys')
-rw-r--r--tests/arch/common/memory_attributes/attributes_test.ys47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/arch/common/memory_attributes/attributes_test.ys b/tests/arch/common/memory_attributes/attributes_test.ys
new file mode 100644
index 000000000..4e06a35e7
--- /dev/null
+++ b/tests/arch/common/memory_attributes/attributes_test.ys
@@ -0,0 +1,47 @@
+# Check that blockram memory without parameters is not modified
+read_verilog attributes_test.v
+hierarchy -top block_ram
+synth_xilinx -top block_ram
+cd block_ram # Constrain all select calls below inside the top module
+select -assert-count 1 t:RAMB18E1
+
+# Check that distributed memory without parameters is not modified
+design -reset
+read_verilog attributes_test.v
+hierarchy -top distributed_ram
+synth_xilinx -top distributed_ram
+cd distributed_ram # Constrain all select calls below inside the top module
+select -assert-count 8 t:RAM32X1D
+
+# Set ram_style distributed to blockram memory; will be implemented as distributed
+design -reset
+read_verilog attributes_test.v
+prep
+setattr -mod -set ram_style "distributed" block_ram
+synth_xilinx -top block_ram
+cd block_ram # Constrain all select calls below inside the top module
+select -assert-count 32 t:RAM128X1D
+
+# Set synthesis, logic_block to blockram memory; will be implemented as distributed
+design -reset
+read_verilog attributes_test.v
+prep
+setattr -mod -set logic_block 1 block_ram
+synth_xilinx -top block_ram
+cd block_ram # Constrain all select calls below inside the top module
+select -assert-count 0 t:RAMB18E1
+select -assert-count 32 t:RAM128X1D
+
+# Set ram_style block to a distributed memory; will be implemented as blockram
+design -reset
+read_verilog attributes_test.v
+synth_xilinx -top distributed_ram_manual
+cd distributed_ram_manual # Constrain all select calls below inside the top module
+select -assert-count 1 t:RAMB18E1
+
+# Set synthesis, ram_block block to a distributed memory; will be implemented as blockram
+design -reset
+read_verilog attributes_test.v
+synth_xilinx -top distributed_ram_manual_syn
+cd distributed_ram_manual_syn # Constrain all select calls below inside the top module
+select -assert-count 1 t:RAMB18E1