blob: ab3423a35e04b29faba7b321462ed38cf0ecc8f1 [file]
/*
* Copyright (C) 2020 The SymbiFlow Authors.
*
* Use of this source code is governed by a ISC-style
* license that can be found in the LICENSE file or at
* https://opensource.org/licenses/ISC
*
* SPDX-License-Identifier: ISC
*/
`include "../vtr/full-adder/adder.sim.v"
module MULTIPLE_INSTANCE (a, b, c, d, cin, cout, sum);
localparam DATA_WIDTH = 4;
input wire [DATA_WIDTH-1:0] a;
input wire [DATA_WIDTH-1:0] b;
input wire [DATA_WIDTH-1:0] c;
input wire [DATA_WIDTH-1:0] d;
output wire [DATA_WIDTH*2-1:0] sum;
input wire [DATA_WIDTH-1:0] cin;
output wire [DATA_WIDTH-1:0] cout;
wire [DATA_WIDTH-1:0] a2b;
genvar i;
/* n = 0..DATA_WIDTH
*
* cin[n]
* ↓
* a[n] + b[n] → sum[n]
* ↓
* c[n] + d[n] → sum[4+n]
* ↓
* cout[n]
*/
for(i=0; i<DATA_WIDTH; i=i+1) begin
ADDER comb_apb (.a(a[i]), .b(b[i]), .cin(cin[i]), .cout(a2b[i]), .sum(sum[i]));
ADDER comb_cpd (.a(c[i]), .b(d[i]), .cin(a2b[i]), .cout(cout[i]), .sum(sum[DATA_WIDTH+i]));
end
endmodule