From 1af046986d3aeb1daa7d0f96e9c17a46fe214d5f Mon Sep 17 00:00:00 2001 From: Mladen Slijepcevic <77167949+mslijepc@users.noreply.github.com> Date: Tue, 6 Sep 2022 00:42:12 +0200 Subject: [PATCH] Fix thread saftey in SystemC VL_ASSIGN_SBW/WSB (#3494) (#3513). --- docs/CONTRIBUTORS | 1 + include/verilated_funcs.h | 46 ++++-- test_regress/t/t_var_sc_bv.cpp | 220 +++++++++++++++++++++++++++++ test_regress/t/t_var_sc_bv.pl | 24 ++++ test_regress/t/t_var_sc_bv.v | 246 +++++++++++++++++++++++++++++++++ 5 files changed, 522 insertions(+), 15 deletions(-) create mode 100644 test_regress/t/t_var_sc_bv.cpp create mode 100755 test_regress/t/t_var_sc_bv.pl create mode 100644 test_regress/t/t_var_sc_bv.v diff --git a/docs/CONTRIBUTORS b/docs/CONTRIBUTORS index 9c10dbb6f..83ab9f830 100644 --- a/docs/CONTRIBUTORS +++ b/docs/CONTRIBUTORS @@ -82,6 +82,7 @@ Michael Killough Michaël Lefebvre Mike Popoloski Miodrag Milanović +Mladen Slijepcevic Morten Borup Petersen Mostafa Gamal Nandu Raj diff --git a/include/verilated_funcs.h b/include/verilated_funcs.h index a7c3fcc73..acba15530 100644 --- a/include/verilated_funcs.h +++ b/include/verilated_funcs.h @@ -446,14 +446,21 @@ static inline void VL_ASSIGNBIT_WO(int bit, WDataOutP owp) VL_MT_SAFE { { (vvar) = VL_CLEAN_QQ((obits), (obits), (svar).read().to_uint64()); } #define VL_ASSIGN_WSB(obits, owp, svar) \ { \ - const int words = VL_WORDS_I(obits); \ - sc_biguint<(obits)> _butemp = (svar).read(); \ - for (int i = 0; i < words; ++i) { \ - int msb = ((i + 1) * VL_IDATASIZE) - 1; \ - msb = (msb >= (obits)) ? ((obits)-1) : msb; \ - (owp)[i] = _butemp.range(msb, i * VL_IDATASIZE).to_uint(); \ - } \ - (owp)[words - 1] &= VL_MASK_E(obits); \ + const int words = VL_WORDS_I(obits); \ + sc_biguint<(obits)> _butemp = (svar).read(); \ + uint32_t* chunk = _butemp.get_raw(); \ + int32_t lsb = 0; \ + while (lsb < obits - BITS_PER_DIGIT) { \ + const uint32_t data = *chunk; \ + ++chunk; \ + _vl_insert_WI(owp.data(), data, lsb+BITS_PER_DIGIT-1, lsb); \ + lsb += BITS_PER_DIGIT; \ + } \ + if (lsb < obits) { \ + const uint32_t msb_data = *chunk; \ + _vl_insert_WI(owp.data(), msb_data, obits-1, lsb); \ + } \ + (owp)[words - 1] &= VL_MASK_E(obits); \ } // Copying verilog format from systemc integers and bit vectors. @@ -492,15 +499,24 @@ static inline void VL_ASSIGNBIT_WO(int bit, WDataOutP owp) VL_MT_SAFE { { (svar).write(rd); } #define VL_ASSIGN_SBQ(obits, svar, rd) \ { (svar).write(rd); } +#define VL_SC_BITS_PER_DIGIT 30 // This comes from sc_nbdefs.h BITS_PER_DIGIT #define VL_ASSIGN_SBW(obits, svar, rwp) \ { \ - sc_biguint<(obits)> _butemp; \ - for (int i = 0; i < VL_WORDS_I(obits); ++i) { \ - int msb = ((i + 1) * VL_IDATASIZE) - 1; \ - msb = (msb >= (obits)) ? ((obits)-1) : msb; \ - _butemp.range(msb, i* VL_IDATASIZE) = (rwp)[i]; \ - } \ - (svar).write(_butemp); \ + sc_biguint<(obits)> _butemp; \ + int32_t lsb = 0; \ + uint32_t* chunk = _butemp.get_raw(); \ + while (lsb + VL_SC_BITS_PER_DIGIT < (obits)) { \ + static_assert(std::is_same::value, "IData and EData missmatch"); \ + const uint32_t data = VL_SEL_IWII(lsb+VL_SC_BITS_PER_DIGIT+1, (rwp).data(), lsb, VL_SC_BITS_PER_DIGIT); \ + *chunk = data & VL_MASK_E(VL_SC_BITS_PER_DIGIT); \ + ++chunk; \ + lsb += VL_SC_BITS_PER_DIGIT; \ + } \ + if (lsb < (obits)) { \ + const uint32_t msb_data = VL_SEL_IWII((obits)+1, (rwp).data(), lsb, (obits) - lsb); \ + *chunk = msb_data & VL_MASK_E((obits) - lsb); \ + } \ + (svar).write(_butemp); \ } //=================================================================== diff --git a/test_regress/t/t_var_sc_bv.cpp b/test_regress/t/t_var_sc_bv.cpp new file mode 100644 index 000000000..d8324bf2f --- /dev/null +++ b/test_regress/t/t_var_sc_bv.cpp @@ -0,0 +1,220 @@ +// -*- mode: C++; c-file-style: "cc-mode" -*- +// +// This file ONLY is placed into the Public Domain, for any use, +// without warranty, 2022 by Wilson Snyder. +// SPDX-License-Identifier: CC0-1.0 + +#include VM_PREFIX_INCLUDE + +VM_PREFIX* tb = nullptr; +bool pass = true; + +double sc_time_stamp() { return 0; } + +void compare_signals(const sc_signal>& ls, const sc_signal>& rs) { + if (ls.read() != rs.read()) { + pass &= false; + VL_PRINTF("%%Error: Data missmatch in signals %s and %s\n", ls.name(), rs.name()); + } +} + +void compareWls(int obits, WDataInP const lwp, WDataInP const rwp) { + const int words = VL_WORDS_I(obits); + bool same = true; + + for (int i = 0; (i < (words - 1)); ++i) { + if (lwp[i] != rwp[i]) { same = false; } + } + if ((lwp[words - 1] & VL_MASK_E(obits)) != (rwp[words - 1] & VL_MASK_E(obits))) { + same = false; + } + + if (!same) { + pass &= false; + VL_PRINTF("%%Error: There is a difference in VlWide variable %d bits wide\n", obits); + } +} + +// old macro which is correct but has MT issue with range +#define VL_ASSIGN_SBW_MT_ISSUE(obits, svar, rwp) \ + { \ + sc_biguint<(obits)> _butemp; \ + for (int i = 0; i < VL_WORDS_I(obits); ++i) { \ + int msb = ((i + 1) * VL_IDATASIZE) - 1; \ + msb = (msb >= (obits)) ? ((obits)-1) : msb; \ + _butemp.range(msb, i* VL_IDATASIZE) = (rwp)[i]; \ + } \ + (svar).write(_butemp); \ + } + +#ifdef SYSTEMC_VERSION +int sc_main(int, char**) +#else +int main() +#endif +{ + Verilated::debug(0); + tb = new VM_PREFIX("tb"); + + VlWide<8> /*255:0*/ input_var; + VlWide<8> /*255:0*/ out_var; + + // msb is always set to F not to be false positive on checking equality + input_var.m_storage[0] = 0xF2341234; + input_var.m_storage[1] = 0xFEADBEEF; + input_var.m_storage[2] = 0xF5A5A5A5; + input_var.m_storage[3] = 0xF1B2C3D4; + input_var.m_storage[4] = 0xFFFFFFFF; + input_var.m_storage[5] = 0xFAAABBBB; + input_var.m_storage[6] = 0xF000AAAA; + input_var.m_storage[7] = 0xF0101010; + +#ifdef SYSTEMC_VERSION + // clang-format off + sc_signal> SC_NAMED(i_29_s), SC_NAMED(i_29_old_s), SC_NAMED(o_29_s), SC_NAMED(o_29_old_s), + SC_NAMED(i_30_s), SC_NAMED(i_30_old_s), SC_NAMED(o_30_s), SC_NAMED(o_30_old_s), + SC_NAMED(i_31_s), SC_NAMED(i_31_old_s), SC_NAMED(o_31_s), SC_NAMED(o_31_old_s), + SC_NAMED(i_32_s), SC_NAMED(i_32_old_s), SC_NAMED(o_32_s), SC_NAMED(o_32_old_s), + SC_NAMED(i_59_s), SC_NAMED(i_59_old_s), SC_NAMED(o_59_s), SC_NAMED(o_59_old_s), + SC_NAMED(i_60_s), SC_NAMED(i_60_old_s), SC_NAMED(o_60_s), SC_NAMED(o_60_old_s), + SC_NAMED(i_62_s), SC_NAMED(i_62_old_s), SC_NAMED(o_62_s), SC_NAMED(o_62_old_s), + SC_NAMED(i_64_s), SC_NAMED(i_64_old_s), SC_NAMED(o_64_s), SC_NAMED(o_64_old_s), + SC_NAMED(i_119_s), SC_NAMED(i_119_old_s), SC_NAMED(o_119_s), SC_NAMED(o_119_old_s), + SC_NAMED(i_120_s), SC_NAMED(i_120_old_s), SC_NAMED(o_120_s), SC_NAMED(o_120_old_s), + SC_NAMED(i_121_s), SC_NAMED(i_121_old_s), SC_NAMED(o_121_s), SC_NAMED(o_121_old_s), + SC_NAMED(i_127_s), SC_NAMED(i_127_old_s), SC_NAMED(o_127_s), SC_NAMED(o_127_old_s), + SC_NAMED(i_128_s), SC_NAMED(i_128_old_s), SC_NAMED(o_128_s), SC_NAMED(o_128_old_s), + SC_NAMED(i_255_s), SC_NAMED(i_255_old_s), SC_NAMED(o_255_s), SC_NAMED(o_255_old_s), + SC_NAMED(i_256_s), SC_NAMED(i_256_old_s), SC_NAMED(o_256_s), SC_NAMED(o_256_old_s); + + + tb->i_29(i_29_s); tb->i_29_old(i_29_old_s); tb->o_29(o_29_s); tb->o_29_old(o_29_old_s); + tb->i_30(i_30_s); tb->i_30_old(i_30_old_s); tb->o_30(o_30_s); tb->o_30_old(o_30_old_s); + tb->i_31(i_31_s); tb->i_31_old(i_31_old_s); tb->o_31(o_31_s); tb->o_31_old(o_31_old_s); + tb->i_32(i_32_s); tb->i_32_old(i_32_old_s); tb->o_32(o_32_s); tb->o_32_old(o_32_old_s); + tb->i_59(i_59_s); tb->i_59_old(i_59_old_s); tb->o_59(o_59_s); tb->o_59_old(o_59_old_s); + tb->i_60(i_60_s); tb->i_60_old(i_60_old_s); tb->o_60(o_60_s); tb->o_60_old(o_60_old_s); + tb->i_62(i_62_s); tb->i_62_old(i_62_old_s); tb->o_62(o_62_s); tb->o_62_old(o_62_old_s); + tb->i_64(i_64_s); tb->i_64_old(i_64_old_s); tb->o_64(o_64_s); tb->o_64_old(o_64_old_s); + tb->i_119(i_119_s); tb->i_119_old(i_119_old_s); tb->o_119(o_119_s); tb->o_119_old(o_119_old_s); + tb->i_120(i_120_s); tb->i_120_old(i_120_old_s); tb->o_120(o_120_s); tb->o_120_old(o_120_old_s); + tb->i_121(i_121_s); tb->i_121_old(i_121_old_s); tb->o_121(o_121_s); tb->o_121_old(o_121_old_s); + tb->i_127(i_127_s); tb->i_127_old(i_127_old_s); tb->o_127(o_127_s); tb->o_127_old(o_127_old_s); + tb->i_128(i_128_s); tb->i_128_old(i_128_old_s); tb->o_128(o_128_s); tb->o_128_old(o_128_old_s); + tb->i_255(i_255_s); tb->i_255_old(i_255_old_s); tb->o_255(o_255_s); tb->o_255_old(o_255_old_s); + tb->i_256(i_256_s); tb->i_256_old(i_256_old_s); tb->o_256(o_256_s); tb->o_256_old(o_256_old_s); + + // clang-format on + +#endif + +// clang-format off +#ifdef SYSTEMC_VERSION + sc_start(1, SC_NS); +#else + tb->eval(); +#endif + // This testcase is testing multi-thread safe VL_ASSIGN_SBW and VL_ASSIGN_WSB macros. + // Testbench is assigning different number of bits from VlWide input_var variable to different inputs. + // Values around multiple of 30 (i.e. BITS_PER_DIGIT defined in SystemC sc_nbdefs.h) are tested with the special care, since + // it is the value by which the data_ptr of sc_biguint underlying data type is increased by (and not expected 32, as width of uint32_t). + // Correctness of the output is compared against the 'old' macro, which is correct but has multi-threaded issue since it's using range function. + // Second part is testing VL_ASSIGN_WSB in a reverse way, it is reading signals from the previous test, + // and comparing the output with (fraction) of VlWide input_var variable. + + // clang-format on + VL_ASSIGN_SBW(29, i_29_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(29, i_29_old_s, input_var); + VL_ASSIGN_SBW(30, i_30_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(30, i_30_old_s, input_var); + VL_ASSIGN_SBW(31, i_31_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(31, i_31_old_s, input_var); + VL_ASSIGN_SBW(32, i_32_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(32, i_32_old_s, input_var); + VL_ASSIGN_SBW(59, i_59_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(59, i_59_old_s, input_var); + VL_ASSIGN_SBW(60, i_60_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(60, i_60_old_s, input_var); + VL_ASSIGN_SBW(62, i_62_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(62, i_62_old_s, input_var); + VL_ASSIGN_SBW(64, i_64_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(64, i_64_old_s, input_var); + VL_ASSIGN_SBW(119, i_119_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(119, i_119_old_s, input_var); + VL_ASSIGN_SBW(120, i_120_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(120, i_120_old_s, input_var); + VL_ASSIGN_SBW(121, i_121_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(121, i_121_old_s, input_var); + VL_ASSIGN_SBW(127, i_127_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(127, i_127_old_s, input_var); + VL_ASSIGN_SBW(128, i_128_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(128, i_128_old_s, input_var); + VL_ASSIGN_SBW(255, i_255_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(255, i_255_old_s, input_var); + VL_ASSIGN_SBW(256, i_256_s, input_var); + VL_ASSIGN_SBW_MT_ISSUE(256, i_256_old_s, input_var); + +#ifdef SYSTEMC_VERSION + sc_start(1, SC_NS); +#else + tb->eval(); +#endif + compare_signals(o_29_s, o_29_old_s); + compare_signals(o_30_s, o_30_old_s); + compare_signals(o_31_s, o_31_old_s); + compare_signals(o_32_s, o_32_old_s); + compare_signals(o_59_s, o_59_old_s); + compare_signals(o_60_s, o_60_old_s); + compare_signals(o_62_s, o_62_old_s); + compare_signals(o_64_s, o_64_old_s); + compare_signals(o_119_s, o_119_old_s); + compare_signals(o_120_s, o_120_old_s); + compare_signals(o_121_s, o_121_old_s); + compare_signals(o_127_s, o_127_old_s); + compare_signals(o_128_s, o_128_old_s); + compare_signals(o_255_s, o_255_old_s); + compare_signals(o_256_s, o_256_old_s); + + //////////////////////////////// + + VL_ASSIGN_WSB(29, out_var, o_29_s); + compareWls(29, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(30, out_var, o_30_s); + compareWls(30, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(31, out_var, o_31_s); + compareWls(31, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(32, out_var, o_32_s); + compareWls(32, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(59, out_var, o_59_s); + compareWls(59, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(60, out_var, o_60_s); + compareWls(60, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(62, out_var, o_62_s); + compareWls(62, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(64, out_var, o_64_s); + compareWls(64, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(119, out_var, o_119_s); + compareWls(119, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(120, out_var, o_120_s); + compareWls(120, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(121, out_var, o_121_s); + compareWls(121, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(127, out_var, o_127_s); + compareWls(127, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(128, out_var, o_128_s); + compareWls(128, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(255, out_var, o_255_s); + compareWls(255, input_var.data(), out_var.data()); + VL_ASSIGN_WSB(256, out_var, o_256_s); + compareWls(256, input_var.data(), out_var.data()); + + tb->final(); + VL_DO_DANGLING(delete tb, tb); + + if (pass) { + VL_PRINTF("*-* All Finished *-*\n"); + } else { + vl_fatal(__FILE__, __LINE__, "top", "Unexpected results from test\n"); + } + return 0; +} diff --git a/test_regress/t/t_var_sc_bv.pl b/test_regress/t/t_var_sc_bv.pl new file mode 100755 index 000000000..0091e49f0 --- /dev/null +++ b/test_regress/t/t_var_sc_bv.pl @@ -0,0 +1,24 @@ +#!/usr/bin/env perl +if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; } +# DESCRIPTION: Verilator: Verilog Test driver/expect definition +# +# Copyright 2003-2009 by Wilson Snyder. This program is free software; you +# can redistribute it and/or modify it under the terms of either the GNU +# Lesser General Public License Version 3 or the Perl Artistic License +# Version 2.0. +# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0 + +scenarios(vlt_all => 1); + +compile( + make_top_shell => 0, + make_main => 0, + verilator_flags2 => ["--exe $Self->{t_dir}/t_var_sc_bv.cpp --sc -fno-inline"], + ); + +execute( + check_finished => 1, + ); + +ok(1); +1; diff --git a/test_regress/t/t_var_sc_bv.v b/test_regress/t/t_var_sc_bv.v new file mode 100644 index 000000000..d3164ee09 --- /dev/null +++ b/test_regress/t/t_var_sc_bv.v @@ -0,0 +1,246 @@ +// DESCRIPTION: Verilator: Verilog Test module +// +// This file ONLY is placed into the Public Domain, for any use, +// without warranty, 2008 by Lane Brooks. +// SPDX-License-Identifier: CC0-1.0 + +module t (/*AUTOARG*/ + // Outputs + o_29,o_29_old, + o_30,o_30_old, + o_31,o_31_old, + o_32,o_32_old, + o_59,o_59_old, + o_60,o_60_old, + o_62,o_62_old, + o_64,o_64_old, + o_119,o_119_old, + o_120,o_120_old, + o_121,o_121_old, + o_127,o_127_old, + o_128,o_128_old, + o_255,o_255_old, + o_256,o_256_old, + // Inputs + i_29,i_29_old, + i_30,i_30_old, + i_31,i_31_old, + i_32,i_32_old, + i_59,i_59_old, + i_60,i_60_old, + i_62,i_62_old, + i_64,i_64_old, + i_119,i_119_old, + i_120,i_120_old, + i_121,i_121_old, + i_127,i_127_old, + i_128,i_128_old, + i_255,i_255_old, + i_256,i_256_old + ); + input [255:0] i_29; + output wire [255:0] o_29; + input [255:0] i_29_old; + output wire [255:0] o_29_old; + input [255:0] i_30; + output wire [255:0] o_30; + input [255:0] i_30_old; + output wire [255:0] o_30_old; + input [255:0] i_31; + output wire [255:0] o_31; + input [255:0] i_31_old; + output wire [255:0] o_31_old; + input [255:0] i_32; + output wire [255:0] o_32; + input [255:0] i_32_old; + output wire [255:0] o_32_old; + input [255:0] i_59; + output wire [255:0] o_59; + input [255:0] i_59_old; + output wire [255:0] o_59_old; + input [255:0] i_60; + output wire [255:0] o_60; + input [255:0] i_60_old; + output wire [255:0] o_60_old; + input [255:0] i_62; + output wire [255:0] o_62; + input [255:0] i_62_old; + output wire [255:0] o_62_old; + input [255:0] i_64; + output wire [255:0] o_64; + input [255:0] i_64_old; + output wire [255:0] o_64_old; + input [255:0] i_119; + output wire [255:0] o_119; + input [255:0] i_119_old; + output wire [255:0] o_119_old; + input [255:0] i_120; + output wire [255:0] o_120; + input [255:0] i_120_old; + output wire [255:0] o_120_old; + input [255:0] i_121; + output wire [255:0] o_121; + input [255:0] i_121_old; + output wire [255:0] o_121_old; + input [255:0] i_127; + output wire [255:0] o_127; + input [255:0] i_127_old; + output wire [255:0] o_127_old; + input [255:0] i_128; + output wire [255:0] o_128; + input [255:0] i_128_old; + output wire [255:0] o_128_old; + input [255:0] i_255; + output wire [255:0] o_255; + input [255:0] i_255_old; + output wire [255:0] o_255_old; + input [255:0] i_256; + output wire [255:0] o_256; + input [255:0] i_256_old; + output wire [255:0] o_256_old; + + sub sub (.*); +endmodule + +module sub (/*AUTOARG*/ + // Outputs + o_29,o_29_old, + o_30,o_30_old, + o_31,o_31_old, + o_32,o_32_old, + o_59,o_59_old, + o_60,o_60_old, + o_62,o_62_old, + o_64,o_64_old, + o_119,o_119_old, + o_120,o_120_old, + o_121,o_121_old, + o_127,o_127_old, + o_128,o_128_old, + o_255,o_255_old, + o_256,o_256_old, + // Inputs + i_29,i_29_old, + i_30,i_30_old, + i_31,i_31_old, + i_32,i_32_old, + i_59,i_59_old, + i_60,i_60_old, + i_62,i_62_old, + i_64,i_64_old, + i_119,i_119_old, + i_120,i_120_old, + i_121,i_121_old, + i_127,i_127_old, + i_128,i_128_old, + i_255,i_255_old, + i_256,i_256_old + ); + + input [255:0] i_29; + output wire [255:0] o_29; + input [255:0] i_29_old; + output wire [255:0] o_29_old; + input [255:0] i_30; + output wire [255:0] o_30; + input [255:0] i_30_old; + output wire [255:0] o_30_old; + input [255:0] i_31; + output wire [255:0] o_31; + input [255:0] i_31_old; + output wire [255:0] o_31_old; + input [255:0] i_32; + output wire [255:0] o_32; + input [255:0] i_32_old; + output wire [255:0] o_32_old; + input [255:0] i_59; + output wire [255:0] o_59; + input [255:0] i_59_old; + output wire [255:0] o_59_old; + input [255:0] i_60; + output wire [255:0] o_60; + input [255:0] i_60_old; + output wire [255:0] o_60_old; + input [255:0] i_62; + output wire [255:0] o_62; + input [255:0] i_62_old; + output wire [255:0] o_62_old; + input [255:0] i_64; + output wire [255:0] o_64; + input [255:0] i_64_old; + output wire [255:0] o_64_old; + input [255:0] i_119; + output wire [255:0] o_119; + input [255:0] i_119_old; + output wire [255:0] o_119_old; + input [255:0] i_120; + output wire [255:0] o_120; + input [255:0] i_120_old; + output wire [255:0] o_120_old; + input [255:0] i_121; + output wire [255:0] o_121; + input [255:0] i_121_old; + output wire [255:0] o_121_old; + input [255:0] i_127; + output wire [255:0] o_127; + input [255:0] i_127_old; + output wire [255:0] o_127_old; + input [255:0] i_128; + output wire [255:0] o_128; + input [255:0] i_128_old; + output wire [255:0] o_128_old; + input [255:0] i_255; + output wire [255:0] o_255; + input [255:0] i_255_old; + output wire [255:0] o_255_old; + input [255:0] i_256; + output wire [255:0] o_256; + input [255:0] i_256_old; + output wire [255:0] o_256_old; + + assign o_29 = i_29; + assign o_29_old = i_29_old; + + assign o_30 = i_30; + assign o_30_old = i_30_old; + + assign o_31 = i_31; + assign o_31_old = i_31_old; + + assign o_32 = i_32; + assign o_32_old = i_32_old; + + assign o_59 = i_59; + assign o_59_old = i_59_old; + + assign o_60 = i_60; + assign o_60_old = i_60_old; + + assign o_62 = i_62; + assign o_62_old = i_62_old; + + assign o_64 = i_64; + assign o_64_old = i_64_old; + + assign o_119 = i_119; + assign o_119_old = i_119_old; + + assign o_120 = i_120; + assign o_120_old = i_120_old; + + assign o_121 = i_121; + assign o_121_old = i_121_old; + + assign o_127 = i_127; + assign o_127_old = i_127_old; + + assign o_128 = i_128; + assign o_128_old = i_128_old; + + assign o_255 = i_255; + assign o_255_old = i_255_old; + + assign o_256 = i_256; + assign o_256_old = i_256_old; + +endmodule