aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite
diff options
context:
space:
mode:
Diffstat (limited to 'testsuite')
-rw-r--r--testsuite/gna/issue50/idct.d/add_163.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_165.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_166.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_167.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_168.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_169.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_170.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_171.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_172.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_173.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_174.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_175.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_176.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_177.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_178.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_179.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_180.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_181.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_182.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_183.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_184.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_191.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_194.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_205.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_206.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_210.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_211.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_212.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_226.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_235.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_236.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_254.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_255.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_276.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_277.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_295.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_296.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_314.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_315.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_323.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_338.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_350.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_382.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_390.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_393.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_419.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_420.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_430.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_466.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_474.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_483.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_487.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_508.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_516.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_537.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_552.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_564.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_570.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_600.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_601.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/add_602.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/assert_uut.vhd419
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_164.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_202.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_203.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_204.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_324.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_325.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_392.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_396.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_398.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_400.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_402.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_404.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_406.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_408.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_410.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_411.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_412.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cmp_413.vhd26
-rw-r--r--testsuite/gna/issue50/idct.d/cp3_test.vhd280
-rw-r--r--testsuite/gna/issue50/idct.d/fsm.vhd396
-rw-r--r--testsuite/gna/issue50/idct.d/fsm_23.vhd4853
-rw-r--r--testsuite/gna/issue50/idct.d/input_split0.vhd74
-rw-r--r--testsuite/gna/issue50/idct.d/input_split1.vhd74
-rw-r--r--testsuite/gna/issue50/idct.d/mul_189.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_190.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_192.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_193.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_195.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_196.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_198.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_199.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_215.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_216.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_218.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_219.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_223.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_230.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_328.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_331.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_341.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_344.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_353.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_357.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_365.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_368.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_373.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_376.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_383.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_416.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_442.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_445.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_447.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_448.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_456.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_457.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_460.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_469.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_477.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_492.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_495.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_499.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_502.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_511.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_520.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_524.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_527.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_531.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_534.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_540.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_543.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_547.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_556.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_559.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_560.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_561.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_565.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_566.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_573.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_577.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_578.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_579.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_589.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_592.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_594.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_595.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/mul_605.vhd27
-rw-r--r--testsuite/gna/issue50/idct.d/muxb_162.vhd22
-rw-r--r--testsuite/gna/issue50/idct.d/muxb_201.vhd22
-rw-r--r--testsuite/gna/issue50/idct.d/muxb_263.vhd22
-rw-r--r--testsuite/gna/issue50/idct.d/muxb_265.vhd22
-rw-r--r--testsuite/gna/issue50/idct.d/muxb_322.vhd22
-rw-r--r--testsuite/gna/issue50/idct.d/output_split0.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split1.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split2.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split3.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split4.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split5.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split6.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/output_split7.vhd65
-rw-r--r--testsuite/gna/issue50/idct.d/pkg_tb.vhd60
-rw-r--r--testsuite/gna/issue50/idct.d/prog.vhd70
-rw-r--r--testsuite/gna/issue50/idct.d/sub_157.vhd64
-rw-r--r--testsuite/gna/issue50/idct.d/sub_159.vhd64
-rw-r--r--testsuite/gna/issue50/idct.d/sub_160.vhd64
-rw-r--r--testsuite/gna/issue50/idct.d/sub_185.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_186.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_187.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_188.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_197.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_200.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_207.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_208.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_209.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_213.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_214.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_217.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_220.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_227.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_243.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_262.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_284.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_303.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_332.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_337.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_345.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_354.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_362.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_369.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_370.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_377.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_391.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_429.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_437.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_446.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_449.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_461.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_478.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_484.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_488.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_489.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_496.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_503.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_517.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_521.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_528.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_544.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_553.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_562.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_563.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_567.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_574.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_580.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_585.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_586.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_593.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_596.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sub_599.vhd33
-rw-r--r--testsuite/gna/issue50/idct.d/sync_ram.vhd42
-rw-r--r--testsuite/gna/issue50/idct.d/tb.vhd44
-rw-r--r--testsuite/gna/issue50/idct.d/top.vhd6740
-rwxr-xr-xtestsuite/gna/issue50/testsuite.sh106
-rw-r--r--testsuite/gna/issue50/vector.d/add_118.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/add_134.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/add_170.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/add_171.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/add_188.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/add_214.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/add_220.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/assert_uut.vhd169
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_111.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_112.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_113.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_114.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_115.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_119.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_126.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_127.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_128.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_129.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_130.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_131.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_132.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_133.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_135.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_136.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_137.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_138.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_139.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_140.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_141.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_142.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_146.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_148.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_150.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_152.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_154.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_156.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_158.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_160.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_174.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_176.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_178.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_180.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_183.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_185.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_187.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_191.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_193.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_195.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_198.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_200.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_202.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_204.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_215.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_216.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_217.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_218.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cmp_221.vhd26
-rw-r--r--testsuite/gna/issue50/vector.d/cp3_test.vhd280
-rw-r--r--testsuite/gna/issue50/vector.d/fsm.vhd396
-rw-r--r--testsuite/gna/issue50/vector.d/fsm_15.vhd539
-rw-r--r--testsuite/gna/issue50/vector.d/muxb_117.vhd22
-rw-r--r--testsuite/gna/issue50/vector.d/muxb_120.vhd22
-rw-r--r--testsuite/gna/issue50/vector.d/muxb_121.vhd22
-rw-r--r--testsuite/gna/issue50/vector.d/muxb_123.vhd22
-rw-r--r--testsuite/gna/issue50/vector.d/muxb_124.vhd22
-rw-r--r--testsuite/gna/issue50/vector.d/muxb_219.vhd22
-rw-r--r--testsuite/gna/issue50/vector.d/pkg_tb.vhd60
-rw-r--r--testsuite/gna/issue50/vector.d/prog.vhd71
-rw-r--r--testsuite/gna/issue50/vector.d/sub_125.vhd64
-rw-r--r--testsuite/gna/issue50/vector.d/sub_145.vhd33
-rw-r--r--testsuite/gna/issue50/vector.d/sub_189.vhd64
-rw-r--r--testsuite/gna/issue50/vector.d/sync_ram.vhd42
-rw-r--r--testsuite/gna/issue50/vector.d/tb.vhd44
-rw-r--r--testsuite/gna/issue50/vector.d/top.vhd2504
-rw-r--r--testsuite/gna/issue50/vector.d/v_split0.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split1.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split2.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split3.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split4.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split5.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split6.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/v_split7.vhd65
-rw-r--r--testsuite/gna/issue50/vector.d/w_split0.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split1.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split2.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split3.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split4.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split5.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split6.vhd67
-rw-r--r--testsuite/gna/issue50/vector.d/w_split7.vhd67
313 files changed, 26870 insertions, 0 deletions
diff --git a/testsuite/gna/issue50/idct.d/add_163.vhd b/testsuite/gna/issue50/idct.d/add_163.vhd
new file mode 100644
index 000000000..e5d5beaa5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_163.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_163 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end add_163;
+
+architecture augh of add_163 is
+
+ signal carry_inA : std_logic_vector(17 downto 0);
+ signal carry_inB : std_logic_vector(17 downto 0);
+ signal carry_res : std_logic_vector(17 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(16 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_165.vhd b/testsuite/gna/issue50/idct.d/add_165.vhd
new file mode 100644
index 000000000..52f02510c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_165.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_165 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_165;
+
+architecture augh of add_165 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_166.vhd b/testsuite/gna/issue50/idct.d/add_166.vhd
new file mode 100644
index 000000000..6a761c6f4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_166.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_166 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_166;
+
+architecture augh of add_166 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_167.vhd b/testsuite/gna/issue50/idct.d/add_167.vhd
new file mode 100644
index 000000000..7a527c2de
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_167.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_167 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_167;
+
+architecture augh of add_167 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_168.vhd b/testsuite/gna/issue50/idct.d/add_168.vhd
new file mode 100644
index 000000000..c90a53a72
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_168.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_168 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_168;
+
+architecture augh of add_168 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_169.vhd b/testsuite/gna/issue50/idct.d/add_169.vhd
new file mode 100644
index 000000000..8bd74492c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_169.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_169 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_169;
+
+architecture augh of add_169 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_170.vhd b/testsuite/gna/issue50/idct.d/add_170.vhd
new file mode 100644
index 000000000..762945f06
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_170.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_170 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_170;
+
+architecture augh of add_170 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_171.vhd b/testsuite/gna/issue50/idct.d/add_171.vhd
new file mode 100644
index 000000000..163da6be4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_171.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_171 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_171;
+
+architecture augh of add_171 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_172.vhd b/testsuite/gna/issue50/idct.d/add_172.vhd
new file mode 100644
index 000000000..0ceb61408
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_172.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_172 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_172;
+
+architecture augh of add_172 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_173.vhd b/testsuite/gna/issue50/idct.d/add_173.vhd
new file mode 100644
index 000000000..a3afed3d0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_173.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_173 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_173;
+
+architecture augh of add_173 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_174.vhd b/testsuite/gna/issue50/idct.d/add_174.vhd
new file mode 100644
index 000000000..3d5fbc07b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_174.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_174 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_174;
+
+architecture augh of add_174 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_175.vhd b/testsuite/gna/issue50/idct.d/add_175.vhd
new file mode 100644
index 000000000..9cde83c4d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_175.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_175 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_175;
+
+architecture augh of add_175 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_176.vhd b/testsuite/gna/issue50/idct.d/add_176.vhd
new file mode 100644
index 000000000..20861aebb
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_176.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_176 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_176;
+
+architecture augh of add_176 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_177.vhd b/testsuite/gna/issue50/idct.d/add_177.vhd
new file mode 100644
index 000000000..91d40b68e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_177.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_177 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_177;
+
+architecture augh of add_177 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_178.vhd b/testsuite/gna/issue50/idct.d/add_178.vhd
new file mode 100644
index 000000000..3ebed0cbe
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_178.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_178 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_178;
+
+architecture augh of add_178 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_179.vhd b/testsuite/gna/issue50/idct.d/add_179.vhd
new file mode 100644
index 000000000..c0e38635b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_179.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_179 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_179;
+
+architecture augh of add_179 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_180.vhd b/testsuite/gna/issue50/idct.d/add_180.vhd
new file mode 100644
index 000000000..ade86c4a5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_180.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_180 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_180;
+
+architecture augh of add_180 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_181.vhd b/testsuite/gna/issue50/idct.d/add_181.vhd
new file mode 100644
index 000000000..e20ca4cac
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_181.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_181 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_181;
+
+architecture augh of add_181 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_182.vhd b/testsuite/gna/issue50/idct.d/add_182.vhd
new file mode 100644
index 000000000..fb9e4a021
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_182.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_182 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_182;
+
+architecture augh of add_182 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_183.vhd b/testsuite/gna/issue50/idct.d/add_183.vhd
new file mode 100644
index 000000000..a2e9e1867
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_183.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_183 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_183;
+
+architecture augh of add_183 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_184.vhd b/testsuite/gna/issue50/idct.d/add_184.vhd
new file mode 100644
index 000000000..8721eaeaf
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_184.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_184 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_184;
+
+architecture augh of add_184 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_191.vhd b/testsuite/gna/issue50/idct.d/add_191.vhd
new file mode 100644
index 000000000..0383c14ec
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_191.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_191 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(30 downto 0)
+ );
+end add_191;
+
+architecture augh of add_191 is
+
+ signal carry_inA : std_logic_vector(32 downto 0);
+ signal carry_inB : std_logic_vector(32 downto 0);
+ signal carry_res : std_logic_vector(32 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(31 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_194.vhd b/testsuite/gna/issue50/idct.d/add_194.vhd
new file mode 100644
index 000000000..864745b93
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_194.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_194 is
+ port (
+ result : out std_logic_vector(29 downto 0);
+ in_a : in std_logic_vector(29 downto 0);
+ in_b : in std_logic_vector(29 downto 0)
+ );
+end add_194;
+
+architecture augh of add_194 is
+
+ signal carry_inA : std_logic_vector(31 downto 0);
+ signal carry_inB : std_logic_vector(31 downto 0);
+ signal carry_res : std_logic_vector(31 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(30 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_205.vhd b/testsuite/gna/issue50/idct.d/add_205.vhd
new file mode 100644
index 000000000..154fbe2c7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_205.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_205 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_205;
+
+architecture augh of add_205 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_206.vhd b/testsuite/gna/issue50/idct.d/add_206.vhd
new file mode 100644
index 000000000..5adf22679
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_206.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_206 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_206;
+
+architecture augh of add_206 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_210.vhd b/testsuite/gna/issue50/idct.d/add_210.vhd
new file mode 100644
index 000000000..8b6a2197d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_210.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_210 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_210;
+
+architecture augh of add_210 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_211.vhd b/testsuite/gna/issue50/idct.d/add_211.vhd
new file mode 100644
index 000000000..e0b50f01d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_211.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_211 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_211;
+
+architecture augh of add_211 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_212.vhd b/testsuite/gna/issue50/idct.d/add_212.vhd
new file mode 100644
index 000000000..9e284041a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_212.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_212 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_212;
+
+architecture augh of add_212 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_226.vhd b/testsuite/gna/issue50/idct.d/add_226.vhd
new file mode 100644
index 000000000..62b7eec4b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_226.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_226 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_226;
+
+architecture augh of add_226 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_235.vhd b/testsuite/gna/issue50/idct.d/add_235.vhd
new file mode 100644
index 000000000..ac484ebaf
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_235.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_235 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_235;
+
+architecture augh of add_235 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_236.vhd b/testsuite/gna/issue50/idct.d/add_236.vhd
new file mode 100644
index 000000000..f0161c138
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_236.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_236 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_236;
+
+architecture augh of add_236 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_254.vhd b/testsuite/gna/issue50/idct.d/add_254.vhd
new file mode 100644
index 000000000..a22dce3a5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_254.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_254 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_254;
+
+architecture augh of add_254 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_255.vhd b/testsuite/gna/issue50/idct.d/add_255.vhd
new file mode 100644
index 000000000..f6b20a3b9
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_255.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_255 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_255;
+
+architecture augh of add_255 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_276.vhd b/testsuite/gna/issue50/idct.d/add_276.vhd
new file mode 100644
index 000000000..9d9fa4bcd
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_276.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_276 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_276;
+
+architecture augh of add_276 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_277.vhd b/testsuite/gna/issue50/idct.d/add_277.vhd
new file mode 100644
index 000000000..4c14a887f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_277.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_277 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_277;
+
+architecture augh of add_277 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_295.vhd b/testsuite/gna/issue50/idct.d/add_295.vhd
new file mode 100644
index 000000000..aea58f9bc
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_295.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_295 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_295;
+
+architecture augh of add_295 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_296.vhd b/testsuite/gna/issue50/idct.d/add_296.vhd
new file mode 100644
index 000000000..a7110a8c0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_296.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_296 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_296;
+
+architecture augh of add_296 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_314.vhd b/testsuite/gna/issue50/idct.d/add_314.vhd
new file mode 100644
index 000000000..0966d60d5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_314.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_314 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_314;
+
+architecture augh of add_314 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_315.vhd b/testsuite/gna/issue50/idct.d/add_315.vhd
new file mode 100644
index 000000000..0efd8d789
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_315.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_315 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_315;
+
+architecture augh of add_315 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_323.vhd b/testsuite/gna/issue50/idct.d/add_323.vhd
new file mode 100644
index 000000000..6d3769be4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_323.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_323 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end add_323;
+
+architecture augh of add_323 is
+
+ signal carry_inA : std_logic_vector(17 downto 0);
+ signal carry_inB : std_logic_vector(17 downto 0);
+ signal carry_res : std_logic_vector(17 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(16 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_338.vhd b/testsuite/gna/issue50/idct.d/add_338.vhd
new file mode 100644
index 000000000..966c49df0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_338.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_338 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_338;
+
+architecture augh of add_338 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_350.vhd b/testsuite/gna/issue50/idct.d/add_350.vhd
new file mode 100644
index 000000000..46969a50b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_350.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_350 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_350;
+
+architecture augh of add_350 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_382.vhd b/testsuite/gna/issue50/idct.d/add_382.vhd
new file mode 100644
index 000000000..1c38f11ef
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_382.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_382 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_382;
+
+architecture augh of add_382 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_390.vhd b/testsuite/gna/issue50/idct.d/add_390.vhd
new file mode 100644
index 000000000..ac1d5d6a2
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_390.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_390 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_390;
+
+architecture augh of add_390 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_393.vhd b/testsuite/gna/issue50/idct.d/add_393.vhd
new file mode 100644
index 000000000..8e2b339fb
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_393.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_393 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_393;
+
+architecture augh of add_393 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_419.vhd b/testsuite/gna/issue50/idct.d/add_419.vhd
new file mode 100644
index 000000000..036d0dfc6
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_419.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_419 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_419;
+
+architecture augh of add_419 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_420.vhd b/testsuite/gna/issue50/idct.d/add_420.vhd
new file mode 100644
index 000000000..46c9183f4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_420.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_420 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_420;
+
+architecture augh of add_420 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_430.vhd b/testsuite/gna/issue50/idct.d/add_430.vhd
new file mode 100644
index 000000000..8b0d8779a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_430.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_430 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_430;
+
+architecture augh of add_430 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_466.vhd b/testsuite/gna/issue50/idct.d/add_466.vhd
new file mode 100644
index 000000000..fefc2340e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_466.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_466 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_466;
+
+architecture augh of add_466 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_474.vhd b/testsuite/gna/issue50/idct.d/add_474.vhd
new file mode 100644
index 000000000..121b554f5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_474.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_474 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_474;
+
+architecture augh of add_474 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_483.vhd b/testsuite/gna/issue50/idct.d/add_483.vhd
new file mode 100644
index 000000000..92b5fde0e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_483.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_483 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_483;
+
+architecture augh of add_483 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_487.vhd b/testsuite/gna/issue50/idct.d/add_487.vhd
new file mode 100644
index 000000000..a3464bb9d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_487.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_487 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_487;
+
+architecture augh of add_487 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_508.vhd b/testsuite/gna/issue50/idct.d/add_508.vhd
new file mode 100644
index 000000000..24e9a80c8
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_508.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_508 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_508;
+
+architecture augh of add_508 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_516.vhd b/testsuite/gna/issue50/idct.d/add_516.vhd
new file mode 100644
index 000000000..88c41b629
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_516.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_516 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_516;
+
+architecture augh of add_516 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_537.vhd b/testsuite/gna/issue50/idct.d/add_537.vhd
new file mode 100644
index 000000000..f3ac3a406
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_537.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_537 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_537;
+
+architecture augh of add_537 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_552.vhd b/testsuite/gna/issue50/idct.d/add_552.vhd
new file mode 100644
index 000000000..ec8fa6f9f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_552.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_552 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_552;
+
+architecture augh of add_552 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_564.vhd b/testsuite/gna/issue50/idct.d/add_564.vhd
new file mode 100644
index 000000000..4108f7e3c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_564.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_564 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_564;
+
+architecture augh of add_564 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_570.vhd b/testsuite/gna/issue50/idct.d/add_570.vhd
new file mode 100644
index 000000000..ad0abfb68
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_570.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_570 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_570;
+
+architecture augh of add_570 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_600.vhd b/testsuite/gna/issue50/idct.d/add_600.vhd
new file mode 100644
index 000000000..cb2c86175
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_600.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_600 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_600;
+
+architecture augh of add_600 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_601.vhd b/testsuite/gna/issue50/idct.d/add_601.vhd
new file mode 100644
index 000000000..338e0052b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_601.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_601 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+end add_601;
+
+architecture augh of add_601 is
+
+ signal carry_inA : std_logic_vector(28 downto 0);
+ signal carry_inB : std_logic_vector(28 downto 0);
+ signal carry_res : std_logic_vector(28 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(27 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/add_602.vhd b/testsuite/gna/issue50/idct.d/add_602.vhd
new file mode 100644
index 000000000..72d3760c4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/add_602.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_602 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+end add_602;
+
+architecture augh of add_602 is
+
+ signal carry_inA : std_logic_vector(21 downto 0);
+ signal carry_inB : std_logic_vector(21 downto 0);
+ signal carry_res : std_logic_vector(21 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(20 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/assert_uut.vhd b/testsuite/gna/issue50/idct.d/assert_uut.vhd
new file mode 100644
index 000000000..1707dcae1
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/assert_uut.vhd
@@ -0,0 +1,419 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+use std.textio.all;
+library work;
+use work.pkg_tb.all;
+
+entity assert_uut is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ context_uut : in context_t;
+ en_feed : in std_logic;
+ stdin_rdy : in std_logic;
+ stdin_ack : out std_logic;
+ stdin_data : out stdin_vector;
+ en_check : in std_logic;
+ stdout_rdy : in std_logic;
+ stdout_ack : out std_logic;
+ stdout_data : in stdout_vector;
+ vecs_found : out std_logic;
+ vec_read : out std_logic;
+ n_error : out std_logic
+ );
+end assert_uut;
+
+architecture rtl of assert_uut is
+
+ type vin_table is array(0 to 2**VEC_NO_SIZE - 1) of stdin_vector;
+ type vout_table is array(0 to 2**VEC_NO_SIZE - 1) of stdout_vector;
+ constant input_vectors_1 : vin_table := (
+ --##INPUT_VECTORS_1_GO_DOWN_HERE##--
+ 0 => x"00_00_00_a3",
+ 1 => x"00_00_00_ea",
+ 2 => x"00_00_00_cc",
+ 3 => x"00_00_00_28",
+ 4 => x"00_00_00_30",
+ 5 => x"00_00_00_a0",
+ 6 => x"00_00_00_c0",
+ 7 => x"00_00_00_80",
+ 8 => x"00_00_00_00",
+ 9 => x"00_00_00_00",
+ 10 => x"00_00_00_00",
+ 11 => x"00_00_00_00",
+ 12 => x"00_00_00_00",
+ 13 => x"00_00_00_00",
+ 14 => x"00_00_00_00",
+ 15 => x"00_00_00_00",
+ 16 => x"00_00_00_00",
+ 17 => x"00_00_00_00",
+ 18 => x"00_00_00_00",
+ 19 => x"00_00_00_00",
+ 20 => x"00_00_00_00",
+ 21 => x"00_00_00_00",
+ 22 => x"00_00_00_00",
+ 23 => x"00_00_00_00",
+ 24 => x"00_00_00_00",
+ 25 => x"00_00_00_00",
+ 26 => x"00_00_00_00",
+ 27 => x"00_00_00_00",
+ 28 => x"00_00_00_00",
+ 29 => x"00_00_00_00",
+ 30 => x"00_00_00_00",
+ 31 => x"00_00_00_00",
+ 32 => x"00_00_00_00",
+ 33 => x"00_00_00_00",
+ 34 => x"00_00_00_00",
+ 35 => x"00_00_00_00",
+ 36 => x"00_00_00_00",
+ 37 => x"00_00_00_00",
+ 38 => x"00_00_00_00",
+ 39 => x"00_00_00_00",
+ 40 => x"00_00_00_00",
+ 41 => x"00_00_00_00",
+ 42 => x"00_00_00_00",
+ 43 => x"00_00_00_00",
+ 44 => x"00_00_00_00",
+ 45 => x"00_00_00_00",
+ 46 => x"00_00_00_00",
+ 47 => x"00_00_00_00",
+ 48 => x"00_00_00_00",
+ 49 => x"00_00_00_00",
+ 50 => x"00_00_00_00",
+ 51 => x"00_00_00_00",
+ 52 => x"00_00_00_00",
+ 53 => x"00_00_00_00",
+ 54 => x"00_00_00_00",
+ 55 => x"00_00_00_00",
+ 56 => x"00_00_00_00",
+ 57 => x"00_00_00_00",
+ 58 => x"00_00_00_00",
+ 59 => x"00_00_00_00",
+ 60 => x"00_00_00_00",
+ 61 => x"00_00_00_00",
+ 62 => x"00_00_00_00",
+ 63 => x"00_00_00_00",
+ --##INPUT_VECTORS_1_GO_OVER_HERE##--
+ others => (others => '0'));
+ constant output_vectors_1 : vout_table := (
+ --##OUTPUT_VECTORS_1_GO_DOWN_HERE##--
+ 0 => x"ff",
+ 1 => x"00",
+ 2 => x"ff",
+ 3 => x"ff",
+ 4 => x"00",
+ 5 => x"00",
+ 6 => x"ff",
+ 7 => x"00",
+ 8 => x"ff",
+ 9 => x"00",
+ 10 => x"ff",
+ 11 => x"ff",
+ 12 => x"00",
+ 13 => x"00",
+ 14 => x"ff",
+ 15 => x"00",
+ 16 => x"ff",
+ 17 => x"00",
+ 18 => x"ff",
+ 19 => x"ff",
+ 20 => x"00",
+ 21 => x"00",
+ 22 => x"ff",
+ 23 => x"00",
+ 24 => x"ff",
+ 25 => x"00",
+ 26 => x"ff",
+ 27 => x"ff",
+ 28 => x"00",
+ 29 => x"00",
+ 30 => x"ff",
+ 31 => x"00",
+ 32 => x"ff",
+ 33 => x"00",
+ 34 => x"ff",
+ 35 => x"ff",
+ 36 => x"00",
+ 37 => x"00",
+ 38 => x"ff",
+ 39 => x"00",
+ 40 => x"ff",
+ 41 => x"00",
+ 42 => x"ff",
+ 43 => x"ff",
+ 44 => x"00",
+ 45 => x"00",
+ 46 => x"ff",
+ 47 => x"00",
+ 48 => x"ff",
+ 49 => x"00",
+ 50 => x"ff",
+ 51 => x"ff",
+ 52 => x"00",
+ 53 => x"00",
+ 54 => x"ff",
+ 55 => x"00",
+ 56 => x"ff",
+ 57 => x"00",
+ 58 => x"ff",
+ 59 => x"ff",
+ 60 => x"00",
+ 61 => x"00",
+ 62 => x"ff",
+ 63 => x"00",
+ --##OUTPUT_VECTORS_1_GO_OVER_HERE##--
+ others => (others => '0'));
+ constant input_vectors_2 : vin_table := (
+ --##INPUT_VECTORS_2_GO_DOWN_HERE##--
+ 0 => x"00_00_00_a3",
+ 1 => x"00_00_00_ea",
+ 2 => x"00_00_00_cc",
+ 3 => x"00_00_00_28",
+ 4 => x"00_00_00_30",
+ 5 => x"00_00_00_a0",
+ 6 => x"00_00_00_c0",
+ 7 => x"00_00_00_80",
+ 8 => x"00_00_00_00",
+ 9 => x"00_00_00_00",
+ 10 => x"00_00_00_00",
+ 11 => x"00_00_00_00",
+ 12 => x"00_00_00_00",
+ 13 => x"00_00_00_00",
+ 14 => x"00_00_00_00",
+ 15 => x"00_00_00_00",
+ 16 => x"00_00_00_00",
+ 17 => x"00_00_00_00",
+ 18 => x"00_00_00_00",
+ 19 => x"00_00_00_00",
+ 20 => x"00_00_00_00",
+ 21 => x"00_00_00_00",
+ 22 => x"00_00_00_00",
+ 23 => x"00_00_00_00",
+ 24 => x"00_00_00_00",
+ 25 => x"00_00_00_00",
+ 26 => x"00_00_00_00",
+ 27 => x"00_00_00_00",
+ 28 => x"00_00_00_00",
+ 29 => x"00_00_00_00",
+ 30 => x"00_00_00_00",
+ 31 => x"00_00_00_00",
+ 32 => x"00_00_00_00",
+ 33 => x"00_00_00_00",
+ 34 => x"00_00_00_00",
+ 35 => x"00_00_00_00",
+ 36 => x"00_00_00_00",
+ 37 => x"00_00_00_00",
+ 38 => x"00_00_00_00",
+ 39 => x"00_00_00_00",
+ 40 => x"00_00_00_00",
+ 41 => x"00_00_00_00",
+ 42 => x"00_00_00_00",
+ 43 => x"00_00_00_00",
+ 44 => x"00_00_00_00",
+ 45 => x"00_00_00_00",
+ 46 => x"00_00_00_00",
+ 47 => x"00_00_00_00",
+ 48 => x"00_00_00_00",
+ 49 => x"00_00_00_00",
+ 50 => x"00_00_00_00",
+ 51 => x"00_00_00_00",
+ 52 => x"00_00_00_00",
+ 53 => x"00_00_00_00",
+ 54 => x"00_00_00_00",
+ 55 => x"00_00_00_00",
+ 56 => x"00_00_00_00",
+ 57 => x"00_00_00_00",
+ 58 => x"00_00_00_00",
+ 59 => x"00_00_00_00",
+ 60 => x"00_00_00_00",
+ 61 => x"00_00_00_00",
+ 62 => x"00_00_00_00",
+ 63 => x"00_00_00_00",
+ --##INPUT_VECTORS_2_GO_OVER_HERE##--
+ others => (others => '0'));
+ constant output_vectors_2 : vout_table := (
+ --##OUTPUT_VECTORS_2_GO_DOWN_HERE##--
+ 0 => x"ff",
+ 1 => x"00",
+ 2 => x"ff",
+ 3 => x"ff",
+ 4 => x"00",
+ 5 => x"00",
+ 6 => x"ff",
+ 7 => x"00",
+ 8 => x"ff",
+ 9 => x"00",
+ 10 => x"ff",
+ 11 => x"ff",
+ 12 => x"00",
+ 13 => x"00",
+ 14 => x"ff",
+ 15 => x"00",
+ 16 => x"ff",
+ 17 => x"00",
+ 18 => x"ff",
+ 19 => x"ff",
+ 20 => x"00",
+ 21 => x"00",
+ 22 => x"ff",
+ 23 => x"00",
+ 24 => x"ff",
+ 25 => x"00",
+ 26 => x"ff",
+ 27 => x"ff",
+ 28 => x"00",
+ 29 => x"00",
+ 30 => x"ff",
+ 31 => x"00",
+ 32 => x"ff",
+ 33 => x"00",
+ 34 => x"ff",
+ 35 => x"ff",
+ 36 => x"00",
+ 37 => x"00",
+ 38 => x"ff",
+ 39 => x"00",
+ 40 => x"ff",
+ 41 => x"00",
+ 42 => x"ff",
+ 43 => x"ff",
+ 44 => x"00",
+ 45 => x"00",
+ 46 => x"ff",
+ 47 => x"00",
+ 48 => x"ff",
+ 49 => x"00",
+ 50 => x"ff",
+ 51 => x"ff",
+ 52 => x"00",
+ 53 => x"00",
+ 54 => x"ff",
+ 55 => x"00",
+ 56 => x"ff",
+ 57 => x"00",
+ 58 => x"ff",
+ 59 => x"ff",
+ 60 => x"00",
+ 61 => x"00",
+ 62 => x"ff",
+ 63 => x"00",
+ --##OUTPUT_VECTORS_2_GO_OVER_HERE##--
+ others => (others => '0'));
+ signal in_vec_counter_1 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ signal in_vec_counter_2 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ signal out_vec_counter_1 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ signal out_vec_counter_2 : unsigned(VEC_NO_SIZE - 1 downto 0);
+
+ signal stdin_ack_sig : std_logic;
+ signal vector_read : std_logic;
+
+begin
+
+ feed : process(reset, clock) is
+ begin
+ if (reset = '1') then
+ in_vec_counter_1 <= (others => '0');
+ in_vec_counter_2 <= (others => '0');
+ stdin_data <= (others => '0');
+ stdin_ack_sig <= '0';
+ elsif rising_edge(clock) then
+ case context_uut is
+ when "01" =>
+ if (en_feed = '1') then
+ stdin_data <= input_vectors_1(to_integer(in_vec_counter_1));
+ stdin_ack_sig <= '1';
+ if (stdin_rdy = '1' and stdin_ack_sig = '1') then
+ in_vec_counter_1 <= in_vec_counter_1 + 1;
+ stdin_ack_sig <= '0';
+ end if;
+ else
+ --in_vec_counter_1 <= (others => '0');
+ stdin_data <= (others => '0');
+ stdin_ack_sig <= '0';
+ end if;
+ when "10" =>
+ if (en_feed = '1') then
+ stdin_data <= input_vectors_2(to_integer(in_vec_counter_2));
+ stdin_ack_sig <= '1';
+ if (stdin_rdy = '1' and stdin_ack_sig = '1') then
+ in_vec_counter_2 <= in_vec_counter_2 + 1;
+ stdin_ack_sig <= '0';
+ end if;
+ else
+ --in_vec_counter_2 <= (others => '0');
+ stdin_data <= (others => '0');
+ stdin_ack_sig <= '0';
+ end if;
+ when others =>
+ end case;
+ end if;
+ end process feed;
+
+ check : process(reset, clock) is
+ begin
+ if (reset = '1') then
+ n_error <= '1';
+ vec_read <= '0';
+ elsif rising_edge(clock) then
+ vec_read <= '0';
+ if (en_check = '1') then
+ if (stdout_rdy = '1') then
+ vec_read <= '1';
+ case context_uut is
+ when "01" =>
+ assert (stdout_data = output_vectors_1(to_integer(out_vec_counter_1)))
+ report "ERROR ---> Bad output vector found";
+ --synthesizable check
+ if (stdout_data /= output_vectors_1(to_integer(out_vec_counter_1))) then
+ n_error <= '0';
+ end if;
+ when "10" =>
+ assert (stdout_data = output_vectors_2(to_integer(out_vec_counter_2)))
+ report "ERROR ---> Bad output vector found";
+ --synthesizable check
+ if (stdout_data /= output_vectors_2(to_integer(out_vec_counter_2))) then
+ n_error <= '0';
+ end if;
+ when others =>
+ end case;
+ end if;
+ end if;
+ end if;
+ end process check;
+
+ read_counter : process(reset, clock) is
+ begin
+ if (reset = '1') then
+ out_vec_counter_1 <= (others => '0');
+ out_vec_counter_2 <= (others => '0');
+ elsif rising_edge(clock) then
+ if (en_check = '1') then
+ if (stdout_rdy = '1') then
+ case context_uut is
+ when "01" =>
+ out_vec_counter_1 <= out_vec_counter_1 + 1;
+ when "10" =>
+ out_vec_counter_2 <= out_vec_counter_2 + 1;
+ when others =>
+ end case;
+ end if;
+ --else
+ -- case context_uut is
+ -- when "01" =>
+ -- out_vec_counter_1 <= (others => '0');
+ -- when "10" =>
+ -- out_vec_counter_2 <= (others => '0');
+ -- when others =>
+ -- end case;
+ end if;
+ end if;
+ end process read_counter;
+
+ --asynchronous declarations
+ stdout_ack <= en_check;
+ stdin_ack <= stdin_ack_sig;
+ vecs_found <= '1' when (out_vec_counter_1 /= 0 or out_vec_counter_2 /= 0) else '0';
+
+end rtl;
diff --git a/testsuite/gna/issue50/idct.d/cmp_164.vhd b/testsuite/gna/issue50/idct.d/cmp_164.vhd
new file mode 100644
index 000000000..6dd5acada
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_164.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_164 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+end cmp_164;
+
+architecture augh of cmp_164 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_202.vhd b/testsuite/gna/issue50/idct.d/cmp_202.vhd
new file mode 100644
index 000000000..8383a0729
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_202.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_202 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+end cmp_202;
+
+architecture augh of cmp_202 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_203.vhd b/testsuite/gna/issue50/idct.d/cmp_203.vhd
new file mode 100644
index 000000000..6f04c559a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_203.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_203 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+end cmp_203;
+
+architecture augh of cmp_203 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_204.vhd b/testsuite/gna/issue50/idct.d/cmp_204.vhd
new file mode 100644
index 000000000..c601768d7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_204.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_204 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+end cmp_204;
+
+architecture augh of cmp_204 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_324.vhd b/testsuite/gna/issue50/idct.d/cmp_324.vhd
new file mode 100644
index 000000000..bc0921c90
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_324.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_324 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+end cmp_324;
+
+architecture augh of cmp_324 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_325.vhd b/testsuite/gna/issue50/idct.d/cmp_325.vhd
new file mode 100644
index 000000000..e21676dae
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_325.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_325 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+end cmp_325;
+
+architecture augh of cmp_325 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_392.vhd b/testsuite/gna/issue50/idct.d/cmp_392.vhd
new file mode 100644
index 000000000..77107d731
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_392.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_392 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(31 downto 0);
+ in1 : in std_logic_vector(31 downto 0)
+ );
+end cmp_392;
+
+architecture augh of cmp_392 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_396.vhd b/testsuite/gna/issue50/idct.d/cmp_396.vhd
new file mode 100644
index 000000000..44eec7bf9
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_396.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_396 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_396;
+
+architecture augh of cmp_396 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_398.vhd b/testsuite/gna/issue50/idct.d/cmp_398.vhd
new file mode 100644
index 000000000..8d63755bf
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_398.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_398 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_398;
+
+architecture augh of cmp_398 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_400.vhd b/testsuite/gna/issue50/idct.d/cmp_400.vhd
new file mode 100644
index 000000000..e2941af5a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_400.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_400 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_400;
+
+architecture augh of cmp_400 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_402.vhd b/testsuite/gna/issue50/idct.d/cmp_402.vhd
new file mode 100644
index 000000000..a86314c04
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_402.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_402 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_402;
+
+architecture augh of cmp_402 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_404.vhd b/testsuite/gna/issue50/idct.d/cmp_404.vhd
new file mode 100644
index 000000000..522f3cc95
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_404.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_404 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_404;
+
+architecture augh of cmp_404 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_406.vhd b/testsuite/gna/issue50/idct.d/cmp_406.vhd
new file mode 100644
index 000000000..38c07a5e7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_406.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_406 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_406;
+
+architecture augh of cmp_406 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_408.vhd b/testsuite/gna/issue50/idct.d/cmp_408.vhd
new file mode 100644
index 000000000..b45136077
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_408.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_408 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_408;
+
+architecture augh of cmp_408 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_410.vhd b/testsuite/gna/issue50/idct.d/cmp_410.vhd
new file mode 100644
index 000000000..5c0abafc4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_410.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_410 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_410;
+
+architecture augh of cmp_410 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_411.vhd b/testsuite/gna/issue50/idct.d/cmp_411.vhd
new file mode 100644
index 000000000..2d6c41656
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_411.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_411 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+end cmp_411;
+
+architecture augh of cmp_411 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_412.vhd b/testsuite/gna/issue50/idct.d/cmp_412.vhd
new file mode 100644
index 000000000..7b91164f3
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_412.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_412 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+end cmp_412;
+
+architecture augh of cmp_412 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cmp_413.vhd b/testsuite/gna/issue50/idct.d/cmp_413.vhd
new file mode 100644
index 000000000..997d10d8f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cmp_413.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_413 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(31 downto 0);
+ in1 : in std_logic_vector(31 downto 0)
+ );
+end cmp_413;
+
+architecture augh of cmp_413 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/cp3_test.vhd b/testsuite/gna/issue50/idct.d/cp3_test.vhd
new file mode 100644
index 000000000..99fdbb678
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/cp3_test.vhd
@@ -0,0 +1,280 @@
+-- written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+library work;
+use work.pkg_tb.all;
+
+entity cp3_test is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ n_error : out std_logic;
+ stopped : out std_logic
+ );
+end cp3_test;
+
+architecture rtl of cp3_test is
+
+ --TOP signals
+ signal reset_top : std_logic := '0';
+ signal stdin_data : stdin_vector;
+ signal stdin_rdy : std_logic;
+ signal stdin_ack : std_logic;
+ signal stdout_data : stdout_vector;
+ signal stdout_rdy : std_logic;
+ signal stdout_ack : std_logic;
+ --ASSERT_UNIT signals
+ signal context_uut : context_t;
+ signal en_feed : std_logic;
+ signal en_check : std_logic;
+ signal n_error_s : std_logic;
+ signal vecs_found : std_logic;
+ signal vec_read : std_logic;
+ --PROG unit signals
+ signal instr_next : instruction;
+ -- FSM unit signals
+ signal step : std_logic;
+ signal start : std_logic;
+ -- FSM signals
+ signal reset_fsm : std_logic;
+ signal stopped_s : std_logic;
+
+
+--------------------------------------
+-- PART OF ARCHITECTURE WITH CP3 --
+
+ --TOP signals
+ signal cp_en : std_logic := '0';
+ signal cp_rest : std_logic := '0';
+ signal cp_ok : std_logic;
+ signal cp_din : cp_vector := (others => '0');
+ signal cp_dout : cp_vector;
+ --RAM signals
+ signal ram_1 : ram_instruction;
+ signal ram_2 : ram_instruction;
+ signal address1 : std_logic_vector(12 downto 0) := (others => '0');
+ signal address2 : std_logic_vector(12 downto 0) := (others => '0');
+ signal datain : cp_vector := (others => '0');
+ signal dout1 : cp_vector;
+ signal dout2 : cp_vector;
+
+ --dut component declaration
+ component top is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ start : in std_logic;
+ stdin_data : in stdin_vector;
+ stdin_rdy : out std_logic;
+ stdin_ack : in std_logic;
+ stdout_data : out stdout_vector;
+ stdout_rdy : out std_logic;
+ stdout_ack : in std_logic;
+ cp_en : in std_logic;
+ cp_rest : in std_logic;
+ cp_din : in cp_vector;
+ cp_dout : out cp_vector;
+ cp_ok : out std_logic
+ );
+ end component top;
+
+begin
+
+ uut : entity work.top(augh)
+ port map(
+ clock => clock,
+ reset => reset_top,
+ start => start,
+ stdin_data => stdin_data,
+ stdin_rdy => stdin_rdy,
+ stdin_ack => stdin_ack,
+ cp_en => cp_en,
+ cp_rest => cp_rest,
+ cp_ok => cp_ok,
+ cp_din => cp_din,
+ cp_dout => cp_dout,
+ stdout_data => stdout_data,
+ stdout_rdy => stdout_rdy,
+ stdout_ack => stdout_ack
+ );
+
+ ram1 : entity work.sync_ram(rtl)
+ port map(
+ clock => clock,
+ we => ram_1.we,
+ address => address1,
+ datain => datain,
+ dataout => dout1
+ );
+
+ ram2 : entity work.sync_ram(rtl)
+ port map(
+ clock => clock,
+ we => ram_2.we,
+ address => address2,
+ datain => datain,
+ dataout => dout2
+ );
+
+ fsm_unit : entity work.fsm(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ --prog interface
+ instr_next => instr_next,
+ step => step,
+ --uut interface
+ cp_ok => cp_ok,
+ stdin_rdy => stdin_rdy,
+ stdin_ack => stdin_ack,
+ reset_fsm => reset_fsm,
+ start => start,
+ cp_en => cp_en,
+ cp_rest => cp_rest,
+ --ram interface
+ ram_1 => ram_1,
+ ram_2 => ram_2,
+ --assert_uut interface
+ context_uut => context_uut,
+ en_feed => en_feed,
+ en_check => en_check,
+ vecs_found => vecs_found,
+ vec_read => vec_read,
+ --tb interface
+ stopped => stopped_s
+ );
+
+ --RAM ADDRESS controller 1
+ ram_ctrl1 : process(clock, reset)
+ begin
+ if (reset = '1') then
+ address1 <= (others => '0');
+ elsif rising_edge(clock) then
+ if (ram_1.addr_z = '1') then
+ address1 <= (others => '0');
+ elsif (ram_1.addr_up = '1') then
+ address1 <= std_logic_vector(unsigned(address1) + 1);
+ end if;
+ end if;
+ end process ram_ctrl1;
+
+ --RAM ADDRESS controller 2
+ ram_ctrl2 : process(clock, reset)
+ begin
+ if (reset = '1') then
+ address2 <= (others => '0');
+ elsif rising_edge(clock) then
+ if (ram_2.addr_z = '1') then
+ address2 <= (others => '0');
+ elsif (ram_2.addr_up = '1') then
+ address2 <= std_logic_vector(unsigned(address2) + 1);
+ end if;
+ end if;
+ end process ram_ctrl2;
+
+ --other comb signals
+ datain <= cp_dout;
+ cp_din <= dout2 when ram_2.sel = '1' else dout1;
+
+-- END OF ARCHITECTURE WITH CP3 --
+--------------------------------------
+
+--------------------------------------
+-- PART OF ARCHITECTURE WITHOUT CP3 --
+--
+-- --dut component declaration
+-- component top is
+-- port (
+-- clock : in std_logic;
+-- reset : in std_logic;
+-- start : in std_logic;
+-- stdin_data : in stdin_vector;
+-- stdin_rdy : out std_logic;
+-- stdin_ack : in std_logic;
+-- stdout_data : out stdout_vector;
+-- stdout_rdy : out std_logic;
+-- stdout_ack : in std_logic
+-- );
+-- end component top;
+--
+--begin
+--
+-- uut : entity work.top(augh)
+-- port map(
+-- clock => clock,
+-- reset => reset_top,
+-- start => start,
+-- stdin_data => stdin_data,
+-- stdin_rdy => stdin_rdy,
+-- stdin_ack => stdin_ack,
+-- stdout_data => stdout_data,
+-- stdout_rdy => stdout_rdy,
+-- stdout_ack => stdout_ack
+-- );
+--
+-- fsm_unit : entity work.fsm(rtl)
+-- port map(
+-- clock => clock,
+-- reset => reset,
+-- --prog interface
+-- instr_next => instr_next,
+-- step => step,
+-- --uut interface
+-- cp_ok => '0',
+-- stdin_rdy => stdin_rdy,
+-- stdin_ack => stdin_ack,
+-- reset_fsm => reset_fsm,
+-- start => start,
+-- cp_en => open,
+-- cp_rest => open,
+-- --ram interface
+-- ram_1 => open,
+-- ram_2 => open,
+-- --assert_uut interface
+-- context_uut => context_uut,
+-- en_feed => en_feed,
+-- en_check => en_check,
+-- vecs_found => vecs_found,
+-- vec_read => vec_read,
+-- --tb interface
+-- stopped => stopped_s
+-- );
+--
+-- END OF ARCHITECTURE WITHOUT CP3 --
+--------------------------------------
+
+ assert_unit : entity work.assert_uut(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ context_uut => context_uut,
+ en_feed => en_feed,
+ stdin_rdy => stdin_rdy,
+ stdin_ack => stdin_ack,
+ stdin_data => stdin_data,
+ en_check => en_check,
+ stdout_rdy => stdout_rdy,
+ stdout_ack => stdout_ack,
+ stdout_data => stdout_data,
+ vecs_found => vecs_found,
+ vec_read => vec_read,
+ n_error => n_error_s
+ );
+
+ prog_unit : entity work.prog(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ step => step,
+ instr_next => instr_next
+ );
+
+ --other comb signals
+ reset_top <= reset or reset_fsm;
+
+ --outputs
+ n_error <= n_error_s;
+ stopped <= stopped_s;
+
+end rtl;
diff --git a/testsuite/gna/issue50/idct.d/fsm.vhd b/testsuite/gna/issue50/idct.d/fsm.vhd
new file mode 100644
index 000000000..2f4ef87ee
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/fsm.vhd
@@ -0,0 +1,396 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+use std.textio.all;
+library work;
+use work.pkg_tb.all;
+
+entity fsm is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ --prog interface
+ instr_next : in instruction;
+ step : out std_logic;
+ --uut interface
+ cp_ok : in std_logic;
+ stdin_rdy : in std_logic;
+ stdin_ack : in std_logic;
+ reset_fsm : out std_logic;
+ start : out std_logic;
+ cp_en : out std_logic;
+ cp_rest : out std_logic;
+ --ram interface
+ ram_1 : out ram_instruction;
+ ram_2 : out ram_instruction;
+ --assert_uut interface
+ context_uut : out context_t;
+ en_feed : out std_logic;
+ en_check : out std_logic;
+ vecs_found : in std_logic;
+ vec_read : in std_logic;
+ --tb interface
+ stopped : out std_logic
+ );
+end fsm;
+
+architecture rtl of fsm is
+
+ -- read output
+ signal step_sig : std_logic;
+ -- FSM signals
+ signal instr_c : instruction := instr_rst;
+ signal instr_n : instruction := instr_rst;
+ -- TIMER signal
+ signal times_en : std_logic := '0';
+ signal times_z : std_logic := '0';
+ signal times : unsigned(ARG_WIDTH - 1 downto 0);
+ signal times_max : unsigned(ARG_WIDTH - 1 downto 0);
+ signal times_ok : std_logic := '0';
+ -- COUNTER signal
+ signal count_en : std_logic := '0';
+ signal count_z : std_logic := '0';
+ signal count : unsigned(ARG_WIDTH - 1 downto 0);
+ signal count_max : unsigned(ARG_WIDTH - 1 downto 0);
+ signal count_ok : std_logic := '0';
+ -- runtime counter
+ signal runtime_en : std_logic := '0';
+ signal runtime : integer range 0 to 99999999; --100 million cycles
+
+begin
+
+ -- FSM
+ state_reg : process (clock, reset) is
+ begin
+ if (reset = '1') then
+ instr_c <= instr_rst;
+ elsif rising_edge(clock) then
+ instr_c <= instr_n;
+ end if;
+ end process state_reg;
+
+ comb_logic: process(instr_next, instr_c, stdin_rdy, count_ok, times_ok, cp_ok, stdin_ack, vecs_found, vec_read)
+ begin
+ --default definition for fsm control signals
+ instr_n <= instr_rst;
+ step_sig <= '0';
+ --top
+ reset_fsm <= '0';
+ start <= '0';
+ cp_en <= '0';
+ cp_rest <= '0';
+ --counter & timer
+ times_en <= '0';
+ times_max <= (others => '0');
+ count_en <= '0';
+ count_max <= (others => '0');
+ --runtime counter
+ runtime_en <= '0';
+ --ram
+ ram_1 <= ram_instr_z;
+ ram_2 <= ram_instr_z;
+ --assert_uut
+ en_feed <= '0';
+ en_check <= '0';
+ --tb interface
+ stopped <= '0';
+
+ case instr_c.state is
+ when Rst =>
+ --signals
+ reset_fsm <= '1';
+ ram_1.addr_z <= '1';
+ ram_2.addr_z <= '1';
+ step_sig <= '1'; --demand for next instruction
+ --transition
+ instr_n <= instr_next;
+
+ when Sig_start =>
+ --signals
+ start <= '1';
+ step_sig <= '1'; --demand for next instruction
+ --transition
+ instr_n <= instr_next;
+ --if (instr_next.state = Ack_data) then
+ --en_feed <= '1';
+ --end if;
+
+ when Ack_data =>
+ times_max <= instr_c.arg - 1;
+ --signals
+ en_feed <= '1';
+ --transition
+ if (stdin_rdy = '1' and stdin_ack = '1') then
+ times_en <= '1';
+ end if;
+ if (times_ok = '1') then
+ en_feed <= '0';
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Running =>
+ --signals
+ count_max <= instr_c.arg;
+ count_en <= '1';
+ --en_check <= '1';
+ --runtime counter
+ if(vecs_found = '0') then
+ runtime_en <= '1';
+ end if;
+ --transition
+ if (count_ok = '1') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Waitfor =>
+ --signals
+ count_max <= instr_c.arg;
+ en_check <= '1';
+ if(vec_read = '1') then
+ count_en <= '1';
+ end if;
+ --runtime counter
+ if(vecs_found = '0') then
+ runtime_en <= '1';
+ end if;
+ --transition
+ if (count_ok = '1') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Cp_search =>
+ --signals
+ cp_en <= '1';
+ --transition
+ if (cp_ok = '1') then
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.we <= '1';
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.we <= '1';
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ instr_n <= (state => Cp_save, context_uut => instr_c.context_uut, arg => (others => '0')); --hard coded
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Cp_save =>
+ --signals
+ cp_en <= '1';
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.we <= '1';
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.we <= '1';
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ if (cp_ok = '0') then
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.we <= '0';
+ ram_1.addr_up <= '0';
+ when "10" =>
+ ram_2.we <= '0';
+ ram_2.addr_up <= '0';
+ when others =>
+ end case;
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Idle =>
+ --signals
+ count_max <= instr_c.arg;
+ count_en <= '1';
+ --transition
+ if (count_ok = '1') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Rst_uut =>
+ --signals
+ reset_fsm <= '1';
+ ram_1.addr_z <= '1';
+ ram_2.addr_z <= '1';
+ --transition
+ step_sig <= '1';
+ instr_n <= instr_next;
+
+ when Rest_ini0 =>
+ --signals
+ start <= '1';
+ cp_en <= '1';
+ cp_rest <= '1';
+ --this is for restoration : reading the first word of the right memory
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ instr_n <= (state => Rest_ini1, context_uut => instr_c.context_uut, arg => (others => '0')); --hard coded
+
+ when Rest_ini1 =>
+ --signals
+ cp_en <= '1';
+ cp_rest <= '1';
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ instr_n <= (state => Rest, context_uut => instr_c.context_uut, arg => (others => '0')); --hard coded
+
+ when Rest =>
+ --signals
+ cp_en <= '1';
+ cp_rest <= '1';
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ if (cp_ok = '0') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Stop =>
+ --signals
+ stopped <= '1';
+ reset_fsm <= '1';
+ report "RUNTIME:" & integer'image(runtime);
+ assert (vecs_found = '0')
+ report "END_OF_SIM ---> Stop state reached, some output vectors were read." severity note;
+ --transition
+ instr_n <= (state => Stop, context_uut => "00", arg => (others => '0')); --hard coded
+
+ when others =>
+ end case;
+ end process comb_logic;
+
+ --*ER reset combo logic
+ --if a step_sig signal is sent, it means a instr_next will be consumed
+ reseter : process(step_sig)
+ begin
+ if (step_sig = '0') then
+ times_z <= '0';
+ count_z <= '0';
+ else
+ times_z <= '1';
+ count_z <= '1';
+ end if;
+ end process reseter;
+
+ --TIMER
+ timer : process(clock, reset)
+ begin
+ if (reset = '1') then
+ times <= (others => '0');
+ times_ok <= '0';
+ elsif rising_edge(clock) then
+ if (times_z = '1') then
+ times <= (others => '0');
+ times_ok <= '0';
+ else
+ if (times_en = '1') then
+ times <= times + 1;
+ if (times = times_max) then
+ times_ok <= '1';
+ else
+ times_ok <= '0';
+ end if;
+ end if;
+ end if;
+ end if;
+ end process timer;
+
+ --COUNTER
+ counter : process(clock, reset)
+ begin
+ if (reset = '1') then
+ count <= (others => '0');
+ count_ok <= '0';
+ elsif rising_edge(clock) then
+ --count_ok driving if
+ if (count_z = '1') then
+ count_ok <= '0';
+ count <= (others => '0');
+ else
+ if (count = count_max) then
+ count_ok <= '1';
+ else
+ count_ok <= '0';
+ if (count_en = '1') then
+ count <= count + 1;
+ end if;
+ end if;
+ end if;
+ end if;
+ end process counter;
+
+ --Runtime counter
+ runtime_counter : process(clock, reset)
+ begin
+ if (reset = '1') then
+ runtime <= 0;
+ elsif rising_edge(clock) then
+ if (runtime_en = '1') then
+ runtime <= runtime + 1;
+ if ((runtime mod 1000) = 0) then
+ report "Running since:" & integer'image(runtime) severity note;
+ end if;
+ end if;
+ end if;
+ end process runtime_counter;
+
+ -- process only used for reporting current instruction
+ reporter : process(instr_c)
+ begin
+ --report "Instruction: " & state_t'image(instr_c.state) severity note;
+ report "Instruction: " & state_t'image(instr_c.state) & " (context " & integer'image(to_integer(unsigned(instr_c.context_uut))) & ")" severity note;
+ end process reporter;
+
+ --Combinational
+ step <= step_sig;
+ context_uut <= instr_c.context_uut;
+end rtl;
diff --git a/testsuite/gna/issue50/idct.d/fsm_23.vhd b/testsuite/gna/issue50/idct.d/fsm_23.vhd
new file mode 100644
index 000000000..f5285a45b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/fsm_23.vhd
@@ -0,0 +1,4853 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity fsm_23 is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ in0 : in std_logic;
+ out181 : out std_logic;
+ out182 : out std_logic;
+ out183 : out std_logic;
+ out184 : out std_logic;
+ out185 : out std_logic;
+ out8 : out std_logic;
+ out13 : out std_logic;
+ out14 : out std_logic;
+ out16 : out std_logic;
+ out18 : out std_logic;
+ out19 : out std_logic;
+ out20 : out std_logic;
+ out21 : out std_logic;
+ out22 : out std_logic;
+ in2 : in std_logic;
+ out23 : out std_logic;
+ out24 : out std_logic;
+ out25 : out std_logic;
+ out26 : out std_logic;
+ out27 : out std_logic;
+ out28 : out std_logic;
+ out29 : out std_logic;
+ out30 : out std_logic;
+ out31 : out std_logic;
+ out33 : out std_logic;
+ out35 : out std_logic;
+ out36 : out std_logic;
+ out38 : out std_logic;
+ out40 : out std_logic;
+ out42 : out std_logic;
+ in3 : in std_logic;
+ out44 : out std_logic;
+ out46 : out std_logic;
+ out48 : out std_logic;
+ out49 : out std_logic;
+ out50 : out std_logic;
+ out52 : out std_logic;
+ out54 : out std_logic;
+ out56 : out std_logic;
+ out57 : out std_logic;
+ out58 : out std_logic;
+ in4 : in std_logic;
+ out60 : out std_logic;
+ in5 : in std_logic;
+ out164 : out std_logic;
+ out165 : out std_logic;
+ out167 : out std_logic;
+ out168 : out std_logic;
+ out170 : out std_logic;
+ out171 : out std_logic;
+ out173 : out std_logic;
+ out174 : out std_logic;
+ out176 : out std_logic;
+ out178 : out std_logic;
+ out0 : out std_logic;
+ out1 : out std_logic;
+ out2 : out std_logic;
+ in1 : in std_logic;
+ out4 : out std_logic;
+ out90 : out std_logic;
+ out91 : out std_logic;
+ out97 : out std_logic;
+ out99 : out std_logic;
+ out101 : out std_logic;
+ in6 : in std_logic;
+ out103 : out std_logic;
+ out105 : out std_logic;
+ out106 : out std_logic;
+ out107 : out std_logic;
+ out108 : out std_logic;
+ out135 : out std_logic;
+ out136 : out std_logic;
+ out137 : out std_logic;
+ out138 : out std_logic;
+ in11 : in std_logic;
+ out140 : out std_logic;
+ out141 : out std_logic;
+ out142 : out std_logic;
+ out143 : out std_logic;
+ out145 : out std_logic;
+ out146 : out std_logic;
+ out148 : out std_logic;
+ out150 : out std_logic;
+ out153 : out std_logic;
+ out154 : out std_logic;
+ out155 : out std_logic;
+ out156 : out std_logic;
+ out157 : out std_logic;
+ out158 : out std_logic;
+ out159 : out std_logic;
+ out160 : out std_logic;
+ out161 : out std_logic;
+ out162 : out std_logic;
+ out111 : out std_logic;
+ out112 : out std_logic;
+ out114 : out std_logic;
+ out116 : out std_logic;
+ out118 : out std_logic;
+ out120 : out std_logic;
+ out121 : out std_logic;
+ out122 : out std_logic;
+ out123 : out std_logic;
+ out124 : out std_logic;
+ out125 : out std_logic;
+ out126 : out std_logic;
+ in7 : in std_logic;
+ out129 : out std_logic;
+ out130 : out std_logic;
+ in8 : in std_logic;
+ out131 : out std_logic;
+ in9 : in std_logic;
+ out132 : out std_logic;
+ out133 : out std_logic;
+ out134 : out std_logic;
+ in10 : in std_logic;
+ out186 : out std_logic;
+ out187 : out std_logic;
+ out190 : out std_logic;
+ out195 : out std_logic;
+ out197 : out std_logic;
+ out198 : out std_logic;
+ out199 : out std_logic;
+ out200 : out std_logic;
+ out201 : out std_logic;
+ out203 : out std_logic;
+ out204 : out std_logic;
+ out206 : out std_logic;
+ out207 : out std_logic;
+ out209 : out std_logic;
+ out210 : out std_logic;
+ out212 : out std_logic;
+ out213 : out std_logic;
+ out215 : out std_logic;
+ out217 : out std_logic;
+ out220 : out std_logic;
+ out221 : out std_logic;
+ out222 : out std_logic;
+ out223 : out std_logic;
+ out224 : out std_logic;
+ out225 : out std_logic;
+ out226 : out std_logic;
+ out227 : out std_logic;
+ out228 : out std_logic;
+ out229 : out std_logic;
+ out231 : out std_logic;
+ out232 : out std_logic;
+ out234 : out std_logic;
+ out235 : out std_logic;
+ out237 : out std_logic;
+ out238 : out std_logic;
+ out240 : out std_logic;
+ out241 : out std_logic;
+ out243 : out std_logic;
+ out245 : out std_logic;
+ out248 : out std_logic;
+ out249 : out std_logic;
+ out250 : out std_logic;
+ out251 : out std_logic;
+ out252 : out std_logic;
+ out253 : out std_logic;
+ out254 : out std_logic;
+ out255 : out std_logic;
+ out256 : out std_logic;
+ out257 : out std_logic;
+ out259 : out std_logic;
+ out260 : out std_logic;
+ out262 : out std_logic;
+ out263 : out std_logic;
+ out265 : out std_logic;
+ out266 : out std_logic;
+ out268 : out std_logic;
+ out269 : out std_logic;
+ out271 : out std_logic;
+ out273 : out std_logic;
+ out276 : out std_logic;
+ out277 : out std_logic;
+ out278 : out std_logic;
+ out279 : out std_logic;
+ out280 : out std_logic;
+ out281 : out std_logic;
+ out282 : out std_logic;
+ out283 : out std_logic;
+ out284 : out std_logic;
+ out285 : out std_logic;
+ out286 : out std_logic;
+ out287 : out std_logic;
+ out288 : out std_logic;
+ out289 : out std_logic;
+ out290 : out std_logic;
+ out291 : out std_logic;
+ out292 : out std_logic;
+ out293 : out std_logic;
+ out294 : out std_logic;
+ out295 : out std_logic;
+ out296 : out std_logic;
+ out297 : out std_logic;
+ out298 : out std_logic;
+ out311 : out std_logic;
+ out312 : out std_logic;
+ out313 : out std_logic;
+ out314 : out std_logic;
+ out315 : out std_logic;
+ out316 : out std_logic;
+ out318 : out std_logic;
+ out321 : out std_logic;
+ out322 : out std_logic;
+ out323 : out std_logic;
+ out324 : out std_logic;
+ out325 : out std_logic;
+ out326 : out std_logic;
+ out327 : out std_logic;
+ out328 : out std_logic;
+ out329 : out std_logic;
+ out333 : out std_logic;
+ out341 : out std_logic;
+ out342 : out std_logic;
+ out343 : out std_logic;
+ out344 : out std_logic;
+ out345 : out std_logic;
+ out346 : out std_logic;
+ out349 : out std_logic;
+ out350 : out std_logic;
+ out351 : out std_logic;
+ out352 : out std_logic;
+ out353 : out std_logic;
+ out354 : out std_logic;
+ out355 : out std_logic;
+ out357 : out std_logic;
+ out361 : out std_logic;
+ out362 : out std_logic;
+ out363 : out std_logic;
+ out364 : out std_logic;
+ out366 : out std_logic;
+ out367 : out std_logic;
+ out371 : out std_logic;
+ out372 : out std_logic;
+ out373 : out std_logic;
+ out382 : out std_logic;
+ out383 : out std_logic;
+ out385 : out std_logic;
+ out393 : out std_logic;
+ out394 : out std_logic;
+ out395 : out std_logic;
+ out396 : out std_logic;
+ out398 : out std_logic;
+ out400 : out std_logic;
+ out401 : out std_logic;
+ out402 : out std_logic;
+ out404 : out std_logic;
+ out406 : out std_logic;
+ out407 : out std_logic;
+ out408 : out std_logic;
+ out409 : out std_logic;
+ out410 : out std_logic;
+ out411 : out std_logic;
+ out412 : out std_logic;
+ out413 : out std_logic;
+ out414 : out std_logic;
+ out416 : out std_logic;
+ out417 : out std_logic;
+ out418 : out std_logic;
+ out419 : out std_logic;
+ out422 : out std_logic;
+ out423 : out std_logic;
+ out425 : out std_logic;
+ out426 : out std_logic;
+ out428 : out std_logic;
+ out429 : out std_logic;
+ out430 : out std_logic;
+ out431 : out std_logic;
+ out433 : out std_logic;
+ out434 : out std_logic;
+ out435 : out std_logic;
+ out436 : out std_logic;
+ out437 : out std_logic;
+ out438 : out std_logic;
+ out440 : out std_logic;
+ out441 : out std_logic;
+ out443 : out std_logic;
+ out444 : out std_logic;
+ out445 : out std_logic;
+ out446 : out std_logic;
+ out447 : out std_logic;
+ out450 : out std_logic;
+ out451 : out std_logic;
+ out454 : out std_logic;
+ out455 : out std_logic;
+ out457 : out std_logic;
+ out458 : out std_logic;
+ out459 : out std_logic;
+ out460 : out std_logic;
+ out461 : out std_logic;
+ out462 : out std_logic;
+ out463 : out std_logic;
+ out464 : out std_logic;
+ out465 : out std_logic;
+ out466 : out std_logic;
+ out467 : out std_logic;
+ out468 : out std_logic;
+ out469 : out std_logic;
+ out472 : out std_logic;
+ out475 : out std_logic;
+ out481 : out std_logic;
+ out482 : out std_logic;
+ out483 : out std_logic;
+ out484 : out std_logic;
+ out487 : out std_logic;
+ out488 : out std_logic;
+ out491 : out std_logic;
+ out495 : out std_logic;
+ out496 : out std_logic;
+ out497 : out std_logic;
+ out498 : out std_logic;
+ out499 : out std_logic;
+ out500 : out std_logic;
+ out501 : out std_logic;
+ out512 : out std_logic;
+ out513 : out std_logic;
+ out517 : out std_logic;
+ out518 : out std_logic;
+ out519 : out std_logic;
+ out521 : out std_logic;
+ out522 : out std_logic;
+ out524 : out std_logic;
+ out525 : out std_logic;
+ out526 : out std_logic;
+ out527 : out std_logic;
+ out528 : out std_logic;
+ out531 : out std_logic;
+ out540 : out std_logic;
+ out542 : out std_logic;
+ out544 : out std_logic;
+ out545 : out std_logic;
+ out554 : out std_logic;
+ out555 : out std_logic;
+ out559 : out std_logic;
+ out560 : out std_logic;
+ out561 : out std_logic;
+ out562 : out std_logic;
+ out563 : out std_logic;
+ out566 : out std_logic;
+ out567 : out std_logic;
+ out570 : out std_logic;
+ out572 : out std_logic;
+ out575 : out std_logic;
+ out577 : out std_logic;
+ out578 : out std_logic;
+ out580 : out std_logic;
+ out581 : out std_logic
+ );
+end fsm_23;
+
+architecture augh of fsm_23 is
+
+ signal state_cur : std_logic_vector(0 to 240) := (7 => '1', others => '0');
+ signal state_next : std_logic_vector(0 to 240) := (7 => '1', others => '0');
+
+ -- Buffers for outputs
+ signal out122_buf : std_logic := '0';
+ signal out122_bufn : std_logic;
+ signal out36_buf : std_logic := '0';
+ signal out36_bufn : std_logic;
+ signal out49_buf : std_logic := '0';
+ signal out49_bufn : std_logic;
+ signal out35_buf : std_logic := '0';
+ signal out35_bufn : std_logic;
+ signal out27_buf : std_logic := '0';
+ signal out27_bufn : std_logic;
+ signal out16_buf : std_logic := '0';
+ signal out16_bufn : std_logic;
+ signal out25_buf : std_logic := '0';
+ signal out25_bufn : std_logic;
+ signal out20_buf : std_logic := '0';
+ signal out20_bufn : std_logic;
+ signal out57_buf : std_logic := '0';
+ signal out57_bufn : std_logic;
+ signal out23_buf : std_logic := '0';
+ signal out23_bufn : std_logic;
+ signal out136_buf : std_logic := '0';
+ signal out136_bufn : std_logic;
+ signal out0_buf : std_logic := '0';
+ signal out0_bufn : std_logic;
+ signal out134_buf : std_logic := '0';
+ signal out134_bufn : std_logic;
+ signal out13_buf : std_logic := '0';
+ signal out13_bufn : std_logic;
+ signal out131_buf : std_logic := '0';
+ signal out131_bufn : std_logic;
+ signal out129_buf : std_logic := '0';
+ signal out129_bufn : std_logic;
+ signal out111_buf : std_logic := '0';
+ signal out111_bufn : std_logic;
+ signal out31_buf : std_logic := '0';
+ signal out31_bufn : std_logic;
+ signal out126_buf : std_logic := '0';
+ signal out126_bufn : std_logic;
+ signal out106_buf : std_logic := '0';
+ signal out106_bufn : std_logic;
+ signal out124_buf : std_logic := '0';
+ signal out124_bufn : std_logic;
+ signal out138_buf : std_logic := '0';
+ signal out138_bufn : std_logic;
+ signal out141_buf : std_logic := '0';
+ signal out141_bufn : std_logic;
+ signal out143_buf : std_logic := '0';
+ signal out143_bufn : std_logic;
+ signal out146_buf : std_logic := '0';
+ signal out146_bufn : std_logic;
+ signal out150_buf : std_logic := '0';
+ signal out150_bufn : std_logic;
+ signal out153_buf : std_logic := '0';
+ signal out153_bufn : std_logic;
+ signal out155_buf : std_logic := '0';
+ signal out155_bufn : std_logic;
+ signal out158_buf : std_logic := '0';
+ signal out158_bufn : std_logic;
+ signal out162_buf : std_logic := '0';
+ signal out162_bufn : std_logic;
+ signal out165_buf : std_logic := '0';
+ signal out165_bufn : std_logic;
+ signal out168_buf : std_logic := '0';
+ signal out168_bufn : std_logic;
+ signal out171_buf : std_logic := '0';
+ signal out171_bufn : std_logic;
+ signal out174_buf : std_logic := '0';
+ signal out174_bufn : std_logic;
+ signal out178_buf : std_logic := '0';
+ signal out178_bufn : std_logic;
+ signal out181_buf : std_logic := '0';
+ signal out181_bufn : std_logic;
+ signal out183_buf : std_logic := '0';
+ signal out183_bufn : std_logic;
+ signal out197_buf : std_logic := '0';
+ signal out197_bufn : std_logic;
+ signal out201_buf : std_logic := '0';
+ signal out201_bufn : std_logic;
+ signal out204_buf : std_logic := '0';
+ signal out204_bufn : std_logic;
+ signal out207_buf : std_logic := '0';
+ signal out207_bufn : std_logic;
+ signal out210_buf : std_logic := '0';
+ signal out210_bufn : std_logic;
+ signal out213_buf : std_logic := '0';
+ signal out213_bufn : std_logic;
+ signal out217_buf : std_logic := '0';
+ signal out217_bufn : std_logic;
+ signal out220_buf : std_logic := '0';
+ signal out220_bufn : std_logic;
+ signal out222_buf : std_logic := '0';
+ signal out222_bufn : std_logic;
+ signal out225_buf : std_logic := '0';
+ signal out225_bufn : std_logic;
+ signal out229_buf : std_logic := '0';
+ signal out229_bufn : std_logic;
+ signal out232_buf : std_logic := '0';
+ signal out232_bufn : std_logic;
+ signal out235_buf : std_logic := '0';
+ signal out235_bufn : std_logic;
+ signal out238_buf : std_logic := '0';
+ signal out238_bufn : std_logic;
+ signal out241_buf : std_logic := '0';
+ signal out241_bufn : std_logic;
+ signal out245_buf : std_logic := '0';
+ signal out245_bufn : std_logic;
+ signal out248_buf : std_logic := '0';
+ signal out248_bufn : std_logic;
+ signal out250_buf : std_logic := '0';
+ signal out250_bufn : std_logic;
+ signal out253_buf : std_logic := '0';
+ signal out253_bufn : std_logic;
+ signal out257_buf : std_logic := '0';
+ signal out257_bufn : std_logic;
+ signal out260_buf : std_logic := '0';
+ signal out260_bufn : std_logic;
+ signal out263_buf : std_logic := '0';
+ signal out263_bufn : std_logic;
+ signal out266_buf : std_logic := '0';
+ signal out266_bufn : std_logic;
+ signal out269_buf : std_logic := '0';
+ signal out269_bufn : std_logic;
+ signal out273_buf : std_logic := '0';
+ signal out273_bufn : std_logic;
+ signal out276_buf : std_logic := '0';
+ signal out276_bufn : std_logic;
+ signal out278_buf : std_logic := '0';
+ signal out278_bufn : std_logic;
+ signal out280_buf : std_logic := '0';
+ signal out280_bufn : std_logic;
+ signal out281_buf : std_logic := '0';
+ signal out281_bufn : std_logic;
+ signal out282_buf : std_logic := '0';
+ signal out282_bufn : std_logic;
+ signal out284_buf : std_logic := '0';
+ signal out284_bufn : std_logic;
+ signal out285_buf : std_logic := '0';
+ signal out285_bufn : std_logic;
+ signal out287_buf : std_logic := '0';
+ signal out287_bufn : std_logic;
+ signal out288_buf : std_logic := '0';
+ signal out288_bufn : std_logic;
+ signal out289_buf : std_logic := '0';
+ signal out289_bufn : std_logic;
+ signal out290_buf : std_logic := '0';
+ signal out290_bufn : std_logic;
+ signal out291_buf : std_logic := '0';
+ signal out291_bufn : std_logic;
+ signal out292_buf : std_logic := '0';
+ signal out292_bufn : std_logic;
+ signal out293_buf : std_logic := '0';
+ signal out293_bufn : std_logic;
+ signal out294_buf : std_logic := '0';
+ signal out294_bufn : std_logic;
+ signal out295_buf : std_logic := '0';
+ signal out295_bufn : std_logic;
+ signal out296_buf : std_logic := '0';
+ signal out296_bufn : std_logic;
+ signal out312_buf : std_logic := '0';
+ signal out312_bufn : std_logic;
+ signal out313_buf : std_logic := '0';
+ signal out313_bufn : std_logic;
+ signal out314_buf : std_logic := '0';
+ signal out314_bufn : std_logic;
+ signal out315_buf : std_logic := '0';
+ signal out315_bufn : std_logic;
+ signal out318_buf : std_logic := '0';
+ signal out318_bufn : std_logic;
+ signal out322_buf : std_logic := '0';
+ signal out322_bufn : std_logic;
+ signal out323_buf : std_logic := '0';
+ signal out323_bufn : std_logic;
+ signal out324_buf : std_logic := '0';
+ signal out324_bufn : std_logic;
+ signal out325_buf : std_logic := '0';
+ signal out325_bufn : std_logic;
+ signal out326_buf : std_logic := '0';
+ signal out326_bufn : std_logic;
+ signal out327_buf : std_logic := '0';
+ signal out327_bufn : std_logic;
+ signal out328_buf : std_logic := '0';
+ signal out328_bufn : std_logic;
+ signal out333_buf : std_logic := '0';
+ signal out333_bufn : std_logic;
+ signal out341_buf : std_logic := '0';
+ signal out341_bufn : std_logic;
+ signal out342_buf : std_logic := '0';
+ signal out342_bufn : std_logic;
+ signal out343_buf : std_logic := '0';
+ signal out343_bufn : std_logic;
+ signal out344_buf : std_logic := '0';
+ signal out344_bufn : std_logic;
+ signal out346_buf : std_logic := '0';
+ signal out346_bufn : std_logic;
+ signal out349_buf : std_logic := '0';
+ signal out349_bufn : std_logic;
+ signal out351_buf : std_logic := '0';
+ signal out351_bufn : std_logic;
+ signal out352_buf : std_logic := '0';
+ signal out352_bufn : std_logic;
+ signal out353_buf : std_logic := '0';
+ signal out353_bufn : std_logic;
+ signal out354_buf : std_logic := '0';
+ signal out354_bufn : std_logic;
+ signal out357_buf : std_logic := '0';
+ signal out357_bufn : std_logic;
+ signal out361_buf : std_logic := '0';
+ signal out361_bufn : std_logic;
+ signal out364_buf : std_logic := '0';
+ signal out364_bufn : std_logic;
+ signal out366_buf : std_logic := '0';
+ signal out366_bufn : std_logic;
+ signal out371_buf : std_logic := '0';
+ signal out371_bufn : std_logic;
+ signal out393_buf : std_logic := '0';
+ signal out393_bufn : std_logic;
+ signal out394_buf : std_logic := '0';
+ signal out394_bufn : std_logic;
+ signal out395_buf : std_logic := '0';
+ signal out395_bufn : std_logic;
+ signal out400_buf : std_logic := '0';
+ signal out400_bufn : std_logic;
+ signal out401_buf : std_logic := '0';
+ signal out401_bufn : std_logic;
+ signal out404_buf : std_logic := '0';
+ signal out404_bufn : std_logic;
+ signal out407_buf : std_logic := '0';
+ signal out407_bufn : std_logic;
+ signal out408_buf : std_logic := '0';
+ signal out408_bufn : std_logic;
+ signal out409_buf : std_logic := '0';
+ signal out409_bufn : std_logic;
+ signal out410_buf : std_logic := '0';
+ signal out410_bufn : std_logic;
+ signal out413_buf : std_logic := '0';
+ signal out413_bufn : std_logic;
+ signal out414_buf : std_logic := '0';
+ signal out414_bufn : std_logic;
+ signal out417_buf : std_logic := '0';
+ signal out417_bufn : std_logic;
+ signal out418_buf : std_logic := '0';
+ signal out418_bufn : std_logic;
+ signal out422_buf : std_logic := '0';
+ signal out422_bufn : std_logic;
+ signal out426_buf : std_logic := '0';
+ signal out426_bufn : std_logic;
+ signal out428_buf : std_logic := '0';
+ signal out428_bufn : std_logic;
+ signal out431_buf : std_logic := '0';
+ signal out431_bufn : std_logic;
+ signal out433_buf : std_logic := '0';
+ signal out433_bufn : std_logic;
+ signal out434_buf : std_logic := '0';
+ signal out434_bufn : std_logic;
+ signal out435_buf : std_logic := '0';
+ signal out435_bufn : std_logic;
+ signal out436_buf : std_logic := '0';
+ signal out436_bufn : std_logic;
+ signal out437_buf : std_logic := '0';
+ signal out437_bufn : std_logic;
+ signal out438_buf : std_logic := '0';
+ signal out438_bufn : std_logic;
+ signal out440_buf : std_logic := '0';
+ signal out440_bufn : std_logic;
+ signal out444_buf : std_logic := '0';
+ signal out444_bufn : std_logic;
+ signal out446_buf : std_logic := '0';
+ signal out446_bufn : std_logic;
+ signal out451_buf : std_logic := '0';
+ signal out451_bufn : std_logic;
+ signal out457_buf : std_logic := '0';
+ signal out457_bufn : std_logic;
+ signal out458_buf : std_logic := '0';
+ signal out458_bufn : std_logic;
+ signal out459_buf : std_logic := '0';
+ signal out459_bufn : std_logic;
+ signal out460_buf : std_logic := '0';
+ signal out460_bufn : std_logic;
+ signal out461_buf : std_logic := '0';
+ signal out461_bufn : std_logic;
+ signal out463_buf : std_logic := '0';
+ signal out463_bufn : std_logic;
+ signal out464_buf : std_logic := '0';
+ signal out464_bufn : std_logic;
+ signal out466_buf : std_logic := '0';
+ signal out466_bufn : std_logic;
+ signal out468_buf : std_logic := '0';
+ signal out468_bufn : std_logic;
+ signal out472_buf : std_logic := '0';
+ signal out472_bufn : std_logic;
+ signal out475_buf : std_logic := '0';
+ signal out475_bufn : std_logic;
+ signal out481_buf : std_logic := '0';
+ signal out481_bufn : std_logic;
+ signal out482_buf : std_logic := '0';
+ signal out482_bufn : std_logic;
+ signal out483_buf : std_logic := '0';
+ signal out483_bufn : std_logic;
+ signal out487_buf : std_logic := '0';
+ signal out487_bufn : std_logic;
+ signal out495_buf : std_logic := '0';
+ signal out495_bufn : std_logic;
+ signal out496_buf : std_logic := '0';
+ signal out496_bufn : std_logic;
+ signal out497_buf : std_logic := '0';
+ signal out497_bufn : std_logic;
+ signal out499_buf : std_logic := '0';
+ signal out499_bufn : std_logic;
+ signal out500_buf : std_logic := '0';
+ signal out500_bufn : std_logic;
+ signal out512_buf : std_logic := '0';
+ signal out512_bufn : std_logic;
+ signal out517_buf : std_logic := '0';
+ signal out517_bufn : std_logic;
+ signal out518_buf : std_logic := '0';
+ signal out518_bufn : std_logic;
+ signal out521_buf : std_logic := '0';
+ signal out521_bufn : std_logic;
+ signal out524_buf : std_logic := '0';
+ signal out524_bufn : std_logic;
+ signal out525_buf : std_logic := '0';
+ signal out525_bufn : std_logic;
+ signal out526_buf : std_logic := '0';
+ signal out526_bufn : std_logic;
+ signal out531_buf : std_logic := '0';
+ signal out531_bufn : std_logic;
+ signal out554_buf : std_logic := '0';
+ signal out554_bufn : std_logic;
+ signal out562_buf : std_logic := '0';
+ signal out562_bufn : std_logic;
+ signal out566_buf : std_logic := '0';
+ signal out566_bufn : std_logic;
+
+ -- Retiming: counters
+ signal rtmcounter0 : unsigned(4 downto 0) := (others => '0');
+ signal rtmcounter0_next : unsigned(4 downto 0);
+
+ -- Retiming: Output of comparators
+ signal rtmcmp90 : std_logic;
+ signal rtmcmp95 : std_logic;
+ signal rtmcmp98 : std_logic;
+ signal rtmcmp104 : std_logic;
+ signal rtmcmp148 : std_logic;
+ signal rtmcmp167 : std_logic;
+ signal rtmcmp174 : std_logic;
+ signal rtmcmp181 : std_logic;
+ signal rtmcmp183 : std_logic;
+ signal rtmcmp194 : std_logic;
+ signal rtmcmp197 : std_logic;
+ signal rtmcmp203 : std_logic;
+ signal rtmcmp205 : std_logic;
+ signal rtmcmp215 : std_logic;
+
+ -- Function calls: return IDs
+
+begin
+
+ -- Sequential process
+ -- Set the current state
+
+ process (clock)
+ begin
+ if rising_edge(clock) then
+
+ -- Next state
+ state_cur <= state_next;
+ -- Buffers for outputs
+ out122_buf <= out122_bufn;
+ out36_buf <= out36_bufn;
+ out49_buf <= out49_bufn;
+ out35_buf <= out35_bufn;
+ out27_buf <= out27_bufn;
+ out16_buf <= out16_bufn;
+ out25_buf <= out25_bufn;
+ out20_buf <= out20_bufn;
+ out57_buf <= out57_bufn;
+ out23_buf <= out23_bufn;
+ out136_buf <= out136_bufn;
+ out0_buf <= out0_bufn;
+ out134_buf <= out134_bufn;
+ out13_buf <= out13_bufn;
+ out131_buf <= out131_bufn;
+ out129_buf <= out129_bufn;
+ out111_buf <= out111_bufn;
+ out31_buf <= out31_bufn;
+ out126_buf <= out126_bufn;
+ out106_buf <= out106_bufn;
+ out124_buf <= out124_bufn;
+ out138_buf <= out138_bufn;
+ out141_buf <= out141_bufn;
+ out143_buf <= out143_bufn;
+ out146_buf <= out146_bufn;
+ out150_buf <= out150_bufn;
+ out153_buf <= out153_bufn;
+ out155_buf <= out155_bufn;
+ out158_buf <= out158_bufn;
+ out162_buf <= out162_bufn;
+ out165_buf <= out165_bufn;
+ out168_buf <= out168_bufn;
+ out171_buf <= out171_bufn;
+ out174_buf <= out174_bufn;
+ out178_buf <= out178_bufn;
+ out181_buf <= out181_bufn;
+ out183_buf <= out183_bufn;
+ out197_buf <= out197_bufn;
+ out201_buf <= out201_bufn;
+ out204_buf <= out204_bufn;
+ out207_buf <= out207_bufn;
+ out210_buf <= out210_bufn;
+ out213_buf <= out213_bufn;
+ out217_buf <= out217_bufn;
+ out220_buf <= out220_bufn;
+ out222_buf <= out222_bufn;
+ out225_buf <= out225_bufn;
+ out229_buf <= out229_bufn;
+ out232_buf <= out232_bufn;
+ out235_buf <= out235_bufn;
+ out238_buf <= out238_bufn;
+ out241_buf <= out241_bufn;
+ out245_buf <= out245_bufn;
+ out248_buf <= out248_bufn;
+ out250_buf <= out250_bufn;
+ out253_buf <= out253_bufn;
+ out257_buf <= out257_bufn;
+ out260_buf <= out260_bufn;
+ out263_buf <= out263_bufn;
+ out266_buf <= out266_bufn;
+ out269_buf <= out269_bufn;
+ out273_buf <= out273_bufn;
+ out276_buf <= out276_bufn;
+ out278_buf <= out278_bufn;
+ out280_buf <= out280_bufn;
+ out281_buf <= out281_bufn;
+ out282_buf <= out282_bufn;
+ out284_buf <= out284_bufn;
+ out285_buf <= out285_bufn;
+ out287_buf <= out287_bufn;
+ out288_buf <= out288_bufn;
+ out289_buf <= out289_bufn;
+ out290_buf <= out290_bufn;
+ out291_buf <= out291_bufn;
+ out292_buf <= out292_bufn;
+ out293_buf <= out293_bufn;
+ out294_buf <= out294_bufn;
+ out295_buf <= out295_bufn;
+ out296_buf <= out296_bufn;
+ out312_buf <= out312_bufn;
+ out313_buf <= out313_bufn;
+ out314_buf <= out314_bufn;
+ out315_buf <= out315_bufn;
+ out318_buf <= out318_bufn;
+ out322_buf <= out322_bufn;
+ out323_buf <= out323_bufn;
+ out324_buf <= out324_bufn;
+ out325_buf <= out325_bufn;
+ out326_buf <= out326_bufn;
+ out327_buf <= out327_bufn;
+ out328_buf <= out328_bufn;
+ out333_buf <= out333_bufn;
+ out341_buf <= out341_bufn;
+ out342_buf <= out342_bufn;
+ out343_buf <= out343_bufn;
+ out344_buf <= out344_bufn;
+ out346_buf <= out346_bufn;
+ out349_buf <= out349_bufn;
+ out351_buf <= out351_bufn;
+ out352_buf <= out352_bufn;
+ out353_buf <= out353_bufn;
+ out354_buf <= out354_bufn;
+ out357_buf <= out357_bufn;
+ out361_buf <= out361_bufn;
+ out364_buf <= out364_bufn;
+ out366_buf <= out366_bufn;
+ out371_buf <= out371_bufn;
+ out393_buf <= out393_bufn;
+ out394_buf <= out394_bufn;
+ out395_buf <= out395_bufn;
+ out400_buf <= out400_bufn;
+ out401_buf <= out401_bufn;
+ out404_buf <= out404_bufn;
+ out407_buf <= out407_bufn;
+ out408_buf <= out408_bufn;
+ out409_buf <= out409_bufn;
+ out410_buf <= out410_bufn;
+ out413_buf <= out413_bufn;
+ out414_buf <= out414_bufn;
+ out417_buf <= out417_bufn;
+ out418_buf <= out418_bufn;
+ out422_buf <= out422_bufn;
+ out426_buf <= out426_bufn;
+ out428_buf <= out428_bufn;
+ out431_buf <= out431_bufn;
+ out433_buf <= out433_bufn;
+ out434_buf <= out434_bufn;
+ out435_buf <= out435_bufn;
+ out436_buf <= out436_bufn;
+ out437_buf <= out437_bufn;
+ out438_buf <= out438_bufn;
+ out440_buf <= out440_bufn;
+ out444_buf <= out444_bufn;
+ out446_buf <= out446_bufn;
+ out451_buf <= out451_bufn;
+ out457_buf <= out457_bufn;
+ out458_buf <= out458_bufn;
+ out459_buf <= out459_bufn;
+ out460_buf <= out460_bufn;
+ out461_buf <= out461_bufn;
+ out463_buf <= out463_bufn;
+ out464_buf <= out464_bufn;
+ out466_buf <= out466_bufn;
+ out468_buf <= out468_bufn;
+ out472_buf <= out472_bufn;
+ out475_buf <= out475_bufn;
+ out481_buf <= out481_bufn;
+ out482_buf <= out482_bufn;
+ out483_buf <= out483_bufn;
+ out487_buf <= out487_bufn;
+ out495_buf <= out495_bufn;
+ out496_buf <= out496_bufn;
+ out497_buf <= out497_bufn;
+ out499_buf <= out499_bufn;
+ out500_buf <= out500_bufn;
+ out512_buf <= out512_bufn;
+ out517_buf <= out517_bufn;
+ out518_buf <= out518_bufn;
+ out521_buf <= out521_bufn;
+ out524_buf <= out524_bufn;
+ out525_buf <= out525_bufn;
+ out526_buf <= out526_bufn;
+ out531_buf <= out531_bufn;
+ out554_buf <= out554_bufn;
+ out562_buf <= out562_bufn;
+ out566_buf <= out566_bufn;
+ -- Retiming: counters
+ rtmcounter0 <= rtmcounter0_next;
+ -- Function calls: return IDs
+
+ end if;
+ end process;
+
+ -- Combinatorial process
+ -- Compute the next state
+ -- Compute the outputs
+
+ process (
+ -- Inputs of the FSM
+ reset, in0, in2, in3, in4, in5, in1, in6, in11, in7, in8, in9, in10,
+ -- Retiming: outputs of the comparators
+ rtmcmp90, rtmcmp95, rtmcmp98, rtmcmp104, rtmcmp148, rtmcmp167, rtmcmp174, rtmcmp181, rtmcmp183, rtmcmp194, rtmcmp197, rtmcmp203, rtmcmp205, rtmcmp215,
+ -- Retiming: the counters
+ rtmcounter0,
+ -- Function calls: return IDs
+ -- Current state
+ state_cur
+ )
+ begin
+
+ -- Reset the next state value
+
+ state_next <= (others => '0');
+
+ -- Default value to the outputs or output buffers
+
+ out22 <= '0';
+ out4 <= '0';
+ out122_bufn <= '0';
+ out50 <= '0';
+ out121 <= '0';
+ out36_bufn <= '0';
+ out49_bufn <= '0';
+ out35_bufn <= '0';
+ out99 <= '0';
+ out52 <= '0';
+ out18 <= '0';
+ out33 <= '0';
+ out123 <= '0';
+ out101 <= '0';
+ out90 <= '0';
+ out91 <= '0';
+ out27_bufn <= '0';
+ out16_bufn <= '0';
+ out26 <= '0';
+ out21 <= '0';
+ out24 <= '0';
+ out54 <= '0';
+ out25_bufn <= '0';
+ out20_bufn <= '0';
+ out58 <= '0';
+ out30 <= '0';
+ out8 <= '0';
+ out57_bufn <= '0';
+ out48 <= '0';
+ out56 <= '0';
+ out23_bufn <= '0';
+ out29 <= '0';
+ out19 <= '0';
+ out136_bufn <= '0';
+ out2 <= '0';
+ out1 <= '0';
+ out46 <= '0';
+ out0_bufn <= '0';
+ out135 <= '0';
+ out118 <= '0';
+ out116 <= '0';
+ out14 <= '0';
+ out134_bufn <= '0';
+ out28 <= '0';
+ out13_bufn <= '0';
+ out133 <= '0';
+ out131_bufn <= '0';
+ out132 <= '0';
+ out114 <= '0';
+ out130 <= '0';
+ out112 <= '0';
+ out38 <= '0';
+ out44 <= '0';
+ out97 <= '0';
+ out129_bufn <= '0';
+ out111_bufn <= '0';
+ out31_bufn <= '0';
+ out126_bufn <= '0';
+ out107 <= '0';
+ out108 <= '0';
+ out105 <= '0';
+ out106_bufn <= '0';
+ out125 <= '0';
+ out120 <= '0';
+ out124_bufn <= '0';
+ out103 <= '0';
+ out42 <= '0';
+ out40 <= '0';
+ out60 <= '0';
+ out137 <= '0';
+ out138_bufn <= '0';
+ out140 <= '0';
+ out141_bufn <= '0';
+ out142 <= '0';
+ out143_bufn <= '0';
+ out145 <= '0';
+ out146_bufn <= '0';
+ out148 <= '0';
+ out150_bufn <= '0';
+ out153_bufn <= '0';
+ out154 <= '0';
+ out155_bufn <= '0';
+ out156 <= '0';
+ out157 <= '0';
+ out158_bufn <= '0';
+ out159 <= '0';
+ out160 <= '0';
+ out161 <= '0';
+ out162_bufn <= '0';
+ out164 <= '0';
+ out165_bufn <= '0';
+ out167 <= '0';
+ out168_bufn <= '0';
+ out170 <= '0';
+ out171_bufn <= '0';
+ out173 <= '0';
+ out174_bufn <= '0';
+ out176 <= '0';
+ out178_bufn <= '0';
+ out181_bufn <= '0';
+ out182 <= '0';
+ out183_bufn <= '0';
+ out184 <= '0';
+ out185 <= '0';
+ out186 <= '0';
+ out187 <= '0';
+ out190 <= '0';
+ out195 <= '0';
+ out197_bufn <= '0';
+ out198 <= '0';
+ out199 <= '0';
+ out200 <= '0';
+ out201_bufn <= '0';
+ out203 <= '0';
+ out204_bufn <= '0';
+ out206 <= '0';
+ out207_bufn <= '0';
+ out209 <= '0';
+ out210_bufn <= '0';
+ out212 <= '0';
+ out213_bufn <= '0';
+ out215 <= '0';
+ out217_bufn <= '0';
+ out220_bufn <= '0';
+ out221 <= '0';
+ out222_bufn <= '0';
+ out223 <= '0';
+ out224 <= '0';
+ out225_bufn <= '0';
+ out226 <= '0';
+ out227 <= '0';
+ out228 <= '0';
+ out229_bufn <= '0';
+ out231 <= '0';
+ out232_bufn <= '0';
+ out234 <= '0';
+ out235_bufn <= '0';
+ out237 <= '0';
+ out238_bufn <= '0';
+ out240 <= '0';
+ out241_bufn <= '0';
+ out243 <= '0';
+ out245_bufn <= '0';
+ out248_bufn <= '0';
+ out249 <= '0';
+ out250_bufn <= '0';
+ out251 <= '0';
+ out252 <= '0';
+ out253_bufn <= '0';
+ out254 <= '0';
+ out255 <= '0';
+ out256 <= '0';
+ out257_bufn <= '0';
+ out259 <= '0';
+ out260_bufn <= '0';
+ out262 <= '0';
+ out263_bufn <= '0';
+ out265 <= '0';
+ out266_bufn <= '0';
+ out268 <= '0';
+ out269_bufn <= '0';
+ out271 <= '0';
+ out273_bufn <= '0';
+ out276_bufn <= '0';
+ out277 <= '0';
+ out278_bufn <= '0';
+ out279 <= '0';
+ out280_bufn <= '0';
+ out281_bufn <= '0';
+ out282_bufn <= '0';
+ out283 <= '0';
+ out284_bufn <= '0';
+ out285_bufn <= '0';
+ out286 <= '0';
+ out287_bufn <= '0';
+ out288_bufn <= '0';
+ out289_bufn <= '0';
+ out290_bufn <= '0';
+ out291_bufn <= '0';
+ out292_bufn <= '0';
+ out293_bufn <= '0';
+ out294_bufn <= '0';
+ out295_bufn <= '0';
+ out296_bufn <= '0';
+ out297 <= '0';
+ out298 <= '0';
+ out311 <= '0';
+ out312_bufn <= '0';
+ out313_bufn <= '0';
+ out314_bufn <= '0';
+ out315_bufn <= '0';
+ out316 <= '0';
+ out318_bufn <= '0';
+ out321 <= '0';
+ out322_bufn <= '0';
+ out323_bufn <= '0';
+ out324_bufn <= '0';
+ out325_bufn <= '0';
+ out326_bufn <= '0';
+ out327_bufn <= '0';
+ out328_bufn <= '0';
+ out329 <= '0';
+ out333_bufn <= '0';
+ out341_bufn <= '0';
+ out342_bufn <= '0';
+ out343_bufn <= '0';
+ out344_bufn <= '0';
+ out345 <= '0';
+ out346_bufn <= '0';
+ out349_bufn <= '0';
+ out350 <= '0';
+ out351_bufn <= '0';
+ out352_bufn <= '0';
+ out353_bufn <= '0';
+ out354_bufn <= '0';
+ out355 <= '0';
+ out357_bufn <= '0';
+ out361_bufn <= '0';
+ out362 <= '0';
+ out363 <= '0';
+ out364_bufn <= '0';
+ out366_bufn <= '0';
+ out367 <= '0';
+ out371_bufn <= '0';
+ out372 <= '0';
+ out373 <= '0';
+ out382 <= '0';
+ out383 <= '0';
+ out385 <= '0';
+ out393_bufn <= '0';
+ out394_bufn <= '0';
+ out395_bufn <= '0';
+ out396 <= '0';
+ out398 <= '0';
+ out400_bufn <= '0';
+ out401_bufn <= '0';
+ out402 <= '0';
+ out404_bufn <= '0';
+ out406 <= '0';
+ out407_bufn <= '0';
+ out408_bufn <= '0';
+ out409_bufn <= '0';
+ out410_bufn <= '0';
+ out411 <= '0';
+ out412 <= '0';
+ out413_bufn <= '0';
+ out414_bufn <= '0';
+ out416 <= '0';
+ out417_bufn <= '0';
+ out418_bufn <= '0';
+ out419 <= '0';
+ out422_bufn <= '0';
+ out423 <= '0';
+ out425 <= '0';
+ out426_bufn <= '0';
+ out428_bufn <= '0';
+ out429 <= '0';
+ out430 <= '0';
+ out431_bufn <= '0';
+ out433_bufn <= '0';
+ out434_bufn <= '0';
+ out435_bufn <= '0';
+ out436_bufn <= '0';
+ out437_bufn <= '0';
+ out438_bufn <= '0';
+ out440_bufn <= '0';
+ out441 <= '0';
+ out443 <= '0';
+ out444_bufn <= '0';
+ out445 <= '0';
+ out446_bufn <= '0';
+ out447 <= '0';
+ out450 <= '0';
+ out451_bufn <= '0';
+ out454 <= '0';
+ out455 <= '0';
+ out457_bufn <= '0';
+ out458_bufn <= '0';
+ out459_bufn <= '0';
+ out460_bufn <= '0';
+ out461_bufn <= '0';
+ out462 <= '0';
+ out463_bufn <= '0';
+ out464_bufn <= '0';
+ out465 <= '0';
+ out466_bufn <= '0';
+ out467 <= '0';
+ out468_bufn <= '0';
+ out469 <= '0';
+ out472_bufn <= '0';
+ out475_bufn <= '0';
+ out481_bufn <= '0';
+ out482_bufn <= '0';
+ out483_bufn <= '0';
+ out484 <= '0';
+ out487_bufn <= '0';
+ out488 <= '0';
+ out491 <= '0';
+ out495_bufn <= '0';
+ out496_bufn <= '0';
+ out497_bufn <= '0';
+ out498 <= '0';
+ out499_bufn <= '0';
+ out500_bufn <= '0';
+ out501 <= '0';
+ out512_bufn <= '0';
+ out513 <= '0';
+ out517_bufn <= '0';
+ out518_bufn <= '0';
+ out519 <= '0';
+ out521_bufn <= '0';
+ out522 <= '0';
+ out524_bufn <= '0';
+ out525_bufn <= '0';
+ out526_bufn <= '0';
+ out527 <= '0';
+ out528 <= '0';
+ out531_bufn <= '0';
+ out540 <= '0';
+ out542 <= '0';
+ out544 <= '0';
+ out545 <= '0';
+ out554_bufn <= '0';
+ out555 <= '0';
+ out559 <= '0';
+ out560 <= '0';
+ out561 <= '0';
+ out562_bufn <= '0';
+ out563 <= '0';
+ out566_bufn <= '0';
+ out567 <= '0';
+ out570 <= '0';
+ out572 <= '0';
+ out575 <= '0';
+ out577 <= '0';
+ out578 <= '0';
+ out580 <= '0';
+ out581 <= '0';
+
+ -- Retiming: default value for counters
+ rtmcounter0_next <= (others => '0');
+
+ -- Function calls: default values (no change)
+
+ -- For all states, compute the next state bits
+ -- And the outputs, and the next value for buffered outputs
+
+ if state_cur(0) = '1' then
+ -- Next state
+ state_next(109) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out1 <= '1';
+ out2 <= '1';
+ end if;
+
+ if state_cur(1) = '1' then
+ -- Next state
+ if (in0) = '1' then
+ state_next(1) <= '1';
+ -- Next values for buffered outputs
+ out13_bufn <= '1';
+ else
+ -- Return from function: memextrct_0
+ state_next(88) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out14 <= '1';
+ out8 <= '1';
+ out4 <= '1';
+ end if;
+
+ if state_cur(2) = '1' then
+ -- Next state
+ state_next(1) <= '1';
+ -- Next values for buffered outputs
+ out13_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out18 <= '1';
+ end if;
+
+ if state_cur(3) = '1' then
+ -- Next state
+ state_next(0) <= '1';
+ -- Next values for buffered outputs
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out2 <= '1';
+ out19 <= '1';
+ end if;
+
+ if state_cur(4) = '1' then
+ -- Next state
+ state_next(3) <= '1';
+ -- Next values for buffered outputs
+ out20_bufn <= '1';
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out2 <= '1';
+ out22 <= '1';
+ end if;
+
+ if state_cur(5) = '1' then
+ -- Next state
+ state_next(4) <= '1';
+ -- Next values for buffered outputs
+ out23_bufn <= '1';
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out2 <= '1';
+ out24 <= '1';
+ end if;
+
+ if state_cur(6) = '1' then
+ -- Next state
+ state_next(5) <= '1';
+ -- Next values for buffered outputs
+ out25_bufn <= '1';
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out2 <= '1';
+ out26 <= '1';
+ end if;
+
+ -- Info: This is the init/reset state
+ if state_cur(7) = '1' then
+ -- Next state
+ if (not (in2)) = '1' then
+ state_next(7) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (in1) = '1' then
+ state_next(60) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(154) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out28 <= '1';
+ out29 <= '1';
+ end if;
+
+ if state_cur(8) = '1' then
+ -- Next state
+ state_next(6) <= '1';
+ -- Next values for buffered outputs
+ out27_bufn <= '1';
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out2 <= '1';
+ out30 <= '1';
+ end if;
+
+ if state_cur(9) = '1' then
+ -- Next state
+ state_next(9) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ end if;
+
+ if state_cur(10) = '1' then
+ -- Next state
+ state_next(8) <= '1';
+ -- Next values for buffered outputs
+ out31_bufn <= '1';
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out33 <= '1';
+ out2 <= '1';
+ end if;
+
+ if state_cur(11) = '1' then
+ -- Next state
+ state_next(10) <= '1';
+ -- Next values for buffered outputs
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ out2 <= '1';
+ end if;
+
+ if state_cur(12) = '1' then
+ -- Next state
+ state_next(11) <= '1';
+ -- Next values for buffered outputs
+ out35_bufn <= '1';
+ out0_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out21 <= '1';
+ end if;
+
+ if state_cur(13) = '1' then
+ -- Next state
+ state_next(12) <= '1';
+ -- Next values for buffered outputs
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out50 <= '1';
+ out48 <= '1';
+ out46 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(14) = '1' then
+ -- Next state
+ state_next(13) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(15) = '1' then
+ -- Next state
+ if (in3) = '1' then
+ state_next(15) <= '1';
+ -- Next values for buffered outputs
+ out13_bufn <= '1';
+ else
+ -- Return from function: memextrct_1
+ state_next(88) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out14 <= '1';
+ out91 <= '1';
+ out90 <= '1';
+ end if;
+
+ if state_cur(16) = '1' then
+ -- Next state
+ if (in5) = '1' then
+ -- Function call: memextrct_1
+ state_next(19) <= '1';
+ -- Next values for buffered outputs
+ out16_bufn <= '1';
+ else
+ if (in4) = '1' then
+ -- Function call: memextrct_0
+ state_next(2) <= '1';
+ -- Next values for buffered outputs
+ out16_bufn <= '1';
+ else
+ state_next(88) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out97 <= '1';
+ end if;
+
+ if state_cur(17) = '1' then
+ -- Next state
+ state_next(14) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out103 <= '1';
+ out101 <= '1';
+ out99 <= '1';
+ end if;
+
+ if state_cur(18) = '1' then
+ -- Next state
+ state_next(17) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out108 <= '1';
+ out107 <= '1';
+ end if;
+
+ if state_cur(19) = '1' then
+ -- Next state
+ state_next(15) <= '1';
+ -- Next values for buffered outputs
+ out13_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out18 <= '1';
+ end if;
+
+ if state_cur(20) = '1' then
+ -- Next state
+ state_next(18) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out108 <= '1';
+ out121 <= '1';
+ end if;
+
+ if state_cur(21) = '1' then
+ -- Next state
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ out126_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out132 <= '1';
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out108 <= '1';
+ end if;
+
+ if state_cur(22) = '1' then
+ -- Next state
+ state_next(21) <= '1';
+ -- Next values for buffered outputs
+ out131_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out108 <= '1';
+ out133 <= '1';
+ end if;
+
+ if state_cur(23) = '1' then
+ -- Next state
+ state_next(22) <= '1';
+ -- Next values for buffered outputs
+ out138_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out140 <= '1';
+ out108 <= '1';
+ end if;
+
+ if state_cur(24) = '1' then
+ -- Next state
+ state_next(23) <= '1';
+ -- Next values for buffered outputs
+ out143_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out145 <= '1';
+ out108 <= '1';
+ end if;
+
+ if state_cur(25) = '1' then
+ -- Next state
+ state_next(24) <= '1';
+ -- Next values for buffered outputs
+ out146_bufn <= '1';
+ out31_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out148 <= '1';
+ out108 <= '1';
+ end if;
+
+ if state_cur(26) = '1' then
+ -- Next state
+ state_next(25) <= '1';
+ -- Next values for buffered outputs
+ out150_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out154 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out108 <= '1';
+ end if;
+
+ if state_cur(27) = '1' then
+ -- Next state
+ state_next(26) <= '1';
+ -- Next values for buffered outputs
+ out153_bufn <= '1';
+ out35_bufn <= '1';
+ out106_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out156 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(28) = '1' then
+ -- Next state
+ state_next(27) <= '1';
+ -- Next values for buffered outputs
+ out155_bufn <= '1';
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(29) = '1' then
+ -- Next state
+ state_next(28) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out157 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(30) = '1' then
+ -- Next state
+ state_next(29) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out103 <= '1';
+ out101 <= '1';
+ out99 <= '1';
+ end if;
+
+ if state_cur(31) = '1' then
+ -- Next state
+ state_next(30) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out160 <= '1';
+ out159 <= '1';
+ end if;
+
+ if state_cur(32) = '1' then
+ -- Next state
+ state_next(31) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out161 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(33) = '1' then
+ -- Next state
+ state_next(32) <= '1';
+ -- Next values for buffered outputs
+ out162_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out164 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(34) = '1' then
+ -- Next state
+ state_next(33) <= '1';
+ -- Next values for buffered outputs
+ out165_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out167 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(35) = '1' then
+ -- Next state
+ state_next(34) <= '1';
+ -- Next values for buffered outputs
+ out168_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out170 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(36) = '1' then
+ -- Next state
+ state_next(35) <= '1';
+ -- Next values for buffered outputs
+ out171_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out173 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(37) = '1' then
+ -- Next state
+ state_next(36) <= '1';
+ -- Next values for buffered outputs
+ out174_bufn <= '1';
+ out31_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out176 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(38) = '1' then
+ -- Next state
+ state_next(37) <= '1';
+ -- Next values for buffered outputs
+ out178_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out182 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out160 <= '1';
+ end if;
+
+ if state_cur(39) = '1' then
+ -- Next state
+ state_next(38) <= '1';
+ -- Next values for buffered outputs
+ out181_bufn <= '1';
+ out35_bufn <= '1';
+ out158_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out184 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(40) = '1' then
+ -- Next state
+ state_next(39) <= '1';
+ -- Next values for buffered outputs
+ out183_bufn <= '1';
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(41) = '1' then
+ -- Next state
+ state_next(40) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out185 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(42) = '1' then
+ -- Next state
+ state_next(41) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out103 <= '1';
+ out101 <= '1';
+ out99 <= '1';
+ end if;
+
+ if state_cur(43) = '1' then
+ -- Next state
+ if (in7) = '1' then
+ state_next(60) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (not (in6)) = '1' then
+ state_next(43) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(108) <= '1';
+ -- Next values for buffered outputs
+ out371_bufn <= '1';
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out190 <= '1';
+ out187 <= '1';
+ out186 <= '1';
+ end if;
+
+ if state_cur(44) = '1' then
+ -- Next state
+ if (in7) = '1' then
+ state_next(60) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (not (in8)) = '1' then
+ state_next(44) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(110) <= '1';
+ -- Next values for buffered outputs
+ out371_bufn <= '1';
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out195 <= '1';
+ out187 <= '1';
+ end if;
+
+ if state_cur(45) = '1' then
+ -- Next state
+ state_next(42) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out199 <= '1';
+ out198 <= '1';
+ end if;
+
+ if state_cur(46) = '1' then
+ -- Next state
+ state_next(45) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out200 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(47) = '1' then
+ -- Next state
+ state_next(46) <= '1';
+ -- Next values for buffered outputs
+ out201_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out203 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(48) = '1' then
+ -- Next state
+ state_next(47) <= '1';
+ -- Next values for buffered outputs
+ out204_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out206 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(49) = '1' then
+ -- Next state
+ state_next(48) <= '1';
+ -- Next values for buffered outputs
+ out207_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out209 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(50) = '1' then
+ -- Next state
+ state_next(49) <= '1';
+ -- Next values for buffered outputs
+ out210_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out212 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(51) = '1' then
+ -- Next state
+ state_next(50) <= '1';
+ -- Next values for buffered outputs
+ out213_bufn <= '1';
+ out31_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out215 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(52) = '1' then
+ -- Next state
+ state_next(51) <= '1';
+ -- Next values for buffered outputs
+ out217_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out221 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out199 <= '1';
+ end if;
+
+ if state_cur(53) = '1' then
+ -- Next state
+ state_next(52) <= '1';
+ -- Next values for buffered outputs
+ out220_bufn <= '1';
+ out35_bufn <= '1';
+ out197_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out223 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(54) = '1' then
+ -- Next state
+ state_next(53) <= '1';
+ -- Next values for buffered outputs
+ out222_bufn <= '1';
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(55) = '1' then
+ -- Next state
+ state_next(54) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out224 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(56) = '1' then
+ -- Next state
+ state_next(55) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out103 <= '1';
+ out101 <= '1';
+ out99 <= '1';
+ end if;
+
+ if state_cur(57) = '1' then
+ -- Next state
+ state_next(56) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out227 <= '1';
+ out226 <= '1';
+ end if;
+
+ if state_cur(58) = '1' then
+ -- Next state
+ state_next(57) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out228 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(59) = '1' then
+ -- Next state
+ state_next(58) <= '1';
+ -- Next values for buffered outputs
+ out229_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out231 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(60) = '1' then
+ -- Next state
+ state_next(87) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out18 <= '1';
+ end if;
+
+ if state_cur(61) = '1' then
+ -- Next state
+ state_next(59) <= '1';
+ -- Next values for buffered outputs
+ out232_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out234 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(62) = '1' then
+ -- Next state
+ state_next(61) <= '1';
+ -- Next values for buffered outputs
+ out235_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out237 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(63) = '1' then
+ -- Next state
+ state_next(62) <= '1';
+ -- Next values for buffered outputs
+ out238_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out240 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(64) = '1' then
+ -- Next state
+ state_next(63) <= '1';
+ -- Next values for buffered outputs
+ out241_bufn <= '1';
+ out31_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out243 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(65) = '1' then
+ -- Next state
+ state_next(64) <= '1';
+ -- Next values for buffered outputs
+ out245_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out249 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out227 <= '1';
+ end if;
+
+ if state_cur(66) = '1' then
+ -- Next state
+ state_next(65) <= '1';
+ -- Next values for buffered outputs
+ out248_bufn <= '1';
+ out35_bufn <= '1';
+ out225_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out251 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(67) = '1' then
+ -- Next state
+ state_next(66) <= '1';
+ -- Next values for buffered outputs
+ out250_bufn <= '1';
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(68) = '1' then
+ -- Next state
+ state_next(67) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out252 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(69) = '1' then
+ -- Next state
+ state_next(68) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out103 <= '1';
+ out101 <= '1';
+ out99 <= '1';
+ end if;
+
+ if state_cur(70) = '1' then
+ -- Next state
+ state_next(69) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out255 <= '1';
+ out254 <= '1';
+ end if;
+
+ if state_cur(71) = '1' then
+ -- Next state
+ state_next(70) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out256 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(72) = '1' then
+ -- Next state
+ state_next(71) <= '1';
+ -- Next values for buffered outputs
+ out257_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out259 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(73) = '1' then
+ -- Next state
+ state_next(72) <= '1';
+ -- Next values for buffered outputs
+ out260_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out262 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(74) = '1' then
+ -- Next state
+ state_next(73) <= '1';
+ -- Next values for buffered outputs
+ out263_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out265 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(75) = '1' then
+ -- Next state
+ state_next(74) <= '1';
+ -- Next values for buffered outputs
+ out266_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out268 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(76) = '1' then
+ -- Next state
+ state_next(75) <= '1';
+ -- Next values for buffered outputs
+ out269_bufn <= '1';
+ out31_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out271 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(77) = '1' then
+ -- Next state
+ state_next(76) <= '1';
+ -- Next values for buffered outputs
+ out273_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out277 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out255 <= '1';
+ end if;
+
+ if state_cur(78) = '1' then
+ -- Next state
+ state_next(77) <= '1';
+ -- Next values for buffered outputs
+ out276_bufn <= '1';
+ out35_bufn <= '1';
+ out253_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out279 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(79) = '1' then
+ -- Next state
+ state_next(80) <= '1';
+ -- Next values for buffered outputs
+ out285_bufn <= '1';
+ out284_bufn <= '1';
+ out269_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(80) = '1' then
+ -- Next state
+ state_next(113) <= '1';
+ -- Next values for buffered outputs
+ out395_bufn <= '1';
+ out284_bufn <= '1';
+ out146_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(81) = '1' then
+ -- Next state
+ state_next(82) <= '1';
+ -- Next values for buffered outputs
+ out290_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(82) = '1' then
+ -- Next state
+ state_next(83) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out292_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(83) = '1' then
+ -- Next state
+ state_next(85) <= '1';
+ -- Next values for buffered outputs
+ out295_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out58 <= '1';
+ out118 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(84) = '1' then
+ -- Next state
+ state_next(89) <= '1';
+ -- Next values for buffered outputs
+ out313_bufn <= '1';
+ out281_bufn <= '1';
+ out312_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(85) = '1' then
+ -- Next state
+ state_next(86) <= '1';
+ -- Next values for buffered outputs
+ out296_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(86) = '1' then
+ -- Next state
+ state_next(90) <= '1';
+ -- Next values for buffered outputs
+ out318_bufn <= '1';
+ out280_bufn <= '1';
+ out315_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(87) = '1' then
+ -- Next state
+ if (in9) = '1' then
+ state_next(87) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(16) <= '1';
+ -- Next values for buffered outputs
+ out16_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs
+ out14 <= '1';
+ out298 <= '1';
+ out297 <= '1';
+ end if;
+
+ if state_cur(88) = '1' then
+ -- Next state
+ if (in1) = '1' then
+ if (in5) = '1' then
+ state_next(43) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(44) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ else
+ state_next(9) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out311 <= '1';
+ end if;
+
+ if state_cur(89) = '1' then
+ -- Next state
+ state_next(112) <= '1';
+ -- Next values for buffered outputs
+ out394_bufn <= '1';
+ out284_bufn <= '1';
+ out393_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(90) = '1' then
+ if rtmcmp90 = '1' then
+ -- Next state
+ state_next(93) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out325_bufn <= '1';
+ out324_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out103 <= '1';
+ out105 <= '1';
+ out56 <= '1';
+ out137 <= '1';
+ out125 <= '1';
+ out116 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(90) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out318_bufn <= '1';
+ out280_bufn <= '1';
+ out315_bufn <= '1';
+ out314_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out316 <= '1';
+ end if;
+
+ if state_cur(91) = '1' then
+ -- Next state
+ state_next(170) <= '1';
+ -- Next values for buffered outputs
+ out487_bufn <= '1';
+ out284_bufn <= '1';
+ out266_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ out321 <= '1';
+ end if;
+
+ if state_cur(92) = '1' then
+ -- Next state
+ state_next(240) <= '1';
+ -- Next values for buffered outputs
+ out217_bufn <= '1';
+ out295_bufn <= '1';
+ out281_bufn <= '1';
+ out562_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(93) = '1' then
+ -- Next state
+ state_next(101) <= '1';
+ -- Next values for buffered outputs
+ out323_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out118 <= '1';
+ out58 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(94) = '1' then
+ -- Next state
+ state_next(96) <= '1';
+ -- Next values for buffered outputs
+ out341_bufn <= '1';
+ out281_bufn <= '1';
+ out241_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(95) = '1' then
+ if rtmcmp95 = '1' then
+ -- Next state
+ state_next(210) <= '1';
+ -- Next values for buffered outputs
+ out418_bufn <= '1';
+ out351_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out130 <= '1';
+ out101 <= '1';
+ out142 <= '1';
+ out112 <= '1';
+ out99 <= '1';
+ out54 <= '1';
+ out123 <= '1';
+ out135 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(95) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out333_bufn <= '1';
+ out245_bufn <= '1';
+ out318_bufn <= '1';
+ out328_bufn <= '1';
+ out327_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out329 <= '1';
+ end if;
+
+ if state_cur(96) = '1' then
+ -- Next state
+ state_next(91) <= '1';
+ -- Next values for buffered outputs
+ out322_bufn <= '1';
+ out281_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(97) = '1' then
+ -- Next state
+ state_next(95) <= '1';
+ -- Next values for buffered outputs
+ out333_bufn <= '1';
+ out245_bufn <= '1';
+ out318_bufn <= '1';
+ out328_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(98) = '1' then
+ if rtmcmp98 = '1' then
+ -- Next state
+ state_next(97) <= '1';
+ -- Next values for buffered outputs
+ out342_bufn <= '1';
+ out324_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out125 <= '1';
+ out137 <= '1';
+ out116 <= '1';
+ out56 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(98) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out346_bufn <= '1';
+ out344_bufn <= '1';
+ out312_bufn <= '1';
+ out343_bufn <= '1';
+ out314_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out345 <= '1';
+ end if;
+
+ if state_cur(99) = '1' then
+ -- Next state
+ state_next(119) <= '1';
+ -- Next values for buffered outputs
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(100) = '1' then
+ -- Next state
+ state_next(233) <= '1';
+ -- Next values for buffered outputs
+ out566_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out125 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(101) = '1' then
+ -- Next state
+ state_next(98) <= '1';
+ -- Next values for buffered outputs
+ out346_bufn <= '1';
+ out344_bufn <= '1';
+ out312_bufn <= '1';
+ out343_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(102) = '1' then
+ -- Next state
+ state_next(239) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out350 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(103) = '1' then
+ -- Next state
+ state_next(146) <= '1';
+ -- Next values for buffered outputs
+ out401_bufn <= '1';
+ out444_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(104) = '1' then
+ if rtmcmp104 = '1' then
+ -- Next state
+ state_next(103) <= '1';
+ -- Next values for buffered outputs
+ out352_bufn <= '1';
+ out351_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out142 <= '1';
+ out99 <= '1';
+ out130 <= '1';
+ out101 <= '1';
+ out54 <= '1';
+ out135 <= '1';
+ out123 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(104) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out129_bufn <= '1';
+ out357_bufn <= '1';
+ out354_bufn <= '1';
+ out353_bufn <= '1';
+ out327_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out355 <= '1';
+ end if;
+
+ if state_cur(105) = '1' then
+ -- Next state
+ state_next(133) <= '1';
+ -- Next values for buffered outputs
+ out431_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out363 <= '1';
+ out362 <= '1';
+ end if;
+
+ if state_cur(106) = '1' then
+ -- Next state
+ state_next(186) <= '1';
+ -- Next values for buffered outputs
+ out518_bufn <= '1';
+ out284_bufn <= '1';
+ out153_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(107) = '1' then
+ -- Next state
+ state_next(148) <= '1';
+ -- Next values for buffered outputs
+ out446_bufn <= '1';
+ out413_bufn <= '1';
+ out281_bufn <= '1';
+ out250_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out112 <= '1';
+ out367 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(108) = '1' then
+ -- Next state
+ if (in10) = '1' then
+ state_next(109) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(154) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out372 <= '1';
+ end if;
+
+ if state_cur(109) = '1' then
+ -- Next state
+ state_next(43) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out382 <= '1';
+ out373 <= '1';
+ end if;
+
+ if state_cur(110) = '1' then
+ -- Next state
+ if (in11) = '1' then
+ state_next(44) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(111) <= '1';
+ -- Next values for buffered outputs
+ out284_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs
+ out372 <= '1';
+ out385 <= '1';
+ out383 <= '1';
+ end if;
+
+ if state_cur(111) = '1' then
+ -- Next state
+ state_next(153) <= '1';
+ -- Next values for buffered outputs
+ out422_bufn <= '1';
+ out284_bufn <= '1';
+ out278_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out372 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(112) = '1' then
+ -- Next state
+ state_next(94) <= '1';
+ -- Next values for buffered outputs
+ out326_bufn <= '1';
+ out284_bufn <= '1';
+ out210_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(113) = '1' then
+ -- Next state
+ state_next(160) <= '1';
+ -- Next values for buffered outputs
+ out461_bufn <= '1';
+ out281_bufn <= '1';
+ out178_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(114) = '1' then
+ -- Next state
+ state_next(196) <= '1';
+ -- Next values for buffered outputs
+ out328_bufn <= '1';
+ out284_bufn <= '1';
+ out155_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out142 <= '1';
+ out396 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(115) = '1' then
+ -- Next state
+ state_next(105) <= '1';
+ -- Next values for buffered outputs
+ out364_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out398 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(116) = '1' then
+ -- Next state
+ state_next(120) <= '1';
+ -- Next values for buffered outputs
+ out407_bufn <= '1';
+ out281_bufn <= '1';
+ out168_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(117) = '1' then
+ -- Next state
+ state_next(211) <= '1';
+ -- Next values for buffered outputs
+ out458_bufn <= '1';
+ out475_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(118) = '1' then
+ -- Next state
+ state_next(151) <= '1';
+ -- Next values for buffered outputs
+ out333_bufn <= '1';
+ out31_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out402 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(119) = '1' then
+ -- Next state
+ state_next(150) <= '1';
+ -- Next values for buffered outputs
+ out366_bufn <= '1';
+ out35_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out406 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(120) = '1' then
+ -- Next state
+ state_next(121) <= '1';
+ -- Next values for buffered outputs
+ out409_bufn <= '1';
+ out281_bufn <= '1';
+ out408_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(121) = '1' then
+ -- Next state
+ state_next(139) <= '1';
+ -- Next values for buffered outputs
+ out438_bufn <= '1';
+ out284_bufn <= '1';
+ out431_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(122) = '1' then
+ -- Next state
+ state_next(123) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out412 <= '1';
+ out411 <= '1';
+ end if;
+
+ if state_cur(123) = '1' then
+ -- Next state
+ state_next(212) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out103 <= '1';
+ out105 <= '1';
+ out99 <= '1';
+ out101 <= '1';
+ end if;
+
+ if state_cur(124) = '1' then
+ -- Next state
+ state_next(81) <= '1';
+ -- Next values for buffered outputs
+ out288_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(125) = '1' then
+ -- Next state
+ state_next(128) <= '1';
+ -- Next values for buffered outputs
+ out422_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(126) = '1' then
+ -- Next state
+ state_next(125) <= '1';
+ -- Next values for buffered outputs
+ out414_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out416 <= '1';
+ out38 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(127) = '1' then
+ -- Next state
+ state_next(169) <= '1';
+ -- Next values for buffered outputs
+ out417_bufn <= '1';
+ out483_bufn <= '1';
+ out482_bufn <= '1';
+ out318_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out112 <= '1';
+ out419 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(128) = '1' then
+ -- Next state
+ state_next(124) <= '1';
+ -- Next values for buffered outputs
+ out413_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(129) = '1' then
+ -- Next state
+ state_next(130) <= '1';
+ -- Next values for buffered outputs
+ out426_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out423 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(130) = '1' then
+ -- Next state
+ state_next(143) <= '1';
+ -- Next values for buffered outputs
+ out435_bufn <= '1';
+ out25_bufn <= '1';
+ out136_bufn <= '1';
+ out134_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out46 <= '1';
+ out21 <= '1';
+ out142 <= '1';
+ out425 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(131) = '1' then
+ -- Next state
+ state_next(102) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out103 <= '1';
+ out105 <= '1';
+ out99 <= '1';
+ out101 <= '1';
+ end if;
+
+ if state_cur(132) = '1' then
+ -- Next state
+ state_next(144) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out114 <= '1';
+ out429 <= '1';
+ out52 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(133) = '1' then
+ -- Next state
+ state_next(237) <= '1';
+ -- Next values for buffered outputs
+ out475_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out430 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(134) = '1' then
+ -- Next state
+ state_next(227) <= '1';
+ -- Next values for buffered outputs
+ out496_bufn <= '1';
+ out284_bufn <= '1';
+ out263_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(135) = '1' then
+ -- Next state
+ state_next(117) <= '1';
+ -- Next values for buffered outputs
+ out352_bufn <= '1';
+ out281_bufn <= '1';
+ out401_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(136) = '1' then
+ -- Next state
+ state_next(135) <= '1';
+ -- Next values for buffered outputs
+ out434_bufn <= '1';
+ out281_bufn <= '1';
+ out165_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(137) = '1' then
+ -- Next state
+ state_next(228) <= '1';
+ -- Next values for buffered outputs
+ out463_bufn <= '1';
+ out284_bufn <= '1';
+ out260_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(138) = '1' then
+ -- Next state
+ state_next(137) <= '1';
+ -- Next values for buffered outputs
+ out436_bufn <= '1';
+ out281_bufn <= '1';
+ out435_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(139) = '1' then
+ -- Next state
+ state_next(229) <= '1';
+ -- Next values for buffered outputs
+ out495_bufn <= '1';
+ out284_bufn <= '1';
+ out204_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(140) = '1' then
+ -- Next state
+ state_next(126) <= '1';
+ -- Next values for buffered outputs
+ out324_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(141) = '1' then
+ -- Next state
+ state_next(142) <= '1';
+ -- Next values for buffered outputs
+ out122_bufn <= '1';
+ out134_bufn <= '1';
+ out400_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out116 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(142) = '1' then
+ -- Next state
+ state_next(168) <= '1';
+ -- Next values for buffered outputs
+ out481_bufn <= '1';
+ out351_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out54 <= '1';
+ out123 <= '1';
+ out135 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(143) = '1' then
+ -- Next state
+ state_next(149) <= '1';
+ -- Next values for buffered outputs
+ out451_bufn <= '1';
+ out23_bufn <= '1';
+ out129_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out48 <= '1';
+ out21 <= '1';
+ out137 <= '1';
+ out135 <= '1';
+ out441 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(144) = '1' then
+ -- Next state
+ state_next(178) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out112 <= '1';
+ end if;
+
+ if state_cur(145) = '1' then
+ -- Next state
+ state_next(99) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out443 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(146) = '1' then
+ -- Next state
+ state_next(100) <= '1';
+ -- Next values for buffered outputs
+ out124_bufn <= '1';
+ out349_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out445 <= '1';
+ out50 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(147) = '1' then
+ -- Next state
+ state_next(78) <= '1';
+ -- Next values for buffered outputs
+ out278_bufn <= '1';
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(148) = '1' then
+ if rtmcmp148 = '1' then
+ -- Next state
+ state_next(172) <= '1';
+ -- Next values for buffered outputs
+ out296_bufn <= '1';
+ out284_bufn <= '1';
+ out220_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out103 <= '1';
+ out125 <= '1';
+ out99 <= '1';
+ out123 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(148) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out446_bufn <= '1';
+ out413_bufn <= '1';
+ out281_bufn <= '1';
+ out250_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out447 <= '1';
+ end if;
+
+ if state_cur(149) = '1' then
+ -- Next state
+ state_next(226) <= '1';
+ -- Next values for buffered outputs
+ out354_bufn <= '1';
+ out20_bufn <= '1';
+ out124_bufn <= '1';
+ out122_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out21 <= '1';
+ out130 <= '1';
+ out450 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(150) = '1' then
+ -- Next state
+ state_next(118) <= '1';
+ -- Next values for buffered outputs
+ out404_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out454 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(151) = '1' then
+ -- Next state
+ state_next(115) <= '1';
+ -- Next values for buffered outputs
+ out393_bufn <= '1';
+ out27_bufn <= '1';
+ out141_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ out21 <= '1';
+ out455 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(152) = '1' then
+ -- Next state
+ state_next(230) <= '1';
+ -- Next values for buffered outputs
+ out512_bufn <= '1';
+ out281_bufn <= '1';
+ out171_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(153) = '1' then
+ -- Next state
+ state_next(114) <= '1';
+ -- Next values for buffered outputs
+ out292_bufn <= '1';
+ out284_bufn <= '1';
+ out222_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(154) = '1' then
+ -- Next state
+ state_next(44) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out372 <= '1';
+ end if;
+
+ if state_cur(155) = '1' then
+ -- Next state
+ state_next(232) <= '1';
+ -- Next values for buffered outputs
+ out517_bufn <= '1';
+ out284_bufn <= '1';
+ out207_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(156) = '1' then
+ -- Next state
+ state_next(104) <= '1';
+ -- Next values for buffered outputs
+ out129_bufn <= '1';
+ out357_bufn <= '1';
+ out354_bufn <= '1';
+ out353_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(157) = '1' then
+ -- Next state
+ state_next(156) <= '1';
+ -- Next values for buffered outputs
+ out458_bufn <= '1';
+ out324_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out56 <= '1';
+ out137 <= '1';
+ out116 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(158) = '1' then
+ -- Next state
+ state_next(157) <= '1';
+ -- Next values for buffered outputs
+ out136_bufn <= '1';
+ out434_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(159) = '1' then
+ -- Next state
+ state_next(158) <= '1';
+ -- Next values for buffered outputs
+ out459_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(160) = '1' then
+ -- Next state
+ state_next(189) <= '1';
+ -- Next values for buffered outputs
+ out525_bufn <= '1';
+ out281_bufn <= '1';
+ out245_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(161) = '1' then
+ -- Next state
+ state_next(106) <= '1';
+ -- Next values for buffered outputs
+ out288_bufn <= '1';
+ out284_bufn <= '1';
+ out276_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ out462 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(162) = '1' then
+ -- Next state
+ state_next(159) <= '1';
+ -- Next values for buffered outputs
+ out460_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(163) = '1' then
+ -- Next state
+ state_next(162) <= '1';
+ -- Next values for buffered outputs
+ out463_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out118 <= '1';
+ out58 <= '1';
+ out465 <= '1';
+ out48 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(164) = '1' then
+ -- Next state
+ state_next(163) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out408_bufn <= '1';
+ out464_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out103 <= '1';
+ out105 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(165) = '1' then
+ -- Next state
+ state_next(166) <= '1';
+ -- Next values for buffered outputs
+ out273_bufn <= '1';
+ out343_bufn <= '1';
+ out281_bufn <= '1';
+ out181_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(166) = '1' then
+ -- Next state
+ state_next(215) <= '1';
+ -- Next values for buffered outputs
+ out562_bufn <= '1';
+ out342_bufn <= '1';
+ out284_bufn <= '1';
+ out404_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out467 <= '1';
+ out142 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(167) = '1' then
+ if rtmcmp167 = '1' then
+ -- Next state
+ state_next(164) <= '1';
+ -- Next values for buffered outputs
+ out409_bufn <= '1';
+ out351_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out130 <= '1';
+ out101 <= '1';
+ out112 <= '1';
+ out142 <= '1';
+ out99 <= '1';
+ out54 <= '1';
+ out135 <= '1';
+ out123 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(167) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out475_bufn <= '1';
+ out257_bufn <= '1';
+ out472_bufn <= '1';
+ out451_bufn <= '1';
+ out468_bufn <= '1';
+ out327_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out469 <= '1';
+ end if;
+
+ if state_cur(168) = '1' then
+ -- Next state
+ state_next(132) <= '1';
+ -- Next values for buffered outputs
+ out357_bufn <= '1';
+ out428_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(169) = '1' then
+ -- Next state
+ state_next(225) <= '1';
+ -- Next values for buffered outputs
+ out554_bufn <= '1';
+ out284_bufn <= '1';
+ out333_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out137 <= '1';
+ out135 <= '1';
+ out484 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(170) = '1' then
+ -- Next state
+ state_next(152) <= '1';
+ -- Next values for buffered outputs
+ out353_bufn <= '1';
+ out284_bufn <= '1';
+ out138_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(171) = '1' then
+ -- Next state
+ state_next(167) <= '1';
+ -- Next values for buffered outputs
+ out475_bufn <= '1';
+ out257_bufn <= '1';
+ out472_bufn <= '1';
+ out451_bufn <= '1';
+ out468_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(172) = '1' then
+ -- Next state
+ state_next(187) <= '1';
+ -- Next values for buffered outputs
+ out521_bufn <= '1';
+ out284_bufn <= '1';
+ out150_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out137 <= '1';
+ out135 <= '1';
+ out488 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(173) = '1' then
+ -- Next state
+ state_next(84) <= '1';
+ -- Next values for buffered outputs
+ out293_bufn <= '1';
+ out281_bufn <= '1';
+ out174_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(174) = '1' then
+ if rtmcmp174 = '1' then
+ -- Next state
+ state_next(171) <= '1';
+ -- Next values for buffered outputs
+ out438_bufn <= '1';
+ out324_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out125 <= '1';
+ out137 <= '1';
+ out116 <= '1';
+ out56 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(174) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out229_bufn <= '1';
+ out357_bufn <= '1';
+ out407_bufn <= '1';
+ out314_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out491 <= '1';
+ end if;
+
+ if state_cur(175) = '1' then
+ -- Next state
+ state_next(174) <= '1';
+ -- Next values for buffered outputs
+ out229_bufn <= '1';
+ out357_bufn <= '1';
+ out407_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(176) = '1' then
+ -- Next state
+ state_next(175) <= '1';
+ -- Next values for buffered outputs
+ out495_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(177) = '1' then
+ -- Next state
+ state_next(176) <= '1';
+ -- Next values for buffered outputs
+ out437_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(178) = '1' then
+ -- Next state
+ state_next(145) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out103 <= '1';
+ out105 <= '1';
+ out99 <= '1';
+ out101 <= '1';
+ end if;
+
+ if state_cur(179) = '1' then
+ -- Next state
+ state_next(177) <= '1';
+ -- Next values for buffered outputs
+ out496_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out58 <= '1';
+ out118 <= '1';
+ out498 <= '1';
+ out46 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(180) = '1' then
+ -- Next state
+ state_next(179) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out497_bufn <= '1';
+ out436_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out103 <= '1';
+ out105 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(181) = '1' then
+ if rtmcmp181 = '1' then
+ -- Next state
+ state_next(180) <= '1';
+ -- Next values for buffered outputs
+ out499_bufn <= '1';
+ out351_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out130 <= '1';
+ out101 <= '1';
+ out112 <= '1';
+ out142 <= '1';
+ out99 <= '1';
+ out54 <= '1';
+ out135 <= '1';
+ out123 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(181) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out260_bufn <= '1';
+ out500_bufn <= '1';
+ out435_bufn <= '1';
+ out395_bufn <= '1';
+ out327_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out501 <= '1';
+ end if;
+
+ if state_cur(182) = '1' then
+ -- Next state
+ state_next(181) <= '1';
+ -- Next values for buffered outputs
+ out260_bufn <= '1';
+ out500_bufn <= '1';
+ out435_bufn <= '1';
+ out395_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(183) = '1' then
+ if rtmcmp183 = '1' then
+ -- Next state
+ state_next(182) <= '1';
+ -- Next values for buffered outputs
+ out457_bufn <= '1';
+ out324_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out125 <= '1';
+ out137 <= '1';
+ out116 <= '1';
+ out56 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(183) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out472_bufn <= '1';
+ out401_bufn <= '1';
+ out512_bufn <= '1';
+ out314_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out513 <= '1';
+ end if;
+
+ if state_cur(184) = '1' then
+ -- Next state
+ state_next(183) <= '1';
+ -- Next values for buffered outputs
+ out472_bufn <= '1';
+ out401_bufn <= '1';
+ out512_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(185) = '1' then
+ -- Next state
+ state_next(92) <= '1';
+ -- Next values for buffered outputs
+ out323_bufn <= '1';
+ out284_bufn <= '1';
+ out217_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out101 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(186) = '1' then
+ -- Next state
+ state_next(107) <= '1';
+ -- Next values for buffered outputs
+ out366_bufn <= '1';
+ out315_bufn <= '1';
+ out281_bufn <= '1';
+ out183_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out142 <= '1';
+ out519 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(187) = '1' then
+ -- Next state
+ state_next(185) <= '1';
+ -- Next values for buffered outputs
+ out290_bufn <= '1';
+ out281_bufn <= '1';
+ out248_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out130 <= '1';
+ out522 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(188) = '1' then
+ -- Next state
+ state_next(184) <= '1';
+ -- Next values for buffered outputs
+ out517_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(189) = '1' then
+ -- Next state
+ state_next(190) <= '1';
+ -- Next values for buffered outputs
+ out526_bufn <= '1';
+ out284_bufn <= '1';
+ out213_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(190) = '1' then
+ -- Next state
+ state_next(173) <= '1';
+ -- Next values for buffered outputs
+ out468_bufn <= '1';
+ out284_bufn <= '1';
+ out143_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(191) = '1' then
+ -- Next state
+ state_next(188) <= '1';
+ -- Next values for buffered outputs
+ out524_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(192) = '1' then
+ -- Next state
+ state_next(191) <= '1';
+ -- Next values for buffered outputs
+ out487_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out58 <= '1';
+ out118 <= '1';
+ out527 <= '1';
+ out44 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(193) = '1' then
+ -- Next state
+ state_next(192) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out312_bufn <= '1';
+ out433_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out103 <= '1';
+ out105 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(194) = '1' then
+ if rtmcmp194 = '1' then
+ -- Next state
+ state_next(193) <= '1';
+ -- Next values for buffered outputs
+ out351_bufn <= '1';
+ out313_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out130 <= '1';
+ out101 <= '1';
+ out112 <= '1';
+ out142 <= '1';
+ out99 <= '1';
+ out54 <= '1';
+ out123 <= '1';
+ out135 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(194) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out263_bufn <= '1';
+ out531_bufn <= '1';
+ out497_bufn <= '1';
+ out521_bufn <= '1';
+ out327_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out528 <= '1';
+ end if;
+
+ if state_cur(195) = '1' then
+ -- Next state
+ state_next(194) <= '1';
+ -- Next values for buffered outputs
+ out263_bufn <= '1';
+ out531_bufn <= '1';
+ out497_bufn <= '1';
+ out521_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(196) = '1' then
+ -- Next state
+ state_next(221) <= '1';
+ -- Next values for buffered outputs
+ out281_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out130 <= '1';
+ out540 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(197) = '1' then
+ if rtmcmp197 = '1' then
+ -- Next state
+ state_next(195) <= '1';
+ -- Next values for buffered outputs
+ out394_bufn <= '1';
+ out324_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out137 <= '1';
+ out125 <= '1';
+ out116 <= '1';
+ out56 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(197) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out500_bufn <= '1';
+ out435_bufn <= '1';
+ out314_bufn <= '1';
+ out293_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out542 <= '1';
+ end if;
+
+ if state_cur(198) = '1' then
+ -- Next state
+ state_next(197) <= '1';
+ -- Next values for buffered outputs
+ out500_bufn <= '1';
+ out435_bufn <= '1';
+ out314_bufn <= '1';
+ out293_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(199) = '1' then
+ -- Next state
+ state_next(198) <= '1';
+ -- Next values for buffered outputs
+ out326_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(200) = '1' then
+ -- Next state
+ state_next(199) <= '1';
+ -- Next values for buffered outputs
+ out341_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(201) = '1' then
+ -- Next state
+ state_next(200) <= '1';
+ -- Next values for buffered outputs
+ out287_bufn <= '1';
+ out285_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out58 <= '1';
+ out118 <= '1';
+ out544 <= '1';
+ out42 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(202) = '1' then
+ -- Next state
+ state_next(201) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out318_bufn <= '1';
+ out322_bufn <= '1';
+ out294_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out103 <= '1';
+ out105 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(203) = '1' then
+ if rtmcmp203 = '1' then
+ -- Next state
+ state_next(202) <= '1';
+ -- Next values for buffered outputs
+ out483_bufn <= '1';
+ out351_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out130 <= '1';
+ out101 <= '1';
+ out142 <= '1';
+ out112 <= '1';
+ out99 <= '1';
+ out54 <= '1';
+ out123 <= '1';
+ out135 <= '1';
+ out114 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(203) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out393_bufn <= '1';
+ out346_bufn <= '1';
+ out344_bufn <= '1';
+ out312_bufn <= '1';
+ out518_bufn <= '1';
+ out327_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out545 <= '1';
+ end if;
+
+ if state_cur(204) = '1' then
+ -- Next state
+ state_next(203) <= '1';
+ -- Next values for buffered outputs
+ out393_bufn <= '1';
+ out346_bufn <= '1';
+ out344_bufn <= '1';
+ out312_bufn <= '1';
+ out518_bufn <= '1';
+ out327_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(205) = '1' then
+ if rtmcmp205 = '1' then
+ -- Next state
+ state_next(204) <= '1';
+ -- Next values for buffered outputs
+ out554_bufn <= '1';
+ out324_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out137 <= '1';
+ out125 <= '1';
+ out116 <= '1';
+ out56 <= '1';
+ out283 <= '1';
+ else -- Stay in the current state
+ state_next(205) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out531_bufn <= '1';
+ out426_bufn <= '1';
+ out461_bufn <= '1';
+ out314_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out555 <= '1';
+ end if;
+
+ if state_cur(206) = '1' then
+ -- Next state
+ state_next(205) <= '1';
+ -- Next values for buffered outputs
+ out531_bufn <= '1';
+ out426_bufn <= '1';
+ out461_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(207) = '1' then
+ -- Next state
+ state_next(206) <= '1';
+ -- Next values for buffered outputs
+ out526_bufn <= '1';
+ out291_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(208) = '1' then
+ -- Next state
+ state_next(207) <= '1';
+ -- Next values for buffered outputs
+ out525_bufn <= '1';
+ out289_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(209) = '1' then
+ -- Next state
+ state_next(208) <= '1';
+ -- Next values for buffered outputs
+ out466_bufn <= '1';
+ out287_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out58 <= '1';
+ out118 <= '1';
+ out559 <= '1';
+ out40 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(210) = '1' then
+ -- Next state
+ state_next(209) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out417_bufn <= '1';
+ out294_bufn <= '1';
+ out282_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out60 <= '1';
+ out103 <= '1';
+ out105 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(211) = '1' then
+ -- Next state
+ state_next(224) <= '1';
+ -- Next values for buffered outputs
+ out459_bufn <= '1';
+ out284_bufn <= '1';
+ out201_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out560 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(212) = '1' then
+ -- Next state
+ state_next(147) <= '1';
+ -- Next values for buffered outputs
+ out49_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out60 <= '1';
+ out561 <= '1';
+ out58 <= '1';
+ out56 <= '1';
+ out54 <= '1';
+ end if;
+
+ if state_cur(213) = '1' then
+ -- Next state
+ state_next(134) <= '1';
+ -- Next values for buffered outputs
+ out433_bufn <= '1';
+ out281_bufn <= '1';
+ out426_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(214) = '1' then
+ -- Next state
+ state_next(140) <= '1';
+ -- Next values for buffered outputs
+ out351_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(215) = '1' then
+ if rtmcmp215 = '1' then
+ -- Next state
+ state_next(127) <= '1';
+ -- Next values for buffered outputs
+ out404_bufn <= '1';
+ out418_bufn <= '1';
+ out281_bufn <= '1';
+ out417_bufn <= '1';
+ -- Last cycle of current state: assignment of non-buffered outputs
+ out125 <= '1';
+ out123 <= '1';
+ out286 <= '1';
+ else -- Stay in the current state
+ state_next(215) <= '1';
+ rtmcounter0_next <= rtmcounter0 + 1;
+ -- Maintain buffered outputs
+ out562_bufn <= '1';
+ out342_bufn <= '1';
+ out284_bufn <= '1';
+ out404_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs;
+ out563 <= '1';
+ end if;
+
+ if state_cur(216) = '1' then
+ -- Next state
+ state_next(214) <= '1';
+ -- Next values for buffered outputs
+ out482_bufn <= '1';
+ out481_bufn <= '1';
+ out357_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(217) = '1' then
+ -- Next state
+ state_next(216) <= '1';
+ -- Next values for buffered outputs
+ out444_bufn <= '1';
+ out281_bufn <= '1';
+ out354_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(218) = '1' then
+ -- Next state
+ state_next(217) <= '1';
+ -- Next values for buffered outputs
+ out566_bufn <= '1';
+ out281_bufn <= '1';
+ out229_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(219) = '1' then
+ -- Next state
+ state_next(218) <= '1';
+ -- Next values for buffered outputs
+ out440_bufn <= '1';
+ out281_bufn <= '1';
+ out162_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(220) = '1' then
+ -- Next state
+ state_next(219) <= '1';
+ -- Next values for buffered outputs
+ out349_bufn <= '1';
+ out284_bufn <= '1';
+ out257_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(221) = '1' then
+ -- Next state
+ state_next(223) <= '1';
+ -- Next values for buffered outputs
+ out325_bufn <= '1';
+ out284_bufn <= '1';
+ out366_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out112 <= '1';
+ out567 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(222) = '1' then
+ -- Next state
+ state_next(220) <= '1';
+ -- Next values for buffered outputs
+ out464_bufn <= '1';
+ out281_bufn <= '1';
+ out451_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(223) = '1' then
+ -- Next state
+ state_next(161) <= '1';
+ -- Next values for buffered outputs
+ out57_bufn <= '1';
+ out414_bufn <= '1';
+ out446_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out105 <= '1';
+ out103 <= '1';
+ out101 <= '1';
+ out99 <= '1';
+ out286 <= '1';
+ end if;
+
+ if state_cur(224) = '1' then
+ -- Next state
+ state_next(222) <= '1';
+ -- Next values for buffered outputs
+ out460_bufn <= '1';
+ out281_bufn <= '1';
+ out232_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(225) = '1' then
+ -- Next state
+ state_next(79) <= '1';
+ -- Next values for buffered outputs
+ out282_bufn <= '1';
+ out281_bufn <= '1';
+ out280_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(226) = '1' then
+ -- Next state
+ state_next(122) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out570 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(227) = '1' then
+ -- Next state
+ state_next(116) <= '1';
+ -- Next values for buffered outputs
+ out400_bufn <= '1';
+ out284_bufn <= '1';
+ out131_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(228) = '1' then
+ -- Next state
+ state_next(136) <= '1';
+ -- Next values for buffered outputs
+ out428_bufn <= '1';
+ out284_bufn <= '1';
+ out126_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(229) = '1' then
+ -- Next state
+ state_next(138) <= '1';
+ -- Next values for buffered outputs
+ out437_bufn <= '1';
+ out281_bufn <= '1';
+ out235_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(230) = '1' then
+ -- Next state
+ state_next(231) <= '1';
+ -- Next values for buffered outputs
+ out499_bufn <= '1';
+ out281_bufn <= '1';
+ out497_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(231) = '1' then
+ -- Next state
+ state_next(155) <= '1';
+ -- Next values for buffered outputs
+ out457_bufn <= '1';
+ out284_bufn <= '1';
+ out364_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out283 <= '1';
+ end if;
+
+ if state_cur(232) = '1' then
+ -- Next state
+ state_next(213) <= '1';
+ -- Next values for buffered outputs
+ out524_bufn <= '1';
+ out281_bufn <= '1';
+ out238_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out286 <= '1';
+ end if;
+
+ if state_cur(233) = '1' then
+ -- Next state
+ state_next(141) <= '1';
+ -- Next values for buffered outputs
+ out440_bufn <= '1';
+ out314_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out118 <= '1';
+ out283 <= '1';
+ end if;
+
+ if state_cur(234) = '1' then
+ -- Next state
+ state_next(129) <= '1';
+ -- Next values for buffered outputs
+ out346_bufn <= '1';
+ out31_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out42 <= '1';
+ out21 <= '1';
+ out572 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(235) = '1' then
+ -- Next state
+ state_next(131) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out120 <= '1';
+ out118 <= '1';
+ out116 <= '1';
+ out114 <= '1';
+ out112 <= '1';
+ out575 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(236) = '1' then
+ -- Next state
+ state_next(234) <= '1';
+ -- Next values for buffered outputs
+ out280_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out577 <= '1';
+ out40 <= '1';
+ out21 <= '1';
+ out412 <= '1';
+ end if;
+
+ if state_cur(237) = '1' then
+ -- Next state
+ state_next(235) <= '1';
+ -- Next values for buffered outputs
+ out111_bufn <= '1';
+ out361_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out52 <= '1';
+ out21 <= '1';
+ out125 <= '1';
+ out123 <= '1';
+ out578 <= '1';
+ out363 <= '1';
+ end if;
+
+ if state_cur(238) = '1' then
+ -- Next state
+ state_next(236) <= '1';
+ -- Next values for buffered outputs
+ out562_bufn <= '1';
+ out35_bufn <= '1';
+ out410_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out580 <= '1';
+ out38 <= '1';
+ out21 <= '1';
+ end if;
+
+ if state_cur(239) = '1' then
+ -- Next state
+ state_next(238) <= '1';
+ -- Next values for buffered outputs
+ out446_bufn <= '1';
+ out36_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out50 <= '1';
+ out46 <= '1';
+ out52 <= '1';
+ out48 <= '1';
+ out44 <= '1';
+ out42 <= '1';
+ out40 <= '1';
+ out38 <= '1';
+ end if;
+
+ if state_cur(240) = '1' then
+ -- Next state
+ state_next(165) <= '1';
+ -- Next values for buffered outputs
+ out466_bufn <= '1';
+ out284_bufn <= '1';
+ out273_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out581 <= '1';
+ out130 <= '1';
+ out283 <= '1';
+ end if;
+
+ -- Reset input
+ if reset = '1' then
+ -- Set the reset state
+ state_next <= (7 => '1', others => '0');
+ -- Note: Resetting all buffers for outputs here is not necessary.
+ -- It would cost hardware. They will be reset at the next clock front.
+ -- Retiming: counters
+ rtmcounter0_next <= (others => '0');
+ -- Reset state: set the buffered outputs
+ end if;
+
+ end process;
+
+ -- Assignment of buffered outputs
+
+ out122 <= out122_buf;
+ out36 <= out36_buf;
+ out49 <= out49_buf;
+ out35 <= out35_buf;
+ out27 <= out27_buf;
+ out16 <= out16_buf;
+ out25 <= out25_buf;
+ out20 <= out20_buf;
+ out57 <= out57_buf;
+ out23 <= out23_buf;
+ out136 <= out136_buf;
+ out0 <= out0_buf;
+ out134 <= out134_buf;
+ out13 <= out13_buf;
+ out131 <= out131_buf;
+ out129 <= out129_buf;
+ out111 <= out111_buf;
+ out31 <= out31_buf;
+ out126 <= out126_buf;
+ out106 <= out106_buf;
+ out124 <= out124_buf;
+ out138 <= out138_buf;
+ out141 <= out141_buf;
+ out143 <= out143_buf;
+ out146 <= out146_buf;
+ out150 <= out150_buf;
+ out153 <= out153_buf;
+ out155 <= out155_buf;
+ out158 <= out158_buf;
+ out162 <= out162_buf;
+ out165 <= out165_buf;
+ out168 <= out168_buf;
+ out171 <= out171_buf;
+ out174 <= out174_buf;
+ out178 <= out178_buf;
+ out181 <= out181_buf;
+ out183 <= out183_buf;
+ out197 <= out197_buf;
+ out201 <= out201_buf;
+ out204 <= out204_buf;
+ out207 <= out207_buf;
+ out210 <= out210_buf;
+ out213 <= out213_buf;
+ out217 <= out217_buf;
+ out220 <= out220_buf;
+ out222 <= out222_buf;
+ out225 <= out225_buf;
+ out229 <= out229_buf;
+ out232 <= out232_buf;
+ out235 <= out235_buf;
+ out238 <= out238_buf;
+ out241 <= out241_buf;
+ out245 <= out245_buf;
+ out248 <= out248_buf;
+ out250 <= out250_buf;
+ out253 <= out253_buf;
+ out257 <= out257_buf;
+ out260 <= out260_buf;
+ out263 <= out263_buf;
+ out266 <= out266_buf;
+ out269 <= out269_buf;
+ out273 <= out273_buf;
+ out276 <= out276_buf;
+ out278 <= out278_buf;
+ out280 <= out280_buf;
+ out281 <= out281_buf;
+ out282 <= out282_buf;
+ out284 <= out284_buf;
+ out285 <= out285_buf;
+ out287 <= out287_buf;
+ out288 <= out288_buf;
+ out289 <= out289_buf;
+ out290 <= out290_buf;
+ out291 <= out291_buf;
+ out292 <= out292_buf;
+ out293 <= out293_buf;
+ out294 <= out294_buf;
+ out295 <= out295_buf;
+ out296 <= out296_buf;
+ out312 <= out312_buf;
+ out313 <= out313_buf;
+ out314 <= out314_buf;
+ out315 <= out315_buf;
+ out318 <= out318_buf;
+ out322 <= out322_buf;
+ out323 <= out323_buf;
+ out324 <= out324_buf;
+ out325 <= out325_buf;
+ out326 <= out326_buf;
+ out327 <= out327_buf;
+ out328 <= out328_buf;
+ out333 <= out333_buf;
+ out341 <= out341_buf;
+ out342 <= out342_buf;
+ out343 <= out343_buf;
+ out344 <= out344_buf;
+ out346 <= out346_buf;
+ out349 <= out349_buf;
+ out351 <= out351_buf;
+ out352 <= out352_buf;
+ out353 <= out353_buf;
+ out354 <= out354_buf;
+ out357 <= out357_buf;
+ out361 <= out361_buf;
+ out364 <= out364_buf;
+ out366 <= out366_buf;
+ out371 <= out371_buf;
+ out393 <= out393_buf;
+ out394 <= out394_buf;
+ out395 <= out395_buf;
+ out400 <= out400_buf;
+ out401 <= out401_buf;
+ out404 <= out404_buf;
+ out407 <= out407_buf;
+ out408 <= out408_buf;
+ out409 <= out409_buf;
+ out410 <= out410_buf;
+ out413 <= out413_buf;
+ out414 <= out414_buf;
+ out417 <= out417_buf;
+ out418 <= out418_buf;
+ out422 <= out422_buf;
+ out426 <= out426_buf;
+ out428 <= out428_buf;
+ out431 <= out431_buf;
+ out433 <= out433_buf;
+ out434 <= out434_buf;
+ out435 <= out435_buf;
+ out436 <= out436_buf;
+ out437 <= out437_buf;
+ out438 <= out438_buf;
+ out440 <= out440_buf;
+ out444 <= out444_buf;
+ out446 <= out446_buf;
+ out451 <= out451_buf;
+ out457 <= out457_buf;
+ out458 <= out458_buf;
+ out459 <= out459_buf;
+ out460 <= out460_buf;
+ out461 <= out461_buf;
+ out463 <= out463_buf;
+ out464 <= out464_buf;
+ out466 <= out466_buf;
+ out468 <= out468_buf;
+ out472 <= out472_buf;
+ out475 <= out475_buf;
+ out481 <= out481_buf;
+ out482 <= out482_buf;
+ out483 <= out483_buf;
+ out487 <= out487_buf;
+ out495 <= out495_buf;
+ out496 <= out496_buf;
+ out497 <= out497_buf;
+ out499 <= out499_buf;
+ out500 <= out500_buf;
+ out512 <= out512_buf;
+ out517 <= out517_buf;
+ out518 <= out518_buf;
+ out521 <= out521_buf;
+ out524 <= out524_buf;
+ out525 <= out525_buf;
+ out526 <= out526_buf;
+ out531 <= out531_buf;
+ out554 <= out554_buf;
+ out562 <= out562_buf;
+ out566 <= out566_buf;
+
+ -- Retiming: the comparators
+
+ rtmcmp90 <= '1' when state_cur(90) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp95 <= '1' when state_cur(95) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp98 <= '1' when state_cur(98) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp104 <= '1' when state_cur(104) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp148 <= '1' when state_cur(148) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp167 <= '1' when state_cur(167) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp174 <= '1' when state_cur(174) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp181 <= '1' when state_cur(181) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp183 <= '1' when state_cur(183) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp194 <= '1' when state_cur(194) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp197 <= '1' when state_cur(197) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp203 <= '1' when state_cur(203) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp205 <= '1' when state_cur(205) = '1' and rtmcounter0 = 1 else '0';
+ rtmcmp215 <= '1' when state_cur(215) = '1' and rtmcounter0 = 1 else '0';
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/idct.d/input_split0.vhd b/testsuite/gna/issue50/idct.d/input_split0.vhd
new file mode 100644
index 000000000..56f2716b9
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/input_split0.vhd
@@ -0,0 +1,74 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity input_split0 is
+ port (
+ ra0_data : out std_logic_vector(31 downto 0);
+ ra0_addr : in std_logic_vector(4 downto 0);
+ ra1_data : out std_logic_vector(31 downto 0);
+ ra1_addr : in std_logic_vector(4 downto 0);
+ ra2_data : out std_logic_vector(31 downto 0);
+ ra2_addr : in std_logic_vector(4 downto 0);
+ ra3_data : out std_logic_vector(31 downto 0);
+ ra3_addr : in std_logic_vector(4 downto 0);
+ clk : in std_logic;
+ wa2_data : in std_logic_vector(31 downto 0);
+ wa2_addr : in std_logic_vector(4 downto 0);
+ wa2_en : in std_logic
+ );
+end input_split0;
+architecture augh of input_split0 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 31) of std_logic_vector(31 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa2_en = '1' then
+ ram( to_integer(wa2_addr) ) <= wa2_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+ ra3_data <= ram( to_integer(ra3_addr) );
+ ra1_data <= ram( to_integer(ra1_addr) );
+ ra2_data <= ram( to_integer(ra2_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/input_split1.vhd b/testsuite/gna/issue50/idct.d/input_split1.vhd
new file mode 100644
index 000000000..8ddb9665f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/input_split1.vhd
@@ -0,0 +1,74 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity input_split1 is
+ port (
+ wa0_data : in std_logic_vector(31 downto 0);
+ wa0_addr : in std_logic_vector(4 downto 0);
+ ra0_data : out std_logic_vector(31 downto 0);
+ ra0_addr : in std_logic_vector(4 downto 0);
+ wa0_en : in std_logic;
+ ra1_data : out std_logic_vector(31 downto 0);
+ ra1_addr : in std_logic_vector(4 downto 0);
+ ra2_data : out std_logic_vector(31 downto 0);
+ ra2_addr : in std_logic_vector(4 downto 0);
+ ra3_data : out std_logic_vector(31 downto 0);
+ ra3_addr : in std_logic_vector(4 downto 0);
+ clk : in std_logic
+ );
+end input_split1;
+architecture augh of input_split1 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 31) of std_logic_vector(31 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+ ra3_data <= ram( to_integer(ra3_addr) );
+ ra1_data <= ram( to_integer(ra1_addr) );
+ ra2_data <= ram( to_integer(ra2_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_189.vhd b/testsuite/gna/issue50/idct.d/mul_189.vhd
new file mode 100644
index 000000000..af014926c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_189.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_189 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(13 downto 0)
+ );
+end mul_189;
+
+architecture augh of mul_189 is
+
+ signal tmp_res : signed(44 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_190.vhd b/testsuite/gna/issue50/idct.d/mul_190.vhd
new file mode 100644
index 000000000..dbdc10130
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_190.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_190 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_190;
+
+architecture augh of mul_190 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_192.vhd b/testsuite/gna/issue50/idct.d/mul_192.vhd
new file mode 100644
index 000000000..914e1f292
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_192.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_192 is
+ port (
+ result : out std_logic_vector(29 downto 0);
+ in_a : in std_logic_vector(29 downto 0);
+ in_b : in std_logic_vector(10 downto 0)
+ );
+end mul_192;
+
+architecture augh of mul_192 is
+
+ signal tmp_res : signed(40 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(29 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_193.vhd b/testsuite/gna/issue50/idct.d/mul_193.vhd
new file mode 100644
index 000000000..4935cf696
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_193.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_193 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_193;
+
+architecture augh of mul_193 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_195.vhd b/testsuite/gna/issue50/idct.d/mul_195.vhd
new file mode 100644
index 000000000..22492f3b4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_195.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_195 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_195;
+
+architecture augh of mul_195 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_196.vhd b/testsuite/gna/issue50/idct.d/mul_196.vhd
new file mode 100644
index 000000000..e298a92d2
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_196.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_196 is
+ port (
+ result : out std_logic_vector(29 downto 0);
+ in_a : in std_logic_vector(29 downto 0);
+ in_b : in std_logic_vector(10 downto 0)
+ );
+end mul_196;
+
+architecture augh of mul_196 is
+
+ signal tmp_res : signed(40 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(29 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_198.vhd b/testsuite/gna/issue50/idct.d/mul_198.vhd
new file mode 100644
index 000000000..48fe0c79d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_198.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_198 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_198;
+
+architecture augh of mul_198 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_199.vhd b/testsuite/gna/issue50/idct.d/mul_199.vhd
new file mode 100644
index 000000000..d229385aa
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_199.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_199 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(13 downto 0)
+ );
+end mul_199;
+
+architecture augh of mul_199 is
+
+ signal tmp_res : signed(44 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_215.vhd b/testsuite/gna/issue50/idct.d/mul_215.vhd
new file mode 100644
index 000000000..4acb0b531
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_215.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_215 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_215;
+
+architecture augh of mul_215 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_216.vhd b/testsuite/gna/issue50/idct.d/mul_216.vhd
new file mode 100644
index 000000000..bb2e15bd4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_216.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_216 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_216;
+
+architecture augh of mul_216 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_218.vhd b/testsuite/gna/issue50/idct.d/mul_218.vhd
new file mode 100644
index 000000000..f97ceb137
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_218.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_218 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_218;
+
+architecture augh of mul_218 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_219.vhd b/testsuite/gna/issue50/idct.d/mul_219.vhd
new file mode 100644
index 000000000..813e12749
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_219.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_219 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_219;
+
+architecture augh of mul_219 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_223.vhd b/testsuite/gna/issue50/idct.d/mul_223.vhd
new file mode 100644
index 000000000..3f28903b7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_223.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_223 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_223;
+
+architecture augh of mul_223 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_230.vhd b/testsuite/gna/issue50/idct.d/mul_230.vhd
new file mode 100644
index 000000000..189ff3e87
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_230.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_230 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_230;
+
+architecture augh of mul_230 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_328.vhd b/testsuite/gna/issue50/idct.d/mul_328.vhd
new file mode 100644
index 000000000..374f73bef
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_328.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_328 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_328;
+
+architecture augh of mul_328 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_331.vhd b/testsuite/gna/issue50/idct.d/mul_331.vhd
new file mode 100644
index 000000000..b5b4522d7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_331.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_331 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_331;
+
+architecture augh of mul_331 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_341.vhd b/testsuite/gna/issue50/idct.d/mul_341.vhd
new file mode 100644
index 000000000..49681535f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_341.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_341 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_341;
+
+architecture augh of mul_341 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_344.vhd b/testsuite/gna/issue50/idct.d/mul_344.vhd
new file mode 100644
index 000000000..2bec140d1
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_344.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_344 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_344;
+
+architecture augh of mul_344 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_353.vhd b/testsuite/gna/issue50/idct.d/mul_353.vhd
new file mode 100644
index 000000000..cbb449a85
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_353.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_353 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_353;
+
+architecture augh of mul_353 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_357.vhd b/testsuite/gna/issue50/idct.d/mul_357.vhd
new file mode 100644
index 000000000..b40f2dc92
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_357.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_357 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_357;
+
+architecture augh of mul_357 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_365.vhd b/testsuite/gna/issue50/idct.d/mul_365.vhd
new file mode 100644
index 000000000..5a80b8482
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_365.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_365 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_365;
+
+architecture augh of mul_365 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_368.vhd b/testsuite/gna/issue50/idct.d/mul_368.vhd
new file mode 100644
index 000000000..52c56106d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_368.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_368 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_368;
+
+architecture augh of mul_368 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_373.vhd b/testsuite/gna/issue50/idct.d/mul_373.vhd
new file mode 100644
index 000000000..78aabd06d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_373.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_373 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_373;
+
+architecture augh of mul_373 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_376.vhd b/testsuite/gna/issue50/idct.d/mul_376.vhd
new file mode 100644
index 000000000..95ebdcd08
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_376.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_376 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_376;
+
+architecture augh of mul_376 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_383.vhd b/testsuite/gna/issue50/idct.d/mul_383.vhd
new file mode 100644
index 000000000..159659041
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_383.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_383 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_383;
+
+architecture augh of mul_383 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_416.vhd b/testsuite/gna/issue50/idct.d/mul_416.vhd
new file mode 100644
index 000000000..cf835ddec
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_416.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_416 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_416;
+
+architecture augh of mul_416 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_442.vhd b/testsuite/gna/issue50/idct.d/mul_442.vhd
new file mode 100644
index 000000000..e4ece2c8a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_442.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_442 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_442;
+
+architecture augh of mul_442 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_445.vhd b/testsuite/gna/issue50/idct.d/mul_445.vhd
new file mode 100644
index 000000000..b47b71fc0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_445.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_445 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_445;
+
+architecture augh of mul_445 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_447.vhd b/testsuite/gna/issue50/idct.d/mul_447.vhd
new file mode 100644
index 000000000..151f84d7d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_447.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_447 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_447;
+
+architecture augh of mul_447 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_448.vhd b/testsuite/gna/issue50/idct.d/mul_448.vhd
new file mode 100644
index 000000000..754f77303
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_448.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_448 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_448;
+
+architecture augh of mul_448 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_456.vhd b/testsuite/gna/issue50/idct.d/mul_456.vhd
new file mode 100644
index 000000000..d012689f1
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_456.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_456 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_456;
+
+architecture augh of mul_456 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_457.vhd b/testsuite/gna/issue50/idct.d/mul_457.vhd
new file mode 100644
index 000000000..db623824f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_457.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_457 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_457;
+
+architecture augh of mul_457 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_460.vhd b/testsuite/gna/issue50/idct.d/mul_460.vhd
new file mode 100644
index 000000000..f81f31d4c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_460.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_460 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_460;
+
+architecture augh of mul_460 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_469.vhd b/testsuite/gna/issue50/idct.d/mul_469.vhd
new file mode 100644
index 000000000..0f9604bf7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_469.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_469 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_469;
+
+architecture augh of mul_469 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_477.vhd b/testsuite/gna/issue50/idct.d/mul_477.vhd
new file mode 100644
index 000000000..7cc4bd860
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_477.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_477 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_477;
+
+architecture augh of mul_477 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_492.vhd b/testsuite/gna/issue50/idct.d/mul_492.vhd
new file mode 100644
index 000000000..7af8f6555
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_492.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_492 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_492;
+
+architecture augh of mul_492 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_495.vhd b/testsuite/gna/issue50/idct.d/mul_495.vhd
new file mode 100644
index 000000000..b60c4c49f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_495.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_495 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_495;
+
+architecture augh of mul_495 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_499.vhd b/testsuite/gna/issue50/idct.d/mul_499.vhd
new file mode 100644
index 000000000..520b5aaa3
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_499.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_499 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_499;
+
+architecture augh of mul_499 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_502.vhd b/testsuite/gna/issue50/idct.d/mul_502.vhd
new file mode 100644
index 000000000..83cb843dc
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_502.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_502 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_502;
+
+architecture augh of mul_502 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_511.vhd b/testsuite/gna/issue50/idct.d/mul_511.vhd
new file mode 100644
index 000000000..a8213e358
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_511.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_511 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_511;
+
+architecture augh of mul_511 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_520.vhd b/testsuite/gna/issue50/idct.d/mul_520.vhd
new file mode 100644
index 000000000..e6703c255
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_520.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_520 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_520;
+
+architecture augh of mul_520 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_524.vhd b/testsuite/gna/issue50/idct.d/mul_524.vhd
new file mode 100644
index 000000000..f938743d6
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_524.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_524 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_524;
+
+architecture augh of mul_524 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_527.vhd b/testsuite/gna/issue50/idct.d/mul_527.vhd
new file mode 100644
index 000000000..3f636e975
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_527.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_527 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_527;
+
+architecture augh of mul_527 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_531.vhd b/testsuite/gna/issue50/idct.d/mul_531.vhd
new file mode 100644
index 000000000..f214ecb26
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_531.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_531 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_531;
+
+architecture augh of mul_531 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_534.vhd b/testsuite/gna/issue50/idct.d/mul_534.vhd
new file mode 100644
index 000000000..672f9820e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_534.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_534 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_534;
+
+architecture augh of mul_534 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_540.vhd b/testsuite/gna/issue50/idct.d/mul_540.vhd
new file mode 100644
index 000000000..ed0311d61
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_540.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_540 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_540;
+
+architecture augh of mul_540 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_543.vhd b/testsuite/gna/issue50/idct.d/mul_543.vhd
new file mode 100644
index 000000000..782a26084
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_543.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_543 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_543;
+
+architecture augh of mul_543 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_547.vhd b/testsuite/gna/issue50/idct.d/mul_547.vhd
new file mode 100644
index 000000000..ede6a5376
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_547.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_547 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_547;
+
+architecture augh of mul_547 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_556.vhd b/testsuite/gna/issue50/idct.d/mul_556.vhd
new file mode 100644
index 000000000..2caa3f3b9
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_556.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_556 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_556;
+
+architecture augh of mul_556 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_559.vhd b/testsuite/gna/issue50/idct.d/mul_559.vhd
new file mode 100644
index 000000000..2ddad5af2
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_559.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_559 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_559;
+
+architecture augh of mul_559 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_560.vhd b/testsuite/gna/issue50/idct.d/mul_560.vhd
new file mode 100644
index 000000000..51d358c61
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_560.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_560 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_560;
+
+architecture augh of mul_560 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_561.vhd b/testsuite/gna/issue50/idct.d/mul_561.vhd
new file mode 100644
index 000000000..325c7e3ca
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_561.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_561 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_561;
+
+architecture augh of mul_561 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_565.vhd b/testsuite/gna/issue50/idct.d/mul_565.vhd
new file mode 100644
index 000000000..1651f8050
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_565.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_565 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_565;
+
+architecture augh of mul_565 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_566.vhd b/testsuite/gna/issue50/idct.d/mul_566.vhd
new file mode 100644
index 000000000..11ce8c301
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_566.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_566 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_566;
+
+architecture augh of mul_566 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_573.vhd b/testsuite/gna/issue50/idct.d/mul_573.vhd
new file mode 100644
index 000000000..9a419fe46
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_573.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_573 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_573;
+
+architecture augh of mul_573 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_577.vhd b/testsuite/gna/issue50/idct.d/mul_577.vhd
new file mode 100644
index 000000000..b8e3f024b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_577.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_577 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_577;
+
+architecture augh of mul_577 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_578.vhd b/testsuite/gna/issue50/idct.d/mul_578.vhd
new file mode 100644
index 000000000..511b8af35
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_578.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_578 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_578;
+
+architecture augh of mul_578 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_579.vhd b/testsuite/gna/issue50/idct.d/mul_579.vhd
new file mode 100644
index 000000000..8eec1bacf
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_579.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_579 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_579;
+
+architecture augh of mul_579 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_589.vhd b/testsuite/gna/issue50/idct.d/mul_589.vhd
new file mode 100644
index 000000000..adbf23bb5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_589.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_589 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_589;
+
+architecture augh of mul_589 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_592.vhd b/testsuite/gna/issue50/idct.d/mul_592.vhd
new file mode 100644
index 000000000..7edf63ecd
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_592.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_592 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_592;
+
+architecture augh of mul_592 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_594.vhd b/testsuite/gna/issue50/idct.d/mul_594.vhd
new file mode 100644
index 000000000..28161e278
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_594.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_594 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_594;
+
+architecture augh of mul_594 is
+
+ signal tmp_res : signed(46 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_595.vhd b/testsuite/gna/issue50/idct.d/mul_595.vhd
new file mode 100644
index 000000000..26e00ce84
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_595.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_595 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end mul_595;
+
+architecture augh of mul_595 is
+
+ signal tmp_res : signed(47 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(31 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/mul_605.vhd b/testsuite/gna/issue50/idct.d/mul_605.vhd
new file mode 100644
index 000000000..46a8124b9
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/mul_605.vhd
@@ -0,0 +1,27 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity mul_605 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+end mul_605;
+
+architecture augh of mul_605 is
+
+ signal tmp_res : signed(45 downto 0);
+
+begin
+
+ -- The actual multiplication
+ tmp_res <= signed(in_a) * signed(in_b);
+
+ -- Set the output
+ result <= std_logic_vector(tmp_res(30 downto 0));
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/muxb_162.vhd b/testsuite/gna/issue50/idct.d/muxb_162.vhd
new file mode 100644
index 000000000..638efae6a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/muxb_162.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_162 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_162;
+
+architecture augh of muxb_162 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/idct.d/muxb_201.vhd b/testsuite/gna/issue50/idct.d/muxb_201.vhd
new file mode 100644
index 000000000..106183a41
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/muxb_201.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_201 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_201;
+
+architecture augh of muxb_201 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/idct.d/muxb_263.vhd b/testsuite/gna/issue50/idct.d/muxb_263.vhd
new file mode 100644
index 000000000..b5e735e12
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/muxb_263.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_263 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_263;
+
+architecture augh of muxb_263 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/idct.d/muxb_265.vhd b/testsuite/gna/issue50/idct.d/muxb_265.vhd
new file mode 100644
index 000000000..17db58201
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/muxb_265.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_265 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_265;
+
+architecture augh of muxb_265 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/idct.d/muxb_322.vhd b/testsuite/gna/issue50/idct.d/muxb_322.vhd
new file mode 100644
index 000000000..e54c9ffde
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/muxb_322.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_322 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_322;
+
+architecture augh of muxb_322 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/idct.d/output_split0.vhd b/testsuite/gna/issue50/idct.d/output_split0.vhd
new file mode 100644
index 000000000..dc3627dcb
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split0.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split0 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split0;
+architecture augh of output_split0 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split1.vhd b/testsuite/gna/issue50/idct.d/output_split1.vhd
new file mode 100644
index 000000000..65980992f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split1.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split1 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split1;
+architecture augh of output_split1 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split2.vhd b/testsuite/gna/issue50/idct.d/output_split2.vhd
new file mode 100644
index 000000000..89e8a1587
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split2.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split2 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split2;
+architecture augh of output_split2 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split3.vhd b/testsuite/gna/issue50/idct.d/output_split3.vhd
new file mode 100644
index 000000000..301380934
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split3.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split3 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split3;
+architecture augh of output_split3 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split4.vhd b/testsuite/gna/issue50/idct.d/output_split4.vhd
new file mode 100644
index 000000000..2e998cef6
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split4.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split4 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split4;
+architecture augh of output_split4 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split5.vhd b/testsuite/gna/issue50/idct.d/output_split5.vhd
new file mode 100644
index 000000000..0a9cfabda
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split5.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split5 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split5;
+architecture augh of output_split5 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split6.vhd b/testsuite/gna/issue50/idct.d/output_split6.vhd
new file mode 100644
index 000000000..888ea9cd2
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split6.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split6 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split6;
+architecture augh of output_split6 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/output_split7.vhd b/testsuite/gna/issue50/idct.d/output_split7.vhd
new file mode 100644
index 000000000..c70550219
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/output_split7.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity output_split7 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+end output_split7;
+architecture augh of output_split7 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 7) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/pkg_tb.vhd b/testsuite/gna/issue50/idct.d/pkg_tb.vhd
new file mode 100644
index 000000000..b770071a4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/pkg_tb.vhd
@@ -0,0 +1,60 @@
+--test bench written by alban bourge @ tima
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+package pkg_tb is
+
+ --fsm state types
+ type state_t is (Rst,Sig_start,Ack_data,Running,Waitfor,Cp_search,Cp_save,Idle,Rst_uut,Rest_ini0,Rest_ini1,Rest,Stop);
+ --context descriptor
+ subtype context_t is std_logic_vector(1 downto 0);
+ --argument width and type of fsm instruction
+ constant ARG_WIDTH : integer := 8;
+ subtype argument_t is unsigned(ARG_WIDTH - 1 downto 0);
+
+ type instruction is
+ record
+ state : state_t;
+ context_uut : context_t;
+ arg : argument_t;
+ end record;
+
+ --reset instruction
+ constant instr_rst : instruction := (state => Rst, context_uut => (others =>'0'), arg => (others =>'0'));
+
+ --ram instruction
+ type ram_instruction is
+ record
+ sel : std_logic;
+ we : std_logic;
+ addr_up : std_logic;
+ addr_z : std_logic;
+ end record;
+
+ constant ram_instr_z : ram_instruction := (sel => '0', we => '0', addr_up => '0', addr_z => '0');
+
+ --assert unit instruction
+ type assert_instruction is
+ record
+ en_feed : std_logic;
+ en_check : std_logic;
+ end record;
+
+ constant assert_instr_z : assert_instruction := (en_feed => '0', en_check => '0');
+
+ --size of instruction table defined by PC_SIZE i.e. width of program counter
+ constant PC_SIZE : integer := 5;
+ type table_behavior is array (0 to 2**PC_SIZE - 1) of instruction;
+
+ --constraint fixed by unit under test (augh dependant)
+ --##CONSTRAINTS_START##--
+ subtype stdin_vector is std_logic_vector(31 downto 0);
+ subtype stdout_vector is std_logic_vector(7 downto 0);
+ subtype cp_vector is std_logic_vector(63 downto 0);
+ --##CONSTRAINTS_END##--
+
+ --assert_uut vector number counter size
+ constant VEC_NO_SIZE : integer := 20;
+
+end pkg_tb;
diff --git a/testsuite/gna/issue50/idct.d/prog.vhd b/testsuite/gna/issue50/idct.d/prog.vhd
new file mode 100644
index 000000000..0bba1578d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/prog.vhd
@@ -0,0 +1,70 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+library work;
+use work.pkg_tb.all;
+
+entity prog is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ step : in std_logic;
+ instr_next : out instruction
+ );
+end prog;
+
+architecture rtl of prog is
+
+ signal instr_n : instruction := instr_rst;
+
+ --Table describing fsm behavior
+ constant fsm_behavior : table_behavior := (
+ --##PROGRAM_GOES_DOWN_HERE##--
+ 0 => (state => Rst, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 1 => (state => Rst, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 2 => (state => Sig_start, context_uut => "01", arg => to_unsigned(0,ARG_WIDTH)),
+ 3 => (state => Ack_data, context_uut => "01", arg => to_unsigned(64,ARG_WIDTH)),
+ 4 => (state => Cp_search, context_uut => "01", arg => to_unsigned(0,ARG_WIDTH)),
+ 5 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 6 => (state => Rst_uut, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 7 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 8 => (state => Sig_start, context_uut => "10", arg => to_unsigned(0,ARG_WIDTH)),
+ 9 => (state => Ack_data, context_uut => "10", arg => to_unsigned(64,ARG_WIDTH)),
+ 10 => (state => Running, context_uut => "10", arg => to_unsigned(20,ARG_WIDTH)),
+ 11 => (state => Cp_search, context_uut => "10", arg => to_unsigned(0,ARG_WIDTH)),
+ 12 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 13 => (state => Rst_uut, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 14 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 15 => (state => Rest_ini0, context_uut => "01", arg => to_unsigned(0,ARG_WIDTH)),
+ 16 => (state => Waitfor, context_uut => "01", arg => to_unsigned(64,ARG_WIDTH)),
+ 17 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 18 => (state => Rst_uut, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 19 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 20 => (state => Rest_ini0, context_uut => "10", arg => to_unsigned(0,ARG_WIDTH)),
+ 21 => (state => Waitfor, context_uut => "10", arg => to_unsigned(64,ARG_WIDTH)),
+ 22 => (state => Stop, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ --##PROGRAM_GOES_OVER_HERE##--
+ others => instr_rst);
+
+ signal pc : unsigned(PC_SIZE - 1 downto 0) := (others => '0');
+
+begin
+
+ drive_state : process (reset,clock) is
+ begin
+ if reset = '1' then
+ instr_n <= instr_rst;
+ pc <= (others => '0');
+ elsif rising_edge(clock) then
+ if (step = '1') then
+ pc <= pc + 1;
+ end if;
+ instr_n <= fsm_behavior(to_integer(pc));
+ end if;
+ end process drive_state;
+
+ --instr_next <= instr_n;
+ instr_next <= fsm_behavior(to_integer(pc));
+
+end rtl;
diff --git a/testsuite/gna/issue50/idct.d/sub_157.vhd b/testsuite/gna/issue50/idct.d/sub_157.vhd
new file mode 100644
index 000000000..60aa5474e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_157.vhd
@@ -0,0 +1,64 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_157 is
+ port (
+ ge : out std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0);
+ sign : in std_logic
+ );
+end sub_157;
+
+architecture augh of sub_157 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+ -- Signals to generate the comparison outputs
+ signal msb_abr : std_logic_vector(2 downto 0);
+ signal tmp_sign : std_logic;
+ signal tmp_eq : std_logic;
+ signal tmp_le : std_logic;
+ signal tmp_ge : std_logic;
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+ -- Other comparison outputs
+
+ -- Temporary signals
+ msb_abr <= carry_inA(32) & carry_inB(32) & carry_res(32);
+ tmp_sign <= sign;
+ tmp_eq <= '1' when in_a = in_b else '0';
+
+ tmp_le <=
+ tmp_eq when msb_abr = "000" or msb_abr = "110" else
+ '1' when msb_abr = "001" or msb_abr = "111" else
+ '1' when tmp_sign = '0' and (msb_abr = "010" or msb_abr = "011") else
+ '1' when tmp_sign = '1' and (msb_abr = "100" or msb_abr = "101") else
+ '0';
+
+ tmp_ge <=
+ '1' when msb_abr = "000" or msb_abr = "110" else
+ '1' when tmp_sign = '0' and (msb_abr = "100" or msb_abr = "101") else
+ '1' when tmp_sign = '1' and (msb_abr = "010" or msb_abr = "011") else
+ '0';
+
+ ge <= tmp_ge;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_159.vhd b/testsuite/gna/issue50/idct.d/sub_159.vhd
new file mode 100644
index 000000000..fb69c2984
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_159.vhd
@@ -0,0 +1,64 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_159 is
+ port (
+ gt : out std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0);
+ sign : in std_logic
+ );
+end sub_159;
+
+architecture augh of sub_159 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+ -- Signals to generate the comparison outputs
+ signal msb_abr : std_logic_vector(2 downto 0);
+ signal tmp_sign : std_logic;
+ signal tmp_eq : std_logic;
+ signal tmp_le : std_logic;
+ signal tmp_ge : std_logic;
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+ -- Other comparison outputs
+
+ -- Temporary signals
+ msb_abr <= carry_inA(32) & carry_inB(32) & carry_res(32);
+ tmp_sign <= sign;
+ tmp_eq <= '1' when in_a = in_b else '0';
+
+ tmp_le <=
+ tmp_eq when msb_abr = "000" or msb_abr = "110" else
+ '1' when msb_abr = "001" or msb_abr = "111" else
+ '1' when tmp_sign = '0' and (msb_abr = "010" or msb_abr = "011") else
+ '1' when tmp_sign = '1' and (msb_abr = "100" or msb_abr = "101") else
+ '0';
+
+ tmp_ge <=
+ '1' when msb_abr = "000" or msb_abr = "110" else
+ '1' when tmp_sign = '0' and (msb_abr = "100" or msb_abr = "101") else
+ '1' when tmp_sign = '1' and (msb_abr = "010" or msb_abr = "011") else
+ '0';
+
+ gt <= not(tmp_le);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_160.vhd b/testsuite/gna/issue50/idct.d/sub_160.vhd
new file mode 100644
index 000000000..33dfaecd3
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_160.vhd
@@ -0,0 +1,64 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_160 is
+ port (
+ le : out std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0);
+ sign : in std_logic
+ );
+end sub_160;
+
+architecture augh of sub_160 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+ -- Signals to generate the comparison outputs
+ signal msb_abr : std_logic_vector(2 downto 0);
+ signal tmp_sign : std_logic;
+ signal tmp_eq : std_logic;
+ signal tmp_le : std_logic;
+ signal tmp_ge : std_logic;
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+ -- Other comparison outputs
+
+ -- Temporary signals
+ msb_abr <= carry_inA(32) & carry_inB(32) & carry_res(32);
+ tmp_sign <= sign;
+ tmp_eq <= '1' when in_a = in_b else '0';
+
+ tmp_le <=
+ tmp_eq when msb_abr = "000" or msb_abr = "110" else
+ '1' when msb_abr = "001" or msb_abr = "111" else
+ '1' when tmp_sign = '0' and (msb_abr = "010" or msb_abr = "011") else
+ '1' when tmp_sign = '1' and (msb_abr = "100" or msb_abr = "101") else
+ '0';
+
+ tmp_ge <=
+ '1' when msb_abr = "000" or msb_abr = "110" else
+ '1' when tmp_sign = '0' and (msb_abr = "100" or msb_abr = "101") else
+ '1' when tmp_sign = '1' and (msb_abr = "010" or msb_abr = "011") else
+ '0';
+
+ le <= tmp_le;
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_185.vhd b/testsuite/gna/issue50/idct.d/sub_185.vhd
new file mode 100644
index 000000000..f6f78be21
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_185.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_185 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_185;
+
+architecture augh of sub_185 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_186.vhd b/testsuite/gna/issue50/idct.d/sub_186.vhd
new file mode 100644
index 000000000..5178357fa
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_186.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_186 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_186;
+
+architecture augh of sub_186 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_187.vhd b/testsuite/gna/issue50/idct.d/sub_187.vhd
new file mode 100644
index 000000000..f38c25ec0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_187.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_187 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_187;
+
+architecture augh of sub_187 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_188.vhd b/testsuite/gna/issue50/idct.d/sub_188.vhd
new file mode 100644
index 000000000..b72ee5f90
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_188.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_188 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_188;
+
+architecture augh of sub_188 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_197.vhd b/testsuite/gna/issue50/idct.d/sub_197.vhd
new file mode 100644
index 000000000..934ef4546
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_197.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_197 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_197;
+
+architecture augh of sub_197 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_200.vhd b/testsuite/gna/issue50/idct.d/sub_200.vhd
new file mode 100644
index 000000000..58eeaf53d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_200.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_200 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_200;
+
+architecture augh of sub_200 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_207.vhd b/testsuite/gna/issue50/idct.d/sub_207.vhd
new file mode 100644
index 000000000..0bbb27861
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_207.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_207 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_207;
+
+architecture augh of sub_207 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_208.vhd b/testsuite/gna/issue50/idct.d/sub_208.vhd
new file mode 100644
index 000000000..04955c989
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_208.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_208 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_208;
+
+architecture augh of sub_208 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_209.vhd b/testsuite/gna/issue50/idct.d/sub_209.vhd
new file mode 100644
index 000000000..7506a9107
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_209.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_209 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_209;
+
+architecture augh of sub_209 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_213.vhd b/testsuite/gna/issue50/idct.d/sub_213.vhd
new file mode 100644
index 000000000..667b143b7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_213.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_213 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_213;
+
+architecture augh of sub_213 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_214.vhd b/testsuite/gna/issue50/idct.d/sub_214.vhd
new file mode 100644
index 000000000..a0cc10e2e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_214.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_214 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_214;
+
+architecture augh of sub_214 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_217.vhd b/testsuite/gna/issue50/idct.d/sub_217.vhd
new file mode 100644
index 000000000..46c08114f
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_217.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_217 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_217;
+
+architecture augh of sub_217 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_220.vhd b/testsuite/gna/issue50/idct.d/sub_220.vhd
new file mode 100644
index 000000000..59afe89d9
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_220.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_220 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_220;
+
+architecture augh of sub_220 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_227.vhd b/testsuite/gna/issue50/idct.d/sub_227.vhd
new file mode 100644
index 000000000..68eb64627
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_227.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_227 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_227;
+
+architecture augh of sub_227 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_243.vhd b/testsuite/gna/issue50/idct.d/sub_243.vhd
new file mode 100644
index 000000000..0082e0974
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_243.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_243 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_243;
+
+architecture augh of sub_243 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_262.vhd b/testsuite/gna/issue50/idct.d/sub_262.vhd
new file mode 100644
index 000000000..607edaf9a
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_262.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_262 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_262;
+
+architecture augh of sub_262 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_284.vhd b/testsuite/gna/issue50/idct.d/sub_284.vhd
new file mode 100644
index 000000000..5a438f2fa
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_284.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_284 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_284;
+
+architecture augh of sub_284 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_303.vhd b/testsuite/gna/issue50/idct.d/sub_303.vhd
new file mode 100644
index 000000000..493d36185
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_303.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_303 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_303;
+
+architecture augh of sub_303 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_332.vhd b/testsuite/gna/issue50/idct.d/sub_332.vhd
new file mode 100644
index 000000000..4b4f033c6
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_332.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_332 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_332;
+
+architecture augh of sub_332 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_337.vhd b/testsuite/gna/issue50/idct.d/sub_337.vhd
new file mode 100644
index 000000000..1e4d7d35e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_337.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_337 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_337;
+
+architecture augh of sub_337 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_345.vhd b/testsuite/gna/issue50/idct.d/sub_345.vhd
new file mode 100644
index 000000000..9fe7ef2d0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_345.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_345 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_345;
+
+architecture augh of sub_345 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_354.vhd b/testsuite/gna/issue50/idct.d/sub_354.vhd
new file mode 100644
index 000000000..afc78d181
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_354.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_354 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_354;
+
+architecture augh of sub_354 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_362.vhd b/testsuite/gna/issue50/idct.d/sub_362.vhd
new file mode 100644
index 000000000..cd1502ed5
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_362.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_362 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_362;
+
+architecture augh of sub_362 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_369.vhd b/testsuite/gna/issue50/idct.d/sub_369.vhd
new file mode 100644
index 000000000..43bb66168
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_369.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_369 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_369;
+
+architecture augh of sub_369 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_370.vhd b/testsuite/gna/issue50/idct.d/sub_370.vhd
new file mode 100644
index 000000000..fcebc0f43
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_370.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_370 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_370;
+
+architecture augh of sub_370 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_377.vhd b/testsuite/gna/issue50/idct.d/sub_377.vhd
new file mode 100644
index 000000000..8acb011b0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_377.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_377 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_377;
+
+architecture augh of sub_377 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_391.vhd b/testsuite/gna/issue50/idct.d/sub_391.vhd
new file mode 100644
index 000000000..b2b1d18e8
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_391.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_391 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_391;
+
+architecture augh of sub_391 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_429.vhd b/testsuite/gna/issue50/idct.d/sub_429.vhd
new file mode 100644
index 000000000..edbf7c17c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_429.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_429 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_429;
+
+architecture augh of sub_429 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_437.vhd b/testsuite/gna/issue50/idct.d/sub_437.vhd
new file mode 100644
index 000000000..3c549f2b0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_437.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_437 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_437;
+
+architecture augh of sub_437 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_446.vhd b/testsuite/gna/issue50/idct.d/sub_446.vhd
new file mode 100644
index 000000000..4b34a5e1e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_446.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_446 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_446;
+
+architecture augh of sub_446 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_449.vhd b/testsuite/gna/issue50/idct.d/sub_449.vhd
new file mode 100644
index 000000000..73bdc38e7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_449.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_449 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_449;
+
+architecture augh of sub_449 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_461.vhd b/testsuite/gna/issue50/idct.d/sub_461.vhd
new file mode 100644
index 000000000..bce5accb7
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_461.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_461 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_461;
+
+architecture augh of sub_461 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_478.vhd b/testsuite/gna/issue50/idct.d/sub_478.vhd
new file mode 100644
index 000000000..6099d883e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_478.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_478 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_478;
+
+architecture augh of sub_478 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_484.vhd b/testsuite/gna/issue50/idct.d/sub_484.vhd
new file mode 100644
index 000000000..a7578a19e
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_484.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_484 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_484;
+
+architecture augh of sub_484 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_488.vhd b/testsuite/gna/issue50/idct.d/sub_488.vhd
new file mode 100644
index 000000000..1f0abf831
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_488.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_488 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_488;
+
+architecture augh of sub_488 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_489.vhd b/testsuite/gna/issue50/idct.d/sub_489.vhd
new file mode 100644
index 000000000..bc1133c19
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_489.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_489 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_489;
+
+architecture augh of sub_489 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_496.vhd b/testsuite/gna/issue50/idct.d/sub_496.vhd
new file mode 100644
index 000000000..6cb195e9c
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_496.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_496 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_496;
+
+architecture augh of sub_496 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_503.vhd b/testsuite/gna/issue50/idct.d/sub_503.vhd
new file mode 100644
index 000000000..cd89e59ca
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_503.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_503 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_503;
+
+architecture augh of sub_503 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_517.vhd b/testsuite/gna/issue50/idct.d/sub_517.vhd
new file mode 100644
index 000000000..1f1714668
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_517.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_517 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_517;
+
+architecture augh of sub_517 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_521.vhd b/testsuite/gna/issue50/idct.d/sub_521.vhd
new file mode 100644
index 000000000..92603bd27
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_521.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_521 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_521;
+
+architecture augh of sub_521 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_528.vhd b/testsuite/gna/issue50/idct.d/sub_528.vhd
new file mode 100644
index 000000000..0f7fbafca
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_528.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_528 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_528;
+
+architecture augh of sub_528 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_544.vhd b/testsuite/gna/issue50/idct.d/sub_544.vhd
new file mode 100644
index 000000000..3583c6ce4
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_544.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_544 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_544;
+
+architecture augh of sub_544 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_553.vhd b/testsuite/gna/issue50/idct.d/sub_553.vhd
new file mode 100644
index 000000000..42c77a6fe
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_553.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_553 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_553;
+
+architecture augh of sub_553 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_562.vhd b/testsuite/gna/issue50/idct.d/sub_562.vhd
new file mode 100644
index 000000000..2ad25bba8
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_562.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_562 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_562;
+
+architecture augh of sub_562 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_563.vhd b/testsuite/gna/issue50/idct.d/sub_563.vhd
new file mode 100644
index 000000000..0a544649b
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_563.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_563 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_563;
+
+architecture augh of sub_563 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_567.vhd b/testsuite/gna/issue50/idct.d/sub_567.vhd
new file mode 100644
index 000000000..42d6ca9e0
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_567.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_567 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_567;
+
+architecture augh of sub_567 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_574.vhd b/testsuite/gna/issue50/idct.d/sub_574.vhd
new file mode 100644
index 000000000..52e0a08e8
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_574.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_574 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_574;
+
+architecture augh of sub_574 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_580.vhd b/testsuite/gna/issue50/idct.d/sub_580.vhd
new file mode 100644
index 000000000..ae77bbd23
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_580.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_580 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_580;
+
+architecture augh of sub_580 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_585.vhd b/testsuite/gna/issue50/idct.d/sub_585.vhd
new file mode 100644
index 000000000..6d809d9e8
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_585.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_585 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_585;
+
+architecture augh of sub_585 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_586.vhd b/testsuite/gna/issue50/idct.d/sub_586.vhd
new file mode 100644
index 000000000..245486a80
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_586.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_586 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_586;
+
+architecture augh of sub_586 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_593.vhd b/testsuite/gna/issue50/idct.d/sub_593.vhd
new file mode 100644
index 000000000..13d9b8296
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_593.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_593 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_593;
+
+architecture augh of sub_593 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_596.vhd b/testsuite/gna/issue50/idct.d/sub_596.vhd
new file mode 100644
index 000000000..5881cf2af
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_596.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_596 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_596;
+
+architecture augh of sub_596 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sub_599.vhd b/testsuite/gna/issue50/idct.d/sub_599.vhd
new file mode 100644
index 000000000..692205a61
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sub_599.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_599 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_599;
+
+architecture augh of sub_599 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/idct.d/sync_ram.vhd b/testsuite/gna/issue50/idct.d/sync_ram.vhd
new file mode 100644
index 000000000..83aecf543
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/sync_ram.vhd
@@ -0,0 +1,42 @@
+-- Simple generic RAM Model
+--
+-- +-----------------------------+
+-- | Copyright 2008 DOULOS |
+-- | designer : JK |
+-- +-----------------------------+
+
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+entity sync_ram is
+ port (
+ clock : in std_logic;
+ we : in std_logic;
+ address : in std_logic_vector;
+ datain : in std_logic_vector;
+ dataout : out std_logic_vector
+ );
+end entity sync_ram;
+
+architecture rtl of sync_ram is
+
+ type ram_type is array (0 to (2**address'length)-1) of std_logic_vector(datain'range);
+ signal ram : ram_type;
+ signal read_address : std_logic_vector(address'range);
+
+begin
+
+ ramproc: process(clock) is
+ begin
+ if rising_edge(clock) then
+ if we = '1' then
+ ram(to_integer(unsigned(address))) <= datain;
+ end if;
+ read_address <= address;
+ end if;
+ end process ramproc;
+
+ dataout <= ram(to_integer(unsigned(read_address)));
+
+end architecture rtl;
diff --git a/testsuite/gna/issue50/idct.d/tb.vhd b/testsuite/gna/issue50/idct.d/tb.vhd
new file mode 100644
index 000000000..94a534963
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/tb.vhd
@@ -0,0 +1,44 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+library work;
+use work.pkg_tb.all;
+
+entity tb is
+end tb;
+
+architecture behavior of tb is
+
+ signal clock : std_logic := '0';
+ signal clock_next : std_logic := '0';
+ signal reset : std_logic := '0';
+ --TOP signals
+ signal n_error : std_logic;
+ signal stopped : std_logic;
+
+begin
+
+ test : entity work.cp3_test(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ n_error => n_error,
+ stopped => stopped
+ );
+
+ --clock generator
+ clock <= clock_next after 10 ns;
+ clock_next <= not clock when stopped = '0' else '0';
+
+ reset_proc : process
+ begin
+ reset <= '1';
+ for i in 1 to 5 loop
+ wait until rising_edge(clock);
+ end loop;
+ reset <= '0';
+ wait;
+ end process reset_proc;
+
+end behavior;
diff --git a/testsuite/gna/issue50/idct.d/top.vhd b/testsuite/gna/issue50/idct.d/top.vhd
new file mode 100644
index 000000000..570e9eb7d
--- /dev/null
+++ b/testsuite/gna/issue50/idct.d/top.vhd
@@ -0,0 +1,6740 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity top is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ start : in std_logic;
+ cp_ok : out std_logic;
+ cp_en : in std_logic;
+ cp_rest : in std_logic;
+ cp_din : in std_logic_vector(63 downto 0);
+ cp_dout : out std_logic_vector(63 downto 0);
+ stdout_data : out std_logic_vector(7 downto 0);
+ stdout_rdy : out std_logic;
+ stdout_ack : in std_logic;
+ stdin_data : in std_logic_vector(31 downto 0);
+ stdin_rdy : out std_logic;
+ stdin_ack : in std_logic
+ );
+end top;
+
+architecture augh of top is
+
+ -- Declaration of components
+
+ component output_split2 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component output_split3 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component sub_159 is
+ port (
+ gt : out std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0);
+ sign : in std_logic
+ );
+ end component;
+
+ component add_165 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component output_split1 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component output_split0 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component add_172 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_176 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_181 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_187 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_189 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(13 downto 0)
+ );
+ end component;
+
+ component add_191 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(30 downto 0)
+ );
+ end component;
+
+ component mul_192 is
+ port (
+ result : out std_logic_vector(29 downto 0);
+ in_a : in std_logic_vector(29 downto 0);
+ in_b : in std_logic_vector(10 downto 0)
+ );
+ end component;
+
+ component mul_193 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_198 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_199 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(13 downto 0)
+ );
+ end component;
+
+ component sub_209 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_212 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_213 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_214 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_215 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_216 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_217 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_218 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_219 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_220 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_223 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_227 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_157 is
+ port (
+ ge : out std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0);
+ sign : in std_logic
+ );
+ end component;
+
+ component add_163 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_164 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component add_170 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_174 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_180 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component sub_186 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_190 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_196 is
+ port (
+ result : out std_logic_vector(29 downto 0);
+ in_a : in std_logic_vector(29 downto 0);
+ in_b : in std_logic_vector(10 downto 0)
+ );
+ end component;
+
+ component sub_200 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_206 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_210 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_171 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_177 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_179 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component mul_195 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_197 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_207 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_230 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_185 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_211 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_226 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_235 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_314 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component sub_160 is
+ port (
+ le : out std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0);
+ sign : in std_logic
+ );
+ end component;
+
+ component add_173 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_182 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_188 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_243 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_262 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component output_split4 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component output_split5 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component output_split6 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component output_split7 is
+ port (
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic_vector(2 downto 0);
+ ra0_data : out std_logic_vector(7 downto 0);
+ ra0_addr : in std_logic_vector(2 downto 0);
+ wa0_en : in std_logic;
+ clk : in std_logic
+ );
+ end component;
+
+ component input_split0 is
+ port (
+ ra0_data : out std_logic_vector(31 downto 0);
+ ra0_addr : in std_logic_vector(4 downto 0);
+ ra1_data : out std_logic_vector(31 downto 0);
+ ra1_addr : in std_logic_vector(4 downto 0);
+ ra2_data : out std_logic_vector(31 downto 0);
+ ra2_addr : in std_logic_vector(4 downto 0);
+ ra3_data : out std_logic_vector(31 downto 0);
+ ra3_addr : in std_logic_vector(4 downto 0);
+ clk : in std_logic;
+ wa2_data : in std_logic_vector(31 downto 0);
+ wa2_addr : in std_logic_vector(4 downto 0);
+ wa2_en : in std_logic
+ );
+ end component;
+
+ component add_194 is
+ port (
+ result : out std_logic_vector(29 downto 0);
+ in_a : in std_logic_vector(29 downto 0);
+ in_b : in std_logic_vector(29 downto 0)
+ );
+ end component;
+
+ component add_205 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_254 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_276 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component sub_284 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component input_split1 is
+ port (
+ wa0_data : in std_logic_vector(31 downto 0);
+ wa0_addr : in std_logic_vector(4 downto 0);
+ ra0_data : out std_logic_vector(31 downto 0);
+ ra0_addr : in std_logic_vector(4 downto 0);
+ wa0_en : in std_logic;
+ ra1_data : out std_logic_vector(31 downto 0);
+ ra1_addr : in std_logic_vector(4 downto 0);
+ ra2_data : out std_logic_vector(31 downto 0);
+ ra2_addr : in std_logic_vector(4 downto 0);
+ ra3_data : out std_logic_vector(31 downto 0);
+ ra3_addr : in std_logic_vector(4 downto 0);
+ clk : in std_logic
+ );
+ end component;
+
+ component add_166 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_168 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_178 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_183 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_332 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_341 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_357 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_365 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_368 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_369 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_370 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_377 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component cmp_398 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_400 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_404 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_406 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_408 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_410 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_412 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+ end component;
+
+ component sub_429 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_466 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_496 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_521 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_528 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component fsm_23 is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ in0 : in std_logic;
+ out181 : out std_logic;
+ out182 : out std_logic;
+ out183 : out std_logic;
+ out184 : out std_logic;
+ out185 : out std_logic;
+ out8 : out std_logic;
+ out13 : out std_logic;
+ out14 : out std_logic;
+ out16 : out std_logic;
+ out18 : out std_logic;
+ out19 : out std_logic;
+ out20 : out std_logic;
+ out21 : out std_logic;
+ out22 : out std_logic;
+ in2 : in std_logic;
+ out23 : out std_logic;
+ out24 : out std_logic;
+ out25 : out std_logic;
+ out26 : out std_logic;
+ out27 : out std_logic;
+ out28 : out std_logic;
+ out29 : out std_logic;
+ out30 : out std_logic;
+ out31 : out std_logic;
+ out33 : out std_logic;
+ out35 : out std_logic;
+ out36 : out std_logic;
+ out38 : out std_logic;
+ out40 : out std_logic;
+ out42 : out std_logic;
+ in3 : in std_logic;
+ out44 : out std_logic;
+ out46 : out std_logic;
+ out48 : out std_logic;
+ out49 : out std_logic;
+ out50 : out std_logic;
+ out52 : out std_logic;
+ out54 : out std_logic;
+ out56 : out std_logic;
+ out57 : out std_logic;
+ out58 : out std_logic;
+ in4 : in std_logic;
+ out60 : out std_logic;
+ in5 : in std_logic;
+ out164 : out std_logic;
+ out165 : out std_logic;
+ out167 : out std_logic;
+ out168 : out std_logic;
+ out170 : out std_logic;
+ out171 : out std_logic;
+ out173 : out std_logic;
+ out174 : out std_logic;
+ out176 : out std_logic;
+ out178 : out std_logic;
+ out0 : out std_logic;
+ out1 : out std_logic;
+ out2 : out std_logic;
+ in1 : in std_logic;
+ out4 : out std_logic;
+ out90 : out std_logic;
+ out91 : out std_logic;
+ out97 : out std_logic;
+ out99 : out std_logic;
+ out101 : out std_logic;
+ in6 : in std_logic;
+ out103 : out std_logic;
+ out105 : out std_logic;
+ out106 : out std_logic;
+ out107 : out std_logic;
+ out108 : out std_logic;
+ out135 : out std_logic;
+ out136 : out std_logic;
+ out137 : out std_logic;
+ out138 : out std_logic;
+ in11 : in std_logic;
+ out140 : out std_logic;
+ out141 : out std_logic;
+ out142 : out std_logic;
+ out143 : out std_logic;
+ out145 : out std_logic;
+ out146 : out std_logic;
+ out148 : out std_logic;
+ out150 : out std_logic;
+ out153 : out std_logic;
+ out154 : out std_logic;
+ out155 : out std_logic;
+ out156 : out std_logic;
+ out157 : out std_logic;
+ out158 : out std_logic;
+ out159 : out std_logic;
+ out160 : out std_logic;
+ out161 : out std_logic;
+ out162 : out std_logic;
+ out111 : out std_logic;
+ out112 : out std_logic;
+ out114 : out std_logic;
+ out116 : out std_logic;
+ out118 : out std_logic;
+ out120 : out std_logic;
+ out121 : out std_logic;
+ out122 : out std_logic;
+ out123 : out std_logic;
+ out124 : out std_logic;
+ out125 : out std_logic;
+ out126 : out std_logic;
+ in7 : in std_logic;
+ out129 : out std_logic;
+ out130 : out std_logic;
+ in8 : in std_logic;
+ out131 : out std_logic;
+ in9 : in std_logic;
+ out132 : out std_logic;
+ out133 : out std_logic;
+ out134 : out std_logic;
+ in10 : in std_logic;
+ out186 : out std_logic;
+ out187 : out std_logic;
+ out190 : out std_logic;
+ out195 : out std_logic;
+ out197 : out std_logic;
+ out198 : out std_logic;
+ out199 : out std_logic;
+ out200 : out std_logic;
+ out201 : out std_logic;
+ out203 : out std_logic;
+ out204 : out std_logic;
+ out206 : out std_logic;
+ out207 : out std_logic;
+ out209 : out std_logic;
+ out210 : out std_logic;
+ out212 : out std_logic;
+ out213 : out std_logic;
+ out215 : out std_logic;
+ out217 : out std_logic;
+ out220 : out std_logic;
+ out221 : out std_logic;
+ out222 : out std_logic;
+ out223 : out std_logic;
+ out224 : out std_logic;
+ out225 : out std_logic;
+ out226 : out std_logic;
+ out227 : out std_logic;
+ out228 : out std_logic;
+ out229 : out std_logic;
+ out231 : out std_logic;
+ out232 : out std_logic;
+ out234 : out std_logic;
+ out235 : out std_logic;
+ out237 : out std_logic;
+ out238 : out std_logic;
+ out240 : out std_logic;
+ out241 : out std_logic;
+ out243 : out std_logic;
+ out245 : out std_logic;
+ out248 : out std_logic;
+ out249 : out std_logic;
+ out250 : out std_logic;
+ out251 : out std_logic;
+ out252 : out std_logic;
+ out253 : out std_logic;
+ out254 : out std_logic;
+ out255 : out std_logic;
+ out256 : out std_logic;
+ out257 : out std_logic;
+ out259 : out std_logic;
+ out260 : out std_logic;
+ out262 : out std_logic;
+ out263 : out std_logic;
+ out265 : out std_logic;
+ out266 : out std_logic;
+ out268 : out std_logic;
+ out269 : out std_logic;
+ out271 : out std_logic;
+ out273 : out std_logic;
+ out276 : out std_logic;
+ out277 : out std_logic;
+ out278 : out std_logic;
+ out279 : out std_logic;
+ out280 : out std_logic;
+ out281 : out std_logic;
+ out282 : out std_logic;
+ out283 : out std_logic;
+ out284 : out std_logic;
+ out285 : out std_logic;
+ out286 : out std_logic;
+ out287 : out std_logic;
+ out288 : out std_logic;
+ out289 : out std_logic;
+ out290 : out std_logic;
+ out291 : out std_logic;
+ out292 : out std_logic;
+ out293 : out std_logic;
+ out294 : out std_logic;
+ out295 : out std_logic;
+ out296 : out std_logic;
+ out297 : out std_logic;
+ out298 : out std_logic;
+ out311 : out std_logic;
+ out312 : out std_logic;
+ out313 : out std_logic;
+ out314 : out std_logic;
+ out315 : out std_logic;
+ out316 : out std_logic;
+ out318 : out std_logic;
+ out321 : out std_logic;
+ out322 : out std_logic;
+ out323 : out std_logic;
+ out324 : out std_logic;
+ out325 : out std_logic;
+ out326 : out std_logic;
+ out327 : out std_logic;
+ out328 : out std_logic;
+ out329 : out std_logic;
+ out333 : out std_logic;
+ out341 : out std_logic;
+ out342 : out std_logic;
+ out343 : out std_logic;
+ out344 : out std_logic;
+ out345 : out std_logic;
+ out346 : out std_logic;
+ out349 : out std_logic;
+ out350 : out std_logic;
+ out351 : out std_logic;
+ out352 : out std_logic;
+ out353 : out std_logic;
+ out354 : out std_logic;
+ out355 : out std_logic;
+ out357 : out std_logic;
+ out361 : out std_logic;
+ out362 : out std_logic;
+ out363 : out std_logic;
+ out364 : out std_logic;
+ out366 : out std_logic;
+ out367 : out std_logic;
+ out371 : out std_logic;
+ out372 : out std_logic;
+ out373 : out std_logic;
+ out382 : out std_logic;
+ out383 : out std_logic;
+ out385 : out std_logic;
+ out393 : out std_logic;
+ out394 : out std_logic;
+ out395 : out std_logic;
+ out396 : out std_logic;
+ out398 : out std_logic;
+ out400 : out std_logic;
+ out401 : out std_logic;
+ out402 : out std_logic;
+ out404 : out std_logic;
+ out406 : out std_logic;
+ out407 : out std_logic;
+ out408 : out std_logic;
+ out409 : out std_logic;
+ out410 : out std_logic;
+ out411 : out std_logic;
+ out412 : out std_logic;
+ out413 : out std_logic;
+ out414 : out std_logic;
+ out416 : out std_logic;
+ out417 : out std_logic;
+ out418 : out std_logic;
+ out419 : out std_logic;
+ out422 : out std_logic;
+ out423 : out std_logic;
+ out425 : out std_logic;
+ out426 : out std_logic;
+ out428 : out std_logic;
+ out429 : out std_logic;
+ out430 : out std_logic;
+ out431 : out std_logic;
+ out433 : out std_logic;
+ out434 : out std_logic;
+ out435 : out std_logic;
+ out436 : out std_logic;
+ out437 : out std_logic;
+ out438 : out std_logic;
+ out440 : out std_logic;
+ out441 : out std_logic;
+ out443 : out std_logic;
+ out444 : out std_logic;
+ out445 : out std_logic;
+ out446 : out std_logic;
+ out447 : out std_logic;
+ out450 : out std_logic;
+ out451 : out std_logic;
+ out454 : out std_logic;
+ out455 : out std_logic;
+ out457 : out std_logic;
+ out458 : out std_logic;
+ out459 : out std_logic;
+ out460 : out std_logic;
+ out461 : out std_logic;
+ out462 : out std_logic;
+ out463 : out std_logic;
+ out464 : out std_logic;
+ out465 : out std_logic;
+ out466 : out std_logic;
+ out467 : out std_logic;
+ out468 : out std_logic;
+ out469 : out std_logic;
+ out472 : out std_logic;
+ out475 : out std_logic;
+ out481 : out std_logic;
+ out482 : out std_logic;
+ out483 : out std_logic;
+ out484 : out std_logic;
+ out487 : out std_logic;
+ out488 : out std_logic;
+ out491 : out std_logic;
+ out495 : out std_logic;
+ out496 : out std_logic;
+ out497 : out std_logic;
+ out498 : out std_logic;
+ out499 : out std_logic;
+ out500 : out std_logic;
+ out501 : out std_logic;
+ out512 : out std_logic;
+ out513 : out std_logic;
+ out517 : out std_logic;
+ out518 : out std_logic;
+ out519 : out std_logic;
+ out521 : out std_logic;
+ out522 : out std_logic;
+ out524 : out std_logic;
+ out525 : out std_logic;
+ out526 : out std_logic;
+ out527 : out std_logic;
+ out528 : out std_logic;
+ out531 : out std_logic;
+ out540 : out std_logic;
+ out542 : out std_logic;
+ out544 : out std_logic;
+ out545 : out std_logic;
+ out554 : out std_logic;
+ out555 : out std_logic;
+ out559 : out std_logic;
+ out560 : out std_logic;
+ out561 : out std_logic;
+ out562 : out std_logic;
+ out563 : out std_logic;
+ out566 : out std_logic;
+ out567 : out std_logic;
+ out570 : out std_logic;
+ out572 : out std_logic;
+ out575 : out std_logic;
+ out577 : out std_logic;
+ out578 : out std_logic;
+ out580 : out std_logic;
+ out581 : out std_logic
+ );
+ end component;
+
+ component add_167 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_169 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_175 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_255 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component sub_362 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_376 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_420 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component sub_446 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_456 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_457 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_461 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_517 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_560 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_565 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_578 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component muxb_162 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component add_184 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component muxb_201 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component cmp_202 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_203 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+ end component;
+
+ component cmp_204 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+ end component;
+
+ component sub_208 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_236 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component muxb_263 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component muxb_265 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component add_277 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component add_295 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_296 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component sub_303 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_315 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component muxb_322 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component add_323 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_324 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_325 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+ end component;
+
+ component mul_328 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_331 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_337 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_338 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_344 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_345 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_350 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_353 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_354 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_373 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component add_382 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_383 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_390 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_391 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component cmp_392 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(31 downto 0);
+ in1 : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_393 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component cmp_396 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_402 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_411 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic;
+ in1 : in std_logic
+ );
+ end component;
+
+ component cmp_413 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(31 downto 0);
+ in1 : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_416 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_419 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_430 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_437 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_442 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_445 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_447 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_448 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_449 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_460 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_469 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_474 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_477 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_478 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_483 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_484 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_487 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_488 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_489 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_492 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_495 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_499 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_502 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_503 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_508 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_511 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_516 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_520 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_524 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_527 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_531 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_534 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_537 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_540 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_543 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_544 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_547 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component add_552 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_553 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_556 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_559 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_561 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_562 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_563 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_564 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_566 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_567 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_570 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_573 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_574 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_577 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_579 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_580 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_585 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_586 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_589 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component mul_592 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component sub_593 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component mul_594 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ component mul_595 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component sub_596 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_599 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_600 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component add_601 is
+ port (
+ result : out std_logic_vector(26 downto 0);
+ in_a : in std_logic_vector(26 downto 0);
+ in_b : in std_logic_vector(26 downto 0)
+ );
+ end component;
+
+ component add_602 is
+ port (
+ result : out std_logic_vector(19 downto 0);
+ in_a : in std_logic_vector(19 downto 0);
+ in_b : in std_logic_vector(19 downto 0)
+ );
+ end component;
+
+ component mul_605 is
+ port (
+ result : out std_logic_vector(30 downto 0);
+ in_a : in std_logic_vector(30 downto 0);
+ in_b : in std_logic_vector(14 downto 0)
+ );
+ end component;
+
+ -- Declaration of signals
+
+ signal sig_clock : std_logic;
+ signal sig_reset : std_logic;
+ signal augh_test_9 : std_logic;
+ signal augh_test_11 : std_logic;
+ signal sig_start : std_logic;
+ signal test_cp_0_16 : std_logic;
+ signal test_cp_1_17 : std_logic;
+ signal memextrct_loop_sig_21 : std_logic;
+ signal psc_loop_sig_20 : std_logic;
+ signal memextrct_loop_sig_22 : std_logic;
+ signal sig_606 : std_logic_vector(30 downto 0);
+ signal sig_607 : std_logic_vector(19 downto 0);
+ signal sig_608 : std_logic_vector(26 downto 0);
+ signal sig_609 : std_logic_vector(31 downto 0);
+ signal sig_610 : std_logic_vector(31 downto 0);
+ signal sig_611 : std_logic_vector(31 downto 0);
+ signal sig_612 : std_logic_vector(31 downto 0);
+ signal sig_613 : std_logic_vector(31 downto 0);
+ signal sig_614 : std_logic_vector(31 downto 0);
+ signal sig_615 : std_logic_vector(31 downto 0);
+ signal sig_616 : std_logic_vector(31 downto 0);
+ signal sig_617 : std_logic_vector(31 downto 0);
+ signal sig_618 : std_logic_vector(31 downto 0);
+ signal sig_619 : std_logic_vector(31 downto 0);
+ signal sig_620 : std_logic_vector(31 downto 0);
+ signal sig_621 : std_logic_vector(30 downto 0);
+ signal sig_622 : std_logic_vector(31 downto 0);
+ signal sig_623 : std_logic_vector(30 downto 0);
+ signal sig_624 : std_logic_vector(31 downto 0);
+ signal sig_625 : std_logic_vector(31 downto 0);
+ signal sig_626 : std_logic_vector(31 downto 0);
+ signal sig_627 : std_logic_vector(31 downto 0);
+ signal sig_628 : std_logic_vector(31 downto 0);
+ signal sig_629 : std_logic_vector(31 downto 0);
+ signal sig_630 : std_logic_vector(31 downto 0);
+ signal sig_631 : std_logic_vector(30 downto 0);
+ signal sig_632 : std_logic_vector(30 downto 0);
+ signal sig_633 : std_logic_vector(31 downto 0);
+ signal sig_634 : std_logic_vector(31 downto 0);
+ signal sig_635 : std_logic_vector(30 downto 0);
+ signal sig_636 : std_logic_vector(31 downto 0);
+ signal sig_637 : std_logic_vector(31 downto 0);
+ signal sig_638 : std_logic_vector(31 downto 0);
+ signal sig_639 : std_logic_vector(31 downto 0);
+ signal sig_640 : std_logic_vector(30 downto 0);
+ signal sig_641 : std_logic_vector(30 downto 0);
+ signal sig_642 : std_logic_vector(31 downto 0);
+ signal sig_643 : std_logic_vector(31 downto 0);
+ signal sig_644 : std_logic_vector(30 downto 0);
+ signal sig_645 : std_logic_vector(31 downto 0);
+ signal sig_646 : std_logic_vector(30 downto 0);
+ signal sig_647 : std_logic_vector(31 downto 0);
+ signal sig_648 : std_logic_vector(31 downto 0);
+ signal sig_649 : std_logic_vector(31 downto 0);
+ signal sig_650 : std_logic_vector(31 downto 0);
+ signal sig_651 : std_logic_vector(31 downto 0);
+ signal sig_652 : std_logic_vector(31 downto 0);
+ signal sig_653 : std_logic_vector(31 downto 0);
+ signal sig_654 : std_logic_vector(31 downto 0);
+ signal sig_655 : std_logic_vector(31 downto 0);
+ signal sig_656 : std_logic_vector(31 downto 0);
+ signal sig_657 : std_logic_vector(31 downto 0);
+ signal sig_658 : std_logic_vector(31 downto 0);
+ signal sig_659 : std_logic_vector(30 downto 0);
+ signal sig_660 : std_logic_vector(31 downto 0);
+ signal sig_661 : std_logic_vector(30 downto 0);
+ signal sig_662 : std_logic_vector(31 downto 0);
+ signal sig_663 : std_logic_vector(31 downto 0);
+ signal sig_664 : std_logic_vector(31 downto 0);
+ signal sig_665 : std_logic_vector(31 downto 0);
+ signal sig_666 : std_logic_vector(31 downto 0);
+ signal sig_667 : std_logic_vector(31 downto 0);
+ signal sig_668 : std_logic_vector(31 downto 0);
+ signal sig_669 : std_logic_vector(31 downto 0);
+ signal sig_670 : std_logic_vector(26 downto 0);
+ signal sig_671 : std_logic_vector(30 downto 0);
+ signal sig_672 : std_logic;
+ signal sig_673 : std_logic;
+ signal sig_674 : std_logic;
+ signal sig_675 : std_logic_vector(31 downto 0);
+ signal sig_676 : std_logic_vector(31 downto 0);
+ signal sig_677 : std_logic_vector(31 downto 0);
+ signal sig_678 : std_logic_vector(30 downto 0);
+ signal sig_679 : std_logic_vector(31 downto 0);
+ signal sig_680 : std_logic_vector(31 downto 0);
+ signal sig_681 : std_logic_vector(31 downto 0);
+ signal sig_682 : std_logic_vector(30 downto 0);
+ signal sig_683 : std_logic_vector(31 downto 0);
+ signal sig_684 : std_logic_vector(31 downto 0);
+ signal sig_685 : std_logic_vector(31 downto 0);
+ signal sig_686 : std_logic_vector(31 downto 0);
+ signal sig_687 : std_logic_vector(31 downto 0);
+ signal sig_688 : std_logic_vector(31 downto 0);
+ signal sig_689 : std_logic_vector(31 downto 0);
+ signal sig_690 : std_logic;
+ signal sig_691 : std_logic_vector(15 downto 0);
+ signal sig_692 : std_logic;
+ signal sig_693 : std_logic_vector(19 downto 0);
+ signal sig_694 : std_logic_vector(31 downto 0);
+ signal sig_695 : std_logic_vector(19 downto 0);
+ signal sig_696 : std_logic_vector(26 downto 0);
+ signal sig_697 : std_logic_vector(19 downto 0);
+ signal sig_698 : std_logic;
+ signal sig_699 : std_logic;
+ signal sig_700 : std_logic_vector(19 downto 0);
+ signal sig_701 : std_logic_vector(31 downto 0);
+ signal sig_702 : std_logic;
+ signal sig_703 : std_logic;
+ signal sig_704 : std_logic_vector(31 downto 0);
+ signal sig_705 : std_logic;
+ signal sig_706 : std_logic_vector(31 downto 0);
+ signal sig_707 : std_logic_vector(31 downto 0);
+ signal sig_708 : std_logic_vector(31 downto 0);
+ signal sig_709 : std_logic_vector(31 downto 0);
+ signal sig_710 : std_logic_vector(31 downto 0);
+ signal sig_711 : std_logic_vector(31 downto 0);
+ signal sig_712 : std_logic_vector(30 downto 0);
+ signal sig_713 : std_logic_vector(31 downto 0);
+ signal sig_714 : std_logic_vector(19 downto 0);
+ signal sig_715 : std_logic_vector(31 downto 0);
+ signal sig_716 : std_logic_vector(31 downto 0);
+ signal sig_717 : std_logic_vector(19 downto 0);
+ signal sig_718 : std_logic_vector(26 downto 0);
+ signal sig_719 : std_logic_vector(26 downto 0);
+ signal sig_720 : std_logic_vector(26 downto 0);
+ signal sig_721 : std_logic;
+ signal sig_722 : std_logic;
+ signal sig_723 : std_logic;
+ signal sig_724 : std_logic;
+ signal sig_725 : std_logic;
+ signal sig_726 : std_logic;
+ signal sig_727 : std_logic;
+ signal sig_728 : std_logic;
+ signal sig_729 : std_logic;
+ signal sig_730 : std_logic;
+ signal sig_731 : std_logic;
+ signal sig_732 : std_logic;
+ signal sig_733 : std_logic;
+ signal sig_734 : std_logic;
+ signal sig_735 : std_logic;
+ signal sig_736 : std_logic;
+ signal sig_737 : std_logic;
+ signal sig_738 : std_logic;
+ signal sig_739 : std_logic;
+ signal sig_740 : std_logic;
+ signal sig_741 : std_logic;
+ signal sig_742 : std_logic;
+ signal sig_743 : std_logic;
+ signal sig_744 : std_logic;
+ signal sig_745 : std_logic;
+ signal sig_746 : std_logic;
+ signal sig_747 : std_logic;
+ signal sig_748 : std_logic;
+ signal sig_749 : std_logic;
+ signal sig_750 : std_logic;
+ signal sig_751 : std_logic;
+ signal sig_752 : std_logic;
+ signal sig_753 : std_logic;
+ signal sig_754 : std_logic;
+ signal sig_755 : std_logic;
+ signal sig_756 : std_logic;
+ signal sig_757 : std_logic;
+ signal sig_758 : std_logic;
+ signal sig_759 : std_logic;
+ signal sig_760 : std_logic;
+ signal sig_761 : std_logic;
+ signal sig_762 : std_logic;
+ signal sig_763 : std_logic;
+ signal sig_764 : std_logic;
+ signal sig_765 : std_logic;
+ signal sig_766 : std_logic;
+ signal sig_767 : std_logic;
+ signal sig_768 : std_logic;
+ signal sig_769 : std_logic;
+ signal sig_770 : std_logic;
+ signal sig_771 : std_logic;
+ signal sig_772 : std_logic;
+ signal sig_773 : std_logic;
+ signal sig_774 : std_logic;
+ signal sig_775 : std_logic;
+ signal sig_776 : std_logic;
+ signal sig_777 : std_logic;
+ signal sig_778 : std_logic;
+ signal sig_779 : std_logic;
+ signal sig_780 : std_logic;
+ signal sig_781 : std_logic;
+ signal sig_782 : std_logic;
+ signal sig_783 : std_logic;
+ signal sig_784 : std_logic;
+ signal sig_785 : std_logic;
+ signal sig_786 : std_logic;
+ signal sig_787 : std_logic;
+ signal sig_788 : std_logic;
+ signal sig_789 : std_logic;
+ signal sig_790 : std_logic;
+ signal sig_791 : std_logic;
+ signal sig_792 : std_logic;
+ signal sig_793 : std_logic;
+ signal sig_794 : std_logic;
+ signal sig_795 : std_logic;
+ signal sig_796 : std_logic;
+ signal sig_797 : std_logic;
+ signal sig_798 : std_logic;
+ signal sig_799 : std_logic;
+ signal sig_800 : std_logic;
+ signal sig_801 : std_logic;
+ signal sig_802 : std_logic;
+ signal sig_803 : std_logic;
+ signal sig_804 : std_logic;
+ signal sig_805 : std_logic;
+ signal sig_806 : std_logic;
+ signal sig_807 : std_logic;
+ signal sig_808 : std_logic;
+ signal sig_809 : std_logic;
+ signal sig_810 : std_logic;
+ signal sig_811 : std_logic;
+ signal sig_812 : std_logic;
+ signal sig_813 : std_logic;
+ signal sig_814 : std_logic;
+ signal sig_815 : std_logic;
+ signal sig_816 : std_logic;
+ signal sig_817 : std_logic;
+ signal sig_818 : std_logic;
+ signal sig_819 : std_logic;
+ signal sig_820 : std_logic;
+ signal sig_821 : std_logic;
+ signal sig_822 : std_logic;
+ signal sig_823 : std_logic;
+ signal sig_824 : std_logic;
+ signal sig_825 : std_logic;
+ signal sig_826 : std_logic;
+ signal sig_827 : std_logic;
+ signal sig_828 : std_logic;
+ signal sig_829 : std_logic;
+ signal sig_830 : std_logic;
+ signal sig_831 : std_logic;
+ signal sig_832 : std_logic;
+ signal sig_833 : std_logic;
+ signal sig_834 : std_logic;
+ signal sig_835 : std_logic;
+ signal sig_836 : std_logic;
+ signal sig_837 : std_logic;
+ signal sig_838 : std_logic;
+ signal sig_839 : std_logic;
+ signal sig_840 : std_logic;
+ signal sig_841 : std_logic;
+ signal sig_842 : std_logic;
+ signal sig_843 : std_logic;
+ signal sig_844 : std_logic;
+ signal sig_845 : std_logic;
+ signal sig_846 : std_logic;
+ signal sig_847 : std_logic;
+ signal sig_848 : std_logic;
+ signal sig_849 : std_logic;
+ signal sig_850 : std_logic;
+ signal sig_851 : std_logic;
+ signal sig_852 : std_logic;
+ signal sig_853 : std_logic;
+ signal sig_854 : std_logic;
+ signal sig_855 : std_logic;
+ signal sig_856 : std_logic;
+ signal sig_857 : std_logic;
+ signal sig_858 : std_logic;
+ signal sig_859 : std_logic;
+ signal sig_860 : std_logic;
+ signal sig_861 : std_logic;
+ signal sig_862 : std_logic;
+ signal sig_863 : std_logic;
+ signal sig_864 : std_logic;
+ signal sig_865 : std_logic;
+ signal sig_866 : std_logic;
+ signal sig_867 : std_logic;
+ signal sig_868 : std_logic;
+ signal sig_869 : std_logic;
+ signal sig_870 : std_logic;
+ signal sig_871 : std_logic;
+ signal sig_872 : std_logic;
+ signal sig_873 : std_logic;
+ signal sig_874 : std_logic;
+ signal sig_875 : std_logic;
+ signal sig_876 : std_logic;
+ signal sig_877 : std_logic;
+ signal sig_878 : std_logic;
+ signal sig_879 : std_logic;
+ signal sig_880 : std_logic;
+ signal sig_881 : std_logic;
+ signal sig_882 : std_logic;
+ signal sig_883 : std_logic;
+ signal sig_884 : std_logic;
+ signal sig_885 : std_logic;
+ signal sig_886 : std_logic;
+ signal sig_887 : std_logic;
+ signal sig_888 : std_logic;
+ signal sig_889 : std_logic;
+ signal sig_890 : std_logic;
+ signal sig_891 : std_logic;
+ signal sig_892 : std_logic;
+ signal sig_893 : std_logic;
+ signal sig_894 : std_logic;
+ signal sig_895 : std_logic;
+ signal sig_896 : std_logic;
+ signal sig_897 : std_logic;
+ signal sig_898 : std_logic;
+ signal sig_899 : std_logic;
+ signal sig_900 : std_logic;
+ signal sig_901 : std_logic;
+ signal sig_902 : std_logic;
+ signal sig_903 : std_logic;
+ signal sig_904 : std_logic;
+ signal sig_905 : std_logic;
+ signal sig_906 : std_logic;
+ signal sig_907 : std_logic;
+ signal sig_908 : std_logic;
+ signal sig_909 : std_logic;
+ signal sig_910 : std_logic;
+ signal sig_911 : std_logic;
+ signal sig_912 : std_logic;
+ signal sig_913 : std_logic;
+ signal sig_914 : std_logic;
+ signal sig_915 : std_logic;
+ signal sig_916 : std_logic;
+ signal sig_917 : std_logic;
+ signal sig_918 : std_logic;
+ signal sig_919 : std_logic;
+ signal sig_920 : std_logic;
+ signal sig_921 : std_logic;
+ signal sig_922 : std_logic;
+ signal sig_923 : std_logic;
+ signal sig_924 : std_logic;
+ signal sig_925 : std_logic;
+ signal sig_926 : std_logic;
+ signal sig_927 : std_logic;
+ signal sig_928 : std_logic;
+ signal sig_929 : std_logic;
+ signal sig_930 : std_logic;
+ signal sig_931 : std_logic;
+ signal sig_932 : std_logic;
+ signal sig_933 : std_logic;
+ signal sig_934 : std_logic;
+ signal sig_935 : std_logic;
+ signal sig_936 : std_logic;
+ signal sig_937 : std_logic;
+ signal sig_938 : std_logic;
+ signal sig_939 : std_logic;
+ signal sig_940 : std_logic;
+ signal sig_941 : std_logic;
+ signal sig_942 : std_logic;
+ signal sig_943 : std_logic;
+ signal sig_944 : std_logic;
+ signal sig_945 : std_logic;
+ signal sig_946 : std_logic;
+ signal sig_947 : std_logic;
+ signal sig_948 : std_logic;
+ signal sig_949 : std_logic;
+ signal sig_950 : std_logic;
+ signal sig_951 : std_logic;
+ signal sig_952 : std_logic;
+ signal sig_953 : std_logic;
+ signal sig_954 : std_logic;
+ signal sig_955 : std_logic;
+ signal sig_956 : std_logic;
+ signal sig_957 : std_logic;
+ signal sig_958 : std_logic;
+ signal sig_959 : std_logic;
+ signal sig_960 : std_logic;
+ signal sig_961 : std_logic;
+ signal sig_962 : std_logic;
+ signal sig_963 : std_logic;
+ signal sig_964 : std_logic;
+ signal sig_965 : std_logic;
+ signal sig_966 : std_logic;
+ signal sig_967 : std_logic;
+ signal sig_968 : std_logic;
+ signal sig_969 : std_logic;
+ signal sig_970 : std_logic;
+ signal sig_971 : std_logic;
+ signal sig_972 : std_logic;
+ signal sig_973 : std_logic;
+ signal sig_974 : std_logic;
+ signal sig_975 : std_logic;
+ signal sig_976 : std_logic;
+ signal sig_977 : std_logic;
+ signal sig_978 : std_logic;
+ signal sig_979 : std_logic;
+ signal sig_980 : std_logic;
+ signal sig_981 : std_logic;
+ signal sig_982 : std_logic;
+ signal sig_983 : std_logic;
+ signal sig_984 : std_logic;
+ signal sig_985 : std_logic;
+ signal sig_986 : std_logic;
+ signal sig_987 : std_logic;
+ signal sig_988 : std_logic;
+ signal sig_989 : std_logic;
+ signal sig_990 : std_logic;
+ signal sig_991 : std_logic;
+ signal sig_992 : std_logic;
+ signal sig_993 : std_logic;
+ signal sig_994 : std_logic;
+ signal sig_995 : std_logic;
+ signal sig_996 : std_logic;
+ signal sig_997 : std_logic;
+ signal sig_998 : std_logic;
+ signal sig_999 : std_logic;
+ signal sig_1000 : std_logic;
+ signal sig_1001 : std_logic;
+ signal sig_1002 : std_logic;
+ signal sig_1003 : std_logic;
+ signal sig_1004 : std_logic;
+ signal sig_1005 : std_logic;
+ signal sig_1006 : std_logic;
+ signal sig_1007 : std_logic;
+ signal sig_1008 : std_logic;
+ signal sig_1009 : std_logic;
+ signal sig_1010 : std_logic;
+ signal sig_1011 : std_logic;
+ signal sig_1012 : std_logic;
+ signal sig_1013 : std_logic;
+ signal sig_1014 : std_logic;
+ signal sig_1015 : std_logic;
+ signal sig_1016 : std_logic;
+ signal sig_1017 : std_logic;
+ signal sig_1018 : std_logic;
+ signal sig_1019 : std_logic;
+ signal sig_1020 : std_logic;
+ signal sig_1021 : std_logic;
+ signal sig_1022 : std_logic;
+ signal sig_1023 : std_logic;
+ signal sig_1024 : std_logic;
+ signal sig_1025 : std_logic;
+ signal sig_1026 : std_logic;
+ signal sig_1027 : std_logic;
+ signal sig_1028 : std_logic;
+ signal sig_1029 : std_logic;
+ signal sig_1030 : std_logic;
+ signal sig_1031 : std_logic;
+ signal sig_1032 : std_logic;
+ signal sig_1033 : std_logic;
+ signal sig_1034 : std_logic;
+ signal sig_1035 : std_logic;
+ signal sig_1036 : std_logic;
+ signal sig_1037 : std_logic;
+ signal sig_1038 : std_logic;
+ signal sig_1039 : std_logic;
+ signal sig_1040 : std_logic;
+ signal sig_1041 : std_logic;
+ signal sig_1042 : std_logic;
+ signal sig_1043 : std_logic;
+ signal sig_1044 : std_logic;
+ signal sig_1045 : std_logic;
+ signal sig_1046 : std_logic;
+ signal sig_1047 : std_logic;
+ signal sig_1048 : std_logic;
+ signal sig_1049 : std_logic;
+ signal sig_1050 : std_logic;
+ signal sig_1051 : std_logic;
+ signal sig_1052 : std_logic;
+ signal sig_1053 : std_logic;
+ signal sig_1054 : std_logic;
+ signal sig_1055 : std_logic;
+ signal sig_1056 : std_logic;
+ signal sig_1057 : std_logic;
+ signal sig_1058 : std_logic;
+ signal sig_1059 : std_logic_vector(31 downto 0);
+ signal sig_1060 : std_logic_vector(31 downto 0);
+ signal sig_1061 : std_logic_vector(31 downto 0);
+ signal sig_1062 : std_logic_vector(31 downto 0);
+ signal sig_1063 : std_logic_vector(31 downto 0);
+ signal sig_1064 : std_logic;
+ signal sig_1065 : std_logic;
+ signal sig_1066 : std_logic;
+ signal sig_1067 : std_logic;
+ signal sig_1068 : std_logic;
+ signal sig_1069 : std_logic;
+ signal sig_1070 : std_logic;
+ signal sig_1071 : std_logic_vector(31 downto 0);
+ signal sig_1072 : std_logic_vector(31 downto 0);
+ signal sig_1073 : std_logic_vector(31 downto 0);
+ signal sig_1074 : std_logic_vector(31 downto 0);
+ signal sig_1075 : std_logic_vector(31 downto 0);
+ signal sig_1076 : std_logic_vector(30 downto 0);
+ signal sig_1077 : std_logic_vector(31 downto 0);
+ signal sig_1078 : std_logic_vector(31 downto 0);
+ signal sig_1079 : std_logic_vector(31 downto 0);
+ signal sig_1080 : std_logic_vector(19 downto 0);
+ signal sig_1081 : std_logic_vector(19 downto 0);
+ signal sig_1082 : std_logic_vector(19 downto 0);
+ signal sig_1083 : std_logic_vector(31 downto 0);
+ signal sig_1084 : std_logic_vector(31 downto 0);
+ signal sig_1085 : std_logic_vector(31 downto 0);
+ signal sig_1086 : std_logic_vector(31 downto 0);
+ signal sig_1087 : std_logic_vector(31 downto 0);
+ signal sig_1088 : std_logic_vector(26 downto 0);
+ signal sig_1089 : std_logic_vector(26 downto 0);
+ signal sig_1090 : std_logic_vector(31 downto 0);
+ signal sig_1091 : std_logic_vector(29 downto 0);
+ signal sig_1092 : std_logic_vector(31 downto 0);
+ signal sig_1093 : std_logic_vector(31 downto 0);
+ signal sig_1094 : std_logic_vector(31 downto 0);
+ signal sig_1095 : std_logic_vector(31 downto 0);
+ signal sig_1096 : std_logic_vector(7 downto 0);
+ signal sig_1097 : std_logic_vector(7 downto 0);
+ signal sig_1098 : std_logic_vector(7 downto 0);
+ signal sig_1099 : std_logic_vector(7 downto 0);
+ signal sig_1100 : std_logic_vector(31 downto 0);
+ signal sig_1101 : std_logic_vector(31 downto 0);
+ signal sig_1102 : std_logic_vector(31 downto 0);
+ signal sig_1103 : std_logic_vector(31 downto 0);
+ signal sig_1104 : std_logic_vector(26 downto 0);
+ signal sig_1105 : std_logic_vector(31 downto 0);
+ signal sig_1106 : std_logic;
+ signal sig_1107 : std_logic_vector(26 downto 0);
+ signal sig_1108 : std_logic_vector(26 downto 0);
+ signal sig_1109 : std_logic_vector(31 downto 0);
+ signal sig_1110 : std_logic_vector(31 downto 0);
+ signal sig_1111 : std_logic_vector(31 downto 0);
+ signal sig_1112 : std_logic_vector(30 downto 0);
+ signal sig_1113 : std_logic_vector(31 downto 0);
+ signal sig_1114 : std_logic_vector(31 downto 0);
+ signal sig_1115 : std_logic_vector(31 downto 0);
+ signal sig_1116 : std_logic_vector(26 downto 0);
+ signal sig_1117 : std_logic_vector(26 downto 0);
+ signal sig_1118 : std_logic_vector(26 downto 0);
+ signal sig_1119 : std_logic_vector(31 downto 0);
+ signal sig_1120 : std_logic_vector(31 downto 0);
+ signal sig_1121 : std_logic_vector(31 downto 0);
+ signal sig_1122 : std_logic_vector(29 downto 0);
+ signal sig_1123 : std_logic_vector(31 downto 0);
+ signal sig_1124 : std_logic_vector(31 downto 0);
+ signal sig_1125 : std_logic_vector(19 downto 0);
+ signal sig_1126 : std_logic_vector(19 downto 0);
+ signal sig_1127 : std_logic_vector(19 downto 0);
+ signal sig_1128 : std_logic_vector(15 downto 0);
+ signal sig_1129 : std_logic_vector(31 downto 0);
+ signal sig_1130 : std_logic;
+ signal sig_1131 : std_logic_vector(31 downto 0);
+ signal sig_1132 : std_logic_vector(30 downto 0);
+ signal sig_1133 : std_logic_vector(31 downto 0);
+ signal sig_1134 : std_logic_vector(31 downto 0);
+ signal sig_1135 : std_logic_vector(31 downto 0);
+ signal sig_1136 : std_logic_vector(31 downto 0);
+ signal sig_1137 : std_logic_vector(31 downto 0);
+ signal sig_1138 : std_logic_vector(31 downto 0);
+ signal sig_1139 : std_logic_vector(31 downto 0);
+ signal sig_1140 : std_logic_vector(31 downto 0);
+ signal sig_1141 : std_logic_vector(31 downto 0);
+ signal sig_1142 : std_logic_vector(31 downto 0);
+ signal sig_1143 : std_logic_vector(30 downto 0);
+ signal sig_1144 : std_logic_vector(31 downto 0);
+ signal sig_1145 : std_logic_vector(31 downto 0);
+ signal sig_1146 : std_logic_vector(29 downto 0);
+ signal sig_1147 : std_logic_vector(30 downto 0);
+ signal sig_1148 : std_logic_vector(30 downto 0);
+ signal sig_1149 : std_logic_vector(31 downto 0);
+ signal sig_1150 : std_logic_vector(31 downto 0);
+ signal sig_1151 : std_logic_vector(19 downto 0);
+ signal sig_1152 : std_logic_vector(19 downto 0);
+ signal sig_1153 : std_logic_vector(7 downto 0);
+ signal sig_1154 : std_logic_vector(7 downto 0);
+ signal sig_1155 : std_logic_vector(26 downto 0);
+ signal sig_1156 : std_logic_vector(31 downto 0);
+ signal sig_1157 : std_logic;
+ signal sig_1158 : std_logic_vector(7 downto 0);
+ signal sig_1159 : std_logic_vector(7 downto 0);
+ signal sig_1160 : std_logic_vector(19 downto 0);
+ signal sig_1161 : std_logic_vector(31 downto 0);
+ signal sig_1162 : std_logic_vector(31 downto 0);
+ signal sig_1163 : std_logic_vector(19 downto 0);
+ signal sig_1164 : std_logic_vector(31 downto 0);
+ signal sig_1165 : std_logic_vector(19 downto 0);
+ signal sig_1166 : std_logic_vector(19 downto 0);
+ signal sig_1167 : std_logic_vector(19 downto 0);
+ signal sig_1168 : std_logic_vector(19 downto 0);
+ signal sig_1169 : std_logic_vector(19 downto 0);
+ signal sig_1170 : std_logic_vector(31 downto 0);
+ signal sig_1171 : std_logic_vector(19 downto 0);
+ signal sig_1172 : std_logic_vector(19 downto 0);
+ signal sig_1173 : std_logic_vector(19 downto 0);
+ signal sig_1174 : std_logic_vector(31 downto 0);
+ signal sig_1175 : std_logic_vector(31 downto 0);
+ signal sig_1176 : std_logic_vector(31 downto 0);
+ signal sig_1177 : std_logic_vector(31 downto 0);
+ signal sig_1178 : std_logic_vector(31 downto 0);
+ signal sig_1179 : std_logic_vector(19 downto 0);
+ signal sig_1180 : std_logic_vector(19 downto 0);
+ signal sig_1181 : std_logic_vector(19 downto 0);
+ signal sig_1182 : std_logic_vector(19 downto 0);
+ signal sig_1183 : std_logic_vector(19 downto 0);
+
+ -- Other inlined components
+
+ signal mux_66 : std_logic_vector(2 downto 0);
+ signal mux_30 : std_logic;
+ signal mux_32 : std_logic;
+ signal mux_33 : std_logic;
+ signal mux_34 : std_logic;
+ signal augh_main_k : std_logic_vector(31 downto 0) := (others => '0');
+ signal read32_ret0_10 : std_logic_vector(31 downto 0) := (others => '0');
+ signal mux_58 : std_logic_vector(2 downto 0);
+ signal mux_59 : std_logic_vector(2 downto 0);
+ signal mux_60 : std_logic;
+ signal mux_61 : std_logic_vector(7 downto 0);
+ signal mux_62 : std_logic_vector(2 downto 0);
+ signal mux_63 : std_logic_vector(2 downto 0);
+ signal mux_64 : std_logic;
+ signal mux_65 : std_logic_vector(7 downto 0);
+ signal mux_35 : std_logic;
+ signal mux_36 : std_logic;
+ signal mux_37 : std_logic_vector(15 downto 0);
+ signal mux_38 : std_logic;
+ signal mux_39 : std_logic_vector(31 downto 0);
+ signal idct_2d_r : std_logic_vector(31 downto 0) := (others => '0');
+ signal mux_45 : std_logic_vector(4 downto 0);
+ signal mux_46 : std_logic_vector(4 downto 0);
+ signal mux_47 : std_logic_vector(4 downto 0);
+ signal mux_48 : std_logic_vector(4 downto 0);
+ signal mux_49 : std_logic_vector(4 downto 0);
+ signal mux_40 : std_logic_vector(4 downto 0);
+ signal mux_41 : std_logic_vector(4 downto 0);
+ signal mux_42 : std_logic;
+ signal mux_43 : std_logic_vector(4 downto 0);
+ signal mux_44 : std_logic_vector(4 downto 0);
+ signal write8_u8 : std_logic_vector(7 downto 0) := (others => '0');
+ signal mux_50 : std_logic_vector(31 downto 0);
+ signal mux_51 : std_logic_vector(4 downto 0);
+ signal mux_52 : std_logic;
+ signal mux_53 : std_logic_vector(7 downto 0);
+ signal mux_54 : std_logic_vector(2 downto 0);
+ signal mux_55 : std_logic_vector(2 downto 0);
+ signal mux_56 : std_logic;
+ signal mux_57 : std_logic_vector(7 downto 0);
+ signal idct_z3_reg4 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z3_reg5 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z3_reg6 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z3_reg7 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg0 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg1 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg2 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg3 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg4 : std_logic_vector(31 downto 0) := (others => '0');
+ signal mux_88 : std_logic;
+ signal mux_67 : std_logic_vector(2 downto 0);
+ signal mux_68 : std_logic;
+ signal mux_69 : std_logic_vector(31 downto 0);
+ signal mux_71 : std_logic_vector(31 downto 0);
+ signal mux_73 : std_logic_vector(31 downto 0);
+ signal mux_75 : std_logic_vector(31 downto 0);
+ signal mux_77 : std_logic_vector(31 downto 0);
+ signal mux_79 : std_logic_vector(31 downto 0);
+ signal mux_81 : std_logic_vector(31 downto 0);
+ signal mux_83 : std_logic_vector(31 downto 0);
+ signal mux_85 : std_logic_vector(7 downto 0);
+ signal mux_86 : std_logic_vector(2 downto 0);
+ signal mux_87 : std_logic_vector(2 downto 0);
+ signal mux_28 : std_logic;
+ signal idct_z1_reg5 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg6 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z1_reg7 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg0 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg1 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg2 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg3 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg4 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg5 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg6 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_z2_reg7 : std_logic_vector(31 downto 0) := (others => '0');
+ signal mux_109 : std_logic_vector(31 downto 0);
+ signal mux_154 : std_logic;
+ signal mux_156 : std_logic_vector(7 downto 0);
+ signal idct_2d_yc_reg0 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg1 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg2 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg3 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg4 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg5 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg6 : std_logic_vector(31 downto 0) := (others => '0');
+ signal idct_2d_yc_reg7 : std_logic_vector(31 downto 0) := (others => '0');
+ signal mux_89 : std_logic_vector(7 downto 0);
+ signal mux_90 : std_logic_vector(2 downto 0);
+ signal mux_134 : std_logic;
+ signal mux_91 : std_logic_vector(2 downto 0);
+ signal mux_92 : std_logic;
+ signal mux_158 : std_logic_vector(7 downto 0);
+ signal mux_111 : std_logic_vector(31 downto 0);
+ signal mux_113 : std_logic_vector(31 downto 0);
+ signal mux_115 : std_logic_vector(31 downto 0);
+ signal mux_117 : std_logic_vector(31 downto 0);
+ signal mux_119 : std_logic_vector(31 downto 0);
+ signal mux_121 : std_logic_vector(31 downto 0);
+ signal mux_123 : std_logic_vector(31 downto 0);
+ signal or_224 : std_logic_vector(31 downto 0);
+ signal and_225 : std_logic_vector(31 downto 0);
+ signal or_231 : std_logic_vector(31 downto 0);
+ signal and_232 : std_logic_vector(31 downto 0);
+ signal or_250 : std_logic_vector(31 downto 0);
+ signal and_251 : std_logic_vector(31 downto 0);
+ signal or_260 : std_logic_vector(31 downto 0);
+ signal and_261 : std_logic_vector(31 downto 0);
+ signal or_282 : std_logic_vector(31 downto 0);
+ signal and_283 : std_logic_vector(31 downto 0);
+ signal or_285 : std_logic_vector(31 downto 0);
+ signal and_286 : std_logic_vector(31 downto 0);
+ signal or_289 : std_logic_vector(31 downto 0);
+ signal and_290 : std_logic_vector(31 downto 0);
+ signal or_291 : std_logic_vector(31 downto 0);
+ signal and_292 : std_logic_vector(31 downto 0);
+ signal or_297 : std_logic_vector(31 downto 0);
+ signal and_298 : std_logic_vector(31 downto 0);
+ signal or_299 : std_logic_vector(31 downto 0);
+ signal and_300 : std_logic_vector(31 downto 0);
+ signal or_320 : std_logic_vector(31 downto 0);
+ signal and_321 : std_logic_vector(31 downto 0);
+ signal or_326 : std_logic_vector(31 downto 0);
+ signal and_327 : std_logic_vector(31 downto 0);
+ signal or_333 : std_logic_vector(31 downto 0);
+ signal and_334 : std_logic_vector(31 downto 0);
+ signal or_363 : std_logic_vector(31 downto 0);
+ signal and_364 : std_logic_vector(31 downto 0);
+ signal and_403 : std_logic_vector(7 downto 0);
+ signal and_405 : std_logic_vector(7 downto 0);
+ signal and_407 : std_logic_vector(7 downto 0);
+ signal and_409 : std_logic_vector(7 downto 0);
+ signal and_415 : std_logic_vector(30 downto 0);
+ signal or_464 : std_logic_vector(31 downto 0);
+ signal and_465 : std_logic_vector(31 downto 0);
+ signal or_470 : std_logic_vector(31 downto 0);
+ signal and_471 : std_logic_vector(31 downto 0);
+ signal or_472 : std_logic_vector(31 downto 0);
+ signal and_473 : std_logic_vector(31 downto 0);
+ signal or_500 : std_logic_vector(31 downto 0);
+ signal and_501 : std_logic_vector(31 downto 0);
+ signal or_504 : std_logic_vector(31 downto 0);
+ signal and_505 : std_logic_vector(31 downto 0);
+ signal or_506 : std_logic_vector(31 downto 0);
+ signal and_507 : std_logic_vector(31 downto 0);
+ signal or_514 : std_logic_vector(31 downto 0);
+ signal and_515 : std_logic_vector(31 downto 0);
+ signal or_522 : std_logic_vector(31 downto 0);
+ signal and_523 : std_logic_vector(31 downto 0);
+ signal psc_loop_reg_13 : std_logic_vector(15 downto 0) := (others => '0');
+ signal cp_id_reg_14 : std_logic := '0';
+ signal cp_id_reg_stable_15 : std_logic := '0';
+ signal psc_stuff_reg_18 : std_logic_vector(23 downto 0) := (others => '0');
+ signal psc_stuff_reg_19 : std_logic_vector(62 downto 0) := "000000000000000000000000000000000000000000000000000000000000000";
+ signal mux_129 : std_logic_vector(31 downto 0);
+ signal mux_133 : std_logic_vector(7 downto 0);
+ signal mux_135 : std_logic_vector(31 downto 0);
+ signal mux_137 : std_logic_vector(7 downto 0);
+ signal mux_138 : std_logic_vector(2 downto 0);
+ signal mux_139 : std_logic_vector(2 downto 0);
+ signal mux_140 : std_logic;
+ signal mux_141 : std_logic_vector(7 downto 0);
+ signal mux_142 : std_logic_vector(2 downto 0);
+ signal mux_143 : std_logic_vector(2 downto 0);
+ signal mux_144 : std_logic;
+ signal mux_147 : std_logic;
+ signal mux_149 : std_logic_vector(31 downto 0);
+ signal mux_150 : std_logic;
+ signal mux_151 : std_logic;
+ signal mux_152 : std_logic_vector(63 downto 0);
+ signal mux_155 : std_logic;
+ signal or_221 : std_logic_vector(31 downto 0);
+ signal and_222 : std_logic_vector(31 downto 0);
+ signal or_233 : std_logic_vector(31 downto 0);
+ signal and_234 : std_logic_vector(31 downto 0);
+ signal or_237 : std_logic_vector(31 downto 0);
+ signal and_238 : std_logic_vector(31 downto 0);
+ signal or_252 : std_logic_vector(31 downto 0);
+ signal and_253 : std_logic_vector(31 downto 0);
+ signal or_256 : std_logic_vector(31 downto 0);
+ signal and_257 : std_logic_vector(31 downto 0);
+ signal or_268 : std_logic_vector(31 downto 0);
+ signal and_269 : std_logic_vector(31 downto 0);
+ signal or_270 : std_logic_vector(31 downto 0);
+ signal and_271 : std_logic_vector(31 downto 0);
+ signal or_274 : std_logic_vector(31 downto 0);
+ signal and_275 : std_logic_vector(31 downto 0);
+ signal or_278 : std_logic_vector(31 downto 0);
+ signal and_279 : std_logic_vector(31 downto 0);
+ signal or_310 : std_logic_vector(31 downto 0);
+ signal and_311 : std_logic_vector(31 downto 0);
+ signal or_316 : std_logic_vector(31 downto 0);
+ signal and_317 : std_logic_vector(31 downto 0);
+ signal or_358 : std_logic_vector(31 downto 0);
+ signal and_359 : std_logic_vector(31 downto 0);
+ signal or_366 : std_logic_vector(31 downto 0);
+ signal and_367 : std_logic_vector(31 downto 0);
+ signal or_374 : std_logic_vector(31 downto 0);
+ signal and_375 : std_logic_vector(31 downto 0);
+ signal or_417 : std_logic_vector(31 downto 0);
+ signal and_418 : std_logic_vector(31 downto 0);
+ signal or_421 : std_logic_vector(31 downto 0);
+ signal and_422 : std_logic_vector(31 downto 0);
+ signal or_435 : std_logic_vector(31 downto 0);
+ signal and_436 : std_logic_vector(31 downto 0);
+ signal or_452 : std_logic_vector(31 downto 0);
+ signal and_453 : std_logic_vector(31 downto 0);
+ signal and_494 : std_logic_vector(31 downto 0);
+ signal and_498 : std_logic_vector(31 downto 0);
+ signal or_509 : std_logic_vector(30 downto 0);
+ signal and_510 : std_logic_vector(30 downto 0);
+ signal or_550 : std_logic_vector(31 downto 0);
+ signal and_551 : std_logic_vector(31 downto 0);
+ signal or_581 : std_logic_vector(31 downto 0);
+ signal and_582 : std_logic_vector(31 downto 0);
+ signal or_583 : std_logic_vector(31 downto 0);
+ signal and_584 : std_logic_vector(31 downto 0);
+ signal or_587 : std_logic_vector(31 downto 0);
+ signal and_588 : std_logic_vector(31 downto 0);
+ signal and_161 : std_logic;
+ signal or_228 : std_logic_vector(31 downto 0);
+ signal and_229 : std_logic_vector(31 downto 0);
+ signal or_239 : std_logic_vector(31 downto 0);
+ signal and_240 : std_logic_vector(31 downto 0);
+ signal or_241 : std_logic_vector(31 downto 0);
+ signal and_242 : std_logic_vector(31 downto 0);
+ signal or_244 : std_logic_vector(31 downto 0);
+ signal and_245 : std_logic_vector(31 downto 0);
+ signal or_246 : std_logic_vector(31 downto 0);
+ signal and_247 : std_logic_vector(31 downto 0);
+ signal or_248 : std_logic_vector(31 downto 0);
+ signal and_249 : std_logic_vector(31 downto 0);
+ signal or_258 : std_logic_vector(31 downto 0);
+ signal and_259 : std_logic_vector(31 downto 0);
+ signal not_264 : std_logic;
+ signal or_266 : std_logic_vector(31 downto 0);
+ signal and_267 : std_logic_vector(31 downto 0);
+ signal or_272 : std_logic_vector(31 downto 0);
+ signal and_273 : std_logic_vector(31 downto 0);
+ signal or_280 : std_logic_vector(31 downto 0);
+ signal and_281 : std_logic_vector(31 downto 0);
+ signal or_287 : std_logic_vector(31 downto 0);
+ signal and_288 : std_logic_vector(31 downto 0);
+ signal or_293 : std_logic_vector(31 downto 0);
+ signal and_294 : std_logic_vector(31 downto 0);
+ signal or_301 : std_logic_vector(31 downto 0);
+ signal and_302 : std_logic_vector(31 downto 0);
+ signal or_304 : std_logic_vector(31 downto 0);
+ signal and_305 : std_logic_vector(31 downto 0);
+ signal or_306 : std_logic_vector(31 downto 0);
+ signal and_307 : std_logic_vector(31 downto 0);
+ signal or_308 : std_logic_vector(31 downto 0);
+ signal and_309 : std_logic_vector(31 downto 0);
+ signal or_312 : std_logic_vector(31 downto 0);
+ signal and_313 : std_logic_vector(31 downto 0);
+ signal or_318 : std_logic_vector(31 downto 0);
+ signal and_319 : std_logic_vector(31 downto 0);
+ signal or_329 : std_logic_vector(31 downto 0);
+ signal and_330 : std_logic_vector(31 downto 0);
+ signal or_335 : std_logic_vector(31 downto 0);
+ signal and_336 : std_logic_vector(31 downto 0);
+ signal or_339 : std_logic_vector(31 downto 0);
+ signal and_340 : std_logic_vector(31 downto 0);
+ signal or_342 : std_logic_vector(31 downto 0);
+ signal and_343 : std_logic_vector(31 downto 0);
+ signal or_346 : std_logic_vector(31 downto 0);
+ signal and_347 : std_logic_vector(31 downto 0);
+ signal or_348 : std_logic_vector(31 downto 0);
+ signal and_349 : std_logic_vector(31 downto 0);
+ signal or_351 : std_logic_vector(30 downto 0);
+ signal and_352 : std_logic_vector(30 downto 0);
+ signal or_355 : std_logic_vector(30 downto 0);
+ signal and_356 : std_logic_vector(30 downto 0);
+ signal or_360 : std_logic_vector(31 downto 0);
+ signal and_361 : std_logic_vector(31 downto 0);
+ signal or_371 : std_logic_vector(31 downto 0);
+ signal and_372 : std_logic_vector(31 downto 0);
+ signal or_378 : std_logic_vector(31 downto 0);
+ signal and_379 : std_logic_vector(31 downto 0);
+ signal or_380 : std_logic_vector(31 downto 0);
+ signal and_381 : std_logic_vector(31 downto 0);
+ signal or_384 : std_logic_vector(31 downto 0);
+ signal and_385 : std_logic_vector(31 downto 0);
+ signal or_386 : std_logic_vector(31 downto 0);
+ signal and_387 : std_logic_vector(31 downto 0);
+ signal or_388 : std_logic_vector(31 downto 0);
+ signal and_389 : std_logic_vector(31 downto 0);
+ signal or_394 : std_logic_vector(7 downto 0);
+ signal and_395 : std_logic_vector(7 downto 0);
+ signal and_397 : std_logic_vector(7 downto 0);
+ signal and_399 : std_logic_vector(7 downto 0);
+ signal and_401 : std_logic_vector(7 downto 0);
+ signal or_414 : std_logic_vector(30 downto 0);
+ signal or_423 : std_logic_vector(31 downto 0);
+ signal and_424 : std_logic_vector(31 downto 0);
+ signal or_425 : std_logic_vector(31 downto 0);
+ signal and_426 : std_logic_vector(31 downto 0);
+ signal or_427 : std_logic_vector(31 downto 0);
+ signal and_428 : std_logic_vector(31 downto 0);
+ signal or_431 : std_logic_vector(31 downto 0);
+ signal and_432 : std_logic_vector(31 downto 0);
+ signal or_433 : std_logic_vector(31 downto 0);
+ signal and_434 : std_logic_vector(31 downto 0);
+ signal or_438 : std_logic_vector(31 downto 0);
+ signal and_439 : std_logic_vector(31 downto 0);
+ signal or_440 : std_logic_vector(31 downto 0);
+ signal and_441 : std_logic_vector(31 downto 0);
+ signal or_443 : std_logic_vector(31 downto 0);
+ signal and_444 : std_logic_vector(31 downto 0);
+ signal or_450 : std_logic_vector(31 downto 0);
+ signal and_451 : std_logic_vector(31 downto 0);
+ signal or_454 : std_logic_vector(30 downto 0);
+ signal and_455 : std_logic_vector(30 downto 0);
+ signal or_458 : std_logic_vector(31 downto 0);
+ signal and_459 : std_logic_vector(31 downto 0);
+ signal or_462 : std_logic_vector(31 downto 0);
+ signal and_463 : std_logic_vector(31 downto 0);
+ signal or_467 : std_logic_vector(30 downto 0);
+ signal and_468 : std_logic_vector(30 downto 0);
+ signal or_475 : std_logic_vector(30 downto 0);
+ signal and_476 : std_logic_vector(30 downto 0);
+ signal or_479 : std_logic_vector(31 downto 0);
+ signal and_480 : std_logic_vector(31 downto 0);
+ signal or_481 : std_logic_vector(31 downto 0);
+ signal and_482 : std_logic_vector(31 downto 0);
+ signal or_485 : std_logic_vector(31 downto 0);
+ signal and_486 : std_logic_vector(31 downto 0);
+ signal or_490 : std_logic_vector(31 downto 0);
+ signal and_491 : std_logic_vector(31 downto 0);
+ signal or_493 : std_logic_vector(31 downto 0);
+ signal or_497 : std_logic_vector(31 downto 0);
+ signal or_512 : std_logic_vector(31 downto 0);
+ signal and_513 : std_logic_vector(31 downto 0);
+ signal or_518 : std_logic_vector(30 downto 0);
+ signal and_519 : std_logic_vector(30 downto 0);
+ signal or_525 : std_logic_vector(31 downto 0);
+ signal and_526 : std_logic_vector(31 downto 0);
+ signal or_529 : std_logic_vector(30 downto 0);
+ signal and_530 : std_logic_vector(30 downto 0);
+ signal or_532 : std_logic_vector(30 downto 0);
+ signal and_533 : std_logic_vector(30 downto 0);
+ signal or_535 : std_logic_vector(31 downto 0);
+ signal and_536 : std_logic_vector(31 downto 0);
+ signal or_538 : std_logic_vector(31 downto 0);
+ signal and_539 : std_logic_vector(31 downto 0);
+ signal or_541 : std_logic_vector(31 downto 0);
+ signal and_542 : std_logic_vector(31 downto 0);
+ signal or_545 : std_logic_vector(30 downto 0);
+ signal and_546 : std_logic_vector(30 downto 0);
+ signal or_548 : std_logic_vector(31 downto 0);
+ signal and_549 : std_logic_vector(31 downto 0);
+ signal or_554 : std_logic_vector(30 downto 0);
+ signal and_555 : std_logic_vector(30 downto 0);
+ signal or_557 : std_logic_vector(30 downto 0);
+ signal and_558 : std_logic_vector(30 downto 0);
+ signal or_568 : std_logic_vector(31 downto 0);
+ signal and_569 : std_logic_vector(31 downto 0);
+ signal or_571 : std_logic_vector(30 downto 0);
+ signal and_572 : std_logic_vector(30 downto 0);
+ signal or_575 : std_logic_vector(30 downto 0);
+ signal and_576 : std_logic_vector(30 downto 0);
+ signal or_590 : std_logic_vector(31 downto 0);
+ signal and_591 : std_logic_vector(31 downto 0);
+ signal or_597 : std_logic_vector(31 downto 0);
+ signal and_598 : std_logic_vector(31 downto 0);
+ signal or_603 : std_logic_vector(30 downto 0);
+ signal and_604 : std_logic_vector(30 downto 0);
+
+ -- This utility function is used for to generate concatenations of std_logic
+
+ -- Little utility function to ease concatenation of an std_logic
+ -- and explicitely return an std_logic_vector
+ function repeat(N: natural; B: std_logic) return std_logic_vector is
+ variable result: std_logic_vector(N-1 downto 0);
+ begin
+ result := (others => B);
+ return result;
+ end;
+
+begin
+
+ -- Instantiation of components
+
+ output_split2_i : output_split2 port map (
+ wa0_data => mux_141,
+ wa0_addr => mux_142,
+ ra0_data => sig_1159,
+ ra0_addr => mux_143,
+ wa0_en => mux_144,
+ clk => sig_clock
+ );
+
+ output_split3_i : output_split3 port map (
+ wa0_data => mux_137,
+ wa0_addr => mux_138,
+ ra0_data => sig_1158,
+ ra0_addr => mux_139,
+ wa0_en => mux_140,
+ clk => sig_clock
+ );
+
+ sub_159_i : sub_159 port map (
+ gt => sig_1157,
+ result => sig_1156,
+ in_a => idct_2d_r,
+ in_b => "00000000000000000000000011111111",
+ sign => '1'
+ );
+
+ add_165_i : add_165 port map (
+ result => sig_1155,
+ in_a => idct_2d_yc_reg7(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ output_split1_i : output_split1 port map (
+ wa0_data => mux_89,
+ wa0_addr => mux_90,
+ ra0_data => sig_1154,
+ ra0_addr => mux_91,
+ wa0_en => mux_92,
+ clk => sig_clock
+ );
+
+ output_split0_i : output_split0 port map (
+ wa0_data => mux_85,
+ wa0_addr => mux_86,
+ ra0_data => sig_1153,
+ ra0_addr => mux_87,
+ wa0_en => mux_88,
+ clk => sig_clock
+ );
+
+ add_172_i : add_172 port map (
+ result => sig_1152,
+ in_a => sig_1183,
+ in_b => "00000000000000000001"
+ );
+
+ add_176_i : add_176 port map (
+ result => sig_1151,
+ in_a => sig_1182,
+ in_b => "00000000000000000001"
+ );
+
+ add_181_i : add_181 port map (
+ result => sig_1150,
+ in_a => idct_z2_reg0,
+ in_b => idct_z3_reg7
+ );
+
+ sub_187_i : sub_187 port map (
+ result => sig_1149,
+ in_a => idct_z2_reg1,
+ in_b => idct_z3_reg6
+ );
+
+ mul_189_i : mul_189 port map (
+ result => sig_1148,
+ in_a => idct_z2_reg4(30 downto 0),
+ in_b => "01000111000111"
+ );
+
+ add_191_i : add_191 port map (
+ result => sig_1147,
+ in_a => sig_1148,
+ in_b => sig_1123(31 downto 1)
+ );
+
+ mul_192_i : mul_192 port map (
+ result => sig_1146,
+ in_a => idct_z2_reg5(29 downto 0),
+ in_b => "01100011111"
+ );
+
+ mul_193_i : mul_193 port map (
+ result => sig_1145,
+ in_a => idct_z2_reg6,
+ in_b => "011111011000101"
+ );
+
+ mul_198_i : mul_198 port map (
+ result => sig_1144,
+ in_a => idct_z2_reg4,
+ in_b => "011010100110111"
+ );
+
+ mul_199_i : mul_199 port map (
+ result => sig_1143,
+ in_a => idct_z2_reg7(30 downto 0),
+ in_b => "01000111000111"
+ );
+
+ sub_209_i : sub_209 port map (
+ result => sig_1142,
+ in_a => idct_2d_yc_reg1,
+ in_b => idct_2d_yc_reg7
+ );
+
+ add_212_i : add_212 port map (
+ result => sig_1141,
+ in_a => idct_z1_reg1,
+ in_b => idct_z1_reg2
+ );
+
+ sub_213_i : sub_213 port map (
+ result => sig_1140,
+ in_a => idct_z1_reg1,
+ in_b => idct_z1_reg2
+ );
+
+ sub_214_i : sub_214 port map (
+ result => sig_1139,
+ in_a => idct_z1_reg0,
+ in_b => idct_z1_reg3
+ );
+
+ mul_215_i : mul_215 port map (
+ result => sig_1138,
+ in_a => idct_2d_yc_reg2,
+ in_b => "0101001110011111"
+ );
+
+ mul_216_i : mul_216 port map (
+ result => sig_1137,
+ in_a => idct_2d_yc_reg6,
+ in_b => "010001010100011"
+ );
+
+ sub_217_i : sub_217 port map (
+ result => sig_1136,
+ in_a => sig_1138,
+ in_b => sig_1137
+ );
+
+ mul_218_i : mul_218 port map (
+ result => sig_1135,
+ in_a => idct_2d_yc_reg2,
+ in_b => "010001010100011"
+ );
+
+ mul_219_i : mul_219 port map (
+ result => sig_1134,
+ in_a => idct_2d_yc_reg6,
+ in_b => "0101001110011111"
+ );
+
+ sub_220_i : sub_220 port map (
+ result => sig_1133,
+ in_a => sig_1135,
+ in_b => sig_1134
+ );
+
+ mul_223_i : mul_223 port map (
+ result => sig_1132,
+ in_a => idct_2d_yc_reg5(30 downto 0),
+ in_b => "010110101000001"
+ );
+
+ sub_227_i : sub_227 port map (
+ result => sig_1131,
+ in_a => idct_2d_yc_reg0,
+ in_b => idct_2d_yc_reg4
+ );
+
+ sub_157_i : sub_157 port map (
+ ge => sig_1130,
+ result => sig_1129,
+ in_a => idct_2d_r,
+ in_b => "00000000000000000000000000000000",
+ sign => '1'
+ );
+
+ add_163_i : add_163 port map (
+ result => sig_1128,
+ in_a => psc_loop_reg_13,
+ in_b => "0000000000000001"
+ );
+
+ cmp_164_i : cmp_164 port map (
+ ne => memextrct_loop_sig_21,
+ in0 => "0000000000011111",
+ in1 => psc_loop_reg_13
+ );
+
+ add_170_i : add_170 port map (
+ result => sig_1127,
+ in_a => sig_1181,
+ in_b => "00000000000000000001"
+ );
+
+ add_174_i : add_174 port map (
+ result => sig_1126,
+ in_a => sig_1180,
+ in_b => "00000000000000000001"
+ );
+
+ add_180_i : add_180 port map (
+ result => sig_1125,
+ in_a => sig_1179,
+ in_b => "00000000000000000001"
+ );
+
+ sub_186_i : sub_186 port map (
+ result => sig_1124,
+ in_a => idct_z2_reg2,
+ in_b => idct_z3_reg5
+ );
+
+ mul_190_i : mul_190 port map (
+ result => sig_1123,
+ in_a => idct_z2_reg7,
+ in_b => "011010100110111"
+ );
+
+ mul_196_i : mul_196 port map (
+ result => sig_1122,
+ in_a => idct_z2_reg6(29 downto 0),
+ in_b => "01100011111"
+ );
+
+ sub_200_i : sub_200 port map (
+ result => sig_1121,
+ in_a => sig_1144,
+ in_b => sig_1178
+ );
+
+ add_206_i : add_206 port map (
+ result => sig_1120,
+ in_a => idct_z1_reg4,
+ in_b => idct_z1_reg6
+ );
+
+ add_210_i : add_210 port map (
+ result => sig_1119,
+ in_a => idct_2d_yc_reg1,
+ in_b => idct_2d_yc_reg7
+ );
+
+ add_171_i : add_171 port map (
+ result => sig_1118,
+ in_a => idct_2d_yc_reg4(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_177_i : add_177 port map (
+ result => sig_1117,
+ in_a => idct_2d_yc_reg1(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_179_i : add_179 port map (
+ result => sig_1116,
+ in_a => idct_2d_yc_reg0(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ mul_195_i : mul_195 port map (
+ result => sig_1115,
+ in_a => idct_z2_reg5,
+ in_b => "011111011000101"
+ );
+
+ sub_197_i : sub_197 port map (
+ result => sig_1114,
+ in_a => sig_1115,
+ in_b => sig_1177
+ );
+
+ sub_207_i : sub_207 port map (
+ result => sig_1113,
+ in_a => idct_z1_reg7,
+ in_b => idct_z1_reg5
+ );
+
+ mul_230_i : mul_230 port map (
+ result => sig_1112,
+ in_a => idct_2d_yc_reg3(30 downto 0),
+ in_b => "010110101000001"
+ );
+
+ sub_185_i : sub_185 port map (
+ result => sig_1111,
+ in_a => idct_z2_reg3,
+ in_b => idct_z3_reg4
+ );
+
+ add_211_i : add_211 port map (
+ result => sig_1110,
+ in_a => idct_z1_reg0,
+ in_b => idct_z1_reg3
+ );
+
+ add_226_i : add_226 port map (
+ result => sig_1109,
+ in_a => idct_2d_yc_reg0,
+ in_b => idct_2d_yc_reg4
+ );
+
+ add_235_i : add_235 port map (
+ result => sig_1108,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_314_i : add_314 port map (
+ result => sig_1107,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ sub_160_i : sub_160 port map (
+ le => sig_1106,
+ result => sig_1105,
+ in_a => idct_2d_r,
+ in_b => "00000000000000000000000011111111",
+ sign => '1'
+ );
+
+ add_173_i : add_173 port map (
+ result => sig_1104,
+ in_a => idct_2d_yc_reg3(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_182_i : add_182 port map (
+ result => sig_1103,
+ in_a => idct_z2_reg1,
+ in_b => idct_z3_reg6
+ );
+
+ sub_188_i : sub_188 port map (
+ result => sig_1102,
+ in_a => idct_z2_reg0,
+ in_b => idct_z3_reg7
+ );
+
+ sub_243_i : sub_243 port map (
+ result => sig_1101,
+ in_a => sig_1115,
+ in_b => sig_1176
+ );
+
+ sub_262_i : sub_262 port map (
+ result => sig_1100,
+ in_a => sig_1115,
+ in_b => sig_1175
+ );
+
+ output_split4_i : output_split4 port map (
+ wa0_data => mux_65,
+ wa0_addr => mux_66,
+ ra0_data => sig_1099,
+ ra0_addr => mux_67,
+ wa0_en => mux_68,
+ clk => sig_clock
+ );
+
+ output_split5_i : output_split5 port map (
+ wa0_data => mux_61,
+ wa0_addr => mux_62,
+ ra0_data => sig_1098,
+ ra0_addr => mux_63,
+ wa0_en => mux_64,
+ clk => sig_clock
+ );
+
+ output_split6_i : output_split6 port map (
+ wa0_data => mux_57,
+ wa0_addr => mux_58,
+ ra0_data => sig_1097,
+ ra0_addr => mux_59,
+ wa0_en => mux_60,
+ clk => sig_clock
+ );
+
+ output_split7_i : output_split7 port map (
+ wa0_data => mux_53,
+ wa0_addr => mux_54,
+ ra0_data => sig_1096,
+ ra0_addr => mux_55,
+ wa0_en => mux_56,
+ clk => sig_clock
+ );
+
+ input_split0_i : input_split0 port map (
+ ra0_data => sig_1095,
+ ra0_addr => mux_46,
+ ra1_data => sig_1094,
+ ra1_addr => mux_47,
+ ra2_data => sig_1093,
+ ra2_addr => mux_48,
+ ra3_data => sig_1092,
+ ra3_addr => mux_49,
+ clk => sig_clock,
+ wa2_data => mux_50,
+ wa2_addr => mux_51,
+ wa2_en => mux_52
+ );
+
+ add_194_i : add_194 port map (
+ result => sig_1091,
+ in_a => sig_1146,
+ in_b => sig_1145(31 downto 2)
+ );
+
+ add_205_i : add_205 port map (
+ result => sig_1090,
+ in_a => idct_z1_reg7,
+ in_b => idct_z1_reg5
+ );
+
+ add_254_i : add_254 port map (
+ result => sig_1089,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_276_i : add_276 port map (
+ result => sig_1088,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ sub_284_i : sub_284 port map (
+ result => sig_1087,
+ in_a => sig_1115,
+ in_b => sig_1174
+ );
+
+ input_split1_i : input_split1 port map (
+ wa0_data => mux_39,
+ wa0_addr => mux_40,
+ ra0_data => sig_1086,
+ ra0_addr => mux_41,
+ wa0_en => mux_42,
+ ra1_data => sig_1085,
+ ra1_addr => mux_43,
+ ra2_data => sig_1084,
+ ra2_addr => mux_44,
+ ra3_data => sig_1083,
+ ra3_addr => mux_45,
+ clk => sig_clock
+ );
+
+ add_166_i : add_166 port map (
+ result => sig_1082,
+ in_a => sig_1173,
+ in_b => "00000000000000000001"
+ );
+
+ add_168_i : add_168 port map (
+ result => sig_1081,
+ in_a => sig_1172,
+ in_b => "00000000000000000001"
+ );
+
+ add_178_i : add_178 port map (
+ result => sig_1080,
+ in_a => sig_1171,
+ in_b => "00000000000000000001"
+ );
+
+ add_183_i : add_183 port map (
+ result => sig_1079,
+ in_a => idct_z2_reg2,
+ in_b => idct_z3_reg5
+ );
+
+ sub_332_i : sub_332 port map (
+ result => sig_1078,
+ in_a => sig_689,
+ in_b => sig_688
+ );
+
+ mul_341_i : mul_341 port map (
+ result => sig_1077,
+ in_a => or_339,
+ in_b => "0101001110011111"
+ );
+
+ mul_357_i : mul_357 port map (
+ result => sig_1076,
+ in_a => or_355,
+ in_b => "010110101000001"
+ );
+
+ mul_365_i : mul_365 port map (
+ result => sig_1075,
+ in_a => or_363,
+ in_b => "010001010100011"
+ );
+
+ mul_368_i : mul_368 port map (
+ result => sig_1074,
+ in_a => or_366,
+ in_b => "0101001110011111"
+ );
+
+ sub_369_i : sub_369 port map (
+ result => sig_1073,
+ in_a => sig_1075,
+ in_b => sig_1074
+ );
+
+ sub_370_i : sub_370 port map (
+ result => sig_1072,
+ in_a => sig_1115,
+ in_b => sig_1170
+ );
+
+ sub_377_i : sub_377 port map (
+ result => sig_1071,
+ in_a => sig_680,
+ in_b => sig_715
+ );
+
+ cmp_398_i : cmp_398 port map (
+ eq => sig_1070,
+ in0 => "110",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_400_i : cmp_400 port map (
+ eq => sig_1069,
+ in0 => "101",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_404_i : cmp_404 port map (
+ eq => sig_1068,
+ in0 => "011",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_406_i : cmp_406 port map (
+ eq => sig_1067,
+ in0 => "010",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_408_i : cmp_408 port map (
+ eq => sig_1066,
+ in0 => "001",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_410_i : cmp_410 port map (
+ eq => sig_1065,
+ in0 => "000",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_412_i : cmp_412 port map (
+ eq => sig_1064,
+ in0 => '0',
+ in1 => augh_main_k(0)
+ );
+
+ sub_429_i : sub_429 port map (
+ result => sig_1063,
+ in_a => or_421,
+ in_b => or_427
+ );
+
+ add_466_i : add_466 port map (
+ result => sig_1062,
+ in_a => or_462,
+ in_b => or_464
+ );
+
+ sub_496_i : sub_496 port map (
+ result => sig_1061,
+ in_a => sig_652,
+ in_b => sig_651
+ );
+
+ sub_521_i : sub_521 port map (
+ result => sig_1060,
+ in_a => or_438,
+ in_b => or_464
+ );
+
+ sub_528_i : sub_528 port map (
+ result => sig_1059,
+ in_a => sig_643,
+ in_b => sig_642
+ );
+
+ fsm_23_i : fsm_23 port map (
+ clock => sig_clock,
+ reset => sig_reset,
+ in0 => memextrct_loop_sig_21,
+ out181 => sig_1058,
+ out182 => sig_1057,
+ out183 => sig_1056,
+ out184 => sig_1055,
+ out185 => sig_1054,
+ out8 => sig_1053,
+ out13 => sig_1052,
+ out14 => sig_1051,
+ out16 => sig_1050,
+ out18 => sig_1049,
+ out19 => sig_1048,
+ out20 => sig_1047,
+ out21 => sig_1046,
+ out22 => sig_1045,
+ in2 => sig_start,
+ out23 => sig_1044,
+ out24 => sig_1043,
+ out25 => sig_1042,
+ out26 => sig_1041,
+ out27 => sig_1040,
+ out28 => sig_1039,
+ out29 => sig_1038,
+ out30 => sig_1037,
+ out31 => sig_1036,
+ out33 => sig_1035,
+ out35 => sig_1034,
+ out36 => sig_1033,
+ out38 => sig_1032,
+ out40 => sig_1031,
+ out42 => sig_1030,
+ in3 => memextrct_loop_sig_22,
+ out44 => sig_1029,
+ out46 => sig_1028,
+ out48 => sig_1027,
+ out49 => sig_1026,
+ out50 => sig_1025,
+ out52 => sig_1024,
+ out54 => sig_1023,
+ out56 => sig_1022,
+ out57 => sig_1021,
+ out58 => sig_1020,
+ in4 => test_cp_0_16,
+ out60 => sig_1019,
+ in5 => test_cp_1_17,
+ out164 => sig_1018,
+ out165 => sig_1017,
+ out167 => sig_1016,
+ out168 => sig_1015,
+ out170 => sig_1014,
+ out171 => sig_1013,
+ out173 => sig_1012,
+ out174 => sig_1011,
+ out176 => sig_1010,
+ out178 => sig_1009,
+ out0 => sig_1008,
+ out1 => sig_1007,
+ out2 => sig_1006,
+ in1 => cp_rest,
+ out4 => sig_1005,
+ out90 => sig_1004,
+ out91 => sig_1003,
+ out97 => sig_1002,
+ out99 => sig_1001,
+ out101 => sig_1000,
+ in6 => stdout_ack,
+ out103 => sig_999,
+ out105 => sig_998,
+ out106 => sig_997,
+ out107 => sig_996,
+ out108 => sig_995,
+ out135 => sig_994,
+ out136 => sig_993,
+ out137 => sig_992,
+ out138 => sig_991,
+ in11 => augh_test_9,
+ out140 => sig_990,
+ out141 => sig_989,
+ out142 => sig_988,
+ out143 => sig_987,
+ out145 => sig_986,
+ out146 => sig_985,
+ out148 => sig_984,
+ out150 => sig_983,
+ out153 => sig_982,
+ out154 => sig_981,
+ out155 => sig_980,
+ out156 => sig_979,
+ out157 => sig_978,
+ out158 => sig_977,
+ out159 => sig_976,
+ out160 => sig_975,
+ out161 => sig_974,
+ out162 => sig_973,
+ out111 => sig_972,
+ out112 => sig_971,
+ out114 => sig_970,
+ out116 => sig_969,
+ out118 => sig_968,
+ out120 => sig_967,
+ out121 => sig_966,
+ out122 => sig_965,
+ out123 => sig_964,
+ out124 => sig_963,
+ out125 => sig_962,
+ out126 => sig_961,
+ in7 => cp_en,
+ out129 => sig_960,
+ out130 => sig_959,
+ in8 => stdin_ack,
+ out131 => sig_958,
+ in9 => psc_loop_sig_20,
+ out132 => sig_957,
+ out133 => sig_956,
+ out134 => sig_955,
+ in10 => augh_test_11,
+ out186 => sig_954,
+ out187 => sig_953,
+ out190 => sig_952,
+ out195 => sig_951,
+ out197 => sig_950,
+ out198 => sig_949,
+ out199 => sig_948,
+ out200 => sig_947,
+ out201 => sig_946,
+ out203 => sig_945,
+ out204 => sig_944,
+ out206 => sig_943,
+ out207 => sig_942,
+ out209 => sig_941,
+ out210 => sig_940,
+ out212 => sig_939,
+ out213 => sig_938,
+ out215 => sig_937,
+ out217 => sig_936,
+ out220 => sig_935,
+ out221 => sig_934,
+ out222 => sig_933,
+ out223 => sig_932,
+ out224 => sig_931,
+ out225 => sig_930,
+ out226 => sig_929,
+ out227 => sig_928,
+ out228 => sig_927,
+ out229 => sig_926,
+ out231 => sig_925,
+ out232 => sig_924,
+ out234 => sig_923,
+ out235 => sig_922,
+ out237 => sig_921,
+ out238 => sig_920,
+ out240 => sig_919,
+ out241 => sig_918,
+ out243 => sig_917,
+ out245 => sig_916,
+ out248 => sig_915,
+ out249 => sig_914,
+ out250 => sig_913,
+ out251 => sig_912,
+ out252 => sig_911,
+ out253 => sig_910,
+ out254 => sig_909,
+ out255 => sig_908,
+ out256 => sig_907,
+ out257 => sig_906,
+ out259 => sig_905,
+ out260 => sig_904,
+ out262 => sig_903,
+ out263 => sig_902,
+ out265 => sig_901,
+ out266 => sig_900,
+ out268 => sig_899,
+ out269 => sig_898,
+ out271 => sig_897,
+ out273 => sig_896,
+ out276 => sig_895,
+ out277 => sig_894,
+ out278 => sig_893,
+ out279 => sig_892,
+ out280 => sig_891,
+ out281 => sig_890,
+ out282 => sig_889,
+ out283 => sig_888,
+ out284 => sig_887,
+ out285 => sig_886,
+ out286 => sig_885,
+ out287 => sig_884,
+ out288 => sig_883,
+ out289 => sig_882,
+ out290 => sig_881,
+ out291 => sig_880,
+ out292 => sig_879,
+ out293 => sig_878,
+ out294 => sig_877,
+ out295 => sig_876,
+ out296 => sig_875,
+ out297 => sig_874,
+ out298 => sig_873,
+ out311 => sig_872,
+ out312 => sig_871,
+ out313 => sig_870,
+ out314 => sig_869,
+ out315 => sig_868,
+ out316 => sig_867,
+ out318 => sig_866,
+ out321 => sig_865,
+ out322 => sig_864,
+ out323 => sig_863,
+ out324 => sig_862,
+ out325 => sig_861,
+ out326 => sig_860,
+ out327 => sig_859,
+ out328 => sig_858,
+ out329 => sig_857,
+ out333 => sig_856,
+ out341 => sig_855,
+ out342 => sig_854,
+ out343 => sig_853,
+ out344 => sig_852,
+ out345 => sig_851,
+ out346 => sig_850,
+ out349 => sig_849,
+ out350 => sig_848,
+ out351 => sig_847,
+ out352 => sig_846,
+ out353 => sig_845,
+ out354 => sig_844,
+ out355 => sig_843,
+ out357 => sig_842,
+ out361 => sig_841,
+ out362 => sig_840,
+ out363 => sig_839,
+ out364 => sig_838,
+ out366 => sig_837,
+ out367 => sig_836,
+ out371 => sig_835,
+ out372 => sig_834,
+ out373 => sig_833,
+ out382 => sig_832,
+ out383 => sig_831,
+ out385 => sig_830,
+ out393 => sig_829,
+ out394 => sig_828,
+ out395 => sig_827,
+ out396 => sig_826,
+ out398 => sig_825,
+ out400 => sig_824,
+ out401 => sig_823,
+ out402 => sig_822,
+ out404 => sig_821,
+ out406 => sig_820,
+ out407 => sig_819,
+ out408 => sig_818,
+ out409 => sig_817,
+ out410 => sig_816,
+ out411 => sig_815,
+ out412 => sig_814,
+ out413 => sig_813,
+ out414 => sig_812,
+ out416 => sig_811,
+ out417 => sig_810,
+ out418 => sig_809,
+ out419 => sig_808,
+ out422 => sig_807,
+ out423 => sig_806,
+ out425 => sig_805,
+ out426 => sig_804,
+ out428 => sig_803,
+ out429 => sig_802,
+ out430 => sig_801,
+ out431 => sig_800,
+ out433 => sig_799,
+ out434 => sig_798,
+ out435 => sig_797,
+ out436 => sig_796,
+ out437 => sig_795,
+ out438 => sig_794,
+ out440 => sig_793,
+ out441 => sig_792,
+ out443 => sig_791,
+ out444 => sig_790,
+ out445 => sig_789,
+ out446 => sig_788,
+ out447 => sig_787,
+ out450 => sig_786,
+ out451 => sig_785,
+ out454 => sig_784,
+ out455 => sig_783,
+ out457 => sig_782,
+ out458 => sig_781,
+ out459 => sig_780,
+ out460 => sig_779,
+ out461 => sig_778,
+ out462 => sig_777,
+ out463 => sig_776,
+ out464 => sig_775,
+ out465 => sig_774,
+ out466 => sig_773,
+ out467 => sig_772,
+ out468 => sig_771,
+ out469 => sig_770,
+ out472 => sig_769,
+ out475 => sig_768,
+ out481 => sig_767,
+ out482 => sig_766,
+ out483 => sig_765,
+ out484 => sig_764,
+ out487 => sig_763,
+ out488 => sig_762,
+ out491 => sig_761,
+ out495 => sig_760,
+ out496 => sig_759,
+ out497 => sig_758,
+ out498 => sig_757,
+ out499 => sig_756,
+ out500 => sig_755,
+ out501 => sig_754,
+ out512 => sig_753,
+ out513 => sig_752,
+ out517 => sig_751,
+ out518 => sig_750,
+ out519 => sig_749,
+ out521 => sig_748,
+ out522 => sig_747,
+ out524 => sig_746,
+ out525 => sig_745,
+ out526 => sig_744,
+ out527 => sig_743,
+ out528 => sig_742,
+ out531 => sig_741,
+ out540 => sig_740,
+ out542 => sig_739,
+ out544 => sig_738,
+ out545 => sig_737,
+ out554 => sig_736,
+ out555 => sig_735,
+ out559 => sig_734,
+ out560 => sig_733,
+ out561 => sig_732,
+ out562 => sig_731,
+ out563 => sig_730,
+ out566 => sig_729,
+ out567 => sig_728,
+ out570 => sig_727,
+ out572 => sig_726,
+ out575 => sig_725,
+ out577 => sig_724,
+ out578 => sig_723,
+ out580 => sig_722,
+ out581 => sig_721
+ );
+
+ add_167_i : add_167 port map (
+ result => sig_720,
+ in_a => idct_2d_yc_reg6(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_169_i : add_169 port map (
+ result => sig_719,
+ in_a => idct_2d_yc_reg5(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_175_i : add_175 port map (
+ result => sig_718,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_255_i : add_255 port map (
+ result => sig_717,
+ in_a => sig_1169,
+ in_b => "00000000000000000001"
+ );
+
+ sub_362_i : sub_362 port map (
+ result => sig_716,
+ in_a => or_358,
+ in_b => or_360
+ );
+
+ mul_376_i : mul_376 port map (
+ result => sig_715,
+ in_a => or_374,
+ in_b => "010001010100011"
+ );
+
+ add_420_i : add_420 port map (
+ result => sig_714,
+ in_a => sig_1168,
+ in_b => "00000000000000000001"
+ );
+
+ sub_446_i : sub_446 port map (
+ result => sig_713,
+ in_a => sig_667,
+ in_b => sig_666
+ );
+
+ mul_456_i : mul_456 port map (
+ result => sig_712,
+ in_a => or_454,
+ in_b => "010110101000001"
+ );
+
+ mul_457_i : mul_457 port map (
+ result => sig_711,
+ in_a => or_450,
+ in_b => "0101001110011111"
+ );
+
+ sub_461_i : sub_461 port map (
+ result => sig_710,
+ in_a => sig_711,
+ in_b => sig_662
+ );
+
+ sub_517_i : sub_517 port map (
+ result => sig_709,
+ in_a => or_512,
+ in_b => or_514
+ );
+
+ mul_560_i : mul_560 port map (
+ result => sig_708,
+ in_a => or_435,
+ in_b => "010001010100011"
+ );
+
+ mul_565_i : mul_565 port map (
+ result => sig_707,
+ in_a => or_363,
+ in_b => "0101001110011111"
+ );
+
+ mul_578_i : mul_578 port map (
+ result => sig_706,
+ in_a => or_431,
+ in_b => "010001010100011"
+ );
+
+ muxb_162_i : muxb_162 port map (
+ in_sel => cp_en,
+ out_data => sig_705,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ add_184_i : add_184 port map (
+ result => sig_704,
+ in_a => idct_z2_reg3,
+ in_b => idct_z3_reg4
+ );
+
+ muxb_201_i : muxb_201 port map (
+ in_sel => cp_en,
+ out_data => sig_703,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ cmp_202_i : cmp_202 port map (
+ ne => memextrct_loop_sig_22,
+ in0 => "0000000000000111",
+ in1 => psc_loop_reg_13
+ );
+
+ cmp_203_i : cmp_203 port map (
+ eq => test_cp_1_17,
+ in0 => '1',
+ in1 => cp_id_reg_stable_15
+ );
+
+ cmp_204_i : cmp_204 port map (
+ eq => sig_702,
+ in0 => '0',
+ in1 => cp_id_reg_stable_15
+ );
+
+ sub_208_i : sub_208 port map (
+ result => sig_701,
+ in_a => idct_z1_reg4,
+ in_b => idct_z1_reg6
+ );
+
+ add_236_i : add_236 port map (
+ result => sig_700,
+ in_a => sig_1167,
+ in_b => "00000000000000000001"
+ );
+
+ muxb_263_i : muxb_263 port map (
+ in_sel => not_264,
+ out_data => sig_699,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ muxb_265_i : muxb_265 port map (
+ in_sel => not_264,
+ out_data => sig_698,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ add_277_i : add_277 port map (
+ result => sig_697,
+ in_a => sig_1166,
+ in_b => "00000000000000000001"
+ );
+
+ add_295_i : add_295 port map (
+ result => sig_696,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_296_i : add_296 port map (
+ result => sig_695,
+ in_a => sig_1165,
+ in_b => "00000000000000000001"
+ );
+
+ sub_303_i : sub_303 port map (
+ result => sig_694,
+ in_a => sig_1115,
+ in_b => sig_1164
+ );
+
+ add_315_i : add_315 port map (
+ result => sig_693,
+ in_a => sig_1163,
+ in_b => "00000000000000000001"
+ );
+
+ muxb_322_i : muxb_322 port map (
+ in_sel => cp_en,
+ out_data => sig_692,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ add_323_i : add_323 port map (
+ result => sig_691,
+ in_a => psc_loop_reg_13,
+ in_b => "0000000000000001"
+ );
+
+ cmp_324_i : cmp_324 port map (
+ ne => psc_loop_sig_20,
+ in0 => "0000000000000001",
+ in1 => psc_loop_reg_13
+ );
+
+ cmp_325_i : cmp_325 port map (
+ eq => sig_690,
+ in0 => '0',
+ in1 => cp_id_reg_stable_15
+ );
+
+ mul_328_i : mul_328 port map (
+ result => sig_689,
+ in_a => or_326,
+ in_b => "010001010100011"
+ );
+
+ mul_331_i : mul_331 port map (
+ result => sig_688,
+ in_a => or_329,
+ in_b => "0101001110011111"
+ );
+
+ sub_337_i : sub_337 port map (
+ result => sig_687,
+ in_a => or_333,
+ in_b => or_335
+ );
+
+ add_338_i : add_338 port map (
+ result => sig_686,
+ in_a => or_333,
+ in_b => or_297
+ );
+
+ mul_344_i : mul_344 port map (
+ result => sig_685,
+ in_a => or_342,
+ in_b => "010001010100011"
+ );
+
+ sub_345_i : sub_345 port map (
+ result => sig_684,
+ in_a => sig_1077,
+ in_b => sig_685
+ );
+
+ add_350_i : add_350 port map (
+ result => sig_683,
+ in_a => or_346,
+ in_b => or_348
+ );
+
+ mul_353_i : mul_353 port map (
+ result => sig_682,
+ in_a => or_351,
+ in_b => "010110101000001"
+ );
+
+ sub_354_i : sub_354 port map (
+ result => sig_681,
+ in_a => or_346,
+ in_b => or_348
+ );
+
+ mul_373_i : mul_373 port map (
+ result => sig_680,
+ in_a => or_371,
+ in_b => "0101001110011111"
+ );
+
+ add_382_i : add_382 port map (
+ result => sig_679,
+ in_a => or_378,
+ in_b => or_380
+ );
+
+ mul_383_i : mul_383 port map (
+ result => sig_678,
+ in_a => idct_2d_yc_reg3(30 downto 0),
+ in_b => "010110101000001"
+ );
+
+ add_390_i : add_390 port map (
+ result => sig_677,
+ in_a => or_386,
+ in_b => or_388
+ );
+
+ sub_391_i : sub_391 port map (
+ result => sig_676,
+ in_a => or_386,
+ in_b => or_388
+ );
+
+ cmp_392_i : cmp_392 port map (
+ ne => augh_test_11,
+ in0 => "00000000000000000000000000111111",
+ in1 => augh_main_k
+ );
+
+ add_393_i : add_393 port map (
+ result => sig_675,
+ in_a => augh_main_k,
+ in_b => "00000000000000000000000000000001"
+ );
+
+ cmp_396_i : cmp_396 port map (
+ eq => sig_674,
+ in0 => "111",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_402_i : cmp_402 port map (
+ eq => sig_673,
+ in0 => "100",
+ in1 => augh_main_k(2 downto 0)
+ );
+
+ cmp_411_i : cmp_411 port map (
+ eq => sig_672,
+ in0 => '1',
+ in1 => augh_main_k(0)
+ );
+
+ cmp_413_i : cmp_413 port map (
+ ne => augh_test_9,
+ in0 => "00000000000000000000000000111111",
+ in1 => augh_main_k
+ );
+
+ mul_416_i : mul_416 port map (
+ result => sig_671,
+ in_a => or_414,
+ in_b => "010110101000001"
+ );
+
+ add_419_i : add_419 port map (
+ result => sig_670,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_430_i : add_430 port map (
+ result => sig_669,
+ in_a => or_421,
+ in_b => or_427
+ );
+
+ sub_437_i : sub_437 port map (
+ result => sig_668,
+ in_a => sig_1115,
+ in_b => sig_1162
+ );
+
+ mul_442_i : mul_442 port map (
+ result => sig_667,
+ in_a => or_440,
+ in_b => "0101001110011111"
+ );
+
+ mul_445_i : mul_445 port map (
+ result => sig_666,
+ in_a => or_443,
+ in_b => "010001010100011"
+ );
+
+ mul_447_i : mul_447 port map (
+ result => sig_665,
+ in_a => or_440,
+ in_b => "010001010100011"
+ );
+
+ mul_448_i : mul_448 port map (
+ result => sig_664,
+ in_a => or_443,
+ in_b => "0101001110011111"
+ );
+
+ sub_449_i : sub_449 port map (
+ result => sig_663,
+ in_a => sig_665,
+ in_b => sig_664
+ );
+
+ mul_460_i : mul_460 port map (
+ result => sig_662,
+ in_a => or_458,
+ in_b => "010001010100011"
+ );
+
+ mul_469_i : mul_469 port map (
+ result => sig_661,
+ in_a => or_467,
+ in_b => "010110101000001"
+ );
+
+ add_474_i : add_474 port map (
+ result => sig_660,
+ in_a => or_470,
+ in_b => or_472
+ );
+
+ mul_477_i : mul_477 port map (
+ result => sig_659,
+ in_a => or_475,
+ in_b => "010110101000001"
+ );
+
+ sub_478_i : sub_478 port map (
+ result => sig_658,
+ in_a => or_470,
+ in_b => or_472
+ );
+
+ add_483_i : add_483 port map (
+ result => sig_657,
+ in_a => or_479,
+ in_b => or_481
+ );
+
+ sub_484_i : sub_484 port map (
+ result => sig_656,
+ in_a => or_479,
+ in_b => or_481
+ );
+
+ add_487_i : add_487 port map (
+ result => sig_655,
+ in_a => or_425,
+ in_b => or_485
+ );
+
+ sub_488_i : sub_488 port map (
+ result => sig_654,
+ in_a => or_425,
+ in_b => or_485
+ );
+
+ sub_489_i : sub_489 port map (
+ result => sig_653,
+ in_a => or_378,
+ in_b => or_285
+ );
+
+ mul_492_i : mul_492 port map (
+ result => sig_652,
+ in_a => or_490,
+ in_b => "010001010100011"
+ );
+
+ mul_495_i : mul_495 port map (
+ result => sig_651,
+ in_a => or_493,
+ in_b => "0101001110011111"
+ );
+
+ mul_499_i : mul_499 port map (
+ result => sig_650,
+ in_a => or_435,
+ in_b => "0101001110011111"
+ );
+
+ mul_502_i : mul_502 port map (
+ result => sig_649,
+ in_a => or_500,
+ in_b => "010001010100011"
+ );
+
+ sub_503_i : sub_503 port map (
+ result => sig_648,
+ in_a => sig_650,
+ in_b => sig_649
+ );
+
+ add_508_i : add_508 port map (
+ result => sig_647,
+ in_a => or_504,
+ in_b => or_506
+ );
+
+ mul_511_i : mul_511 port map (
+ result => sig_646,
+ in_a => or_509,
+ in_b => "010110101000001"
+ );
+
+ add_516_i : add_516 port map (
+ result => sig_645,
+ in_a => or_512,
+ in_b => or_514
+ );
+
+ mul_520_i : mul_520 port map (
+ result => sig_644,
+ in_a => or_518,
+ in_b => "010110101000001"
+ );
+
+ mul_524_i : mul_524 port map (
+ result => sig_643,
+ in_a => or_522,
+ in_b => "010001010100011"
+ );
+
+ mul_527_i : mul_527 port map (
+ result => sig_642,
+ in_a => or_525,
+ in_b => "0101001110011111"
+ );
+
+ mul_531_i : mul_531 port map (
+ result => sig_641,
+ in_a => or_529,
+ in_b => "010110101000001"
+ );
+
+ mul_534_i : mul_534 port map (
+ result => sig_640,
+ in_a => or_532,
+ in_b => "010110101000001"
+ );
+
+ add_537_i : add_537 port map (
+ result => sig_639,
+ in_a => or_497,
+ in_b => or_535
+ );
+
+ mul_540_i : mul_540 port map (
+ result => sig_638,
+ in_a => or_538,
+ in_b => "0101001110011111"
+ );
+
+ mul_543_i : mul_543 port map (
+ result => sig_637,
+ in_a => or_541,
+ in_b => "010001010100011"
+ );
+
+ sub_544_i : sub_544 port map (
+ result => sig_636,
+ in_a => sig_638,
+ in_b => sig_637
+ );
+
+ mul_547_i : mul_547 port map (
+ result => sig_635,
+ in_a => or_545,
+ in_b => "010110101000001"
+ );
+
+ add_552_i : add_552 port map (
+ result => sig_634,
+ in_a => or_548,
+ in_b => or_550
+ );
+
+ sub_553_i : sub_553 port map (
+ result => sig_633,
+ in_a => or_548,
+ in_b => or_550
+ );
+
+ mul_556_i : mul_556 port map (
+ result => sig_632,
+ in_a => or_554,
+ in_b => "010110101000001"
+ );
+
+ mul_559_i : mul_559 port map (
+ result => sig_631,
+ in_a => or_557,
+ in_b => "010110101000001"
+ );
+
+ mul_561_i : mul_561 port map (
+ result => sig_630,
+ in_a => or_500,
+ in_b => "0101001110011111"
+ );
+
+ sub_562_i : sub_562 port map (
+ result => sig_629,
+ in_a => sig_708,
+ in_b => sig_630
+ );
+
+ sub_563_i : sub_563 port map (
+ result => sig_628,
+ in_a => or_504,
+ in_b => or_506
+ );
+
+ add_564_i : add_564 port map (
+ result => sig_627,
+ in_a => or_358,
+ in_b => or_360
+ );
+
+ mul_566_i : mul_566 port map (
+ result => sig_626,
+ in_a => or_366,
+ in_b => "010001010100011"
+ );
+
+ sub_567_i : sub_567 port map (
+ result => sig_625,
+ in_a => sig_707,
+ in_b => sig_626
+ );
+
+ add_570_i : add_570 port map (
+ result => sig_624,
+ in_a => or_417,
+ in_b => or_568
+ );
+
+ mul_573_i : mul_573 port map (
+ result => sig_623,
+ in_a => or_571,
+ in_b => "010110101000001"
+ );
+
+ sub_574_i : sub_574 port map (
+ result => sig_622,
+ in_a => or_417,
+ in_b => or_568
+ );
+
+ mul_577_i : mul_577 port map (
+ result => sig_621,
+ in_a => or_575,
+ in_b => "010110101000001"
+ );
+
+ mul_579_i : mul_579 port map (
+ result => sig_620,
+ in_a => or_541,
+ in_b => "0101001110011111"
+ );
+
+ sub_580_i : sub_580 port map (
+ result => sig_619,
+ in_a => sig_706,
+ in_b => sig_620
+ );
+
+ sub_585_i : sub_585 port map (
+ result => sig_618,
+ in_a => or_581,
+ in_b => or_583
+ );
+
+ sub_586_i : sub_586 port map (
+ result => sig_617,
+ in_a => sig_1115,
+ in_b => sig_1161
+ );
+
+ mul_589_i : mul_589 port map (
+ result => sig_616,
+ in_a => or_587,
+ in_b => "0101001110011111"
+ );
+
+ mul_592_i : mul_592 port map (
+ result => sig_615,
+ in_a => or_590,
+ in_b => "010001010100011"
+ );
+
+ sub_593_i : sub_593 port map (
+ result => sig_614,
+ in_a => sig_616,
+ in_b => sig_615
+ );
+
+ mul_594_i : mul_594 port map (
+ result => sig_613,
+ in_a => or_587,
+ in_b => "010001010100011"
+ );
+
+ mul_595_i : mul_595 port map (
+ result => sig_612,
+ in_a => or_590,
+ in_b => "0101001110011111"
+ );
+
+ sub_596_i : sub_596 port map (
+ result => sig_611,
+ in_a => sig_613,
+ in_b => sig_612
+ );
+
+ sub_599_i : sub_599 port map (
+ result => sig_610,
+ in_a => or_423,
+ in_b => or_597
+ );
+
+ add_600_i : add_600 port map (
+ result => sig_609,
+ in_a => or_423,
+ in_b => or_597
+ );
+
+ add_601_i : add_601 port map (
+ result => sig_608,
+ in_a => idct_2d_yc_reg2(31 downto 5),
+ in_b => "000000000000000000000000001"
+ );
+
+ add_602_i : add_602 port map (
+ result => sig_607,
+ in_a => sig_1160,
+ in_b => "00000000000000000001"
+ );
+
+ mul_605_i : mul_605 port map (
+ result => sig_606,
+ in_a => or_603,
+ in_b => "010110101000001"
+ );
+
+ -- Behaviour of component 'mux_66' model 'mux'
+ mux_66 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_947) and "110") or
+ (repeat(3, sig_945) and "101") or
+ (repeat(3, sig_943) and "100") or
+ (repeat(3, sig_941) and "011") or
+ (repeat(3, sig_949) and "111") or
+ (repeat(3, sig_939) and "010") or
+ (repeat(3, sig_937) and "001");
+
+ -- Behaviour of component 'mux_30' model 'mux'
+ mux_30 <=
+ (sig_873 and cp_en);
+
+ -- Behaviour of component 'mux_32' model 'mux'
+ mux_32 <=
+ (sig_1002 and sig_702) or
+ (sig_872 and sig_690);
+
+ -- Behaviour of component 'mux_33' model 'mux'
+ mux_33 <=
+ (sig_1039 and cp_din(0)) or
+ (sig_954 and '1');
+
+ -- Behaviour of component 'mux_34' model 'mux'
+ mux_34 <=
+ (sig_1038 and cp_rest) or
+ (sig_953 and '1');
+
+ -- Behaviour of component 'mux_58' model 'mux'
+ mux_58 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_966) and "110") or
+ (repeat(3, sig_957) and "101") or
+ (repeat(3, sig_956) and "100") or
+ (repeat(3, sig_990) and "011") or
+ (repeat(3, sig_996) and "111") or
+ (repeat(3, sig_986) and "010") or
+ (repeat(3, sig_984) and "001");
+
+ -- Behaviour of component 'mux_59' model 'mux'
+ mux_59 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_60' model 'mux'
+ mux_60 <=
+ (sig_1004 and and_161) or
+ (sig_995 and '1');
+
+ -- Behaviour of component 'mux_61' model 'mux'
+ mux_61 <=
+ (repeat(8, sig_1003) and cp_din(23 downto 16)) or
+ (repeat(8, sig_977) and mux_156);
+
+ -- Behaviour of component 'mux_62' model 'mux'
+ mux_62 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_974) and "110") or
+ (repeat(3, sig_1018) and "101") or
+ (repeat(3, sig_1016) and "100") or
+ (repeat(3, sig_1014) and "011") or
+ (repeat(3, sig_976) and "111") or
+ (repeat(3, sig_1012) and "010") or
+ (repeat(3, sig_1010) and "001");
+
+ -- Behaviour of component 'mux_63' model 'mux'
+ mux_63 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_64' model 'mux'
+ mux_64 <=
+ (sig_1004 and and_161) or
+ (sig_975 and '1');
+
+ -- Behaviour of component 'mux_65' model 'mux'
+ mux_65 <=
+ (repeat(8, sig_1003) and cp_din(31 downto 24)) or
+ (repeat(8, sig_950) and mux_156);
+
+ -- Behaviour of component 'mux_35' model 'mux'
+ mux_35 <=
+ (sig_954 and '1') or
+ (sig_874 and augh_main_k(0));
+
+ -- Behaviour of component 'mux_36' model 'mux'
+ mux_36 <=
+ (sig_953 and '1') or
+ (sig_873 and cp_en);
+
+ -- Behaviour of component 'mux_37' model 'mux'
+ mux_37 <=
+ (repeat(16, sig_1052) and sig_1128) or
+ (repeat(16, sig_874) and sig_691);
+
+ -- Behaviour of component 'mux_38' model 'mux'
+ mux_38 <=
+ (sig_1051 and cp_en) or
+ (sig_1049 and '1');
+
+ -- Behaviour of component 'mux_39' model 'mux'
+ mux_39 <=
+ (repeat(32, sig_1005) and cp_din(31 downto 0)) or
+ (repeat(32, sig_884) and sig_704) or
+ (repeat(32, sig_880) and sig_1124) or
+ (repeat(32, sig_862) and sig_1103) or
+ (repeat(32, sig_859) and sig_1102) or
+ (repeat(32, sig_887) and (sig_1084(28 downto 0) & "000")) or
+ (repeat(32, sig_831) and read32_ret0_10) or
+ (repeat(32, sig_733) and (sig_1085(28 downto 0) & "000"));
+
+ -- Behaviour of component 'mux_45' model 'mux'
+ mux_45 <=
+ (repeat(5, sig_857) and "01101") or
+ (repeat(5, sig_754) and "11011") or
+ (repeat(5, sig_742) and "10111") or
+ (repeat(5, sig_737) and "10001") or
+ (repeat(5, sig_770) and "11111");
+
+ -- Behaviour of component 'mux_46' model 'mux'
+ mux_46 <=
+ (repeat(5, sig_867) and "01010") or
+ (repeat(5, sig_852) and "01111") or
+ (repeat(5, sig_843) and "11110") or
+ (repeat(5, sig_769) and "11010") or
+ (repeat(5, sig_761) and "11111") or
+ (repeat(5, sig_857) and "01011") or
+ (repeat(5, sig_755) and "10110") or
+ (repeat(5, sig_741) and "10011");
+
+ -- Behaviour of component 'mux_47' model 'mux'
+ mux_47 <=
+ (repeat(5, sig_867) and "01011") or
+ (repeat(5, sig_852) and "01110") or
+ (repeat(5, sig_843) and "11111") or
+ (repeat(5, sig_788) and "00001") or
+ (repeat(5, sig_770) and "11011") or
+ (repeat(5, sig_730) and "00111") or
+ (repeat(5, sig_857) and "01001") or
+ (repeat(5, sig_764) and "00110") or
+ (repeat(5, sig_742) and "10010") or
+ (repeat(5, sig_735) and "10000") or
+ (repeat(5, sig_762) and "00010") or
+ (repeat(5, sig_761) and "11101") or
+ (repeat(5, sig_755) and "10111") or
+ (repeat(5, sig_752) and "11001");
+
+ -- Behaviour of component 'mux_48' model 'mux'
+ mux_48 <=
+ (repeat(5, sig_1005) and psc_loop_reg_13(4 downto 0)) or
+ (repeat(5, sig_865) and "01101") or
+ (repeat(5, sig_844) and "11101") or
+ (repeat(5, sig_823) and "11000") or
+ (repeat(5, sig_818) and "10100") or
+ (repeat(5, sig_810) and "00100") or
+ (repeat(5, sig_804) and "10001") or
+ (repeat(5, sig_797) and "10101") or
+ (repeat(5, sig_785) and "11001") or
+ (repeat(5, sig_758) and "10000") or
+ (repeat(5, sig_731) and "00101") or
+ (repeat(5, sig_1017) and "11011") or
+ (repeat(5, sig_1015) and "10111") or
+ (repeat(5, sig_1013) and "10011") or
+ (repeat(5, sig_1011) and "01111") or
+ (repeat(5, sig_918) and "01110") or
+ (repeat(5, sig_916) and "01010") or
+ (repeat(5, sig_915) and "00110") or
+ (repeat(5, sig_973) and "11111") or
+ (repeat(5, sig_913) and "00010") or
+ (repeat(5, sig_891) and "01001") or
+ (repeat(5, sig_871) and "01100") or
+ (repeat(5, sig_1009) and "01011") or
+ (repeat(5, sig_922) and "10110") or
+ (repeat(5, sig_920) and "10010") or
+ (repeat(5, sig_1058) and "00111") or
+ (repeat(5, sig_1056) and "00011") or
+ (repeat(5, sig_926) and "11110") or
+ (repeat(5, sig_924) and "11010");
+
+ -- Behaviour of component 'mux_49' model 'mux'
+ mux_49 <=
+ (repeat(5, sig_866) and "01000") or
+ (repeat(5, sig_842) and "11100") or
+ (repeat(5, sig_787) and "00011") or
+ (repeat(5, sig_770) and "11000") or
+ (repeat(5, sig_755) and "10100") or
+ (repeat(5, sig_850) and "01101") or
+ (repeat(5, sig_752) and "11011") or
+ (repeat(5, sig_742) and "10001") or
+ (repeat(5, sig_735) and "10010");
+
+ -- Behaviour of component 'mux_40' model 'mux'
+ mux_40 <=
+ (repeat(5, sig_1005) and psc_loop_reg_13(4 downto 0)) or
+ (repeat(5, sig_794) and "11000") or
+ (repeat(5, sig_782) and "10100") or
+ (repeat(5, sig_781) and "11100") or
+ (repeat(5, sig_780) and "11110") or
+ (repeat(5, sig_776) and "11001") or
+ (repeat(5, sig_773) and "01001") or
+ (repeat(5, sig_771) and "10011") or
+ (repeat(5, sig_763) and "10001") or
+ (repeat(5, sig_760) and "11010") or
+ (repeat(5, sig_759) and "10101") or
+ (repeat(5, sig_751) and "10110") or
+ (repeat(5, sig_750) and "00111") or
+ (repeat(5, sig_748) and "01011") or
+ (repeat(5, sig_744) and "01110") or
+ (repeat(5, sig_736) and "01100") or
+ (repeat(5, sig_883) and "00101") or
+ (repeat(5, sig_879) and "00010") or
+ (repeat(5, sig_875) and "00110") or
+ (repeat(5, sig_863) and "01010") or
+ (repeat(5, sig_828) and "10000") or
+ (repeat(5, sig_827) and "01111") or
+ (repeat(5, sig_886) and "01101") or
+ (repeat(5, sig_824) and "11011") or
+ (repeat(5, sig_807) and "00001") or
+ (repeat(5, sig_803) and "11111") or
+ (repeat(5, sig_861) and "00100") or
+ (repeat(5, sig_845) and "10111") or
+ (repeat(5, sig_831) and augh_main_k(5 downto 1)) or
+ (repeat(5, sig_860) and "10010") or
+ (repeat(5, sig_858) and "00011") or
+ (repeat(5, sig_854) and "01000") or
+ (repeat(5, sig_849) and "11101");
+
+ -- Behaviour of component 'mux_41' model 'mux'
+ mux_41 <=
+ (repeat(5, sig_857) and "01110") or
+ (repeat(5, sig_754) and "11010") or
+ (repeat(5, sig_742) and "10110") or
+ (repeat(5, sig_737) and "10010") or
+ (repeat(5, sig_770) and "11110");
+
+ -- Behaviour of component 'mux_42' model 'mux'
+ mux_42 <=
+ (sig_1053 and and_161) or
+ (sig_830 and sig_672) or
+ (sig_885 and '1');
+
+ -- Behaviour of component 'mux_43' model 'mux'
+ mux_43 <=
+ (repeat(5, sig_857) and "01111") or
+ (repeat(5, sig_826) and "00001") or
+ (repeat(5, sig_808) and "01011") or
+ (repeat(5, sig_768) and "11100") or
+ (repeat(5, sig_754) and "11000") or
+ (repeat(5, sig_836) and "00111") or
+ (repeat(5, sig_749) and "00101") or
+ (repeat(5, sig_728) and "00011") or
+ (repeat(5, sig_747) and "00110") or
+ (repeat(5, sig_742) and "10100") or
+ (repeat(5, sig_740) and "00010") or
+ (repeat(5, sig_737) and "10011");
+
+ -- Behaviour of component 'mux_44' model 'mux'
+ mux_44 <=
+ (repeat(5, sig_1005) and psc_loop_reg_13(4 downto 0)) or
+ (repeat(5, sig_902) and "10101") or
+ (repeat(5, sig_900) and "10001") or
+ (repeat(5, sig_898) and "01101") or
+ (repeat(5, sig_896) and "01001") or
+ (repeat(5, sig_895) and "00101") or
+ (repeat(5, sig_893) and "00001") or
+ (repeat(5, sig_856) and "01100") or
+ (repeat(5, sig_838) and "10100") or
+ (repeat(5, sig_837) and "00100") or
+ (repeat(5, sig_829) and "10000") or
+ (repeat(5, sig_821) and "01000") or
+ (repeat(5, sig_800) and "11000") or
+ (repeat(5, sig_958) and "11011") or
+ (repeat(5, sig_991) and "10111") or
+ (repeat(5, sig_987) and "10011") or
+ (repeat(5, sig_985) and "01111") or
+ (repeat(5, sig_938) and "01110") or
+ (repeat(5, sig_936) and "01010") or
+ (repeat(5, sig_935) and "00110") or
+ (repeat(5, sig_961) and "11111") or
+ (repeat(5, sig_933) and "00010") or
+ (repeat(5, sig_906) and "11101") or
+ (repeat(5, sig_904) and "11001") or
+ (repeat(5, sig_983) and "01011") or
+ (repeat(5, sig_942) and "10110") or
+ (repeat(5, sig_940) and "10010") or
+ (repeat(5, sig_982) and "00111") or
+ (repeat(5, sig_980) and "00011") or
+ (repeat(5, sig_946) and "11110") or
+ (repeat(5, sig_944) and "11010");
+
+ -- Behaviour of component 'mux_50' model 'mux'
+ mux_50 <=
+ (repeat(32, sig_1005) and cp_din(63 downto 32)) or
+ (repeat(32, sig_882) and sig_1111) or
+ (repeat(32, sig_877) and sig_1079) or
+ (repeat(32, sig_869) and sig_1149) or
+ (repeat(32, sig_847) and sig_1150) or
+ (repeat(32, sig_890) and (sig_1093(28 downto 0) & "000")) or
+ (repeat(32, sig_831) and read32_ret0_10) or
+ (repeat(32, sig_777) and (sig_1094(28 downto 0) & "000")) or
+ (repeat(32, sig_766) and (sig_1092(28 downto 0) & "000"));
+
+ -- Behaviour of component 'mux_51' model 'mux'
+ mux_51 <=
+ (repeat(5, sig_1005) and psc_loop_reg_13(4 downto 0)) or
+ (repeat(5, sig_796) and "10101") or
+ (repeat(5, sig_795) and "10110") or
+ (repeat(5, sig_793) and "11111") or
+ (repeat(5, sig_790) and "11101") or
+ (repeat(5, sig_779) and "11010") or
+ (repeat(5, sig_778) and "01011") or
+ (repeat(5, sig_775) and "11001") or
+ (repeat(5, sig_767) and "11100") or
+ (repeat(5, sig_765) and "01000") or
+ (repeat(5, sig_756) and "10000") or
+ (repeat(5, sig_753) and "10011") or
+ (repeat(5, sig_746) and "10010") or
+ (repeat(5, sig_745) and "01010") or
+ (repeat(5, sig_729) and "11110") or
+ (repeat(5, sig_881) and "00110") or
+ (repeat(5, sig_878) and "01111") or
+ (repeat(5, sig_876) and "00101") or
+ (repeat(5, sig_870) and "01100") or
+ (repeat(5, sig_817) and "10100") or
+ (repeat(5, sig_813) and "00010") or
+ (repeat(5, sig_812) and "00001") or
+ (repeat(5, sig_889) and "01001") or
+ (repeat(5, sig_809) and "00100") or
+ (repeat(5, sig_799) and "10001") or
+ (repeat(5, sig_798) and "11011") or
+ (repeat(5, sig_868) and "00011") or
+ (repeat(5, sig_831) and augh_main_k(5 downto 1)) or
+ (repeat(5, sig_819) and "10111") or
+ (repeat(5, sig_864) and "01101") or
+ (repeat(5, sig_855) and "01110") or
+ (repeat(5, sig_853) and "00111") or
+ (repeat(5, sig_846) and "11000");
+
+ -- Behaviour of component 'mux_52' model 'mux'
+ mux_52 <=
+ (sig_1053 and and_161) or
+ (sig_830 and sig_1064) or
+ (sig_888 and '1');
+
+ -- Behaviour of component 'mux_53' model 'mux'
+ mux_53 <=
+ (repeat(8, sig_1008) and mux_156) or
+ (repeat(8, sig_1003) and cp_din(7 downto 0));
+
+ -- Behaviour of component 'mux_54' model 'mux'
+ mux_54 <=
+ (repeat(3, sig_1007) and "111") or
+ (repeat(3, sig_1045) and "101") or
+ (repeat(3, sig_1043) and "100") or
+ (repeat(3, sig_1041) and "011") or
+ (repeat(3, sig_1037) and "010") or
+ (repeat(3, sig_1048) and "110") or
+ (repeat(3, sig_1035) and "001") or
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0));
+
+ -- Behaviour of component 'mux_55' model 'mux'
+ mux_55 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_56' model 'mux'
+ mux_56 <=
+ (sig_1006 and '1') or
+ (sig_1004 and and_161);
+
+ -- Behaviour of component 'mux_57' model 'mux'
+ mux_57 <=
+ (repeat(8, sig_1003) and cp_din(15 downto 8)) or
+ (repeat(8, sig_997) and mux_156);
+
+ -- Behaviour of component 'mux_88' model 'mux'
+ mux_88 <=
+ (sig_1004 and and_161) or
+ (sig_839 and '1');
+
+ -- Behaviour of component 'mux_67' model 'mux'
+ mux_67 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_68' model 'mux'
+ mux_68 <=
+ (sig_1004 and and_161) or
+ (sig_948 and '1');
+
+ -- Behaviour of component 'mux_69' model 'mux'
+ mux_69 <=
+ (repeat(32, sig_1026) and sig_1102) or
+ (repeat(32, sig_974) and or_244) or
+ (repeat(32, sig_947) and or_266) or
+ (repeat(32, sig_927) and or_285) or
+ (repeat(32, sig_907) and or_304) or
+ (repeat(32, sig_966) and or_221) or
+ (repeat(32, sig_802) and or_378) or
+ (repeat(32, sig_727) and or_371) or
+ (repeat(32, sig_723) and or_470);
+
+ -- Behaviour of component 'mux_71' model 'mux'
+ mux_71 <=
+ (repeat(32, sig_1026) and sig_1149) or
+ (repeat(32, sig_1018) and or_246) or
+ (repeat(32, sig_945) and or_268) or
+ (repeat(32, sig_925) and or_287) or
+ (repeat(32, sig_905) and or_306) or
+ (repeat(32, sig_957) and or_224) or
+ (repeat(32, sig_801) and or_433) or
+ (repeat(32, sig_789) and or_438) or
+ (repeat(32, sig_786) and or_450);
+
+ -- Behaviour of component 'mux_73' model 'mux'
+ mux_73 <=
+ (repeat(32, sig_1026) and sig_1124) or
+ (repeat(32, sig_1016) and or_248) or
+ (repeat(32, sig_943) and or_270) or
+ (repeat(32, sig_923) and or_289) or
+ (repeat(32, sig_903) and or_308) or
+ (repeat(32, sig_956) and or_228) or
+ (repeat(32, sig_840) and or_384) or
+ (repeat(32, sig_792) and or_435) or
+ (repeat(32, sig_774) and or_452);
+
+ -- Behaviour of component 'mux_75' model 'mux'
+ mux_75 <=
+ (repeat(32, sig_1026) and sig_1111) or
+ (repeat(32, sig_1014) and or_250) or
+ (repeat(32, sig_941) and or_272) or
+ (repeat(32, sig_921) and or_291) or
+ (repeat(32, sig_901) and or_310) or
+ (repeat(32, sig_990) and or_231) or
+ (repeat(32, sig_825) and or_417) or
+ (repeat(32, sig_805) and or_431) or
+ (repeat(32, sig_757) and or_497);
+
+ -- Behaviour of component 'mux_77' model 'mux'
+ mux_77 <=
+ (repeat(32, sig_1026) and sig_704) or
+ (repeat(32, sig_1012) and or_252) or
+ (repeat(32, sig_939) and or_274) or
+ (repeat(32, sig_919) and or_293) or
+ (repeat(32, sig_899) and or_312) or
+ (repeat(32, sig_986) and or_233) or
+ (repeat(32, sig_806) and or_363) or
+ (repeat(32, sig_783) and or_346) or
+ (repeat(32, sig_743) and or_358);
+
+ -- Behaviour of component 'mux_79' model 'mux'
+ mux_79 <=
+ (repeat(32, sig_1026) and sig_1079) or
+ (repeat(32, sig_1010) and or_256) or
+ (repeat(32, sig_937) and or_278) or
+ (repeat(32, sig_917) and or_297) or
+ (repeat(32, sig_897) and or_316) or
+ (repeat(32, sig_984) and or_237) or
+ (repeat(32, sig_822) and or_421) or
+ (repeat(32, sig_738) and or_333) or
+ (repeat(32, sig_726) and or_326);
+
+ -- Behaviour of component 'mux_81' model 'mux'
+ mux_81 <=
+ (repeat(32, sig_1026) and sig_1103) or
+ (repeat(32, sig_1057) and or_258) or
+ (repeat(32, sig_934) and or_280) or
+ (repeat(32, sig_914) and or_299) or
+ (repeat(32, sig_894) and or_318) or
+ (repeat(32, sig_981) and or_239) or
+ (repeat(32, sig_784) and or_386) or
+ (repeat(32, sig_734) and or_479) or
+ (repeat(32, sig_724) and or_587);
+
+ -- Behaviour of component 'mux_83' model 'mux'
+ mux_83 <=
+ (repeat(32, sig_1026) and sig_1150) or
+ (repeat(32, sig_1055) and or_260) or
+ (repeat(32, sig_932) and or_282) or
+ (repeat(32, sig_912) and or_301) or
+ (repeat(32, sig_892) and or_320) or
+ (repeat(32, sig_979) and or_241) or
+ (repeat(32, sig_820) and or_423) or
+ (repeat(32, sig_811) and or_425) or
+ (repeat(32, sig_722) and or_440);
+
+ -- Behaviour of component 'mux_85' model 'mux'
+ mux_85 <=
+ (repeat(8, sig_1003) and cp_din(63 downto 56)) or
+ (repeat(8, sig_841) and mux_156);
+
+ -- Behaviour of component 'mux_86' model 'mux'
+ mux_86 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_825) and "011") or
+ (repeat(3, sig_822) and "001") or
+ (repeat(3, sig_801) and "101") or
+ (repeat(3, sig_840) and "100") or
+ (repeat(3, sig_783) and "010") or
+ (repeat(3, sig_725) and "111") or
+ (repeat(3, sig_723) and "110");
+
+ -- Behaviour of component 'mux_87' model 'mux'
+ mux_87 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_28' model 'mux'
+ mux_28 <=
+ (sig_873 and cp_en);
+
+ -- Behaviour of component 'mux_109' model 'mux'
+ mux_109 <=
+ (repeat(32, sig_972) and sig_1119) or
+ (repeat(32, sig_836) and sig_677) or
+ (repeat(32, sig_808) and sig_669) or
+ (repeat(32, sig_770) and sig_660) or
+ (repeat(32, sig_754) and sig_645) or
+ (repeat(32, sig_857) and sig_683) or
+ (repeat(32, sig_742) and sig_634) or
+ (repeat(32, sig_737) and sig_624) or
+ (repeat(32, sig_728) and sig_609);
+
+ -- Behaviour of component 'mux_154' model 'mux'
+ mux_154 <=
+ (sig_952 and sig_699);
+
+ -- Behaviour of component 'mux_156' model 'mux'
+ mux_156 <=
+ (repeat(8, sig_1130) and mux_158);
+
+ -- Behaviour of component 'mux_89' model 'mux'
+ mux_89 <=
+ (repeat(8, sig_1003) and cp_din(55 downto 48)) or
+ (repeat(8, sig_816) and mux_156);
+
+ -- Behaviour of component 'mux_90' model 'mux'
+ mux_90 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_806) and "010") or
+ (repeat(3, sig_805) and "011") or
+ (repeat(3, sig_792) and "100") or
+ (repeat(3, sig_786) and "101") or
+ (repeat(3, sig_815) and "111") or
+ (repeat(3, sig_727) and "110") or
+ (repeat(3, sig_726) and "001");
+
+ -- Behaviour of component 'mux_134' model 'mux'
+ mux_134 <=
+ (sig_873 and cp_en) or
+ (sig_832 and '1');
+
+ -- Behaviour of component 'mux_91' model 'mux'
+ mux_91 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_92' model 'mux'
+ mux_92 <=
+ (sig_1004 and and_161) or
+ (sig_814 and '1');
+
+ -- Behaviour of component 'mux_158' model 'mux'
+ mux_158 <=
+ (repeat(8, sig_1157) and "11111111") or
+ (repeat(8, sig_1106) and idct_2d_r(7 downto 0));
+
+ -- Behaviour of component 'mux_111' model 'mux'
+ mux_111 <=
+ (repeat(32, sig_960) and (sig_1132 & '0')) or
+ (repeat(32, sig_770) and (sig_659 & '0')) or
+ (repeat(32, sig_754) and (sig_644 & '0')) or
+ (repeat(32, sig_747) and (sig_640 & '0')) or
+ (repeat(32, sig_742) and (sig_632 & '0')) or
+ (repeat(32, sig_857) and (sig_1076 & '0')) or
+ (repeat(32, sig_740) and (sig_631 & '0')) or
+ (repeat(32, sig_737) and (sig_621 & '0')) or
+ (repeat(32, sig_721) and (sig_606 & '0'));
+
+ -- Behaviour of component 'mux_113' model 'mux'
+ mux_113 <=
+ (repeat(32, sig_989) and (sig_1112 & '0')) or
+ (repeat(32, sig_843) and (sig_678 & '0')) or
+ (repeat(32, sig_826) and (sig_671 & '0')) or
+ (repeat(32, sig_772) and (sig_712 & '0')) or
+ (repeat(32, sig_770) and (sig_661 & '0')) or
+ (repeat(32, sig_857) and (sig_682 & '0')) or
+ (repeat(32, sig_754) and (sig_646 & '0')) or
+ (repeat(32, sig_749) and (sig_641 & '0')) or
+ (repeat(32, sig_742) and (sig_635 & '0')) or
+ (repeat(32, sig_737) and (sig_623 & '0'));
+
+ -- Behaviour of component 'mux_115' model 'mux'
+ mux_115 <=
+ (repeat(32, sig_972) and sig_1142) or
+ (repeat(32, sig_836) and sig_676) or
+ (repeat(32, sig_808) and sig_1063) or
+ (repeat(32, sig_770) and sig_658) or
+ (repeat(32, sig_754) and sig_709) or
+ (repeat(32, sig_857) and sig_681) or
+ (repeat(32, sig_742) and sig_633) or
+ (repeat(32, sig_737) and sig_622) or
+ (repeat(32, sig_728) and sig_610);
+
+ -- Behaviour of component 'mux_117' model 'mux'
+ mux_117 <=
+ (repeat(32, sig_965) and sig_1136) or
+ (repeat(32, sig_843) and sig_1071) or
+ (repeat(32, sig_787) and sig_713) or
+ (repeat(32, sig_770) and sig_710) or
+ (repeat(32, sig_754) and sig_648) or
+ (repeat(32, sig_857) and sig_684) or
+ (repeat(32, sig_742) and sig_636) or
+ (repeat(32, sig_737) and sig_625) or
+ (repeat(32, sig_730) and sig_614);
+
+ -- Behaviour of component 'mux_119' model 'mux'
+ mux_119 <=
+ (repeat(32, sig_963) and sig_1133) or
+ (repeat(32, sig_851) and sig_1073) or
+ (repeat(32, sig_787) and sig_663) or
+ (repeat(32, sig_761) and sig_1061) or
+ (repeat(32, sig_752) and sig_1059) or
+ (repeat(32, sig_867) and sig_1078) or
+ (repeat(32, sig_739) and sig_629) or
+ (repeat(32, sig_735) and sig_619) or
+ (repeat(32, sig_730) and sig_611);
+
+ -- Behaviour of component 'mux_121' model 'mux'
+ mux_121 <=
+ (repeat(32, sig_993) and sig_1131) or
+ (repeat(32, sig_851) and sig_716) or
+ (repeat(32, sig_764) and sig_656) or
+ (repeat(32, sig_762) and sig_654) or
+ (repeat(32, sig_761) and sig_653) or
+ (repeat(32, sig_867) and sig_687) or
+ (repeat(32, sig_752) and sig_1060) or
+ (repeat(32, sig_739) and sig_628) or
+ (repeat(32, sig_735) and sig_618);
+
+ -- Behaviour of component 'mux_123' model 'mux'
+ mux_123 <=
+ (repeat(32, sig_955) and sig_1109) or
+ (repeat(32, sig_843) and sig_679) or
+ (repeat(32, sig_770) and sig_1062) or
+ (repeat(32, sig_764) and sig_657) or
+ (repeat(32, sig_762) and sig_655) or
+ (repeat(32, sig_857) and sig_686) or
+ (repeat(32, sig_754) and sig_647) or
+ (repeat(32, sig_742) and sig_639) or
+ (repeat(32, sig_737) and sig_627);
+
+ -- Behaviour of component 'or_224' model 'or'
+ or_224 <=
+ and_225;
+
+ -- Behaviour of component 'and_225' model 'and'
+ and_225 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_231' model 'or'
+ or_231 <=
+ and_232;
+
+ -- Behaviour of component 'and_232' model 'and'
+ and_232 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_250' model 'or'
+ or_250 <=
+ and_251;
+
+ -- Behaviour of component 'and_251' model 'and'
+ and_251 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_260' model 'or'
+ or_260 <=
+ and_261;
+
+ -- Behaviour of component 'and_261' model 'and'
+ and_261 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_282' model 'or'
+ or_282 <=
+ and_283;
+
+ -- Behaviour of component 'and_283' model 'and'
+ and_283 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_285' model 'or'
+ or_285 <=
+ and_286;
+
+ -- Behaviour of component 'and_286' model 'and'
+ and_286 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_289' model 'or'
+ or_289 <=
+ and_290;
+
+ -- Behaviour of component 'and_290' model 'and'
+ and_290 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_291' model 'or'
+ or_291 <=
+ and_292;
+
+ -- Behaviour of component 'and_292' model 'and'
+ and_292 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_297' model 'or'
+ or_297 <=
+ and_298;
+
+ -- Behaviour of component 'and_298' model 'and'
+ and_298 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_299' model 'or'
+ or_299 <=
+ and_300;
+
+ -- Behaviour of component 'and_300' model 'and'
+ and_300 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_320' model 'or'
+ or_320 <=
+ and_321;
+
+ -- Behaviour of component 'and_321' model 'and'
+ and_321 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_326' model 'or'
+ or_326 <=
+ and_327;
+
+ -- Behaviour of component 'and_327' model 'and'
+ and_327 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_333' model 'or'
+ or_333 <=
+ and_334;
+
+ -- Behaviour of component 'and_334' model 'and'
+ and_334 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_363' model 'or'
+ or_363 <=
+ and_364;
+
+ -- Behaviour of component 'and_364' model 'and'
+ and_364 <=
+ sig_1092;
+
+ -- Behaviour of component 'and_403' model 'and'
+ and_403 <=
+ sig_1158 and
+ repeat(8, sig_1068);
+
+ -- Behaviour of component 'and_405' model 'and'
+ and_405 <=
+ sig_1159 and
+ repeat(8, sig_1067);
+
+ -- Behaviour of component 'and_407' model 'and'
+ and_407 <=
+ sig_1154 and
+ repeat(8, sig_1066);
+
+ -- Behaviour of component 'and_409' model 'and'
+ and_409 <=
+ sig_1153 and
+ repeat(8, sig_1065);
+
+ -- Behaviour of component 'and_415' model 'and'
+ and_415 <=
+ sig_1085(30 downto 0);
+
+ -- Behaviour of component 'or_464' model 'or'
+ or_464 <=
+ and_465;
+
+ -- Behaviour of component 'and_465' model 'and'
+ and_465 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_470' model 'or'
+ or_470 <=
+ and_471;
+
+ -- Behaviour of component 'and_471' model 'and'
+ and_471 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_472' model 'or'
+ or_472 <=
+ and_473;
+
+ -- Behaviour of component 'and_473' model 'and'
+ and_473 <=
+ sig_1083;
+
+ -- Behaviour of component 'or_500' model 'or'
+ or_500 <=
+ and_501;
+
+ -- Behaviour of component 'and_501' model 'and'
+ and_501 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_504' model 'or'
+ or_504 <=
+ and_505;
+
+ -- Behaviour of component 'and_505' model 'and'
+ and_505 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_506' model 'or'
+ or_506 <=
+ and_507;
+
+ -- Behaviour of component 'and_507' model 'and'
+ and_507 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_514' model 'or'
+ or_514 <=
+ and_515;
+
+ -- Behaviour of component 'and_515' model 'and'
+ and_515 <=
+ sig_1083;
+
+ -- Behaviour of component 'or_522' model 'or'
+ or_522 <=
+ and_523;
+
+ -- Behaviour of component 'and_523' model 'and'
+ and_523 <=
+ sig_1094;
+
+ -- Behaviour of component 'mux_129' model 'mux'
+ mux_129 <=
+ (repeat(32, sig_1021) and sig_1114) or
+ (repeat(32, sig_1054) and sig_1100) or
+ (repeat(32, sig_931) and sig_1087) or
+ (repeat(32, sig_911) and sig_694) or
+ (repeat(32, sig_848) and sig_1072) or
+ (repeat(32, sig_978) and sig_1101) or
+ (repeat(32, sig_791) and sig_668) or
+ (repeat(32, sig_732) and sig_617);
+
+ -- Behaviour of component 'mux_133' model 'mux'
+ mux_133 <=
+ (repeat(8, sig_874) and cp_din(39 downto 32)) or
+ (repeat(8, sig_833) and or_394);
+
+ -- Behaviour of component 'mux_135' model 'mux'
+ mux_135 <=
+ (repeat(32, sig_1047) and (repeat(5, sig_1082(19)) & sig_1082 & sig_1155(7 downto 1))) or
+ (repeat(32, sig_1042) and (repeat(5, sig_1127(19)) & sig_1127 & sig_719(7 downto 1))) or
+ (repeat(32, sig_1040) and (repeat(5, sig_1152(19)) & sig_1152 & sig_1118(7 downto 1))) or
+ (repeat(32, sig_1036) and (repeat(5, sig_1126(19)) & sig_1126 & sig_1104(7 downto 1))) or
+ (repeat(32, sig_1035) and (repeat(5, sig_1151(19)) & sig_1151 & sig_718(7 downto 1))) or
+ (repeat(32, sig_822) and (repeat(5, sig_714(19)) & sig_714 & sig_670(7 downto 1))) or
+ (repeat(32, sig_726) and (repeat(5, sig_607(19)) & sig_607 & sig_608(7 downto 1))) or
+ (repeat(32, sig_1044) and (repeat(5, sig_1081(19)) & sig_1081 & sig_720(7 downto 1))) or
+ (repeat(32, sig_1034) and (repeat(5, sig_1080(19)) & sig_1080 & sig_1117(7 downto 1))) or
+ (repeat(32, sig_917) and (repeat(5, sig_695(19)) & sig_695 & sig_696(7 downto 1))) or
+ (repeat(32, sig_897) and (repeat(5, sig_693(19)) & sig_693 & sig_1107(7 downto 1))) or
+ (repeat(32, sig_1033) and (repeat(5, sig_1125(19)) & sig_1125 & sig_1116(7 downto 1))) or
+ (repeat(32, sig_984) and (repeat(5, sig_700(19)) & sig_700 & sig_1108(7 downto 1))) or
+ (repeat(32, sig_1010) and (repeat(5, sig_717(19)) & sig_717 & sig_1089(7 downto 1))) or
+ (repeat(32, sig_937) and (repeat(5, sig_697(19)) & sig_697 & sig_1088(7 downto 1)));
+
+ -- Behaviour of component 'mux_137' model 'mux'
+ mux_137 <=
+ (repeat(8, sig_1003) and cp_din(39 downto 32)) or
+ (repeat(8, sig_930) and mux_156);
+
+ -- Behaviour of component 'mux_138' model 'mux'
+ mux_138 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_927) and "110") or
+ (repeat(3, sig_925) and "101") or
+ (repeat(3, sig_923) and "100") or
+ (repeat(3, sig_921) and "011") or
+ (repeat(3, sig_929) and "111") or
+ (repeat(3, sig_919) and "010") or
+ (repeat(3, sig_917) and "001");
+
+ -- Behaviour of component 'mux_139' model 'mux'
+ mux_139 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_140' model 'mux'
+ mux_140 <=
+ (sig_1004 and and_161) or
+ (sig_928 and '1');
+
+ -- Behaviour of component 'mux_141' model 'mux'
+ mux_141 <=
+ (repeat(8, sig_1003) and cp_din(47 downto 40)) or
+ (repeat(8, sig_910) and mux_156);
+
+ -- Behaviour of component 'mux_142' model 'mux'
+ mux_142 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_907) and "110") or
+ (repeat(3, sig_905) and "101") or
+ (repeat(3, sig_903) and "100") or
+ (repeat(3, sig_901) and "011") or
+ (repeat(3, sig_909) and "111") or
+ (repeat(3, sig_899) and "010") or
+ (repeat(3, sig_897) and "001");
+
+ -- Behaviour of component 'mux_143' model 'mux'
+ mux_143 <=
+ (repeat(3, sig_1003) and psc_loop_reg_13(2 downto 0)) or
+ (repeat(3, sig_833) and augh_main_k(5 downto 3));
+
+ -- Behaviour of component 'mux_144' model 'mux'
+ mux_144 <=
+ (sig_1004 and and_161) or
+ (sig_908 and '1');
+
+ -- Behaviour of component 'mux_147' model 'mux'
+ mux_147 <=
+ (sig_951 and not_264);
+
+ -- Behaviour of component 'mux_149' model 'mux'
+ mux_149 <=
+ (repeat(32, sig_874) and cp_din(31 downto 0)) or
+ (repeat(32, sig_835) and sig_675);
+
+ -- Behaviour of component 'mux_150' model 'mux'
+ mux_150 <=
+ (sig_873 and cp_en) or
+ (sig_834 and '1');
+
+ -- Behaviour of component 'mux_151' model 'mux'
+ mux_151 <=
+ (sig_1005 and sig_705) or
+ (sig_1003 and sig_703) or
+ (sig_874 and sig_692) or
+ (sig_1050 and '1');
+
+ -- Behaviour of component 'mux_152' model 'mux'
+ mux_152 <=
+ (repeat(64, sig_1005) and (sig_1093 & sig_1084)) or
+ (repeat(64, sig_874) and (psc_stuff_reg_19 & cp_id_reg_14)) or
+ (repeat(64, sig_1003) and (sig_1153 & sig_1154 & sig_1159 & sig_1158 & sig_1099 & sig_1098 & sig_1097 & sig_1096));
+
+ -- Behaviour of component 'mux_155' model 'mux'
+ mux_155 <=
+ (sig_951 and sig_698);
+
+ -- Behaviour of component 'or_221' model 'or'
+ or_221 <=
+ and_222;
+
+ -- Behaviour of component 'and_222' model 'and'
+ and_222 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_233' model 'or'
+ or_233 <=
+ and_234;
+
+ -- Behaviour of component 'and_234' model 'and'
+ and_234 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_237' model 'or'
+ or_237 <=
+ and_238;
+
+ -- Behaviour of component 'and_238' model 'and'
+ and_238 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_252' model 'or'
+ or_252 <=
+ and_253;
+
+ -- Behaviour of component 'and_253' model 'and'
+ and_253 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_256' model 'or'
+ or_256 <=
+ and_257;
+
+ -- Behaviour of component 'and_257' model 'and'
+ and_257 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_268' model 'or'
+ or_268 <=
+ and_269;
+
+ -- Behaviour of component 'and_269' model 'and'
+ and_269 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_270' model 'or'
+ or_270 <=
+ and_271;
+
+ -- Behaviour of component 'and_271' model 'and'
+ and_271 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_274' model 'or'
+ or_274 <=
+ and_275;
+
+ -- Behaviour of component 'and_275' model 'and'
+ and_275 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_278' model 'or'
+ or_278 <=
+ and_279;
+
+ -- Behaviour of component 'and_279' model 'and'
+ and_279 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_310' model 'or'
+ or_310 <=
+ and_311;
+
+ -- Behaviour of component 'and_311' model 'and'
+ and_311 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_316' model 'or'
+ or_316 <=
+ and_317;
+
+ -- Behaviour of component 'and_317' model 'and'
+ and_317 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_358' model 'or'
+ or_358 <=
+ and_359;
+
+ -- Behaviour of component 'and_359' model 'and'
+ and_359 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_366' model 'or'
+ or_366 <=
+ and_367;
+
+ -- Behaviour of component 'and_367' model 'and'
+ and_367 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_374' model 'or'
+ or_374 <=
+ and_375;
+
+ -- Behaviour of component 'and_375' model 'and'
+ and_375 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_417' model 'or'
+ or_417 <=
+ and_418;
+
+ -- Behaviour of component 'and_418' model 'and'
+ and_418 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_421' model 'or'
+ or_421 <=
+ and_422;
+
+ -- Behaviour of component 'and_422' model 'and'
+ and_422 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_435' model 'or'
+ or_435 <=
+ and_436;
+
+ -- Behaviour of component 'and_436' model 'and'
+ and_436 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_452' model 'or'
+ or_452 <=
+ and_453;
+
+ -- Behaviour of component 'and_453' model 'and'
+ and_453 <=
+ sig_1093;
+
+ -- Behaviour of component 'and_494' model 'and'
+ and_494 <=
+ sig_1095;
+
+ -- Behaviour of component 'and_498' model 'and'
+ and_498 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_509' model 'or'
+ or_509 <=
+ and_510;
+
+ -- Behaviour of component 'and_510' model 'and'
+ and_510 <=
+ sig_1084(30 downto 0);
+
+ -- Behaviour of component 'or_550' model 'or'
+ or_550 <=
+ and_551;
+
+ -- Behaviour of component 'and_551' model 'and'
+ and_551 <=
+ sig_1083;
+
+ -- Behaviour of component 'or_581' model 'or'
+ or_581 <=
+ and_582;
+
+ -- Behaviour of component 'and_582' model 'and'
+ and_582 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_583' model 'or'
+ or_583 <=
+ and_584;
+
+ -- Behaviour of component 'and_584' model 'and'
+ and_584 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_587' model 'or'
+ or_587 <=
+ and_588;
+
+ -- Behaviour of component 'and_588' model 'and'
+ and_588 <=
+ sig_1093;
+
+ -- Behaviour of component 'and_161' model 'and'
+ and_161 <=
+ cp_en and
+ cp_rest;
+
+ -- Behaviour of component 'or_228' model 'or'
+ or_228 <=
+ and_229;
+
+ -- Behaviour of component 'and_229' model 'and'
+ and_229 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_239' model 'or'
+ or_239 <=
+ and_240;
+
+ -- Behaviour of component 'and_240' model 'and'
+ and_240 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_241' model 'or'
+ or_241 <=
+ and_242;
+
+ -- Behaviour of component 'and_242' model 'and'
+ and_242 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_244' model 'or'
+ or_244 <=
+ and_245;
+
+ -- Behaviour of component 'and_245' model 'and'
+ and_245 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_246' model 'or'
+ or_246 <=
+ and_247;
+
+ -- Behaviour of component 'and_247' model 'and'
+ and_247 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_248' model 'or'
+ or_248 <=
+ and_249;
+
+ -- Behaviour of component 'and_249' model 'and'
+ and_249 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_258' model 'or'
+ or_258 <=
+ and_259;
+
+ -- Behaviour of component 'and_259' model 'and'
+ and_259 <=
+ sig_1093;
+
+ -- Behaviour of component 'not_264' model 'not'
+ not_264 <= not (
+ cp_en
+ );
+
+ -- Behaviour of component 'or_266' model 'or'
+ or_266 <=
+ and_267;
+
+ -- Behaviour of component 'and_267' model 'and'
+ and_267 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_272' model 'or'
+ or_272 <=
+ and_273;
+
+ -- Behaviour of component 'and_273' model 'and'
+ and_273 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_280' model 'or'
+ or_280 <=
+ and_281;
+
+ -- Behaviour of component 'and_281' model 'and'
+ and_281 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_287' model 'or'
+ or_287 <=
+ and_288;
+
+ -- Behaviour of component 'and_288' model 'and'
+ and_288 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_293' model 'or'
+ or_293 <=
+ and_294;
+
+ -- Behaviour of component 'and_294' model 'and'
+ and_294 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_301' model 'or'
+ or_301 <=
+ and_302;
+
+ -- Behaviour of component 'and_302' model 'and'
+ and_302 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_304' model 'or'
+ or_304 <=
+ and_305;
+
+ -- Behaviour of component 'and_305' model 'and'
+ and_305 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_306' model 'or'
+ or_306 <=
+ and_307;
+
+ -- Behaviour of component 'and_307' model 'and'
+ and_307 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_308' model 'or'
+ or_308 <=
+ and_309;
+
+ -- Behaviour of component 'and_309' model 'and'
+ and_309 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_312' model 'or'
+ or_312 <=
+ and_313;
+
+ -- Behaviour of component 'and_313' model 'and'
+ and_313 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_318' model 'or'
+ or_318 <=
+ and_319;
+
+ -- Behaviour of component 'and_319' model 'and'
+ and_319 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_329' model 'or'
+ or_329 <=
+ and_330;
+
+ -- Behaviour of component 'and_330' model 'and'
+ and_330 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_335' model 'or'
+ or_335 <=
+ and_336;
+
+ -- Behaviour of component 'and_336' model 'and'
+ and_336 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_339' model 'or'
+ or_339 <=
+ and_340;
+
+ -- Behaviour of component 'and_340' model 'and'
+ and_340 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_342' model 'or'
+ or_342 <=
+ and_343;
+
+ -- Behaviour of component 'and_343' model 'and'
+ and_343 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_346' model 'or'
+ or_346 <=
+ and_347;
+
+ -- Behaviour of component 'and_347' model 'and'
+ and_347 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_348' model 'or'
+ or_348 <=
+ and_349;
+
+ -- Behaviour of component 'and_349' model 'and'
+ and_349 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_351' model 'or'
+ or_351 <=
+ and_352;
+
+ -- Behaviour of component 'and_352' model 'and'
+ and_352 <=
+ sig_1083(30 downto 0);
+
+ -- Behaviour of component 'or_355' model 'or'
+ or_355 <=
+ and_356;
+
+ -- Behaviour of component 'and_356' model 'and'
+ and_356 <=
+ sig_1086(30 downto 0);
+
+ -- Behaviour of component 'or_360' model 'or'
+ or_360 <=
+ and_361;
+
+ -- Behaviour of component 'and_361' model 'and'
+ and_361 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_371' model 'or'
+ or_371 <=
+ and_372;
+
+ -- Behaviour of component 'and_372' model 'and'
+ and_372 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_378' model 'or'
+ or_378 <=
+ and_379;
+
+ -- Behaviour of component 'and_379' model 'and'
+ and_379 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_380' model 'or'
+ or_380 <=
+ and_381;
+
+ -- Behaviour of component 'and_381' model 'and'
+ and_381 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_384' model 'or'
+ or_384 <=
+ and_385;
+
+ -- Behaviour of component 'and_385' model 'and'
+ and_385 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_386' model 'or'
+ or_386 <=
+ and_387;
+
+ -- Behaviour of component 'and_387' model 'and'
+ and_387 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_388' model 'or'
+ or_388 <=
+ and_389;
+
+ -- Behaviour of component 'and_389' model 'and'
+ and_389 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_394' model 'or'
+ or_394 <=
+ and_395 or
+ and_399 or
+ and_401 or
+ and_403 or
+ and_405 or
+ and_397 or
+ and_407 or
+ and_409;
+
+ -- Behaviour of component 'and_395' model 'and'
+ and_395 <=
+ sig_1096 and
+ repeat(8, sig_674);
+
+ -- Behaviour of component 'and_397' model 'and'
+ and_397 <=
+ sig_1097 and
+ repeat(8, sig_1070);
+
+ -- Behaviour of component 'and_399' model 'and'
+ and_399 <=
+ sig_1098 and
+ repeat(8, sig_1069);
+
+ -- Behaviour of component 'and_401' model 'and'
+ and_401 <=
+ sig_1099 and
+ repeat(8, sig_673);
+
+ -- Behaviour of component 'or_414' model 'or'
+ or_414 <=
+ and_415;
+
+ -- Behaviour of component 'or_423' model 'or'
+ or_423 <=
+ and_424;
+
+ -- Behaviour of component 'and_424' model 'and'
+ and_424 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_425' model 'or'
+ or_425 <=
+ and_426;
+
+ -- Behaviour of component 'and_426' model 'and'
+ and_426 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_427' model 'or'
+ or_427 <=
+ and_428;
+
+ -- Behaviour of component 'and_428' model 'and'
+ and_428 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_431' model 'or'
+ or_431 <=
+ and_432;
+
+ -- Behaviour of component 'and_432' model 'and'
+ and_432 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_433' model 'or'
+ or_433 <=
+ and_434;
+
+ -- Behaviour of component 'and_434' model 'and'
+ and_434 <=
+ sig_1084;
+
+ -- Behaviour of component 'or_438' model 'or'
+ or_438 <=
+ and_439;
+
+ -- Behaviour of component 'and_439' model 'and'
+ and_439 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_440' model 'or'
+ or_440 <=
+ and_441;
+
+ -- Behaviour of component 'and_441' model 'and'
+ and_441 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_443' model 'or'
+ or_443 <=
+ and_444;
+
+ -- Behaviour of component 'and_444' model 'and'
+ and_444 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_450' model 'or'
+ or_450 <=
+ and_451;
+
+ -- Behaviour of component 'and_451' model 'and'
+ and_451 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_454' model 'or'
+ or_454 <=
+ and_455;
+
+ -- Behaviour of component 'and_455' model 'and'
+ and_455 <=
+ sig_1084(30 downto 0);
+
+ -- Behaviour of component 'or_458' model 'or'
+ or_458 <=
+ and_459;
+
+ -- Behaviour of component 'and_459' model 'and'
+ and_459 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_462' model 'or'
+ or_462 <=
+ and_463;
+
+ -- Behaviour of component 'and_463' model 'and'
+ and_463 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_467' model 'or'
+ or_467 <=
+ and_468;
+
+ -- Behaviour of component 'and_468' model 'and'
+ and_468 <=
+ sig_1084(30 downto 0);
+
+ -- Behaviour of component 'or_475' model 'or'
+ or_475 <=
+ and_476;
+
+ -- Behaviour of component 'and_476' model 'and'
+ and_476 <=
+ sig_1086(30 downto 0);
+
+ -- Behaviour of component 'or_479' model 'or'
+ or_479 <=
+ and_480;
+
+ -- Behaviour of component 'and_480' model 'and'
+ and_480 <=
+ sig_1093;
+
+ -- Behaviour of component 'or_481' model 'or'
+ or_481 <=
+ and_482;
+
+ -- Behaviour of component 'and_482' model 'and'
+ and_482 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_485' model 'or'
+ or_485 <=
+ and_486;
+
+ -- Behaviour of component 'and_486' model 'and'
+ and_486 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_490' model 'or'
+ or_490 <=
+ and_491;
+
+ -- Behaviour of component 'and_491' model 'and'
+ and_491 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_493' model 'or'
+ or_493 <=
+ and_494;
+
+ -- Behaviour of component 'or_497' model 'or'
+ or_497 <=
+ and_498;
+
+ -- Behaviour of component 'or_512' model 'or'
+ or_512 <=
+ and_513;
+
+ -- Behaviour of component 'and_513' model 'and'
+ and_513 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_518' model 'or'
+ or_518 <=
+ and_519;
+
+ -- Behaviour of component 'and_519' model 'and'
+ and_519 <=
+ sig_1086(30 downto 0);
+
+ -- Behaviour of component 'or_525' model 'or'
+ or_525 <=
+ and_526;
+
+ -- Behaviour of component 'and_526' model 'and'
+ and_526 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_529' model 'or'
+ or_529 <=
+ and_530;
+
+ -- Behaviour of component 'and_530' model 'and'
+ and_530 <=
+ sig_1085(30 downto 0);
+
+ -- Behaviour of component 'or_532' model 'or'
+ or_532 <=
+ and_533;
+
+ -- Behaviour of component 'and_533' model 'and'
+ and_533 <=
+ sig_1085(30 downto 0);
+
+ -- Behaviour of component 'or_535' model 'or'
+ or_535 <=
+ and_536;
+
+ -- Behaviour of component 'and_536' model 'and'
+ and_536 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_538' model 'or'
+ or_538 <=
+ and_539;
+
+ -- Behaviour of component 'and_539' model 'and'
+ and_539 <=
+ sig_1092;
+
+ -- Behaviour of component 'or_541' model 'or'
+ or_541 <=
+ and_542;
+
+ -- Behaviour of component 'and_542' model 'and'
+ and_542 <=
+ sig_1095;
+
+ -- Behaviour of component 'or_545' model 'or'
+ or_545 <=
+ and_546;
+
+ -- Behaviour of component 'and_546' model 'and'
+ and_546 <=
+ sig_1084(30 downto 0);
+
+ -- Behaviour of component 'or_548' model 'or'
+ or_548 <=
+ and_549;
+
+ -- Behaviour of component 'and_549' model 'and'
+ and_549 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_554' model 'or'
+ or_554 <=
+ and_555;
+
+ -- Behaviour of component 'and_555' model 'and'
+ and_555 <=
+ sig_1086(30 downto 0);
+
+ -- Behaviour of component 'or_557' model 'or'
+ or_557 <=
+ and_558;
+
+ -- Behaviour of component 'and_558' model 'and'
+ and_558 <=
+ sig_1085(30 downto 0);
+
+ -- Behaviour of component 'or_568' model 'or'
+ or_568 <=
+ and_569;
+
+ -- Behaviour of component 'and_569' model 'and'
+ and_569 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_571' model 'or'
+ or_571 <=
+ and_572;
+
+ -- Behaviour of component 'and_572' model 'and'
+ and_572 <=
+ sig_1083(30 downto 0);
+
+ -- Behaviour of component 'or_575' model 'or'
+ or_575 <=
+ and_576;
+
+ -- Behaviour of component 'and_576' model 'and'
+ and_576 <=
+ sig_1086(30 downto 0);
+
+ -- Behaviour of component 'or_590' model 'or'
+ or_590 <=
+ and_591;
+
+ -- Behaviour of component 'and_591' model 'and'
+ and_591 <=
+ sig_1094;
+
+ -- Behaviour of component 'or_597' model 'or'
+ or_597 <=
+ and_598;
+
+ -- Behaviour of component 'and_598' model 'and'
+ and_598 <=
+ sig_1085;
+
+ -- Behaviour of component 'or_603' model 'or'
+ or_603 <=
+ and_604;
+
+ -- Behaviour of component 'and_604' model 'and'
+ and_604 <=
+ sig_1084(30 downto 0);
+
+ -- Behaviour of all components of model 'reg'
+ -- Registers with clock = sig_clock and reset = sig_reset active '1'
+ process(sig_clock, sig_reset)
+ begin
+ if sig_reset = '1' then
+ psc_stuff_reg_19 <= "000000000000000000000000000000000000000000000000000000000000000";
+ else
+ if rising_edge(sig_clock) then
+ if mux_28 = '1' then
+ psc_stuff_reg_19 <= psc_stuff_reg_18 & write8_u8 & augh_main_k(31 downto 1);
+ end if;
+ end if;
+ end if;
+ end process;
+ -- Registers with clock = sig_clock and no reset
+ process(sig_clock)
+ begin
+ if rising_edge(sig_clock) then
+ if mux_30 = '1' then
+ psc_stuff_reg_18 <= cp_din(63 downto 40);
+ end if;
+ if mux_34 = '1' then
+ cp_id_reg_stable_15 <= mux_33;
+ end if;
+ if mux_36 = '1' then
+ cp_id_reg_14 <= mux_35;
+ end if;
+ if mux_38 = '1' then
+ psc_loop_reg_13 <= mux_37;
+ end if;
+ if sig_1024 = '1' then
+ idct_2d_yc_reg7 <= mux_69;
+ end if;
+ if sig_1025 = '1' then
+ idct_2d_yc_reg6 <= mux_71;
+ end if;
+ if sig_1027 = '1' then
+ idct_2d_yc_reg5 <= mux_73;
+ end if;
+ if sig_1028 = '1' then
+ idct_2d_yc_reg4 <= mux_75;
+ end if;
+ if sig_1029 = '1' then
+ idct_2d_yc_reg3 <= mux_77;
+ end if;
+ if sig_1030 = '1' then
+ idct_2d_yc_reg2 <= mux_79;
+ end if;
+ if sig_1031 = '1' then
+ idct_2d_yc_reg1 <= mux_81;
+ end if;
+ if sig_1032 = '1' then
+ idct_2d_yc_reg0 <= mux_83;
+ end if;
+ if sig_1001 = '1' then
+ idct_z2_reg7 <= sig_1090;
+ end if;
+ if sig_998 = '1' then
+ idct_z2_reg6 <= sig_701;
+ end if;
+ if sig_999 = '1' then
+ idct_z2_reg5 <= sig_1113;
+ end if;
+ if sig_1000 = '1' then
+ idct_z2_reg4 <= sig_1120;
+ end if;
+ if sig_967 = '1' then
+ idct_z2_reg3 <= sig_1139;
+ end if;
+ if sig_968 = '1' then
+ idct_z2_reg2 <= sig_1140;
+ end if;
+ if sig_969 = '1' then
+ idct_z2_reg1 <= sig_1141;
+ end if;
+ if sig_970 = '1' then
+ idct_z2_reg0 <= sig_1110;
+ end if;
+ if sig_971 = '1' then
+ idct_z1_reg7 <= mux_109;
+ end if;
+ if sig_959 = '1' then
+ idct_z1_reg6 <= mux_111;
+ end if;
+ if sig_988 = '1' then
+ idct_z1_reg5 <= mux_113;
+ end if;
+ if sig_971 = '1' then
+ idct_z1_reg4 <= mux_115;
+ end if;
+ if sig_964 = '1' then
+ idct_z1_reg3 <= mux_117;
+ end if;
+ if sig_962 = '1' then
+ idct_z1_reg2 <= mux_119;
+ end if;
+ if sig_992 = '1' then
+ idct_z1_reg1 <= mux_121;
+ end if;
+ if sig_994 = '1' then
+ idct_z1_reg0 <= mux_123;
+ end if;
+ if sig_1023 = '1' then
+ idct_z3_reg7 <= sig_1147 & idct_z2_reg7(0);
+ end if;
+ if sig_1022 = '1' then
+ idct_z3_reg6 <= sig_1091 & idct_z2_reg6(1 downto 0);
+ end if;
+ if sig_1020 = '1' then
+ idct_z3_reg5 <= mux_129;
+ end if;
+ if sig_1019 = '1' then
+ idct_z3_reg4 <= sig_1121;
+ end if;
+ if mux_134 = '1' then
+ write8_u8 <= mux_133;
+ end if;
+ if sig_1046 = '1' then
+ idct_2d_r <= mux_135;
+ end if;
+ if mux_147 = '1' then
+ read32_ret0_10 <= stdin_data;
+ end if;
+ if mux_150 = '1' then
+ augh_main_k <= mux_149;
+ end if;
+ end if;
+ end process;
+
+ -- Remaining signal assignments
+ -- Those who are not assigned by component instantiation
+
+ sig_clock <= clock;
+ sig_reset <= reset;
+ sig_start <= start;
+ test_cp_0_16 <= mux_32;
+ sig_1160 <= sig_608(26) & sig_608(26 downto 8);
+ sig_1161 <= sig_1122 & "00";
+ sig_1162 <= sig_1122 & "00";
+ sig_1163 <= sig_1107(26) & sig_1107(26 downto 8);
+ sig_1164 <= sig_1122 & "00";
+ sig_1165 <= sig_696(26) & sig_696(26 downto 8);
+ sig_1166 <= sig_1088(26) & sig_1088(26 downto 8);
+ sig_1167 <= sig_1108(26) & sig_1108(26 downto 8);
+ sig_1168 <= sig_670(26) & sig_670(26 downto 8);
+ sig_1169 <= sig_1089(26) & sig_1089(26 downto 8);
+ sig_1170 <= sig_1122 & "00";
+ sig_1171 <= sig_1117(26) & sig_1117(26 downto 8);
+ sig_1172 <= sig_720(26) & sig_720(26 downto 8);
+ sig_1173 <= sig_1155(26) & sig_1155(26 downto 8);
+ sig_1174 <= sig_1122 & "00";
+ sig_1175 <= sig_1122 & "00";
+ sig_1176 <= sig_1122 & "00";
+ sig_1177 <= sig_1122 & "00";
+ sig_1178 <= sig_1143 & '0';
+ sig_1179 <= sig_1116(26) & sig_1116(26 downto 8);
+ sig_1180 <= sig_1104(26) & sig_1104(26 downto 8);
+ sig_1181 <= sig_719(26) & sig_719(26 downto 8);
+ sig_1182 <= sig_718(26) & sig_718(26 downto 8);
+ sig_1183 <= sig_1118(26) & sig_1118(26 downto 8);
+
+ -- Remaining top-level ports assignments
+ -- Those who are not assigned by component instantiation
+
+ cp_ok <= mux_151;
+ cp_dout <= mux_152;
+ stdout_data <= write8_u8;
+ stdout_rdy <= mux_154;
+ stdin_rdy <= mux_155;
+
+end architecture;
diff --git a/testsuite/gna/issue50/testsuite.sh b/testsuite/gna/issue50/testsuite.sh
new file mode 100755
index 000000000..ad042ea61
--- /dev/null
+++ b/testsuite/gna/issue50/testsuite.sh
@@ -0,0 +1,106 @@
+#! /bin/sh
+
+. ../../testenv.sh
+
+files="
+pkg_tb.vhd
+add_118.vhd
+add_134.vhd
+add_170.vhd
+add_171.vhd
+add_188.vhd
+add_214.vhd
+add_220.vhd
+assert_uut.vhd
+cmp_111.vhd
+cmp_112.vhd
+cmp_113.vhd
+cmp_114.vhd
+cmp_115.vhd
+cmp_119.vhd
+cmp_126.vhd
+cmp_127.vhd
+cmp_128.vhd
+cmp_129.vhd
+cmp_130.vhd
+cmp_131.vhd
+cmp_132.vhd
+cmp_133.vhd
+cmp_135.vhd
+cmp_136.vhd
+cmp_137.vhd
+cmp_138.vhd
+cmp_139.vhd
+cmp_140.vhd
+cmp_141.vhd
+cmp_142.vhd
+cmp_146.vhd
+cmp_148.vhd
+cmp_150.vhd
+cmp_152.vhd
+cmp_154.vhd
+cmp_156.vhd
+cmp_158.vhd
+cmp_160.vhd
+cmp_174.vhd
+cmp_176.vhd
+cmp_178.vhd
+cmp_180.vhd
+cmp_183.vhd
+cmp_185.vhd
+cmp_187.vhd
+cmp_191.vhd
+cmp_193.vhd
+cmp_195.vhd
+cmp_198.vhd
+cmp_200.vhd
+cmp_202.vhd
+cmp_204.vhd
+cmp_215.vhd
+cmp_216.vhd
+cmp_217.vhd
+cmp_218.vhd
+cmp_221.vhd
+fsm.vhd
+fsm_15.vhd
+muxb_117.vhd
+muxb_120.vhd
+muxb_121.vhd
+muxb_123.vhd
+muxb_124.vhd
+muxb_219.vhd
+prog.vhd
+sub_125.vhd
+sub_145.vhd
+sub_189.vhd
+sync_ram.vhd
+v_split0.vhd
+v_split1.vhd
+v_split2.vhd
+v_split3.vhd
+v_split4.vhd
+v_split5.vhd
+v_split6.vhd
+v_split7.vhd
+w_split0.vhd
+w_split1.vhd
+w_split2.vhd
+w_split3.vhd
+w_split4.vhd
+w_split5.vhd
+w_split6.vhd
+w_split7.vhd
+top.vhd
+cp3_test.vhd
+tb.vhd
+"
+
+for f in $files; do
+ analyze vector.d/$f
+done
+
+elab_simulate tb
+
+clean
+
+echo "Test successful"
diff --git a/testsuite/gna/issue50/vector.d/add_118.vhd b/testsuite/gna/issue50/vector.d/add_118.vhd
new file mode 100644
index 000000000..9134bc04d
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_118.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_118 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end add_118;
+
+architecture augh of add_118 is
+
+ signal carry_inA : std_logic_vector(17 downto 0);
+ signal carry_inB : std_logic_vector(17 downto 0);
+ signal carry_res : std_logic_vector(17 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(16 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/add_134.vhd b/testsuite/gna/issue50/vector.d/add_134.vhd
new file mode 100644
index 000000000..4f33da61f
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_134.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_134 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_134;
+
+architecture augh of add_134 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/add_170.vhd b/testsuite/gna/issue50/vector.d/add_170.vhd
new file mode 100644
index 000000000..dc7f53489
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_170.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_170 is
+ port (
+ result : out std_logic_vector(8 downto 0);
+ in_a : in std_logic_vector(8 downto 0);
+ in_b : in std_logic_vector(8 downto 0)
+ );
+end add_170;
+
+architecture augh of add_170 is
+
+ signal carry_inA : std_logic_vector(10 downto 0);
+ signal carry_inB : std_logic_vector(10 downto 0);
+ signal carry_res : std_logic_vector(10 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(9 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/add_171.vhd b/testsuite/gna/issue50/vector.d/add_171.vhd
new file mode 100644
index 000000000..82b3708ec
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_171.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_171 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_171;
+
+architecture augh of add_171 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/add_188.vhd b/testsuite/gna/issue50/vector.d/add_188.vhd
new file mode 100644
index 000000000..4bb414f53
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_188.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_188 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end add_188;
+
+architecture augh of add_188 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/add_214.vhd b/testsuite/gna/issue50/vector.d/add_214.vhd
new file mode 100644
index 000000000..97020f26b
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_214.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_214 is
+ port (
+ result : out std_logic_vector(7 downto 0);
+ in_a : in std_logic_vector(7 downto 0);
+ in_b : in std_logic_vector(7 downto 0)
+ );
+end add_214;
+
+architecture augh of add_214 is
+
+ signal carry_inA : std_logic_vector(9 downto 0);
+ signal carry_inB : std_logic_vector(9 downto 0);
+ signal carry_res : std_logic_vector(9 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(8 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/add_220.vhd b/testsuite/gna/issue50/vector.d/add_220.vhd
new file mode 100644
index 000000000..b527a5d81
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/add_220.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity add_220 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+end add_220;
+
+architecture augh of add_220 is
+
+ signal carry_inA : std_logic_vector(17 downto 0);
+ signal carry_inB : std_logic_vector(17 downto 0);
+ signal carry_res : std_logic_vector(17 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '1' + CI
+ -- If CI is not present, the operation is '1' + '0'
+ carry_inA <= '0' & in_a & '1';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) + unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(16 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/assert_uut.vhd b/testsuite/gna/issue50/vector.d/assert_uut.vhd
new file mode 100644
index 000000000..b097652a9
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/assert_uut.vhd
@@ -0,0 +1,169 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+use std.textio.all;
+library work;
+use work.pkg_tb.all;
+
+entity assert_uut is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ context_uut : in context_t;
+ en_feed : in std_logic;
+ stdin_rdy : in std_logic;
+ stdin_ack : out std_logic;
+ stdin_data : out stdin_vector;
+ en_check : in std_logic;
+ stdout_rdy : in std_logic;
+ stdout_ack : out std_logic;
+ stdout_data : in stdout_vector;
+ vecs_found : out std_logic;
+ vec_read : out std_logic;
+ n_error : out std_logic
+ );
+end assert_uut;
+
+architecture rtl of assert_uut is
+
+ type vin_table is array(0 to 2**VEC_NO_SIZE - 1) of stdin_vector;
+ type vout_table is array(0 to 2**VEC_NO_SIZE - 1) of stdout_vector;
+ constant input_vectors_1 : vin_table := (
+ --##INPUT_VECTORS_1_GO_DOWN_HERE##--
+ 0 => x"00_00_00_07",
+ 1 => x"00_00_00_03",
+ --##INPUT_VECTORS_1_GO_OVER_HERE##--
+ others => (others => '0'));
+ constant output_vectors_1 : vout_table := (
+ --##OUTPUT_VECTORS_1_GO_DOWN_HERE##--
+ 0 => x"00_00_00_16",
+ --##OUTPUT_VECTORS_1_GO_OVER_HERE##--
+ others => (others => '0'));
+ constant input_vectors_2 : vin_table := (
+ --##INPUT_VECTORS_2_GO_DOWN_HERE##--
+ 0 => x"00_00_00_07",
+ 1 => x"00_00_00_03",
+ --##INPUT_VECTORS_2_GO_OVER_HERE##--
+ others => (others => '0'));
+ constant output_vectors_2 : vout_table := (
+ --##OUTPUT_VECTORS_2_GO_DOWN_HERE##--
+ 0 => x"00_00_00_16",
+ --##OUTPUT_VECTORS_2_GO_OVER_HERE##--
+ others => (others => '0'));
+
+ signal out_vec_counter_1 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ signal out_vec_counter_2 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ signal stdin_ack_sig : std_logic;
+ signal vector_read : std_logic;
+
+begin
+
+ feed : process(reset, clock) is
+ variable in_vec_counter_1 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ variable in_vec_counter_2 : unsigned(VEC_NO_SIZE - 1 downto 0);
+ begin
+ if (reset = '1') then
+ in_vec_counter_1 := (others => '0');
+ in_vec_counter_2 := (others => '0');
+ stdin_data <= (others => '0');
+ stdin_ack_sig <= '0';
+ elsif rising_edge(clock) then
+ case context_uut is
+ when "01" =>
+ if (en_feed = '1') then
+ stdin_data <= input_vectors_1(to_integer(in_vec_counter_1));
+ stdin_ack_sig <= '1';
+ if (stdin_rdy = '1' and stdin_ack_sig = '1') then
+ in_vec_counter_1 := in_vec_counter_1 + 1;
+ stdin_ack_sig <= '0';
+ end if;
+ else
+ --in_vec_counter_1 <= (others => '0');
+ stdin_data <= (others => '0');
+ stdin_ack_sig <= '0';
+ end if;
+ when "10" =>
+ if (en_feed = '1') then
+ stdin_data <= input_vectors_2(to_integer(in_vec_counter_2));
+ stdin_ack_sig <= '1';
+ if (stdin_rdy = '1' and stdin_ack_sig = '1') then
+ in_vec_counter_2 := in_vec_counter_2 + 1;
+ stdin_ack_sig <= '0';
+ end if;
+ else
+ --in_vec_counter_2 <= (others => '0');
+ stdin_data <= (others => '0');
+ stdin_ack_sig <= '0';
+ end if;
+ when others =>
+ end case;
+ end if;
+ end process feed;
+
+ check : process(reset, clock) is
+ begin
+ if (reset = '1') then
+ n_error <= '1';
+ vec_read <= '0';
+ elsif rising_edge(clock) then
+ vec_read <= '0';
+ if (en_check = '1') then
+ if (stdout_rdy = '1') then
+ vec_read <= '1';
+ case context_uut is
+ when "01" =>
+ assert (stdout_data = output_vectors_1(to_integer(out_vec_counter_1)))
+ report "ERROR ---> Bad output vector found";
+ --synthesizable check
+ if (stdout_data /= output_vectors_1(to_integer(out_vec_counter_1))) then
+ n_error <= '0';
+ end if;
+ when "10" =>
+ assert (stdout_data = output_vectors_2(to_integer(out_vec_counter_2)))
+ report "ERROR ---> Bad output vector found";
+ --synthesizable check
+ if (stdout_data /= output_vectors_2(to_integer(out_vec_counter_2))) then
+ n_error <= '0';
+ end if;
+ when others =>
+ end case;
+ end if;
+ end if;
+ end if;
+ end process check;
+
+ read_counter : process(reset, clock) is
+ begin
+ if (reset = '1') then
+ out_vec_counter_1 <= (others => '0');
+ out_vec_counter_2 <= (others => '0');
+ elsif rising_edge(clock) then
+ if (en_check = '1') then
+ if (stdout_rdy = '1') then
+ case context_uut is
+ when "01" =>
+ out_vec_counter_1 <= out_vec_counter_1 + 1;
+ when "10" =>
+ out_vec_counter_2 <= out_vec_counter_2 + 1;
+ when others =>
+ end case;
+ end if;
+ --else
+ -- case context_uut is
+ -- when "01" =>
+ -- out_vec_counter_1 <= (others => '0');
+ -- when "10" =>
+ -- out_vec_counter_2 <= (others => '0');
+ -- when others =>
+ -- end case;
+ end if;
+ end if;
+ end process read_counter;
+
+ --asynchronous declarations
+ stdout_ack <= en_check;
+ stdin_ack <= stdin_ack_sig;
+ vecs_found <= '1' when (out_vec_counter_1 /= 0 or out_vec_counter_2 /= 0) else '0';
+
+end rtl;
diff --git a/testsuite/gna/issue50/vector.d/cmp_111.vhd b/testsuite/gna/issue50/vector.d/cmp_111.vhd
new file mode 100644
index 000000000..5e35d5292
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_111.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_111 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_111;
+
+architecture augh of cmp_111 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_112.vhd b/testsuite/gna/issue50/vector.d/cmp_112.vhd
new file mode 100644
index 000000000..e27456ee4
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_112.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_112 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_112;
+
+architecture augh of cmp_112 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_113.vhd b/testsuite/gna/issue50/vector.d/cmp_113.vhd
new file mode 100644
index 000000000..f83b71ce1
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_113.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_113 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_113;
+
+architecture augh of cmp_113 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_114.vhd b/testsuite/gna/issue50/vector.d/cmp_114.vhd
new file mode 100644
index 000000000..e15bf43cd
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_114.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_114 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_114;
+
+architecture augh of cmp_114 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_115.vhd b/testsuite/gna/issue50/vector.d/cmp_115.vhd
new file mode 100644
index 000000000..00d218957
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_115.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_115 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_115;
+
+architecture augh of cmp_115 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_119.vhd b/testsuite/gna/issue50/vector.d/cmp_119.vhd
new file mode 100644
index 000000000..2b2245787
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_119.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_119 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+end cmp_119;
+
+architecture augh of cmp_119 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_126.vhd b/testsuite/gna/issue50/vector.d/cmp_126.vhd
new file mode 100644
index 000000000..f2a630842
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_126.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_126 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_126;
+
+architecture augh of cmp_126 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_127.vhd b/testsuite/gna/issue50/vector.d/cmp_127.vhd
new file mode 100644
index 000000000..94611a018
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_127.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_127 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_127;
+
+architecture augh of cmp_127 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_128.vhd b/testsuite/gna/issue50/vector.d/cmp_128.vhd
new file mode 100644
index 000000000..d23132fd4
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_128.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_128 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_128;
+
+architecture augh of cmp_128 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_129.vhd b/testsuite/gna/issue50/vector.d/cmp_129.vhd
new file mode 100644
index 000000000..cc56d03b8
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_129.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_129 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_129;
+
+architecture augh of cmp_129 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_130.vhd b/testsuite/gna/issue50/vector.d/cmp_130.vhd
new file mode 100644
index 000000000..6e3e529eb
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_130.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_130 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_130;
+
+architecture augh of cmp_130 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_131.vhd b/testsuite/gna/issue50/vector.d/cmp_131.vhd
new file mode 100644
index 000000000..c7450e430
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_131.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_131 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_131;
+
+architecture augh of cmp_131 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_132.vhd b/testsuite/gna/issue50/vector.d/cmp_132.vhd
new file mode 100644
index 000000000..12cbe3918
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_132.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_132 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_132;
+
+architecture augh of cmp_132 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_133.vhd b/testsuite/gna/issue50/vector.d/cmp_133.vhd
new file mode 100644
index 000000000..efee40dc7
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_133.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_133 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_133;
+
+architecture augh of cmp_133 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_135.vhd b/testsuite/gna/issue50/vector.d/cmp_135.vhd
new file mode 100644
index 000000000..d5e1d49e3
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_135.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_135 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_135;
+
+architecture augh of cmp_135 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_136.vhd b/testsuite/gna/issue50/vector.d/cmp_136.vhd
new file mode 100644
index 000000000..1dfb02bc3
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_136.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_136 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_136;
+
+architecture augh of cmp_136 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_137.vhd b/testsuite/gna/issue50/vector.d/cmp_137.vhd
new file mode 100644
index 000000000..064415f94
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_137.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_137 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_137;
+
+architecture augh of cmp_137 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_138.vhd b/testsuite/gna/issue50/vector.d/cmp_138.vhd
new file mode 100644
index 000000000..c5f42eaa5
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_138.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_138 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_138;
+
+architecture augh of cmp_138 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_139.vhd b/testsuite/gna/issue50/vector.d/cmp_139.vhd
new file mode 100644
index 000000000..809619fbf
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_139.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_139 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_139;
+
+architecture augh of cmp_139 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_140.vhd b/testsuite/gna/issue50/vector.d/cmp_140.vhd
new file mode 100644
index 000000000..033dd940a
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_140.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_140 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_140;
+
+architecture augh of cmp_140 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_141.vhd b/testsuite/gna/issue50/vector.d/cmp_141.vhd
new file mode 100644
index 000000000..f514e59d4
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_141.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_141 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_141;
+
+architecture augh of cmp_141 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_142.vhd b/testsuite/gna/issue50/vector.d/cmp_142.vhd
new file mode 100644
index 000000000..8e618fb9b
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_142.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_142 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_142;
+
+architecture augh of cmp_142 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_146.vhd b/testsuite/gna/issue50/vector.d/cmp_146.vhd
new file mode 100644
index 000000000..56262f16c
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_146.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_146 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_146;
+
+architecture augh of cmp_146 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_148.vhd b/testsuite/gna/issue50/vector.d/cmp_148.vhd
new file mode 100644
index 000000000..de5f67862
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_148.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_148 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_148;
+
+architecture augh of cmp_148 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_150.vhd b/testsuite/gna/issue50/vector.d/cmp_150.vhd
new file mode 100644
index 000000000..75c66f25a
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_150.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_150 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_150;
+
+architecture augh of cmp_150 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_152.vhd b/testsuite/gna/issue50/vector.d/cmp_152.vhd
new file mode 100644
index 000000000..4d05e52bf
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_152.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_152 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_152;
+
+architecture augh of cmp_152 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_154.vhd b/testsuite/gna/issue50/vector.d/cmp_154.vhd
new file mode 100644
index 000000000..b9dde5333
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_154.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_154 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_154;
+
+architecture augh of cmp_154 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_156.vhd b/testsuite/gna/issue50/vector.d/cmp_156.vhd
new file mode 100644
index 000000000..75cf950bd
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_156.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_156 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_156;
+
+architecture augh of cmp_156 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_158.vhd b/testsuite/gna/issue50/vector.d/cmp_158.vhd
new file mode 100644
index 000000000..82efe368c
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_158.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_158 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_158;
+
+architecture augh of cmp_158 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_160.vhd b/testsuite/gna/issue50/vector.d/cmp_160.vhd
new file mode 100644
index 000000000..9fb84d1cd
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_160.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_160 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_160;
+
+architecture augh of cmp_160 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_174.vhd b/testsuite/gna/issue50/vector.d/cmp_174.vhd
new file mode 100644
index 000000000..86a3b443b
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_174.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_174 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_174;
+
+architecture augh of cmp_174 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_176.vhd b/testsuite/gna/issue50/vector.d/cmp_176.vhd
new file mode 100644
index 000000000..9ba5527e2
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_176.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_176 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_176;
+
+architecture augh of cmp_176 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_178.vhd b/testsuite/gna/issue50/vector.d/cmp_178.vhd
new file mode 100644
index 000000000..f594227ac
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_178.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_178 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_178;
+
+architecture augh of cmp_178 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_180.vhd b/testsuite/gna/issue50/vector.d/cmp_180.vhd
new file mode 100644
index 000000000..b69344eec
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_180.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_180 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_180;
+
+architecture augh of cmp_180 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_183.vhd b/testsuite/gna/issue50/vector.d/cmp_183.vhd
new file mode 100644
index 000000000..3fea5412e
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_183.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_183 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_183;
+
+architecture augh of cmp_183 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_185.vhd b/testsuite/gna/issue50/vector.d/cmp_185.vhd
new file mode 100644
index 000000000..e45f5ca03
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_185.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_185 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_185;
+
+architecture augh of cmp_185 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_187.vhd b/testsuite/gna/issue50/vector.d/cmp_187.vhd
new file mode 100644
index 000000000..4254b67ab
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_187.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_187 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_187;
+
+architecture augh of cmp_187 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_191.vhd b/testsuite/gna/issue50/vector.d/cmp_191.vhd
new file mode 100644
index 000000000..af123383f
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_191.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_191 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_191;
+
+architecture augh of cmp_191 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_193.vhd b/testsuite/gna/issue50/vector.d/cmp_193.vhd
new file mode 100644
index 000000000..3eeeba859
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_193.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_193 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_193;
+
+architecture augh of cmp_193 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_195.vhd b/testsuite/gna/issue50/vector.d/cmp_195.vhd
new file mode 100644
index 000000000..61851b275
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_195.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_195 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_195;
+
+architecture augh of cmp_195 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_198.vhd b/testsuite/gna/issue50/vector.d/cmp_198.vhd
new file mode 100644
index 000000000..6620b9de3
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_198.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_198 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_198;
+
+architecture augh of cmp_198 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_200.vhd b/testsuite/gna/issue50/vector.d/cmp_200.vhd
new file mode 100644
index 000000000..794a2ddad
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_200.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_200 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_200;
+
+architecture augh of cmp_200 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_202.vhd b/testsuite/gna/issue50/vector.d/cmp_202.vhd
new file mode 100644
index 000000000..a16cc719a
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_202.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_202 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_202;
+
+architecture augh of cmp_202 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_204.vhd b/testsuite/gna/issue50/vector.d/cmp_204.vhd
new file mode 100644
index 000000000..18c2cade8
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_204.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_204 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_204;
+
+architecture augh of cmp_204 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_215.vhd b/testsuite/gna/issue50/vector.d/cmp_215.vhd
new file mode 100644
index 000000000..2671110bd
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_215.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_215 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_215;
+
+architecture augh of cmp_215 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_216.vhd b/testsuite/gna/issue50/vector.d/cmp_216.vhd
new file mode 100644
index 000000000..37307f2b6
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_216.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_216 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_216;
+
+architecture augh of cmp_216 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_217.vhd b/testsuite/gna/issue50/vector.d/cmp_217.vhd
new file mode 100644
index 000000000..ca2756b70
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_217.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_217 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_217;
+
+architecture augh of cmp_217 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_218.vhd b/testsuite/gna/issue50/vector.d/cmp_218.vhd
new file mode 100644
index 000000000..09b8d9273
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_218.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_218 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+end cmp_218;
+
+architecture augh of cmp_218 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ eq <= tmp;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cmp_221.vhd b/testsuite/gna/issue50/vector.d/cmp_221.vhd
new file mode 100644
index 000000000..6c7aaac74
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cmp_221.vhd
@@ -0,0 +1,26 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity cmp_221 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+end cmp_221;
+
+architecture augh of cmp_221 is
+
+ signal tmp : std_logic;
+
+begin
+
+ -- Compute the result
+ tmp <=
+ '0' when in0 /= in1 else
+ '1';
+
+ -- Set the outputs
+ ne <= not(tmp);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/cp3_test.vhd b/testsuite/gna/issue50/vector.d/cp3_test.vhd
new file mode 100644
index 000000000..99fdbb678
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/cp3_test.vhd
@@ -0,0 +1,280 @@
+-- written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+library work;
+use work.pkg_tb.all;
+
+entity cp3_test is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ n_error : out std_logic;
+ stopped : out std_logic
+ );
+end cp3_test;
+
+architecture rtl of cp3_test is
+
+ --TOP signals
+ signal reset_top : std_logic := '0';
+ signal stdin_data : stdin_vector;
+ signal stdin_rdy : std_logic;
+ signal stdin_ack : std_logic;
+ signal stdout_data : stdout_vector;
+ signal stdout_rdy : std_logic;
+ signal stdout_ack : std_logic;
+ --ASSERT_UNIT signals
+ signal context_uut : context_t;
+ signal en_feed : std_logic;
+ signal en_check : std_logic;
+ signal n_error_s : std_logic;
+ signal vecs_found : std_logic;
+ signal vec_read : std_logic;
+ --PROG unit signals
+ signal instr_next : instruction;
+ -- FSM unit signals
+ signal step : std_logic;
+ signal start : std_logic;
+ -- FSM signals
+ signal reset_fsm : std_logic;
+ signal stopped_s : std_logic;
+
+
+--------------------------------------
+-- PART OF ARCHITECTURE WITH CP3 --
+
+ --TOP signals
+ signal cp_en : std_logic := '0';
+ signal cp_rest : std_logic := '0';
+ signal cp_ok : std_logic;
+ signal cp_din : cp_vector := (others => '0');
+ signal cp_dout : cp_vector;
+ --RAM signals
+ signal ram_1 : ram_instruction;
+ signal ram_2 : ram_instruction;
+ signal address1 : std_logic_vector(12 downto 0) := (others => '0');
+ signal address2 : std_logic_vector(12 downto 0) := (others => '0');
+ signal datain : cp_vector := (others => '0');
+ signal dout1 : cp_vector;
+ signal dout2 : cp_vector;
+
+ --dut component declaration
+ component top is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ start : in std_logic;
+ stdin_data : in stdin_vector;
+ stdin_rdy : out std_logic;
+ stdin_ack : in std_logic;
+ stdout_data : out stdout_vector;
+ stdout_rdy : out std_logic;
+ stdout_ack : in std_logic;
+ cp_en : in std_logic;
+ cp_rest : in std_logic;
+ cp_din : in cp_vector;
+ cp_dout : out cp_vector;
+ cp_ok : out std_logic
+ );
+ end component top;
+
+begin
+
+ uut : entity work.top(augh)
+ port map(
+ clock => clock,
+ reset => reset_top,
+ start => start,
+ stdin_data => stdin_data,
+ stdin_rdy => stdin_rdy,
+ stdin_ack => stdin_ack,
+ cp_en => cp_en,
+ cp_rest => cp_rest,
+ cp_ok => cp_ok,
+ cp_din => cp_din,
+ cp_dout => cp_dout,
+ stdout_data => stdout_data,
+ stdout_rdy => stdout_rdy,
+ stdout_ack => stdout_ack
+ );
+
+ ram1 : entity work.sync_ram(rtl)
+ port map(
+ clock => clock,
+ we => ram_1.we,
+ address => address1,
+ datain => datain,
+ dataout => dout1
+ );
+
+ ram2 : entity work.sync_ram(rtl)
+ port map(
+ clock => clock,
+ we => ram_2.we,
+ address => address2,
+ datain => datain,
+ dataout => dout2
+ );
+
+ fsm_unit : entity work.fsm(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ --prog interface
+ instr_next => instr_next,
+ step => step,
+ --uut interface
+ cp_ok => cp_ok,
+ stdin_rdy => stdin_rdy,
+ stdin_ack => stdin_ack,
+ reset_fsm => reset_fsm,
+ start => start,
+ cp_en => cp_en,
+ cp_rest => cp_rest,
+ --ram interface
+ ram_1 => ram_1,
+ ram_2 => ram_2,
+ --assert_uut interface
+ context_uut => context_uut,
+ en_feed => en_feed,
+ en_check => en_check,
+ vecs_found => vecs_found,
+ vec_read => vec_read,
+ --tb interface
+ stopped => stopped_s
+ );
+
+ --RAM ADDRESS controller 1
+ ram_ctrl1 : process(clock, reset)
+ begin
+ if (reset = '1') then
+ address1 <= (others => '0');
+ elsif rising_edge(clock) then
+ if (ram_1.addr_z = '1') then
+ address1 <= (others => '0');
+ elsif (ram_1.addr_up = '1') then
+ address1 <= std_logic_vector(unsigned(address1) + 1);
+ end if;
+ end if;
+ end process ram_ctrl1;
+
+ --RAM ADDRESS controller 2
+ ram_ctrl2 : process(clock, reset)
+ begin
+ if (reset = '1') then
+ address2 <= (others => '0');
+ elsif rising_edge(clock) then
+ if (ram_2.addr_z = '1') then
+ address2 <= (others => '0');
+ elsif (ram_2.addr_up = '1') then
+ address2 <= std_logic_vector(unsigned(address2) + 1);
+ end if;
+ end if;
+ end process ram_ctrl2;
+
+ --other comb signals
+ datain <= cp_dout;
+ cp_din <= dout2 when ram_2.sel = '1' else dout1;
+
+-- END OF ARCHITECTURE WITH CP3 --
+--------------------------------------
+
+--------------------------------------
+-- PART OF ARCHITECTURE WITHOUT CP3 --
+--
+-- --dut component declaration
+-- component top is
+-- port (
+-- clock : in std_logic;
+-- reset : in std_logic;
+-- start : in std_logic;
+-- stdin_data : in stdin_vector;
+-- stdin_rdy : out std_logic;
+-- stdin_ack : in std_logic;
+-- stdout_data : out stdout_vector;
+-- stdout_rdy : out std_logic;
+-- stdout_ack : in std_logic
+-- );
+-- end component top;
+--
+--begin
+--
+-- uut : entity work.top(augh)
+-- port map(
+-- clock => clock,
+-- reset => reset_top,
+-- start => start,
+-- stdin_data => stdin_data,
+-- stdin_rdy => stdin_rdy,
+-- stdin_ack => stdin_ack,
+-- stdout_data => stdout_data,
+-- stdout_rdy => stdout_rdy,
+-- stdout_ack => stdout_ack
+-- );
+--
+-- fsm_unit : entity work.fsm(rtl)
+-- port map(
+-- clock => clock,
+-- reset => reset,
+-- --prog interface
+-- instr_next => instr_next,
+-- step => step,
+-- --uut interface
+-- cp_ok => '0',
+-- stdin_rdy => stdin_rdy,
+-- stdin_ack => stdin_ack,
+-- reset_fsm => reset_fsm,
+-- start => start,
+-- cp_en => open,
+-- cp_rest => open,
+-- --ram interface
+-- ram_1 => open,
+-- ram_2 => open,
+-- --assert_uut interface
+-- context_uut => context_uut,
+-- en_feed => en_feed,
+-- en_check => en_check,
+-- vecs_found => vecs_found,
+-- vec_read => vec_read,
+-- --tb interface
+-- stopped => stopped_s
+-- );
+--
+-- END OF ARCHITECTURE WITHOUT CP3 --
+--------------------------------------
+
+ assert_unit : entity work.assert_uut(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ context_uut => context_uut,
+ en_feed => en_feed,
+ stdin_rdy => stdin_rdy,
+ stdin_ack => stdin_ack,
+ stdin_data => stdin_data,
+ en_check => en_check,
+ stdout_rdy => stdout_rdy,
+ stdout_ack => stdout_ack,
+ stdout_data => stdout_data,
+ vecs_found => vecs_found,
+ vec_read => vec_read,
+ n_error => n_error_s
+ );
+
+ prog_unit : entity work.prog(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ step => step,
+ instr_next => instr_next
+ );
+
+ --other comb signals
+ reset_top <= reset or reset_fsm;
+
+ --outputs
+ n_error <= n_error_s;
+ stopped <= stopped_s;
+
+end rtl;
diff --git a/testsuite/gna/issue50/vector.d/fsm.vhd b/testsuite/gna/issue50/vector.d/fsm.vhd
new file mode 100644
index 000000000..2f4ef87ee
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/fsm.vhd
@@ -0,0 +1,396 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+use std.textio.all;
+library work;
+use work.pkg_tb.all;
+
+entity fsm is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ --prog interface
+ instr_next : in instruction;
+ step : out std_logic;
+ --uut interface
+ cp_ok : in std_logic;
+ stdin_rdy : in std_logic;
+ stdin_ack : in std_logic;
+ reset_fsm : out std_logic;
+ start : out std_logic;
+ cp_en : out std_logic;
+ cp_rest : out std_logic;
+ --ram interface
+ ram_1 : out ram_instruction;
+ ram_2 : out ram_instruction;
+ --assert_uut interface
+ context_uut : out context_t;
+ en_feed : out std_logic;
+ en_check : out std_logic;
+ vecs_found : in std_logic;
+ vec_read : in std_logic;
+ --tb interface
+ stopped : out std_logic
+ );
+end fsm;
+
+architecture rtl of fsm is
+
+ -- read output
+ signal step_sig : std_logic;
+ -- FSM signals
+ signal instr_c : instruction := instr_rst;
+ signal instr_n : instruction := instr_rst;
+ -- TIMER signal
+ signal times_en : std_logic := '0';
+ signal times_z : std_logic := '0';
+ signal times : unsigned(ARG_WIDTH - 1 downto 0);
+ signal times_max : unsigned(ARG_WIDTH - 1 downto 0);
+ signal times_ok : std_logic := '0';
+ -- COUNTER signal
+ signal count_en : std_logic := '0';
+ signal count_z : std_logic := '0';
+ signal count : unsigned(ARG_WIDTH - 1 downto 0);
+ signal count_max : unsigned(ARG_WIDTH - 1 downto 0);
+ signal count_ok : std_logic := '0';
+ -- runtime counter
+ signal runtime_en : std_logic := '0';
+ signal runtime : integer range 0 to 99999999; --100 million cycles
+
+begin
+
+ -- FSM
+ state_reg : process (clock, reset) is
+ begin
+ if (reset = '1') then
+ instr_c <= instr_rst;
+ elsif rising_edge(clock) then
+ instr_c <= instr_n;
+ end if;
+ end process state_reg;
+
+ comb_logic: process(instr_next, instr_c, stdin_rdy, count_ok, times_ok, cp_ok, stdin_ack, vecs_found, vec_read)
+ begin
+ --default definition for fsm control signals
+ instr_n <= instr_rst;
+ step_sig <= '0';
+ --top
+ reset_fsm <= '0';
+ start <= '0';
+ cp_en <= '0';
+ cp_rest <= '0';
+ --counter & timer
+ times_en <= '0';
+ times_max <= (others => '0');
+ count_en <= '0';
+ count_max <= (others => '0');
+ --runtime counter
+ runtime_en <= '0';
+ --ram
+ ram_1 <= ram_instr_z;
+ ram_2 <= ram_instr_z;
+ --assert_uut
+ en_feed <= '0';
+ en_check <= '0';
+ --tb interface
+ stopped <= '0';
+
+ case instr_c.state is
+ when Rst =>
+ --signals
+ reset_fsm <= '1';
+ ram_1.addr_z <= '1';
+ ram_2.addr_z <= '1';
+ step_sig <= '1'; --demand for next instruction
+ --transition
+ instr_n <= instr_next;
+
+ when Sig_start =>
+ --signals
+ start <= '1';
+ step_sig <= '1'; --demand for next instruction
+ --transition
+ instr_n <= instr_next;
+ --if (instr_next.state = Ack_data) then
+ --en_feed <= '1';
+ --end if;
+
+ when Ack_data =>
+ times_max <= instr_c.arg - 1;
+ --signals
+ en_feed <= '1';
+ --transition
+ if (stdin_rdy = '1' and stdin_ack = '1') then
+ times_en <= '1';
+ end if;
+ if (times_ok = '1') then
+ en_feed <= '0';
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Running =>
+ --signals
+ count_max <= instr_c.arg;
+ count_en <= '1';
+ --en_check <= '1';
+ --runtime counter
+ if(vecs_found = '0') then
+ runtime_en <= '1';
+ end if;
+ --transition
+ if (count_ok = '1') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Waitfor =>
+ --signals
+ count_max <= instr_c.arg;
+ en_check <= '1';
+ if(vec_read = '1') then
+ count_en <= '1';
+ end if;
+ --runtime counter
+ if(vecs_found = '0') then
+ runtime_en <= '1';
+ end if;
+ --transition
+ if (count_ok = '1') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Cp_search =>
+ --signals
+ cp_en <= '1';
+ --transition
+ if (cp_ok = '1') then
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.we <= '1';
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.we <= '1';
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ instr_n <= (state => Cp_save, context_uut => instr_c.context_uut, arg => (others => '0')); --hard coded
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Cp_save =>
+ --signals
+ cp_en <= '1';
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.we <= '1';
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.we <= '1';
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ if (cp_ok = '0') then
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.we <= '0';
+ ram_1.addr_up <= '0';
+ when "10" =>
+ ram_2.we <= '0';
+ ram_2.addr_up <= '0';
+ when others =>
+ end case;
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Idle =>
+ --signals
+ count_max <= instr_c.arg;
+ count_en <= '1';
+ --transition
+ if (count_ok = '1') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Rst_uut =>
+ --signals
+ reset_fsm <= '1';
+ ram_1.addr_z <= '1';
+ ram_2.addr_z <= '1';
+ --transition
+ step_sig <= '1';
+ instr_n <= instr_next;
+
+ when Rest_ini0 =>
+ --signals
+ start <= '1';
+ cp_en <= '1';
+ cp_rest <= '1';
+ --this is for restoration : reading the first word of the right memory
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ instr_n <= (state => Rest_ini1, context_uut => instr_c.context_uut, arg => (others => '0')); --hard coded
+
+ when Rest_ini1 =>
+ --signals
+ cp_en <= '1';
+ cp_rest <= '1';
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ instr_n <= (state => Rest, context_uut => instr_c.context_uut, arg => (others => '0')); --hard coded
+
+ when Rest =>
+ --signals
+ cp_en <= '1';
+ cp_rest <= '1';
+ case instr_c.context_uut is
+ when "01" =>
+ ram_1.addr_up <= '1';
+ ram_1.sel <= '1';
+ when "10" =>
+ ram_2.addr_up <= '1';
+ ram_2.sel <= '1';
+ when others =>
+ end case;
+ --transition
+ if (cp_ok = '0') then
+ step_sig <= '1';
+ instr_n <= instr_next;
+ else
+ instr_n <= instr_c;
+ end if;
+
+ when Stop =>
+ --signals
+ stopped <= '1';
+ reset_fsm <= '1';
+ report "RUNTIME:" & integer'image(runtime);
+ assert (vecs_found = '0')
+ report "END_OF_SIM ---> Stop state reached, some output vectors were read." severity note;
+ --transition
+ instr_n <= (state => Stop, context_uut => "00", arg => (others => '0')); --hard coded
+
+ when others =>
+ end case;
+ end process comb_logic;
+
+ --*ER reset combo logic
+ --if a step_sig signal is sent, it means a instr_next will be consumed
+ reseter : process(step_sig)
+ begin
+ if (step_sig = '0') then
+ times_z <= '0';
+ count_z <= '0';
+ else
+ times_z <= '1';
+ count_z <= '1';
+ end if;
+ end process reseter;
+
+ --TIMER
+ timer : process(clock, reset)
+ begin
+ if (reset = '1') then
+ times <= (others => '0');
+ times_ok <= '0';
+ elsif rising_edge(clock) then
+ if (times_z = '1') then
+ times <= (others => '0');
+ times_ok <= '0';
+ else
+ if (times_en = '1') then
+ times <= times + 1;
+ if (times = times_max) then
+ times_ok <= '1';
+ else
+ times_ok <= '0';
+ end if;
+ end if;
+ end if;
+ end if;
+ end process timer;
+
+ --COUNTER
+ counter : process(clock, reset)
+ begin
+ if (reset = '1') then
+ count <= (others => '0');
+ count_ok <= '0';
+ elsif rising_edge(clock) then
+ --count_ok driving if
+ if (count_z = '1') then
+ count_ok <= '0';
+ count <= (others => '0');
+ else
+ if (count = count_max) then
+ count_ok <= '1';
+ else
+ count_ok <= '0';
+ if (count_en = '1') then
+ count <= count + 1;
+ end if;
+ end if;
+ end if;
+ end if;
+ end process counter;
+
+ --Runtime counter
+ runtime_counter : process(clock, reset)
+ begin
+ if (reset = '1') then
+ runtime <= 0;
+ elsif rising_edge(clock) then
+ if (runtime_en = '1') then
+ runtime <= runtime + 1;
+ if ((runtime mod 1000) = 0) then
+ report "Running since:" & integer'image(runtime) severity note;
+ end if;
+ end if;
+ end if;
+ end process runtime_counter;
+
+ -- process only used for reporting current instruction
+ reporter : process(instr_c)
+ begin
+ --report "Instruction: " & state_t'image(instr_c.state) severity note;
+ report "Instruction: " & state_t'image(instr_c.state) & " (context " & integer'image(to_integer(unsigned(instr_c.context_uut))) & ")" severity note;
+ end process reporter;
+
+ --Combinational
+ step <= step_sig;
+ context_uut <= instr_c.context_uut;
+end rtl;
diff --git a/testsuite/gna/issue50/vector.d/fsm_15.vhd b/testsuite/gna/issue50/vector.d/fsm_15.vhd
new file mode 100644
index 000000000..576089e8b
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/fsm_15.vhd
@@ -0,0 +1,539 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity fsm_15 is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ out3 : out std_logic;
+ out157 : out std_logic;
+ out159 : out std_logic;
+ out160 : out std_logic;
+ out171 : out std_logic;
+ out172 : out std_logic;
+ out173 : out std_logic;
+ out175 : out std_logic;
+ out178 : out std_logic;
+ in0 : in std_logic;
+ out0 : out std_logic;
+ in5 : in std_logic;
+ in6 : in std_logic;
+ in7 : in std_logic;
+ out35 : out std_logic;
+ out39 : out std_logic;
+ out40 : out std_logic;
+ out41 : out std_logic;
+ out44 : out std_logic;
+ out46 : out std_logic;
+ out140 : out std_logic;
+ in8 : in std_logic;
+ in9 : in std_logic;
+ in10 : in std_logic;
+ in11 : in std_logic;
+ in12 : in std_logic;
+ in13 : in std_logic;
+ in14 : in std_logic;
+ out65 : out std_logic;
+ in1 : in std_logic;
+ in2 : in std_logic;
+ in3 : in std_logic;
+ in4 : in std_logic;
+ out225 : out std_logic;
+ out227 : out std_logic;
+ out231 : out std_logic;
+ out235 : out std_logic;
+ out236 : out std_logic;
+ out237 : out std_logic;
+ out238 : out std_logic;
+ out97 : out std_logic;
+ out98 : out std_logic;
+ out101 : out std_logic;
+ out102 : out std_logic;
+ out124 : out std_logic;
+ out125 : out std_logic;
+ out80 : out std_logic;
+ out81 : out std_logic;
+ out84 : out std_logic;
+ out86 : out std_logic;
+ out88 : out std_logic;
+ out93 : out std_logic;
+ out94 : out std_logic
+ );
+end fsm_15;
+
+architecture augh of fsm_15 is
+
+ signal state_cur : std_logic_vector(0 to 21) := (19 => '1', others => '0');
+ signal state_next : std_logic_vector(0 to 21) := (19 => '1', others => '0');
+
+ -- Buffers for outputs
+ signal out0_buf : std_logic := '0';
+ signal out0_bufn : std_logic;
+ signal out40_buf : std_logic := '0';
+ signal out40_bufn : std_logic;
+ signal out101_buf : std_logic := '0';
+ signal out101_bufn : std_logic;
+ signal out172_buf : std_logic := '0';
+ signal out172_bufn : std_logic;
+
+ -- Function calls: return IDs
+ signal funccall0 : unsigned(0 downto 0) := (others => '0');
+ signal funccall0_next : unsigned(0 downto 0) := (others => '0');
+
+begin
+
+ -- Sequential process
+ -- Set the current state
+
+ process (clock)
+ begin
+ if rising_edge(clock) then
+
+ -- Next state
+ state_cur <= state_next;
+ -- Buffers for outputs
+ out0_buf <= out0_bufn;
+ out40_buf <= out40_bufn;
+ out101_buf <= out101_bufn;
+ out172_buf <= out172_bufn;
+ -- Function calls: return IDs
+ funccall0 <= funccall0_next;
+
+ end if;
+ end process;
+
+ -- Combinatorial process
+ -- Compute the next state
+ -- Compute the outputs
+
+ process (
+ -- Inputs of the FSM
+ reset, in0, in5, in6, in7, in8, in9, in10, in11, in12, in13, in14, in1, in2, in3, in4,
+ -- Function calls: return IDs
+ funccall0,
+ -- Current state
+ state_cur
+ )
+ begin
+
+ -- Reset the next state value
+
+ state_next <= (others => '0');
+
+ -- Default value to the outputs or output buffers
+
+ out46 <= '0';
+ out35 <= '0';
+ out65 <= '0';
+ out39 <= '0';
+ out3 <= '0';
+ out44 <= '0';
+ out0_bufn <= '0';
+ out41 <= '0';
+ out40_bufn <= '0';
+ out80 <= '0';
+ out81 <= '0';
+ out84 <= '0';
+ out86 <= '0';
+ out88 <= '0';
+ out93 <= '0';
+ out94 <= '0';
+ out97 <= '0';
+ out98 <= '0';
+ out101_bufn <= '0';
+ out102 <= '0';
+ out124 <= '0';
+ out125 <= '0';
+ out140 <= '0';
+ out157 <= '0';
+ out159 <= '0';
+ out160 <= '0';
+ out171 <= '0';
+ out172_bufn <= '0';
+ out173 <= '0';
+ out175 <= '0';
+ out178 <= '0';
+ out225 <= '0';
+ out227 <= '0';
+ out231 <= '0';
+ out235 <= '0';
+ out236 <= '0';
+ out237 <= '0';
+ out238 <= '0';
+
+ -- Function calls: default values (no change)
+ funccall0_next <= funccall0;
+
+ -- For all states, compute the next state bits
+ -- And the outputs, and the next value for buffered outputs
+
+ if state_cur(0) = '1' then
+ -- Next state
+ if ((in4) or (in3) or (in2)) = '1' then
+ state_next(17) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (in1) = '1' then
+ -- Function call: memextrct_0
+ -- Save the origin of the call
+ funccall0_next <= to_unsigned(0, 1);
+ -- This is where the function call leads
+ state_next(4) <= '1';
+ -- Next values for buffered outputs
+ out0_bufn <= '1';
+ else
+ if (in0) = '1' then
+ -- Function call: memextrct_1
+ state_next(2) <= '1';
+ -- Next values for buffered outputs
+ out0_bufn <= '1';
+ else
+ state_next(17) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out3 <= '1';
+ end if;
+
+ if state_cur(1) = '1' then
+ -- Next state
+ if (in5) = '1' then
+ state_next(1) <= '1';
+ -- Next values for buffered outputs
+ out40_bufn <= '1';
+ else
+ -- Return from function: memextrct_1
+ -- Function call: memextrct_0
+ -- Save the origin of the call
+ funccall0_next <= to_unsigned(1, 1);
+ -- This is where the function call leads
+ state_next(4) <= '1';
+ -- Next values for buffered outputs
+ out0_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs
+ out41 <= '1';
+ out39 <= '1';
+ out35 <= '1';
+ end if;
+
+ if state_cur(2) = '1' then
+ -- Next state
+ state_next(1) <= '1';
+ -- Next values for buffered outputs
+ out40_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ end if;
+
+ if state_cur(3) = '1' then
+ -- Next state
+ if (in6) = '1' then
+ state_next(3) <= '1';
+ -- Next values for buffered outputs
+ out40_bufn <= '1';
+ else
+ -- Return from function: memextrct_0
+ if funccall0 = 1 then
+ state_next(17) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Return from function: memextrct_0
+ if funccall0 = 0 then
+ state_next(17) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out41 <= '1';
+ out65 <= '1';
+ out46 <= '1';
+ end if;
+
+ if state_cur(4) = '1' then
+ -- Next state
+ state_next(3) <= '1';
+ -- Next values for buffered outputs
+ out40_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ end if;
+
+ if state_cur(5) = '1' then
+ -- Next state
+ if (in8) = '1' then
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (not (in7)) = '1' then
+ state_next(5) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(6) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out84 <= '1';
+ out81 <= '1';
+ out80 <= '1';
+ end if;
+
+ if state_cur(6) = '1' then
+ -- Next state
+ if (in8) = '1' then
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (not (in9)) = '1' then
+ state_next(6) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(7) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out88 <= '1';
+ out86 <= '1';
+ out81 <= '1';
+ end if;
+
+ if state_cur(7) = '1' then
+ -- Next state
+ if (in8) = '1' then
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (not (in9)) = '1' then
+ state_next(7) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(16) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out94 <= '1';
+ out93 <= '1';
+ out81 <= '1';
+ end if;
+
+ if state_cur(8) = '1' then
+ -- Next state
+ state_next(14) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out98 <= '1';
+ out97 <= '1';
+ end if;
+
+ if state_cur(9) = '1' then
+ -- Next state
+ if (in10) = '1' then
+ state_next(10) <= '1';
+ -- Next values for buffered outputs
+ out101_bufn <= '1';
+ else
+ state_next(5) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ end if;
+
+ if state_cur(10) = '1' then
+ -- Next state
+ state_next(11) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out102 <= '1';
+ end if;
+
+ if state_cur(11) = '1' then
+ -- Next state
+ state_next(13) <= '1';
+ -- Next values for buffered outputs
+ out172_bufn <= '1';
+ -- Assignment of non-buffered outputs
+ out125 <= '1';
+ out124 <= '1';
+ end if;
+
+ if state_cur(12) = '1' then
+ -- Next state
+ state_next(9) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out159 <= '1';
+ out157 <= '1';
+ out140 <= '1';
+ end if;
+
+ if state_cur(13) = '1' then
+ -- Next state
+ if (in8) = '1' then
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(9) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out173 <= '1';
+ out171 <= '1';
+ out160 <= '1';
+ out81 <= '1';
+ end if;
+
+ if state_cur(14) = '1' then
+ -- Next state
+ if (in11) = '1' then
+ state_next(15) <= '1';
+ -- Next values for buffered outputs
+ out172_bufn <= '1';
+ out101_bufn <= '1';
+ else
+ state_next(12) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ end if;
+
+ if state_cur(15) = '1' then
+ -- Next state
+ if (in8) = '1' then
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(14) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out173 <= '1';
+ out178 <= '1';
+ out175 <= '1';
+ out81 <= '1';
+ end if;
+
+ if state_cur(16) = '1' then
+ -- Next state
+ state_next(8) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out159 <= '1';
+ out227 <= '1';
+ out225 <= '1';
+ end if;
+
+ if state_cur(17) = '1' then
+ -- Next state
+ if (in12) = '1' then
+ if (in4) = '1' then
+ state_next(5) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (in3) = '1' then
+ state_next(6) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (in2) = '1' then
+ state_next(7) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (in1) = '1' then
+ state_next(13) <= '1';
+ -- Next values for buffered outputs
+ out172_bufn <= '1';
+ else
+ state_next(15) <= '1';
+ -- Next values for buffered outputs
+ out172_bufn <= '1';
+ out101_bufn <= '1';
+ end if;
+ end if;
+ end if;
+ end if;
+ else
+ state_next(18) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ -- Assignment of non-buffered outputs
+ out231 <= '1';
+ end if;
+
+ if state_cur(18) = '1' then
+ -- Next state
+ state_next(18) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ end if;
+
+ -- Info: This is the init/reset state
+ if state_cur(19) = '1' then
+ -- Next state
+ if (not (in13)) = '1' then
+ state_next(19) <= '1';
+ -- Next values for buffered outputs
+ else
+ if (in12) = '1' then
+ state_next(20) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(6) <= '1';
+ -- Next values for buffered outputs
+ end if;
+ end if;
+ -- Assignment of non-buffered outputs
+ out236 <= '1';
+ out235 <= '1';
+ end if;
+
+ if state_cur(20) = '1' then
+ -- Next state
+ state_next(21) <= '1';
+ -- Next values for buffered outputs
+ -- Assignment of non-buffered outputs
+ out44 <= '1';
+ end if;
+
+ if state_cur(21) = '1' then
+ -- Next state
+ if (in14) = '1' then
+ state_next(21) <= '1';
+ -- Next values for buffered outputs
+ else
+ state_next(0) <= '1';
+ -- Next values for buffered outputs
+ out0_bufn <= '1';
+ end if;
+ -- Assignment of non-buffered outputs
+ out41 <= '1';
+ out238 <= '1';
+ out237 <= '1';
+ end if;
+
+ -- Reset input
+ if reset = '1' then
+ -- Set the reset state
+ state_next <= (19 => '1', others => '0');
+ -- Note: Resetting all buffers for outputs here is not necessary.
+ -- It would cost hardware. They will be reset at the next clock front.
+ -- Reset state: set the buffered outputs
+ end if;
+
+ end process;
+
+ -- Assignment of buffered outputs
+
+ out0 <= out0_buf;
+ out40 <= out40_buf;
+ out101 <= out101_buf;
+ out172 <= out172_buf;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/muxb_117.vhd b/testsuite/gna/issue50/vector.d/muxb_117.vhd
new file mode 100644
index 000000000..6f615b120
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/muxb_117.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_117 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_117;
+
+architecture augh of muxb_117 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/muxb_120.vhd b/testsuite/gna/issue50/vector.d/muxb_120.vhd
new file mode 100644
index 000000000..e04495904
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/muxb_120.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_120 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_120;
+
+architecture augh of muxb_120 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/muxb_121.vhd b/testsuite/gna/issue50/vector.d/muxb_121.vhd
new file mode 100644
index 000000000..a87b25e2e
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/muxb_121.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_121 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_121;
+
+architecture augh of muxb_121 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/muxb_123.vhd b/testsuite/gna/issue50/vector.d/muxb_123.vhd
new file mode 100644
index 000000000..150ed33cd
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/muxb_123.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_123 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_123;
+
+architecture augh of muxb_123 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/muxb_124.vhd b/testsuite/gna/issue50/vector.d/muxb_124.vhd
new file mode 100644
index 000000000..72f4f37dc
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/muxb_124.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_124 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_124;
+
+architecture augh of muxb_124 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/muxb_219.vhd b/testsuite/gna/issue50/vector.d/muxb_219.vhd
new file mode 100644
index 000000000..d26913c7c
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/muxb_219.vhd
@@ -0,0 +1,22 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity muxb_219 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+end muxb_219;
+
+architecture augh of muxb_219 is
+begin
+
+ out_data <= in_data0 when in_sel = '0' else in_data1;
+
+end architecture;
+
diff --git a/testsuite/gna/issue50/vector.d/pkg_tb.vhd b/testsuite/gna/issue50/vector.d/pkg_tb.vhd
new file mode 100644
index 000000000..89886725d
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/pkg_tb.vhd
@@ -0,0 +1,60 @@
+--test bench written by alban bourge @ tima
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+package pkg_tb is
+
+ --fsm state types
+ type state_t is (Rst,Sig_start,Ack_data,Running,Waitfor,Cp_search,Cp_save,Idle,Rst_uut,Rest_ini0,Rest_ini1,Rest,Stop);
+ --context descriptor
+ subtype context_t is std_logic_vector(1 downto 0);
+ --argument width and type of fsm instruction
+ constant ARG_WIDTH : integer := 8;
+ subtype argument_t is unsigned(ARG_WIDTH - 1 downto 0);
+
+ type instruction is
+ record
+ state : state_t;
+ context_uut : context_t;
+ arg : argument_t;
+ end record;
+
+ --reset instruction
+ constant instr_rst : instruction := (state => Rst, context_uut => (others =>'0'), arg => (others =>'0'));
+
+ --ram instruction
+ type ram_instruction is
+ record
+ sel : std_logic;
+ we : std_logic;
+ addr_up : std_logic;
+ addr_z : std_logic;
+ end record;
+
+ constant ram_instr_z : ram_instruction := (sel => '0', we => '0', addr_up => '0', addr_z => '0');
+
+ --assert unit instruction
+ type assert_instruction is
+ record
+ en_feed : std_logic;
+ en_check : std_logic;
+ end record;
+
+ constant assert_instr_z : assert_instruction := (en_feed => '0', en_check => '0');
+
+ --size of instruction table defined by PC_SIZE i.e. width of program counter
+ constant PC_SIZE : integer := 5;
+ type table_behavior is array (0 to 2**PC_SIZE - 1) of instruction;
+
+ --constraint fixed by unit under test (augh dependant)
+ --##CONSTRAINTS_START##--
+ subtype stdin_vector is std_logic_vector(31 downto 0);
+ subtype stdout_vector is std_logic_vector(31 downto 0);
+ subtype cp_vector is std_logic_vector(63 downto 0);
+ --##CONSTRAINTS_END##--
+
+ --assert_uut vector number counter size
+ constant VEC_NO_SIZE : integer := 20;
+
+end pkg_tb;
diff --git a/testsuite/gna/issue50/vector.d/prog.vhd b/testsuite/gna/issue50/vector.d/prog.vhd
new file mode 100644
index 000000000..4d7aa42db
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/prog.vhd
@@ -0,0 +1,71 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+library work;
+use work.pkg_tb.all;
+
+entity prog is
+ port(
+ clock : in std_logic;
+ reset : in std_logic;
+ step : in std_logic;
+ instr_next : out instruction
+ );
+end prog;
+
+architecture rtl of prog is
+
+ signal instr_n : instruction := instr_rst;
+
+ --Table describing fsm behavior
+ constant fsm_behavior : table_behavior := (
+ --##PROGRAM_GOES_DOWN_HERE##--
+ 0 => (state => Rst, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 1 => (state => Rst, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 2 => (state => Sig_start, context_uut => "01", arg => to_unsigned(0,ARG_WIDTH)),
+ 3 => (state => Ack_data, context_uut => "01", arg => to_unsigned(2,ARG_WIDTH)),
+ 4 => (state => Running, context_uut => "01", arg => to_unsigned(5,ARG_WIDTH)),
+ 5 => (state => Cp_search, context_uut => "01", arg => to_unsigned(0,ARG_WIDTH)),
+ 6 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 7 => (state => Rst_uut, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 8 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 9 => (state => Sig_start, context_uut => "10", arg => to_unsigned(0,ARG_WIDTH)),
+ 10 => (state => Ack_data, context_uut => "10", arg => to_unsigned(2,ARG_WIDTH)),
+ 11 => (state => Running, context_uut => "10", arg => to_unsigned(6,ARG_WIDTH)),
+ 12 => (state => Cp_search, context_uut => "10", arg => to_unsigned(0,ARG_WIDTH)),
+ 13 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 14 => (state => Rst_uut, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 15 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 16 => (state => Rest_ini0, context_uut => "01", arg => to_unsigned(0,ARG_WIDTH)),
+ 17 => (state => Waitfor, context_uut => "01", arg => to_unsigned(1,ARG_WIDTH)),
+ 18 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 19 => (state => Rst_uut, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ 20 => (state => Idle, context_uut => "00", arg => to_unsigned(5,ARG_WIDTH)),
+ 21 => (state => Rest_ini0, context_uut => "10", arg => to_unsigned(0,ARG_WIDTH)),
+ 22 => (state => Waitfor, context_uut => "10", arg => to_unsigned(1,ARG_WIDTH)),
+ 23 => (state => Stop, context_uut => "00", arg => to_unsigned(0,ARG_WIDTH)),
+ --##PROGRAM_GOES_OVER_HERE##--
+ others => instr_rst);
+
+ signal pc : unsigned(PC_SIZE - 1 downto 0) := (others => '0');
+
+begin
+
+ drive_state : process (reset,clock) is
+ begin
+ if reset = '1' then
+ instr_n <= instr_rst;
+ pc <= (others => '0');
+ elsif rising_edge(clock) then
+ if (step = '1') then
+ pc <= pc + 1;
+ end if;
+ instr_n <= fsm_behavior(to_integer(pc));
+ end if;
+ end process drive_state;
+
+ --instr_next <= instr_n;
+ instr_next <= fsm_behavior(to_integer(pc));
+
+end rtl;
diff --git a/testsuite/gna/issue50/vector.d/sub_125.vhd b/testsuite/gna/issue50/vector.d/sub_125.vhd
new file mode 100644
index 000000000..dd458f161
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/sub_125.vhd
@@ -0,0 +1,64 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_125 is
+ port (
+ le : out std_logic;
+ sign : in std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_125;
+
+architecture augh of sub_125 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+ -- Signals to generate the comparison outputs
+ signal msb_abr : std_logic_vector(2 downto 0);
+ signal tmp_sign : std_logic;
+ signal tmp_eq : std_logic;
+ signal tmp_le : std_logic;
+ signal tmp_ge : std_logic;
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+ -- Other comparison outputs
+
+ -- Temporary signals
+ msb_abr <= carry_inA(32) & carry_inB(32) & carry_res(32);
+ tmp_sign <= sign;
+ tmp_eq <= '1' when in_a = in_b else '0';
+
+ tmp_le <=
+ tmp_eq when msb_abr = "000" or msb_abr = "110" else
+ '1' when msb_abr = "001" or msb_abr = "111" else
+ '1' when tmp_sign = '0' and (msb_abr = "010" or msb_abr = "011") else
+ '1' when tmp_sign = '1' and (msb_abr = "100" or msb_abr = "101") else
+ '0';
+
+ tmp_ge <=
+ '1' when msb_abr = "000" or msb_abr = "110" else
+ '1' when tmp_sign = '0' and (msb_abr = "100" or msb_abr = "101") else
+ '1' when tmp_sign = '1' and (msb_abr = "010" or msb_abr = "011") else
+ '0';
+
+ le <= tmp_le;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/sub_145.vhd b/testsuite/gna/issue50/vector.d/sub_145.vhd
new file mode 100644
index 000000000..d8fe56a80
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/sub_145.vhd
@@ -0,0 +1,33 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_145 is
+ port (
+ result : out std_logic_vector(3 downto 0);
+ in_a : in std_logic_vector(3 downto 0);
+ in_b : in std_logic_vector(3 downto 0)
+ );
+end sub_145;
+
+architecture augh of sub_145 is
+
+ signal carry_inA : std_logic_vector(5 downto 0);
+ signal carry_inB : std_logic_vector(5 downto 0);
+ signal carry_res : std_logic_vector(5 downto 0);
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(4 downto 1);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/sub_189.vhd b/testsuite/gna/issue50/vector.d/sub_189.vhd
new file mode 100644
index 000000000..02a52c0d2
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/sub_189.vhd
@@ -0,0 +1,64 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity sub_189 is
+ port (
+ lt : out std_logic;
+ sign : in std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+end sub_189;
+
+architecture augh of sub_189 is
+
+ signal carry_inA : std_logic_vector(33 downto 0);
+ signal carry_inB : std_logic_vector(33 downto 0);
+ signal carry_res : std_logic_vector(33 downto 0);
+
+ -- Signals to generate the comparison outputs
+ signal msb_abr : std_logic_vector(2 downto 0);
+ signal tmp_sign : std_logic;
+ signal tmp_eq : std_logic;
+ signal tmp_le : std_logic;
+ signal tmp_ge : std_logic;
+
+begin
+
+ -- To handle the CI input, the operation is '0' - CI
+ -- If CI is not present, the operation is '0' - '0'
+ carry_inA <= '0' & in_a & '0';
+ carry_inB <= '0' & in_b & '0';
+ -- Compute the result
+ carry_res <= std_logic_vector(unsigned(carry_inA) - unsigned(carry_inB));
+
+ -- Set the outputs
+ result <= carry_res(32 downto 1);
+
+ -- Other comparison outputs
+
+ -- Temporary signals
+ msb_abr <= carry_inA(32) & carry_inB(32) & carry_res(32);
+ tmp_sign <= sign;
+ tmp_eq <= '1' when in_a = in_b else '0';
+
+ tmp_le <=
+ tmp_eq when msb_abr = "000" or msb_abr = "110" else
+ '1' when msb_abr = "001" or msb_abr = "111" else
+ '1' when tmp_sign = '0' and (msb_abr = "010" or msb_abr = "011") else
+ '1' when tmp_sign = '1' and (msb_abr = "100" or msb_abr = "101") else
+ '0';
+
+ tmp_ge <=
+ '1' when msb_abr = "000" or msb_abr = "110" else
+ '1' when tmp_sign = '0' and (msb_abr = "100" or msb_abr = "101") else
+ '1' when tmp_sign = '1' and (msb_abr = "010" or msb_abr = "011") else
+ '0';
+
+ lt <= not(tmp_ge);
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/sync_ram.vhd b/testsuite/gna/issue50/vector.d/sync_ram.vhd
new file mode 100644
index 000000000..83aecf543
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/sync_ram.vhd
@@ -0,0 +1,42 @@
+-- Simple generic RAM Model
+--
+-- +-----------------------------+
+-- | Copyright 2008 DOULOS |
+-- | designer : JK |
+-- +-----------------------------+
+
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+
+entity sync_ram is
+ port (
+ clock : in std_logic;
+ we : in std_logic;
+ address : in std_logic_vector;
+ datain : in std_logic_vector;
+ dataout : out std_logic_vector
+ );
+end entity sync_ram;
+
+architecture rtl of sync_ram is
+
+ type ram_type is array (0 to (2**address'length)-1) of std_logic_vector(datain'range);
+ signal ram : ram_type;
+ signal read_address : std_logic_vector(address'range);
+
+begin
+
+ ramproc: process(clock) is
+ begin
+ if rising_edge(clock) then
+ if we = '1' then
+ ram(to_integer(unsigned(address))) <= datain;
+ end if;
+ read_address <= address;
+ end if;
+ end process ramproc;
+
+ dataout <= ram(to_integer(unsigned(read_address)));
+
+end architecture rtl;
diff --git a/testsuite/gna/issue50/vector.d/tb.vhd b/testsuite/gna/issue50/vector.d/tb.vhd
new file mode 100644
index 000000000..94a534963
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/tb.vhd
@@ -0,0 +1,44 @@
+--test bench written by Alban Bourge @ TIMA
+library ieee;
+use ieee.std_logic_1164.all;
+use ieee.numeric_std.all;
+library work;
+use work.pkg_tb.all;
+
+entity tb is
+end tb;
+
+architecture behavior of tb is
+
+ signal clock : std_logic := '0';
+ signal clock_next : std_logic := '0';
+ signal reset : std_logic := '0';
+ --TOP signals
+ signal n_error : std_logic;
+ signal stopped : std_logic;
+
+begin
+
+ test : entity work.cp3_test(rtl)
+ port map(
+ clock => clock,
+ reset => reset,
+ n_error => n_error,
+ stopped => stopped
+ );
+
+ --clock generator
+ clock <= clock_next after 10 ns;
+ clock_next <= not clock when stopped = '0' else '0';
+
+ reset_proc : process
+ begin
+ reset <= '1';
+ for i in 1 to 5 loop
+ wait until rising_edge(clock);
+ end loop;
+ reset <= '0';
+ wait;
+ end process reset_proc;
+
+end behavior;
diff --git a/testsuite/gna/issue50/vector.d/top.vhd b/testsuite/gna/issue50/vector.d/top.vhd
new file mode 100644
index 000000000..b82be5e72
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/top.vhd
@@ -0,0 +1,2504 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+entity top is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ start : in std_logic;
+ stdin_data : in std_logic_vector(31 downto 0);
+ stdin_rdy : out std_logic;
+ stdin_ack : in std_logic;
+ stdout_data : out std_logic_vector(31 downto 0);
+ stdout_rdy : out std_logic;
+ stdout_ack : in std_logic;
+ cp_en : in std_logic;
+ cp_rest : in std_logic;
+ cp_din : in std_logic_vector(63 downto 0);
+ cp_dout : out std_logic_vector(63 downto 0);
+ cp_ok : out std_logic
+ );
+end top;
+
+architecture augh of top is
+
+ -- Declaration of components
+
+ component v_split0 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split1 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split2 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split3 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split4 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split5 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split6 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component v_split7 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split0 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split1 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split2 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split3 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split4 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split5 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split6 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component w_split7 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+ end component;
+
+ component add_171 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component cmp_183 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_185 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_193 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_195 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component muxb_120 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component muxb_124 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component cmp_128 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_130 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_132 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_136 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_137 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_138 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_139 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_140 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_141 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_142 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component muxb_117 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component add_118 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_119 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component muxb_121 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component muxb_123 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component sub_125 is
+ port (
+ le : out std_logic;
+ sign : in std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component cmp_126 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component add_134 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_145 is
+ port (
+ result : out std_logic_vector(3 downto 0);
+ in_a : in std_logic_vector(3 downto 0);
+ in_b : in std_logic_vector(3 downto 0)
+ );
+ end component;
+
+ component cmp_146 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component add_170 is
+ port (
+ result : out std_logic_vector(8 downto 0);
+ in_a : in std_logic_vector(8 downto 0);
+ in_b : in std_logic_vector(8 downto 0)
+ );
+ end component;
+
+ component cmp_174 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_176 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_178 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_180 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_187 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component add_188 is
+ port (
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component sub_189 is
+ port (
+ lt : out std_logic;
+ sign : in std_logic;
+ result : out std_logic_vector(31 downto 0);
+ in_a : in std_logic_vector(31 downto 0);
+ in_b : in std_logic_vector(31 downto 0)
+ );
+ end component;
+
+ component cmp_191 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_198 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_200 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_202 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_204 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component add_214 is
+ port (
+ result : out std_logic_vector(7 downto 0);
+ in_a : in std_logic_vector(7 downto 0);
+ in_b : in std_logic_vector(7 downto 0)
+ );
+ end component;
+
+ component cmp_215 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component muxb_219 is
+ port (
+ in_sel : in std_logic;
+ out_data : out std_logic;
+ in_data0 : in std_logic;
+ in_data1 : in std_logic
+ );
+ end component;
+
+ component add_220 is
+ port (
+ result : out std_logic_vector(15 downto 0);
+ in_a : in std_logic_vector(15 downto 0);
+ in_b : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_221 is
+ port (
+ ne : out std_logic;
+ in0 : in std_logic_vector(15 downto 0);
+ in1 : in std_logic_vector(15 downto 0)
+ );
+ end component;
+
+ component cmp_111 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_113 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_216 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_217 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_218 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component fsm_15 is
+ port (
+ clock : in std_logic;
+ reset : in std_logic;
+ out3 : out std_logic;
+ out157 : out std_logic;
+ out159 : out std_logic;
+ out160 : out std_logic;
+ out171 : out std_logic;
+ out172 : out std_logic;
+ out173 : out std_logic;
+ out175 : out std_logic;
+ out178 : out std_logic;
+ in0 : in std_logic;
+ out0 : out std_logic;
+ in5 : in std_logic;
+ in6 : in std_logic;
+ in7 : in std_logic;
+ out35 : out std_logic;
+ out39 : out std_logic;
+ out40 : out std_logic;
+ out41 : out std_logic;
+ out44 : out std_logic;
+ out46 : out std_logic;
+ out140 : out std_logic;
+ in8 : in std_logic;
+ in9 : in std_logic;
+ in10 : in std_logic;
+ in11 : in std_logic;
+ in12 : in std_logic;
+ in13 : in std_logic;
+ in14 : in std_logic;
+ out65 : out std_logic;
+ in1 : in std_logic;
+ in2 : in std_logic;
+ in3 : in std_logic;
+ in4 : in std_logic;
+ out225 : out std_logic;
+ out227 : out std_logic;
+ out231 : out std_logic;
+ out235 : out std_logic;
+ out236 : out std_logic;
+ out237 : out std_logic;
+ out238 : out std_logic;
+ out97 : out std_logic;
+ out98 : out std_logic;
+ out101 : out std_logic;
+ out102 : out std_logic;
+ out124 : out std_logic;
+ out125 : out std_logic;
+ out80 : out std_logic;
+ out81 : out std_logic;
+ out84 : out std_logic;
+ out86 : out std_logic;
+ out88 : out std_logic;
+ out93 : out std_logic;
+ out94 : out std_logic
+ );
+ end component;
+
+ component cmp_112 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_114 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_115 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_148 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_150 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_152 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_154 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_156 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_158 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_160 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_127 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_129 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_131 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_133 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ component cmp_135 is
+ port (
+ eq : out std_logic;
+ in0 : in std_logic_vector(2 downto 0);
+ in1 : in std_logic_vector(2 downto 0)
+ );
+ end component;
+
+ -- Declaration of signals
+
+ signal sig_clock : std_logic;
+ signal sig_reset : std_logic;
+ signal sig_222 : std_logic;
+ signal sig_223 : std_logic;
+ signal sig_224 : std_logic;
+ signal sig_225 : std_logic;
+ signal sig_226 : std_logic;
+ signal sig_227 : std_logic;
+ signal sig_228 : std_logic;
+ signal sig_229 : std_logic;
+ signal sig_230 : std_logic;
+ signal sig_231 : std_logic;
+ signal sig_232 : std_logic;
+ signal sig_233 : std_logic;
+ signal sig_234 : std_logic;
+ signal sig_235 : std_logic;
+ signal sig_236 : std_logic;
+ signal sig_237 : std_logic;
+ signal sig_238 : std_logic;
+ signal sig_239 : std_logic;
+ signal sig_240 : std_logic;
+ signal sig_241 : std_logic;
+ signal sig_242 : std_logic;
+ signal sig_243 : std_logic;
+ signal sig_244 : std_logic;
+ signal sig_245 : std_logic;
+ signal sig_246 : std_logic;
+ signal sig_247 : std_logic;
+ signal sig_248 : std_logic;
+ signal sig_249 : std_logic;
+ signal sig_250 : std_logic;
+ signal sig_251 : std_logic;
+ signal sig_252 : std_logic;
+ signal sig_253 : std_logic;
+ signal sig_254 : std_logic;
+ signal sig_255 : std_logic;
+ signal sig_256 : std_logic;
+ signal sig_257 : std_logic;
+ signal sig_258 : std_logic;
+ signal sig_259 : std_logic;
+ signal sig_260 : std_logic;
+ signal sig_261 : std_logic;
+ signal sig_262 : std_logic;
+ signal sig_263 : std_logic;
+ signal sig_264 : std_logic;
+ signal sig_265 : std_logic;
+ signal sig_266 : std_logic;
+ signal sig_267 : std_logic;
+ signal sig_268 : std_logic;
+ signal sig_269 : std_logic;
+ signal sig_270 : std_logic;
+ signal sig_271 : std_logic;
+ signal sig_272 : std_logic;
+ signal sig_273 : std_logic;
+ signal sig_274 : std_logic;
+ signal sig_275 : std_logic;
+ signal sig_276 : std_logic;
+ signal sig_277 : std_logic;
+ signal sig_278 : std_logic;
+ signal augh_test_0 : std_logic;
+ signal augh_test_1 : std_logic;
+ signal sig_start : std_logic;
+ signal test_cp_4_6 : std_logic;
+ signal test_cp_3_7 : std_logic;
+ signal test_cp_0_8 : std_logic;
+ signal test_cp_1_9 : std_logic;
+ signal test_cp_2_10 : std_logic;
+ signal memextrct_loop_sig_13 : std_logic;
+ signal memextrct_loop_sig_14 : std_logic;
+ signal psc_loop_sig_12 : std_logic;
+ signal sig_279 : std_logic_vector(15 downto 0);
+ signal sig_280 : std_logic;
+ signal sig_281 : std_logic;
+ signal sig_282 : std_logic_vector(7 downto 0);
+ signal sig_283 : std_logic;
+ signal sig_284 : std_logic;
+ signal sig_285 : std_logic;
+ signal sig_286 : std_logic;
+ signal sig_287 : std_logic;
+ signal sig_288 : std_logic_vector(31 downto 0);
+ signal sig_289 : std_logic_vector(31 downto 0);
+ signal sig_290 : std_logic;
+ signal sig_291 : std_logic;
+ signal sig_292 : std_logic;
+ signal sig_293 : std_logic;
+ signal sig_294 : std_logic;
+ signal sig_295 : std_logic_vector(8 downto 0);
+ signal sig_296 : std_logic;
+ signal sig_297 : std_logic_vector(3 downto 0);
+ signal sig_298 : std_logic_vector(31 downto 0);
+ signal sig_299 : std_logic;
+ signal sig_300 : std_logic_vector(31 downto 0);
+ signal sig_301 : std_logic;
+ signal sig_302 : std_logic;
+ signal sig_303 : std_logic;
+ signal sig_304 : std_logic_vector(15 downto 0);
+ signal sig_305 : std_logic;
+ signal sig_306 : std_logic;
+ signal sig_307 : std_logic;
+ signal sig_308 : std_logic;
+ signal sig_309 : std_logic;
+ signal sig_310 : std_logic;
+ signal sig_311 : std_logic;
+ signal sig_312 : std_logic;
+ signal sig_313 : std_logic;
+ signal sig_314 : std_logic;
+ signal sig_315 : std_logic;
+ signal sig_316 : std_logic;
+ signal sig_317 : std_logic;
+ signal sig_318 : std_logic;
+ signal sig_319 : std_logic;
+ signal sig_320 : std_logic;
+ signal sig_321 : std_logic;
+ signal sig_322 : std_logic_vector(31 downto 0);
+ signal sig_323 : std_logic_vector(7 downto 0);
+ signal sig_324 : std_logic_vector(7 downto 0);
+ signal sig_325 : std_logic_vector(7 downto 0);
+ signal sig_326 : std_logic_vector(7 downto 0);
+ signal sig_327 : std_logic_vector(7 downto 0);
+ signal sig_328 : std_logic_vector(7 downto 0);
+ signal sig_329 : std_logic_vector(7 downto 0);
+ signal sig_330 : std_logic_vector(7 downto 0);
+ signal sig_331 : std_logic_vector(7 downto 0);
+ signal sig_332 : std_logic_vector(7 downto 0);
+ signal sig_333 : std_logic_vector(7 downto 0);
+ signal sig_334 : std_logic_vector(7 downto 0);
+ signal sig_335 : std_logic_vector(7 downto 0);
+ signal sig_336 : std_logic_vector(7 downto 0);
+ signal sig_337 : std_logic_vector(7 downto 0);
+ signal sig_338 : std_logic_vector(7 downto 0);
+ signal sig_339 : std_logic_vector(31 downto 0);
+ signal sig_340 : std_logic_vector(8 downto 0);
+ signal sig_341 : std_logic_vector(8 downto 0);
+ signal sig_342 : std_logic_vector(31 downto 0);
+
+ -- Other inlined components
+
+ signal mux_25 : std_logic;
+ signal mux_26 : std_logic_vector(2 downto 0);
+ signal mux_27 : std_logic;
+ signal mux_28 : std_logic_vector(2 downto 0);
+ signal mux_29 : std_logic;
+ signal mux_30 : std_logic_vector(15 downto 0);
+ signal mux_31 : std_logic;
+ signal mux_32 : std_logic_vector(7 downto 0);
+ signal mux_33 : std_logic;
+ signal mux_34 : std_logic;
+ signal mux_35 : std_logic;
+ signal mux_36 : std_logic_vector(7 downto 0);
+ signal mux_37 : std_logic;
+ signal mux_38 : std_logic;
+ signal mux_39 : std_logic;
+ signal mux_40 : std_logic_vector(7 downto 0);
+ signal mux_41 : std_logic;
+ signal mux_42 : std_logic;
+ signal mux_43 : std_logic;
+ signal augh_main_max_iter : std_logic_vector(31 downto 0) := (others => '0');
+ signal augh_main_std_addition : std_logic_vector(31 downto 0) := (others => '0');
+ signal augh_main_result : std_logic_vector(31 downto 0) := (others => '0');
+ signal augh_main_i : std_logic_vector(31 downto 0) := (others => '0');
+ signal mux_23 : std_logic;
+ signal mux_24 : std_logic;
+ signal mux_44 : std_logic_vector(7 downto 0);
+ signal mux_45 : std_logic;
+ signal mux_46 : std_logic;
+ signal mux_47 : std_logic;
+ signal mux_48 : std_logic_vector(7 downto 0);
+ signal mux_49 : std_logic;
+ signal mux_50 : std_logic;
+ signal mux_51 : std_logic;
+ signal mux_52 : std_logic_vector(7 downto 0);
+ signal mux_53 : std_logic;
+ signal mux_54 : std_logic;
+ signal mux_55 : std_logic;
+ signal mux_56 : std_logic_vector(7 downto 0);
+ signal mux_57 : std_logic;
+ signal mux_58 : std_logic;
+ signal mux_59 : std_logic;
+ signal mux_60 : std_logic_vector(7 downto 0);
+ signal mux_61 : std_logic;
+ signal mux_62 : std_logic;
+ signal mux_63 : std_logic;
+ signal mux_64 : std_logic_vector(31 downto 0);
+ signal mux_65 : std_logic;
+ signal mux_66 : std_logic_vector(31 downto 0);
+ signal mux_67 : std_logic;
+ signal mux_68 : std_logic_vector(31 downto 0);
+ signal mux_69 : std_logic;
+ signal mux_70 : std_logic_vector(31 downto 0);
+ signal mux_71 : std_logic;
+ signal mux_72 : std_logic_vector(7 downto 0);
+ signal mux_73 : std_logic;
+ signal mux_74 : std_logic;
+ signal mux_75 : std_logic;
+ signal mux_76 : std_logic_vector(7 downto 0);
+ signal mux_77 : std_logic;
+ signal mux_78 : std_logic;
+ signal mux_79 : std_logic;
+ signal mux_80 : std_logic_vector(7 downto 0);
+ signal mux_20 : std_logic;
+ signal mux_22 : std_logic;
+ signal and_163 : std_logic_vector(7 downto 0);
+ signal and_164 : std_logic_vector(7 downto 0);
+ signal and_165 : std_logic_vector(7 downto 0);
+ signal and_166 : std_logic_vector(7 downto 0);
+ signal and_167 : std_logic_vector(7 downto 0);
+ signal and_168 : std_logic_vector(7 downto 0);
+ signal and_169 : std_logic_vector(7 downto 0);
+ signal and_182 : std_logic_vector(7 downto 0);
+ signal and_184 : std_logic_vector(7 downto 0);
+ signal and_186 : std_logic_vector(7 downto 0);
+ signal and_192 : std_logic;
+ signal and_194 : std_logic;
+ signal and_196 : std_logic;
+ signal mux_81 : std_logic;
+ signal mux_82 : std_logic;
+ signal mux_83 : std_logic;
+ signal mux_84 : std_logic_vector(7 downto 0);
+ signal mux_85 : std_logic;
+ signal mux_86 : std_logic;
+ signal mux_87 : std_logic;
+ signal mux_88 : std_logic_vector(7 downto 0);
+ signal mux_89 : std_logic;
+ signal mux_90 : std_logic;
+ signal mux_91 : std_logic;
+ signal mux_92 : std_logic_vector(7 downto 0);
+ signal mux_93 : std_logic;
+ signal mux_94 : std_logic;
+ signal mux_95 : std_logic;
+ signal mux_96 : std_logic_vector(7 downto 0);
+ signal mux_97 : std_logic;
+ signal mux_98 : std_logic;
+ signal mux_99 : std_logic;
+ signal mux_100 : std_logic_vector(7 downto 0);
+ signal mux_101 : std_logic;
+ signal mux_102 : std_logic;
+ signal mux_103 : std_logic;
+ signal mux_106 : std_logic;
+ signal mux_108 : std_logic;
+ signal mux_109 : std_logic_vector(63 downto 0);
+ signal mux_110 : std_logic;
+ signal and_116 : std_logic;
+ signal not_122 : std_logic;
+ signal or_143 : std_logic_vector(7 downto 0);
+ signal and_147 : std_logic_vector(7 downto 0);
+ signal and_149 : std_logic_vector(7 downto 0);
+ signal and_151 : std_logic_vector(7 downto 0);
+ signal and_153 : std_logic_vector(7 downto 0);
+ signal and_155 : std_logic_vector(7 downto 0);
+ signal and_157 : std_logic_vector(7 downto 0);
+ signal and_159 : std_logic_vector(7 downto 0);
+ signal or_161 : std_logic_vector(7 downto 0);
+ signal and_162 : std_logic_vector(7 downto 0);
+ signal or_172 : std_logic_vector(7 downto 0);
+ signal and_173 : std_logic_vector(7 downto 0);
+ signal and_175 : std_logic_vector(7 downto 0);
+ signal and_177 : std_logic_vector(7 downto 0);
+ signal and_179 : std_logic_vector(7 downto 0);
+ signal and_181 : std_logic_vector(7 downto 0);
+ signal and_190 : std_logic;
+ signal and_197 : std_logic;
+ signal and_199 : std_logic;
+ signal and_201 : std_logic;
+ signal and_203 : std_logic;
+ signal or_205 : std_logic_vector(7 downto 0);
+ signal and_206 : std_logic_vector(7 downto 0);
+ signal and_207 : std_logic_vector(7 downto 0);
+ signal and_208 : std_logic_vector(7 downto 0);
+ signal and_209 : std_logic_vector(7 downto 0);
+ signal and_210 : std_logic_vector(7 downto 0);
+ signal and_211 : std_logic_vector(7 downto 0);
+ signal and_212 : std_logic_vector(7 downto 0);
+ signal and_213 : std_logic_vector(7 downto 0);
+ signal psc_loop_reg_3 : std_logic_vector(15 downto 0) := (others => '0');
+ signal cp_id_reg_4 : std_logic_vector(2 downto 0) := (others => '0');
+ signal cp_id_reg_stable_5 : std_logic_vector(2 downto 0) := (others => '0');
+ signal psc_stuff_reg_11 : std_logic_vector(60 downto 0) := "0000000000000000000000000000000000000000000000000000000000000";
+ signal and_144 : std_logic_vector(7 downto 0);
+
+ -- This utility function is used for to generate concatenations of std_logic
+
+ -- Little utility function to ease concatenation of an std_logic
+ -- and explicitely return an std_logic_vector
+ function repeat(N: natural; B: std_logic) return std_logic_vector is
+ variable result: std_logic_vector(N-1 downto 0);
+ begin
+ result := (others => B);
+ return result;
+ end;
+
+begin
+
+ -- Instantiation of components
+
+ v_split0_i : v_split0 port map (
+ clk => sig_clock,
+ ra0_data => sig_338,
+ wa0_data => mux_100,
+ wa0_addr => mux_101,
+ wa0_en => mux_102,
+ ra0_addr => mux_103
+ );
+
+ v_split1_i : v_split1 port map (
+ clk => sig_clock,
+ ra0_data => sig_337,
+ wa0_data => mux_96,
+ wa0_addr => mux_97,
+ wa0_en => mux_98,
+ ra0_addr => mux_99
+ );
+
+ v_split2_i : v_split2 port map (
+ clk => sig_clock,
+ ra0_data => sig_336,
+ wa0_data => mux_92,
+ wa0_addr => mux_93,
+ wa0_en => mux_94,
+ ra0_addr => mux_95
+ );
+
+ v_split3_i : v_split3 port map (
+ clk => sig_clock,
+ ra0_data => sig_335,
+ wa0_data => mux_88,
+ wa0_addr => mux_89,
+ wa0_en => mux_90,
+ ra0_addr => mux_91
+ );
+
+ v_split4_i : v_split4 port map (
+ clk => sig_clock,
+ ra0_data => sig_334,
+ wa0_data => mux_84,
+ wa0_addr => mux_85,
+ wa0_en => mux_86,
+ ra0_addr => mux_87
+ );
+
+ v_split5_i : v_split5 port map (
+ clk => sig_clock,
+ ra0_data => sig_333,
+ wa0_data => mux_80,
+ wa0_addr => mux_81,
+ wa0_en => mux_82,
+ ra0_addr => mux_83
+ );
+
+ v_split6_i : v_split6 port map (
+ clk => sig_clock,
+ ra0_data => sig_332,
+ wa0_data => mux_76,
+ wa0_addr => mux_77,
+ wa0_en => mux_78,
+ ra0_addr => mux_79
+ );
+
+ v_split7_i : v_split7 port map (
+ clk => sig_clock,
+ ra0_data => sig_331,
+ wa0_data => mux_72,
+ wa0_addr => mux_73,
+ wa0_en => mux_74,
+ ra0_addr => mux_75
+ );
+
+ w_split0_i : w_split0 port map (
+ clk => sig_clock,
+ ra0_data => sig_330,
+ wa0_data => mux_60,
+ wa0_addr => mux_61,
+ wa0_en => mux_62,
+ ra0_addr => mux_63
+ );
+
+ w_split1_i : w_split1 port map (
+ clk => sig_clock,
+ ra0_data => sig_329,
+ wa0_data => mux_56,
+ wa0_addr => mux_57,
+ wa0_en => mux_58,
+ ra0_addr => mux_59
+ );
+
+ w_split2_i : w_split2 port map (
+ clk => sig_clock,
+ ra0_data => sig_328,
+ wa0_data => mux_52,
+ wa0_addr => mux_53,
+ wa0_en => mux_54,
+ ra0_addr => mux_55
+ );
+
+ w_split3_i : w_split3 port map (
+ clk => sig_clock,
+ ra0_data => sig_327,
+ wa0_data => mux_48,
+ wa0_addr => mux_49,
+ wa0_en => mux_50,
+ ra0_addr => mux_51
+ );
+
+ w_split4_i : w_split4 port map (
+ clk => sig_clock,
+ ra0_data => sig_326,
+ wa0_data => mux_44,
+ wa0_addr => mux_45,
+ wa0_en => mux_46,
+ ra0_addr => mux_47
+ );
+
+ w_split5_i : w_split5 port map (
+ clk => sig_clock,
+ ra0_data => sig_325,
+ wa0_data => mux_40,
+ wa0_addr => mux_41,
+ wa0_en => mux_42,
+ ra0_addr => mux_43
+ );
+
+ w_split6_i : w_split6 port map (
+ clk => sig_clock,
+ ra0_data => sig_324,
+ wa0_data => mux_36,
+ wa0_addr => mux_37,
+ wa0_en => mux_38,
+ ra0_addr => mux_39
+ );
+
+ w_split7_i : w_split7 port map (
+ clk => sig_clock,
+ ra0_data => sig_323,
+ wa0_data => mux_32,
+ wa0_addr => mux_33,
+ wa0_en => mux_34,
+ ra0_addr => mux_35
+ );
+
+ add_171_i : add_171 port map (
+ result => sig_322,
+ in_a => sig_342,
+ in_b => augh_main_std_addition
+ );
+
+ cmp_183_i : cmp_183 port map (
+ eq => sig_321,
+ in0 => "010",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_185_i : cmp_185 port map (
+ eq => sig_320,
+ in0 => "001",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_193_i : cmp_193 port map (
+ eq => sig_319,
+ in0 => "110",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_195_i : cmp_195 port map (
+ eq => sig_318,
+ in0 => "101",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ muxb_120_i : muxb_120 port map (
+ in_sel => cp_en,
+ out_data => sig_317,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ muxb_124_i : muxb_124 port map (
+ in_sel => not_122,
+ out_data => sig_316,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ cmp_128_i : cmp_128 port map (
+ eq => sig_315,
+ in0 => "101",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_130_i : cmp_130 port map (
+ eq => sig_314,
+ in0 => "011",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_132_i : cmp_132 port map (
+ eq => sig_313,
+ in0 => "001",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_136_i : cmp_136 port map (
+ eq => sig_312,
+ in0 => "110",
+ in1 => sig_298(2 downto 0)
+ );
+
+ cmp_137_i : cmp_137 port map (
+ eq => sig_311,
+ in0 => "101",
+ in1 => sig_298(2 downto 0)
+ );
+
+ cmp_138_i : cmp_138 port map (
+ eq => sig_310,
+ in0 => "100",
+ in1 => sig_298(2 downto 0)
+ );
+
+ cmp_139_i : cmp_139 port map (
+ eq => sig_309,
+ in0 => "011",
+ in1 => sig_298(2 downto 0)
+ );
+
+ cmp_140_i : cmp_140 port map (
+ eq => sig_308,
+ in0 => "010",
+ in1 => sig_298(2 downto 0)
+ );
+
+ cmp_141_i : cmp_141 port map (
+ eq => sig_307,
+ in0 => "001",
+ in1 => sig_298(2 downto 0)
+ );
+
+ cmp_142_i : cmp_142 port map (
+ eq => sig_306,
+ in0 => "000",
+ in1 => sig_298(2 downto 0)
+ );
+
+ muxb_117_i : muxb_117 port map (
+ in_sel => cp_en,
+ out_data => sig_305,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ add_118_i : add_118 port map (
+ result => sig_304,
+ in_a => psc_loop_reg_3,
+ in_b => "0000000000000001"
+ );
+
+ cmp_119_i : cmp_119 port map (
+ ne => sig_303,
+ in0 => "0000000000000001",
+ in1 => psc_loop_reg_3
+ );
+
+ muxb_121_i : muxb_121 port map (
+ in_sel => not_122,
+ out_data => sig_302,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ muxb_123_i : muxb_123 port map (
+ in_sel => not_122,
+ out_data => sig_301,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ sub_125_i : sub_125 port map (
+ le => augh_test_1,
+ sign => '1',
+ result => sig_300,
+ in_a => augh_main_i,
+ in_b => "00000000000000000000000000000111"
+ );
+
+ cmp_126_i : cmp_126 port map (
+ eq => sig_299,
+ in0 => "111",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ add_134_i : add_134 port map (
+ result => sig_298,
+ in_a => augh_main_i,
+ in_b => "00000000000000000000000000000001"
+ );
+
+ sub_145_i : sub_145 port map (
+ result => sig_297,
+ in_a => augh_main_max_iter(3 downto 0),
+ in_b => "0001"
+ );
+
+ cmp_146_i : cmp_146 port map (
+ eq => sig_296,
+ in0 => "111",
+ in1 => sig_297(2 downto 0)
+ );
+
+ add_170_i : add_170 port map (
+ result => sig_295,
+ in_a => sig_341,
+ in_b => sig_340
+ );
+
+ cmp_174_i : cmp_174 port map (
+ eq => sig_294,
+ in0 => "111",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_176_i : cmp_176 port map (
+ eq => sig_293,
+ in0 => "110",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_178_i : cmp_178 port map (
+ eq => sig_292,
+ in0 => "101",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_180_i : cmp_180 port map (
+ eq => sig_291,
+ in0 => "100",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_187_i : cmp_187 port map (
+ eq => sig_290,
+ in0 => "000",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ add_188_i : add_188 port map (
+ result => sig_289,
+ in_a => augh_main_result,
+ in_b => sig_339
+ );
+
+ sub_189_i : sub_189 port map (
+ lt => augh_test_0,
+ sign => '1',
+ result => sig_288,
+ in_a => augh_main_i,
+ in_b => augh_main_max_iter
+ );
+
+ cmp_191_i : cmp_191 port map (
+ eq => sig_287,
+ in0 => "111",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_198_i : cmp_198 port map (
+ eq => sig_286,
+ in0 => "011",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_200_i : cmp_200 port map (
+ eq => sig_285,
+ in0 => "010",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_202_i : cmp_202 port map (
+ eq => sig_284,
+ in0 => "001",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_204_i : cmp_204 port map (
+ eq => sig_283,
+ in0 => "000",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ add_214_i : add_214 port map (
+ result => sig_282,
+ in_a => or_205,
+ in_b => augh_main_i(7 downto 0)
+ );
+
+ cmp_215_i : cmp_215 port map (
+ eq => sig_281,
+ in0 => "001",
+ in1 => cp_id_reg_stable_5
+ );
+
+ muxb_219_i : muxb_219 port map (
+ in_sel => cp_en,
+ out_data => sig_280,
+ in_data0 => '0',
+ in_data1 => '1'
+ );
+
+ add_220_i : add_220 port map (
+ result => sig_279,
+ in_a => psc_loop_reg_3,
+ in_b => "0000000000000001"
+ );
+
+ cmp_221_i : cmp_221 port map (
+ ne => psc_loop_sig_12,
+ in0 => "0000000000000010",
+ in1 => psc_loop_reg_3
+ );
+
+ cmp_111_i : cmp_111 port map (
+ eq => test_cp_2_10,
+ in0 => "010",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_113_i : cmp_113 port map (
+ eq => sig_278,
+ in0 => "000",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_216_i : cmp_216 port map (
+ eq => sig_277,
+ in0 => "000",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_217_i : cmp_217 port map (
+ eq => sig_276,
+ in0 => "011",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_218_i : cmp_218 port map (
+ eq => sig_275,
+ in0 => "100",
+ in1 => cp_id_reg_stable_5
+ );
+
+ fsm_15_i : fsm_15 port map (
+ clock => sig_clock,
+ reset => sig_reset,
+ out3 => sig_274,
+ out157 => sig_273,
+ out159 => sig_272,
+ out160 => sig_271,
+ out171 => sig_270,
+ out172 => sig_269,
+ out173 => sig_268,
+ out175 => sig_267,
+ out178 => sig_266,
+ in0 => test_cp_4_6,
+ out0 => sig_265,
+ in5 => memextrct_loop_sig_14,
+ in6 => memextrct_loop_sig_13,
+ in7 => stdout_ack,
+ out35 => sig_264,
+ out39 => sig_263,
+ out40 => sig_262,
+ out41 => sig_261,
+ out44 => sig_260,
+ out46 => sig_259,
+ out140 => sig_258,
+ in8 => cp_en,
+ in9 => stdin_ack,
+ in10 => augh_test_1,
+ in11 => augh_test_0,
+ in12 => cp_rest,
+ in13 => sig_start,
+ in14 => psc_loop_sig_12,
+ out65 => sig_257,
+ in1 => test_cp_3_7,
+ in2 => test_cp_0_8,
+ in3 => test_cp_1_9,
+ in4 => test_cp_2_10,
+ out225 => sig_256,
+ out227 => sig_255,
+ out231 => sig_254,
+ out235 => sig_253,
+ out236 => sig_252,
+ out237 => sig_251,
+ out238 => sig_250,
+ out97 => sig_249,
+ out98 => sig_248,
+ out101 => sig_247,
+ out102 => sig_246,
+ out124 => sig_245,
+ out125 => sig_244,
+ out80 => sig_243,
+ out81 => sig_242,
+ out84 => sig_241,
+ out86 => sig_240,
+ out88 => sig_239,
+ out93 => sig_238,
+ out94 => sig_237
+ );
+
+ cmp_112_i : cmp_112 port map (
+ eq => sig_236,
+ in0 => "001",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_114_i : cmp_114 port map (
+ eq => sig_235,
+ in0 => "011",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_115_i : cmp_115 port map (
+ eq => sig_234,
+ in0 => "100",
+ in1 => cp_id_reg_stable_5
+ );
+
+ cmp_148_i : cmp_148 port map (
+ eq => sig_233,
+ in0 => "110",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_150_i : cmp_150 port map (
+ eq => sig_232,
+ in0 => "101",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_152_i : cmp_152 port map (
+ eq => sig_231,
+ in0 => "100",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_154_i : cmp_154 port map (
+ eq => sig_230,
+ in0 => "011",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_156_i : cmp_156 port map (
+ eq => sig_229,
+ in0 => "010",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_158_i : cmp_158 port map (
+ eq => sig_228,
+ in0 => "001",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_160_i : cmp_160 port map (
+ eq => sig_227,
+ in0 => "000",
+ in1 => sig_297(2 downto 0)
+ );
+
+ cmp_127_i : cmp_127 port map (
+ eq => sig_226,
+ in0 => "110",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_129_i : cmp_129 port map (
+ eq => sig_225,
+ in0 => "100",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_131_i : cmp_131 port map (
+ eq => sig_224,
+ in0 => "010",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_133_i : cmp_133 port map (
+ eq => sig_223,
+ in0 => "000",
+ in1 => augh_main_i(2 downto 0)
+ );
+
+ cmp_135_i : cmp_135 port map (
+ eq => sig_222,
+ in0 => "111",
+ in1 => sig_298(2 downto 0)
+ );
+
+ -- Behaviour of component 'mux_25' model 'mux'
+ mux_25 <=
+ (sig_274 and sig_234) or
+ (sig_254 and sig_275);
+
+ -- Behaviour of component 'mux_26' model 'mux'
+ mux_26 <=
+ (repeat(3, sig_243) and "010") or
+ (repeat(3, sig_253) and cp_din(2 downto 0)) or
+ (repeat(3, sig_240) and "001") or
+ (repeat(3, sig_271) and "011") or
+ (repeat(3, sig_267) and "100");
+
+ -- Behaviour of component 'mux_27' model 'mux'
+ mux_27 <=
+ (sig_242 and '1') or
+ (sig_252 and cp_rest);
+
+ -- Behaviour of component 'mux_28' model 'mux'
+ mux_28 <=
+ (repeat(3, sig_243) and "010") or
+ (repeat(3, sig_251) and augh_main_result(2 downto 0)) or
+ (repeat(3, sig_240) and "001") or
+ (repeat(3, sig_271) and "011") or
+ (repeat(3, sig_267) and "100");
+
+ -- Behaviour of component 'mux_29' model 'mux'
+ mux_29 <=
+ (sig_242 and '1') or
+ (sig_250 and cp_en);
+
+ -- Behaviour of component 'mux_30' model 'mux'
+ mux_30 <=
+ (repeat(16, sig_262) and sig_304) or
+ (repeat(16, sig_251) and sig_279);
+
+ -- Behaviour of component 'mux_31' model 'mux'
+ mux_31 <=
+ (sig_261 and cp_en) or
+ (sig_260 and '1');
+
+ -- Behaviour of component 'mux_32' model 'mux'
+ mux_32 <=
+ (repeat(8, sig_263) and cp_din(7 downto 0)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_33' model 'mux'
+ mux_33 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_34' model 'mux'
+ mux_34 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_190);
+
+ -- Behaviour of component 'mux_35' model 'mux'
+ mux_35 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_36' model 'mux'
+ mux_36 <=
+ (repeat(8, sig_263) and cp_din(15 downto 8)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_37' model 'mux'
+ mux_37 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_38' model 'mux'
+ mux_38 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_192);
+
+ -- Behaviour of component 'mux_39' model 'mux'
+ mux_39 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_40' model 'mux'
+ mux_40 <=
+ (repeat(8, sig_263) and cp_din(23 downto 16)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_41' model 'mux'
+ mux_41 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_42' model 'mux'
+ mux_42 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_194);
+
+ -- Behaviour of component 'mux_43' model 'mux'
+ mux_43 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_23' model 'mux'
+ mux_23 <=
+ (sig_274 and sig_278) or
+ (sig_254 and sig_277);
+
+ -- Behaviour of component 'mux_24' model 'mux'
+ mux_24 <=
+ (sig_274 and sig_235) or
+ (sig_254 and sig_276);
+
+ -- Behaviour of component 'mux_44' model 'mux'
+ mux_44 <=
+ (repeat(8, sig_263) and cp_din(31 downto 24)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_45' model 'mux'
+ mux_45 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_249 and '1') or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_46' model 'mux'
+ mux_46 <=
+ (sig_264 and and_116) or
+ (sig_248 and '1') or
+ (sig_266 and and_196);
+
+ -- Behaviour of component 'mux_47' model 'mux'
+ mux_47 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_48' model 'mux'
+ mux_48 <=
+ (repeat(8, sig_263) and cp_din(39 downto 32)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_49' model 'mux'
+ mux_49 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_50' model 'mux'
+ mux_50 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_197);
+
+ -- Behaviour of component 'mux_51' model 'mux'
+ mux_51 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_52' model 'mux'
+ mux_52 <=
+ (repeat(8, sig_263) and cp_din(47 downto 40)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_53' model 'mux'
+ mux_53 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_54' model 'mux'
+ mux_54 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_199);
+
+ -- Behaviour of component 'mux_55' model 'mux'
+ mux_55 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_56' model 'mux'
+ mux_56 <=
+ (repeat(8, sig_263) and cp_din(55 downto 48)) or
+ (repeat(8, sig_267) and sig_282) or
+ (repeat(8, sig_256) and "00000011");
+
+ -- Behaviour of component 'mux_57' model 'mux'
+ mux_57 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_58' model 'mux'
+ mux_58 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_201) or
+ (sig_255 and '1');
+
+ -- Behaviour of component 'mux_59' model 'mux'
+ mux_59 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_60' model 'mux'
+ mux_60 <=
+ (repeat(8, sig_263) and cp_din(63 downto 56)) or
+ (repeat(8, sig_267) and sig_282);
+
+ -- Behaviour of component 'mux_61' model 'mux'
+ mux_61 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_62' model 'mux'
+ mux_62 <=
+ (sig_264 and and_116) or
+ (sig_266 and and_203);
+
+ -- Behaviour of component 'mux_63' model 'mux'
+ mux_63 <=
+ (sig_263 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_267 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_64' model 'mux'
+ mux_64 <=
+ (repeat(32, sig_269) and sig_298) or
+ (repeat(32, sig_251) and augh_main_std_addition);
+
+ -- Behaviour of component 'mux_65' model 'mux'
+ mux_65 <=
+ (sig_272 and '1') or
+ (sig_268 and not_122) or
+ (sig_250 and cp_en);
+
+ -- Behaviour of component 'mux_66' model 'mux'
+ mux_66 <=
+ (repeat(32, sig_258) and sig_322) or
+ (repeat(32, sig_271) and sig_289) or
+ (repeat(32, sig_251) and augh_main_max_iter);
+
+ -- Behaviour of component 'mux_67' model 'mux'
+ mux_67 <=
+ (sig_273 and '1') or
+ (sig_270 and not_122) or
+ (sig_250 and cp_en);
+
+ -- Behaviour of component 'mux_68' model 'mux'
+ mux_68 <=
+ (repeat(32, sig_237) and stdin_data) or
+ (repeat(32, sig_251) and cp_din(63 downto 32));
+
+ -- Behaviour of component 'mux_69' model 'mux'
+ mux_69 <=
+ (sig_238 and not_122) or
+ (sig_250 and cp_en);
+
+ -- Behaviour of component 'mux_70' model 'mux'
+ mux_70 <=
+ (repeat(32, sig_240) and stdin_data) or
+ (repeat(32, sig_251) and cp_din(31 downto 0));
+
+ -- Behaviour of component 'mux_71' model 'mux'
+ mux_71 <=
+ (sig_239 and not_122) or
+ (sig_250 and cp_en);
+
+ -- Behaviour of component 'mux_72' model 'mux'
+ mux_72 <=
+ (repeat(8, sig_259) and cp_din(7 downto 0)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_73' model 'mux'
+ mux_73 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_74' model 'mux'
+ mux_74 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_299) or
+ (sig_244 and sig_222) or
+ (sig_266 and and_190);
+
+ -- Behaviour of component 'mux_75' model 'mux'
+ mux_75 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_76' model 'mux'
+ mux_76 <=
+ (repeat(8, sig_259) and cp_din(15 downto 8)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_77' model 'mux'
+ mux_77 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_78' model 'mux'
+ mux_78 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_226) or
+ (sig_244 and sig_312) or
+ (sig_266 and and_192);
+
+ -- Behaviour of component 'mux_79' model 'mux'
+ mux_79 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_80' model 'mux'
+ mux_80 <=
+ (repeat(8, sig_259) and cp_din(23 downto 16)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0)) or
+ (repeat(8, sig_256) and "00001100");
+
+ -- Behaviour of component 'mux_20' model 'mux'
+ mux_20 <=
+ (sig_250 and cp_en);
+
+ -- Behaviour of component 'mux_22' model 'mux'
+ mux_22 <=
+ (sig_274 and sig_236) or
+ (sig_254 and sig_281);
+
+ -- Behaviour of component 'and_163' model 'and'
+ and_163 <=
+ sig_324 and
+ repeat(8, sig_233);
+
+ -- Behaviour of component 'and_164' model 'and'
+ and_164 <=
+ sig_325 and
+ repeat(8, sig_232);
+
+ -- Behaviour of component 'and_165' model 'and'
+ and_165 <=
+ sig_326 and
+ repeat(8, sig_231);
+
+ -- Behaviour of component 'and_166' model 'and'
+ and_166 <=
+ sig_327 and
+ repeat(8, sig_230);
+
+ -- Behaviour of component 'and_167' model 'and'
+ and_167 <=
+ sig_328 and
+ repeat(8, sig_229);
+
+ -- Behaviour of component 'and_168' model 'and'
+ and_168 <=
+ sig_329 and
+ repeat(8, sig_228);
+
+ -- Behaviour of component 'and_169' model 'and'
+ and_169 <=
+ sig_330 and
+ repeat(8, sig_227);
+
+ -- Behaviour of component 'and_182' model 'and'
+ and_182 <=
+ sig_336 and
+ repeat(8, sig_321);
+
+ -- Behaviour of component 'and_184' model 'and'
+ and_184 <=
+ sig_337 and
+ repeat(8, sig_320);
+
+ -- Behaviour of component 'and_186' model 'and'
+ and_186 <=
+ sig_338 and
+ repeat(8, sig_290);
+
+ -- Behaviour of component 'and_192' model 'and'
+ and_192 <=
+ not_122 and
+ sig_319;
+
+ -- Behaviour of component 'and_194' model 'and'
+ and_194 <=
+ not_122 and
+ sig_318;
+
+ -- Behaviour of component 'and_196' model 'and'
+ and_196 <=
+ not_122 and
+ sig_225;
+
+ -- Behaviour of component 'mux_81' model 'mux'
+ mux_81 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_82' model 'mux'
+ mux_82 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_315) or
+ (sig_244 and sig_311) or
+ (sig_266 and and_194) or
+ (sig_255 and '1');
+
+ -- Behaviour of component 'mux_83' model 'mux'
+ mux_83 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_84' model 'mux'
+ mux_84 <=
+ (repeat(8, sig_259) and cp_din(31 downto 24)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_85' model 'mux'
+ mux_85 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_86' model 'mux'
+ mux_86 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_225) or
+ (sig_244 and sig_310) or
+ (sig_266 and and_196);
+
+ -- Behaviour of component 'mux_87' model 'mux'
+ mux_87 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_88' model 'mux'
+ mux_88 <=
+ (repeat(8, sig_259) and cp_din(39 downto 32)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_89' model 'mux'
+ mux_89 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_90' model 'mux'
+ mux_90 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_314) or
+ (sig_244 and sig_309) or
+ (sig_266 and and_197);
+
+ -- Behaviour of component 'mux_91' model 'mux'
+ mux_91 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_92' model 'mux'
+ mux_92 <=
+ (repeat(8, sig_259) and cp_din(47 downto 40)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_93' model 'mux'
+ mux_93 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_94' model 'mux'
+ mux_94 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_224) or
+ (sig_244 and sig_308) or
+ (sig_266 and and_199);
+
+ -- Behaviour of component 'mux_95' model 'mux'
+ mux_95 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_96' model 'mux'
+ mux_96 <=
+ (repeat(8, sig_259) and cp_din(55 downto 48)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_97' model 'mux'
+ mux_97 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_98' model 'mux'
+ mux_98 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_313) or
+ (sig_244 and sig_307) or
+ (sig_266 and and_201);
+
+ -- Behaviour of component 'mux_99' model 'mux'
+ mux_99 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_100' model 'mux'
+ mux_100 <=
+ (repeat(8, sig_259) and cp_din(63 downto 56)) or
+ (repeat(8, sig_267) and augh_main_i(7 downto 0));
+
+ -- Behaviour of component 'mux_101' model 'mux'
+ mux_101 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_247 and augh_main_i(3)) or
+ (sig_245 and sig_298(3));
+
+ -- Behaviour of component 'mux_102' model 'mux'
+ mux_102 <=
+ (sig_257 and and_116) or
+ (sig_246 and sig_223) or
+ (sig_244 and sig_306) or
+ (sig_266 and and_203);
+
+ -- Behaviour of component 'mux_103' model 'mux'
+ mux_103 <=
+ (sig_259 and psc_loop_reg_3(0)) or
+ (sig_258 and sig_297(3)) or
+ (sig_271 and augh_main_i(3));
+
+ -- Behaviour of component 'mux_106' model 'mux'
+ mux_106 <=
+ (sig_239 and sig_301) or
+ (sig_238 and sig_316);
+
+ -- Behaviour of component 'mux_108' model 'mux'
+ mux_108 <=
+ (sig_241 and sig_302);
+
+ -- Behaviour of component 'mux_109' model 'mux'
+ mux_109 <=
+ (repeat(64, sig_263) and (sig_330 & sig_329 & sig_328 & sig_327 & sig_326 & sig_325 & sig_324 & sig_323)) or
+ (repeat(64, sig_259) and (sig_338 & sig_337 & sig_336 & sig_335 & sig_334 & sig_333 & sig_332 & sig_331)) or
+ (repeat(64, sig_251) and (psc_stuff_reg_11 & cp_id_reg_4));
+
+ -- Behaviour of component 'mux_110' model 'mux'
+ mux_110 <=
+ (sig_265 and '1') or
+ (sig_263 and sig_305) or
+ (sig_259 and sig_317) or
+ (sig_251 and sig_280);
+
+ -- Behaviour of component 'and_116' model 'and'
+ and_116 <=
+ cp_en and
+ cp_rest;
+
+ -- Behaviour of component 'not_122' model 'not'
+ not_122 <= not (
+ cp_en
+ );
+
+ -- Behaviour of component 'or_143' model 'or'
+ or_143 <=
+ and_144 or
+ and_155 or
+ and_157 or
+ and_159 or
+ and_147 or
+ and_149 or
+ and_151 or
+ and_153;
+
+ -- Behaviour of component 'and_147' model 'and'
+ and_147 <=
+ sig_332 and
+ repeat(8, sig_233);
+
+ -- Behaviour of component 'and_149' model 'and'
+ and_149 <=
+ sig_333 and
+ repeat(8, sig_232);
+
+ -- Behaviour of component 'and_151' model 'and'
+ and_151 <=
+ sig_334 and
+ repeat(8, sig_231);
+
+ -- Behaviour of component 'and_153' model 'and'
+ and_153 <=
+ sig_335 and
+ repeat(8, sig_230);
+
+ -- Behaviour of component 'and_155' model 'and'
+ and_155 <=
+ sig_336 and
+ repeat(8, sig_229);
+
+ -- Behaviour of component 'and_157' model 'and'
+ and_157 <=
+ sig_337 and
+ repeat(8, sig_228);
+
+ -- Behaviour of component 'and_159' model 'and'
+ and_159 <=
+ sig_338 and
+ repeat(8, sig_227);
+
+ -- Behaviour of component 'or_161' model 'or'
+ or_161 <=
+ and_162 or
+ and_167 or
+ and_168 or
+ and_169 or
+ and_163 or
+ and_164 or
+ and_165 or
+ and_166;
+
+ -- Behaviour of component 'and_162' model 'and'
+ and_162 <=
+ sig_323 and
+ repeat(8, sig_296);
+
+ -- Behaviour of component 'or_172' model 'or'
+ or_172 <=
+ and_173 or
+ and_182 or
+ and_184 or
+ and_186 or
+ and_175 or
+ and_177 or
+ and_179 or
+ and_181;
+
+ -- Behaviour of component 'and_173' model 'and'
+ and_173 <=
+ sig_331 and
+ repeat(8, sig_294);
+
+ -- Behaviour of component 'and_175' model 'and'
+ and_175 <=
+ sig_332 and
+ repeat(8, sig_293);
+
+ -- Behaviour of component 'and_177' model 'and'
+ and_177 <=
+ sig_333 and
+ repeat(8, sig_292);
+
+ -- Behaviour of component 'and_179' model 'and'
+ and_179 <=
+ sig_334 and
+ repeat(8, sig_291);
+
+ -- Behaviour of component 'and_181' model 'and'
+ and_181 <=
+ sig_335 and
+ repeat(8, sig_314);
+
+ -- Behaviour of component 'and_190' model 'and'
+ and_190 <=
+ not_122 and
+ sig_287;
+
+ -- Behaviour of component 'and_197' model 'and'
+ and_197 <=
+ not_122 and
+ sig_286;
+
+ -- Behaviour of component 'and_199' model 'and'
+ and_199 <=
+ not_122 and
+ sig_285;
+
+ -- Behaviour of component 'and_201' model 'and'
+ and_201 <=
+ not_122 and
+ sig_284;
+
+ -- Behaviour of component 'and_203' model 'and'
+ and_203 <=
+ not_122 and
+ sig_283;
+
+ -- Behaviour of component 'or_205' model 'or'
+ or_205 <=
+ and_206 or
+ and_211 or
+ and_212 or
+ and_213 or
+ and_207 or
+ and_208 or
+ and_209 or
+ and_210;
+
+ -- Behaviour of component 'and_206' model 'and'
+ and_206 <=
+ sig_323 and
+ repeat(8, sig_287);
+
+ -- Behaviour of component 'and_207' model 'and'
+ and_207 <=
+ sig_324 and
+ repeat(8, sig_319);
+
+ -- Behaviour of component 'and_208' model 'and'
+ and_208 <=
+ sig_325 and
+ repeat(8, sig_318);
+
+ -- Behaviour of component 'and_209' model 'and'
+ and_209 <=
+ sig_326 and
+ repeat(8, sig_225);
+
+ -- Behaviour of component 'and_210' model 'and'
+ and_210 <=
+ sig_327 and
+ repeat(8, sig_286);
+
+ -- Behaviour of component 'and_211' model 'and'
+ and_211 <=
+ sig_328 and
+ repeat(8, sig_285);
+
+ -- Behaviour of component 'and_212' model 'and'
+ and_212 <=
+ sig_329 and
+ repeat(8, sig_284);
+
+ -- Behaviour of component 'and_213' model 'and'
+ and_213 <=
+ sig_330 and
+ repeat(8, sig_283);
+
+ -- Behaviour of component 'and_144' model 'and'
+ and_144 <=
+ sig_331 and
+ repeat(8, sig_296);
+
+ -- Behaviour of all components of model 'reg'
+ -- Registers with clock = sig_clock and reset = sig_reset active '1'
+ process(sig_clock, sig_reset)
+ begin
+ if sig_reset = '1' then
+ psc_stuff_reg_11 <= "0000000000000000000000000000000000000000000000000000000000000";
+ else
+ if rising_edge(sig_clock) then
+ if mux_20 = '1' then
+ psc_stuff_reg_11 <= augh_main_i & augh_main_result(31 downto 3);
+ end if;
+ end if;
+ end if;
+ end process;
+ -- Registers with clock = sig_clock and no reset
+ process(sig_clock)
+ begin
+ if rising_edge(sig_clock) then
+ if mux_27 = '1' then
+ cp_id_reg_stable_5 <= mux_26;
+ end if;
+ if mux_29 = '1' then
+ cp_id_reg_4 <= mux_28;
+ end if;
+ if mux_31 = '1' then
+ psc_loop_reg_3 <= mux_30;
+ end if;
+ if mux_65 = '1' then
+ augh_main_i <= mux_64;
+ end if;
+ if mux_67 = '1' then
+ augh_main_result <= mux_66;
+ end if;
+ if mux_69 = '1' then
+ augh_main_std_addition <= mux_68;
+ end if;
+ if mux_71 = '1' then
+ augh_main_max_iter <= mux_70;
+ end if;
+ end if;
+ end process;
+
+ -- Remaining signal assignments
+ -- Those who are not assigned by component instantiation
+
+ sig_clock <= clock;
+ sig_reset <= reset;
+ sig_start <= start;
+ test_cp_4_6 <= mux_25;
+ test_cp_3_7 <= mux_24;
+ test_cp_0_8 <= mux_23;
+ test_cp_1_9 <= mux_22;
+ memextrct_loop_sig_13 <= sig_303;
+ memextrct_loop_sig_14 <= sig_303;
+ sig_339 <= repeat(24, or_172(7)) & or_172;
+ sig_340 <= or_161(7) & or_161;
+ sig_341 <= or_143(7) & or_143;
+ sig_342 <= repeat(23, sig_295(8)) & sig_295;
+
+ -- Remaining top-level ports assignments
+ -- Those who are not assigned by component instantiation
+
+ stdin_rdy <= mux_106;
+ stdout_data <= augh_main_result;
+ stdout_rdy <= mux_108;
+ cp_dout <= mux_109;
+ cp_ok <= mux_110;
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split0.vhd b/testsuite/gna/issue50/vector.d/v_split0.vhd
new file mode 100644
index 000000000..e95973e01
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split0.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split0 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split0;
+architecture augh of v_split0 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split1.vhd b/testsuite/gna/issue50/vector.d/v_split1.vhd
new file mode 100644
index 000000000..537758796
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split1.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split1 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split1;
+architecture augh of v_split1 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split2.vhd b/testsuite/gna/issue50/vector.d/v_split2.vhd
new file mode 100644
index 000000000..3ec8ce48c
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split2.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split2 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split2;
+architecture augh of v_split2 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split3.vhd b/testsuite/gna/issue50/vector.d/v_split3.vhd
new file mode 100644
index 000000000..a2a569c3b
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split3.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split3 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split3;
+architecture augh of v_split3 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split4.vhd b/testsuite/gna/issue50/vector.d/v_split4.vhd
new file mode 100644
index 000000000..f48a53a47
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split4.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split4 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split4;
+architecture augh of v_split4 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split5.vhd b/testsuite/gna/issue50/vector.d/v_split5.vhd
new file mode 100644
index 000000000..ea9acd5a5
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split5.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split5 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split5;
+architecture augh of v_split5 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split6.vhd b/testsuite/gna/issue50/vector.d/v_split6.vhd
new file mode 100644
index 000000000..98e87b9cc
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split6.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split6 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split6;
+architecture augh of v_split6 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/v_split7.vhd b/testsuite/gna/issue50/vector.d/v_split7.vhd
new file mode 100644
index 000000000..ff89b3c21
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/v_split7.vhd
@@ -0,0 +1,65 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity v_split7 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end v_split7;
+architecture augh of v_split7 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (others => (others => '0'));
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split0.vhd b/testsuite/gna/issue50/vector.d/w_split0.vhd
new file mode 100644
index 000000000..0fcb022f3
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split0.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split0 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split0;
+architecture augh of w_split0 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split1.vhd b/testsuite/gna/issue50/vector.d/w_split1.vhd
new file mode 100644
index 000000000..aa72b9f55
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split1.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split1 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split1;
+architecture augh of w_split1 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split2.vhd b/testsuite/gna/issue50/vector.d/w_split2.vhd
new file mode 100644
index 000000000..b23549ac2
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split2.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split2 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split2;
+architecture augh of w_split2 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split3.vhd b/testsuite/gna/issue50/vector.d/w_split3.vhd
new file mode 100644
index 000000000..446b4ee14
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split3.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split3 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split3;
+architecture augh of w_split3 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000000"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split4.vhd b/testsuite/gna/issue50/vector.d/w_split4.vhd
new file mode 100644
index 000000000..0be33beb5
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split4.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split4 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split4;
+architecture augh of w_split4 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split5.vhd b/testsuite/gna/issue50/vector.d/w_split5.vhd
new file mode 100644
index 000000000..dd447b296
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split5.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split5 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split5;
+architecture augh of w_split5 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split6.vhd b/testsuite/gna/issue50/vector.d/w_split6.vhd
new file mode 100644
index 000000000..e00068742
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split6.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split6 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split6;
+architecture augh of w_split6 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;
diff --git a/testsuite/gna/issue50/vector.d/w_split7.vhd b/testsuite/gna/issue50/vector.d/w_split7.vhd
new file mode 100644
index 000000000..046b02597
--- /dev/null
+++ b/testsuite/gna/issue50/vector.d/w_split7.vhd
@@ -0,0 +1,67 @@
+library ieee;
+use ieee.std_logic_1164.all;
+
+
+library ieee;
+use ieee.numeric_std.all;
+
+entity w_split7 is
+ port (
+ clk : in std_logic;
+ ra0_data : out std_logic_vector(7 downto 0);
+ wa0_data : in std_logic_vector(7 downto 0);
+ wa0_addr : in std_logic;
+ wa0_en : in std_logic;
+ ra0_addr : in std_logic
+ );
+end w_split7;
+architecture augh of w_split7 is
+
+ -- Embedded RAM
+
+ type ram_type is array (0 to 1) of std_logic_vector(7 downto 0);
+ signal ram : ram_type := (
+ "00000111", "00000111"
+ );
+
+
+ -- Little utility functions to make VHDL syntactically correct
+ -- with the syntax to_integer(unsigned(vector)) when 'vector' is a std_logic.
+ -- This happens when accessing arrays with <= 2 cells, for example.
+
+ function to_integer(B: std_logic) return integer is
+ variable V: std_logic_vector(0 to 0);
+ begin
+ V(0) := B;
+ return to_integer(unsigned(V));
+ end;
+
+ function to_integer(V: std_logic_vector) return integer is
+ begin
+ return to_integer(unsigned(V));
+ end;
+
+begin
+
+ -- Sequential process
+ -- It handles the Writes
+
+ process (clk)
+ begin
+ if rising_edge(clk) then
+
+ -- Write to the RAM
+ -- Note: there should be only one port.
+
+ if wa0_en = '1' then
+ ram( to_integer(wa0_addr) ) <= wa0_data;
+ end if;
+
+ end if;
+ end process;
+
+ -- The Read side (the outputs)
+
+ ra0_data <= ram( to_integer(ra0_addr) );
+
+end architecture;