// ========== Copyright Header Begin ========================================== // // OpenSPARC T1 Processor File: u1.behV // Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved. // DO NOT ALTER OR REMOVE COPYRIGHT NOTICES. // // The above named program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public // License version 2 as published by the Free Software Foundation. // // The above named program is distributed in the hope that it will be // useful, but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // General Public License for more details. // // You should have received a copy of the GNU General Public // License along with this work; if not, write to the Free Software // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. // // ========== Copyright Header End ============================================ //////////////////////////////////////////////////////////////////////// // // basic gates { // //////////////////////////////////////////////////////////////////////// //bw_u1_inv_0p6x // //module bw_u1_inv_0p6x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_1x // //
module bw_u1_inv_1x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_1p4x // // module bw_u1_inv_1p4x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_2x // //
... (truncated) module bw_u1_inv_2x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_3x // //
module bw_u1_inv_3x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_4x // //
... (truncated) module bw_u1_inv_4x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_5x // //
... (truncated) module bw_u1_inv_5x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_8x // //
... (truncated) module bw_u1_inv_8x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_10x // //
... (truncated) module bw_u1_inv_10x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_15x // //
module bw_u1_inv_15x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_20x // //
module bw_u1_inv_20x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_30x // //
module bw_u1_inv_30x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_inv_40x // //
module bw_u1_inv_40x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_invh_15x // //
module bw_u1_invh_15x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_invh_25x // // module bw_u1_invh_25x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_invh_30x // // module bw_u1_invh_30x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_invh_50x // // module bw_u1_invh_50x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_invh_60x // // module bw_u1_invh_60x
( z, a ); output z; input a; assign z = ~( a ); endmodule //bw_u1_nand2_0p4x // // module bw_u1_nand2_0p4x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_0p6x // // module bw_u1_nand2_0p6x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_1x // //
module bw_u1_nand2_1x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_1p4x // // module bw_u1_nand2_1p4x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_2x // //
... (truncated) module bw_u1_nand2_2x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_3x // // module bw_u1_nand2_3x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_4x // //
... (truncated) module bw_u1_nand2_4x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_5x // //
module bw_u1_nand2_5x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_7x // //
module bw_u1_nand2_7x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_10x // //
module bw_u1_nand2_10x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand2_15x // //
module bw_u1_nand2_15x
( z, a, b ); output z; input a; input b; assign z = ~( a & b ); endmodule //bw_u1_nand3_0p4x // // module bw_u1_nand3_0p4x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_0p6x // // module bw_u1_nand3_0p6x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_1x // //
module bw_u1_nand3_1x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_1p4x // // module bw_u1_nand3_1p4x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_2x // //
module bw_u1_nand3_2x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_3x // //
module bw_u1_nand3_3x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_4x // //
module bw_u1_nand3_4x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_5x // //
module bw_u1_nand3_5x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_7x // // module bw_u1_nand3_7x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand3_10x // // module bw_u1_nand3_10x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a & b & c ); endmodule //bw_u1_nand4_0p6x // // module bw_u1_nand4_0p6x
( z, a, b, c, d ); output z; input a; input b; input c; input d; assign z = ~( a & b & c & d ); endmodule //bw_u1_nand4_1x // // module bw_u1_nand4_1x
( z, a, b, c, d ); output z; input a; input b; input c; input d; assign z = ~( a & b & c & d ); endmodule //bw_u1_nand4_1p4x // // module bw_u1_nand4_1p4x
( z, a, b, c, d ); output z; input a; input b; input c; input d; assign z = ~( a & b & c & d ); endmodule //bw_u1_nand4_2x // //
module bw_u1_nand4_2x
( z, a, b, c, d ); output z; input a; input b; input c; input d; assign z = ~( a & b & c & d ); endmodule //bw_u1_nand4_3x // // module bw_u1_nand4_3x
( z, a, b, c, d ); output z; input a; input b; input c; input d; assign z = ~( a & b & c & d ); endmodule //bw_u1_nand4_4x // //
module bw_u1_nand4_4x
( z, a, b, c, d ); output z; input a; input b; input c; input d; assign z = ~( a & b & c & d ); endmodule //bw_u1_nand4_6x // // module bw_u1_nand4_6x
( z, a, b, c, d ); output z; input a; input b; input c; input d; nand( z, a, b,c,d); endmodule //bw_u1_nand4_8x // // module bw_u1_nand4_8x
( z, a, b, c, d ); output z; input a; input b; input c; input d; nand( z, a, b,c,d); endmodule //bw_u1_nor2_0p6x // // module bw_u1_nor2_0p6x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_1x // //
module bw_u1_nor2_1x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_1p4x // // module bw_u1_nor2_1p4x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_2x // //
module bw_u1_nor2_2x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_3x // // module bw_u1_nor2_3x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_4x // //
module bw_u1_nor2_4x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_6x // //
module bw_u1_nor2_6x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_8x // //
module bw_u1_nor2_8x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor2_12x // // module bw_u1_nor2_12x
( z, a, b ); output z; input a; input b; assign z = ~( a | b ); endmodule //bw_u1_nor3_0p6x // // module bw_u1_nor3_0p6x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_1x // //
module bw_u1_nor3_1x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_1p4x // //
module bw_u1_nor3_1p4x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_2x // // module bw_u1_nor3_2x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_3x // //
module bw_u1_nor3_3x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_4x // // module bw_u1_nor3_4x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_6x // // module bw_u1_nor3_6x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_nor3_8x // //
module bw_u1_nor3_8x
( z, a, b, c ); output z; input a; input b; input c; assign z = ~( a | b | c ); endmodule //bw_u1_aoi21_0p4x // // module bw_u1_aoi21_0p4x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 & b2 ) | ( a )); endmodule //bw_u1_aoi21_1x // // module bw_u1_aoi21_1x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 & b2 ) | ( a )); endmodule //bw_u1_aoi21_2x // // module bw_u1_aoi21_2x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 & b2 ) | ( a )); endmodule //bw_u1_aoi21_4x // //
module bw_u1_aoi21_4x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 & b2 ) | ( a )); endmodule //bw_u1_aoi21_8x // // module bw_u1_aoi21_8x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 & b2 ) | ( a )); endmodule //bw_u1_aoi21_12x // // module bw_u1_aoi21_12x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 & b2 ) | ( a )); endmodule //bw_u1_aoi22_0p4x // // module bw_u1_aoi22_0p4x
( z, a1, a2, b1, b2 ); output z; input a1; input a2; input b1; input b2; assign z = ~(( a1 & a2 ) | ( b1 & b2 )); endmodule //bw_u1_aoi22_1x // // module bw_u1_aoi22_1x
( z, b1, b2, a1, a2 ); output z; input b1; input b2; input a1; input a2; assign z = ~(( a1 & a2 ) | ( b1 & b2 )); endmodule //bw_u1_aoi22_2x // //
module bw_u1_aoi22_2x
( z, b1, b2, a1, a2 ); output z; input b1; input b2; input a1; input a2; assign z = ~(( a1 & a2 ) | ( b1 & b2 )); endmodule //bw_u1_aoi22_4x // //
module bw_u1_aoi22_4x
( z, b1, b2, a1, a2 ); output z; input b1; input b2; input a1; input a2; assign z = ~(( a1 & a2 ) | ( b1 & b2 )); endmodule //bw_u1_aoi22_8x // // module bw_u1_aoi22_8x
( z, b1, b2, a1, a2 ); output z; input b1; input b2; input a1; input a2; assign z = ~(( a1 & a2 ) | ( b1 & b2 )); endmodule //bw_u1_aoi211_0p3x // // module bw_u1_aoi211_0p3x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 & c2 ) | (a)| (b)); endmodule //bw_u1_aoi211_1x // // module bw_u1_aoi211_1x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 & c2 ) | (a)| (b)); endmodule //bw_u1_aoi211_2x // // module bw_u1_aoi211_2x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 & c2 ) | (a)| (b)); endmodule //bw_u1_aoi211_4x // // module bw_u1_aoi211_4x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 & c2 ) | (a)| (b)); endmodule //bw_u1_aoi211_8x // // module bw_u1_aoi211_8x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 & c2 ) | (a)| (b)); endmodule //bw_u1_oai21_0p4x // // module bw_u1_oai21_0p4x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 | b2 ) & ( a )); endmodule //bw_u1_oai21_1x // // module bw_u1_oai21_1x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 | b2 ) & ( a )); endmodule //bw_u1_oai21_2x // // module bw_u1_oai21_2x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 | b2 ) & ( a )); endmodule //bw_u1_oai21_4x // //
module bw_u1_oai21_4x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 | b2 ) & ( a )); endmodule //bw_u1_oai21_8x // //
module bw_u1_oai21_8x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 | b2 ) & ( a )); endmodule //bw_u1_oai21_12x // // module bw_u1_oai21_12x
( z, b1, b2, a ); output z; input b1; input b2; input a; assign z = ~(( b1 | b2 ) & ( a )); endmodule //bw_u1_oai22_0p4x // module bw_u1_oai22_0p4x
( z, a1, a2, b1, b2 ); output z; input a1; input a2; input b1; input b2; assign z = ~(( a1 | a2 ) & ( b1 | b2 )); endmodule //bw_u1_oai22_1x // module bw_u1_oai22_1x
( z, a1, a2, b1, b2 ); output z; input a1; input a2; input b1; input b2; assign z = ~(( a1 | a2 ) & ( b1 | b2 )); endmodule //bw_u1_oai22_2x // module bw_u1_oai22_2x
( z, a1, a2, b1, b2 ); output z; input a1; input a2; input b1; input b2; assign z = ~(( a1 | a2 ) & ( b1 | b2 )); endmodule //bw_u1_oai22_4x // module bw_u1_oai22_4x
( z, a1, a2, b1, b2 ); output z; input a1; input a2; input b1; input b2; assign z = ~(( a1 | a2 ) & ( b1 | b2 )); endmodule //bw_u1_oai22_8x // module bw_u1_oai22_8x
( z, a1, a2, b1, b2 ); output z; input a1; input a2; input b1; input b2; assign z = ~(( a1 | a2 ) & ( b1 | b2 )); endmodule //bw_u1_oai211_0p3x // // module bw_u1_oai211_0p3x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b)); endmodule //bw_u1_oai211_1x // // module bw_u1_oai211_1x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b)); endmodule //bw_u1_oai211_2x // // module bw_u1_oai211_2x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b)); endmodule //bw_u1_oai211_4x // // module bw_u1_oai211_4x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b)); endmodule //bw_u1_oai211_8x // // module bw_u1_oai211_8x
( z, c1, c2, b, a ); output z; input c1; input c2; input b; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b)); endmodule //bw_u1_aoi31_1x // // module bw_u1_aoi31_1x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 & b2&b3 ) | ( a )); endmodule //bw_u1_aoi31_2x // // module bw_u1_aoi31_2x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 & b2&b3 ) | ( a )); endmodule //bw_u1_aoi31_4x // // module bw_u1_aoi31_4x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 & b2&b3 ) | ( a )); endmodule //bw_u1_aoi31_8x // //
module bw_u1_aoi31_8x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 & b2&b3 ) | ( a )); endmodule //bw_u1_aoi32_1x // // module bw_u1_aoi32_1x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 & b2&b3 ) | ( a1 & a2 )); endmodule //bw_u1_aoi32_2x // // module bw_u1_aoi32_2x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 & b2&b3 ) | ( a1 & a2 )); endmodule //bw_u1_aoi32_4x // // module bw_u1_aoi32_4x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 & b2&b3 ) | ( a1 & a2 )); endmodule //bw_u1_aoi32_8x // // module bw_u1_aoi32_8x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 & b2&b3 ) | ( a1 & a2 )); endmodule //bw_u1_aoi33_1x // // module bw_u1_aoi33_1x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 & b2&b3 ) | ( a1&a2&a3 )); endmodule //bw_u1_aoi33_2x // // module bw_u1_aoi33_2x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 & b2&b3 ) | ( a1&a2&a3 )); endmodule //bw_u1_aoi33_4x // // module bw_u1_aoi33_4x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 & b2&b3 ) | ( a1&a2&a3 )); endmodule //bw_u1_aoi33_8x // // module bw_u1_aoi33_8x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 & b2&b3 ) | ( a1&a2&a3 )); endmodule //bw_u1_aoi221_1x // // module bw_u1_aoi221_1x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 & c2 ) | (b1&b2)| (a)); endmodule //bw_u1_aoi221_2x // // module bw_u1_aoi221_2x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 & c2 ) | (b1&b2)| (a)); endmodule //bw_u1_aoi221_4x // // module bw_u1_aoi221_4x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 & c2 ) | (b1&b2)| (a)); endmodule //bw_u1_aoi221_8x // // module bw_u1_aoi221_8x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 & c2 ) | (b1&b2)| (a)); endmodule //bw_u1_aoi222_1x // // module bw_u1_aoi222_1x
( z, a1, a2, b1, b2, c1, c2 ); output z; input a1; input a2; input b1; input b2; input c1; input c2; assign z = ~(( c1 & c2 ) | (b1&b2)| (a1& a2)); endmodule //bw_u1_aoi222_2x // // module bw_u1_aoi222_2x
( z, a1, a2, b1, b2, c1, c2 ); output z; input a1; input a2; input b1; input b2; input c1; input c2; assign z = ~(( c1 & c2 ) | (b1&b2)| (a1& a2)); endmodule //bw_u1_aoi222_4x // // module bw_u1_aoi222_4x
( z, a1, a2, b1, b2, c1, c2 ); output z; input a1; input a2; input b1; input b2; input c1; input c2; assign z = ~(( c1 & c2 ) | (b1&b2)| (a1& a2)); endmodule //bw_u1_aoi311_1x // // module bw_u1_aoi311_1x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 & c2& c3 ) | (a)| (b)); endmodule //bw_u1_aoi311_2x // // module bw_u1_aoi311_2x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 & c2& c3 ) | (a)| (b)); endmodule //bw_u1_aoi311_4x // // module bw_u1_aoi311_4x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 & c2& c3 ) | (a)| (b)); endmodule //bw_u1_aoi311_8x // // module bw_u1_aoi311_8x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 & c2& c3 ) | (a)| (b)); endmodule //bw_u1_oai31_1x // // module bw_u1_oai31_1x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 | b2|b3 ) & ( a )); endmodule //bw_u1_oai31_2x // // module bw_u1_oai31_2x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 | b2|b3 ) & ( a )); endmodule //bw_u1_oai31_4x // // module bw_u1_oai31_4x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 | b2|b3 ) & ( a )); endmodule //bw_u1_oai31_8x // // module bw_u1_oai31_8x
( z, b1, b2, b3, a ); output z; input b1; input b2; input b3; input a; assign z = ~(( b1 | b2|b3 ) & ( a )); endmodule //bw_u1_oai32_1x // // module bw_u1_oai32_1x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 | b2 | b3 ) & ( a1 | a2 )); endmodule //bw_u1_oai32_2x // // module bw_u1_oai32_2x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 | b2 | b3 ) & ( a1 | a2 )); endmodule //bw_u1_oai32_4x // // module bw_u1_oai32_4x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 | b2 | b3 ) & ( a1 | a2 )); endmodule //bw_u1_oai32_8x // // module bw_u1_oai32_8x
( z, b1, b2, b3, a1, a2 ); output z; input b1; input b2; input b3; input a1; input a2; assign z = ~(( b1 | b2 | b3 ) & ( a1 | a2 )); endmodule //bw_u1_oai33_1x // // module bw_u1_oai33_1x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 | b2|b3 ) & ( a1|a2|a3 )); endmodule //bw_u1_oai33_2x // // module bw_u1_oai33_2x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 | b2|b3 ) & ( a1|a2|a3 )); endmodule //bw_u1_oai33_4x // // module bw_u1_oai33_4x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 | b2|b3 ) & ( a1|a2|a3 )); endmodule //bw_u1_oai33_8x // // module bw_u1_oai33_8x
( z, b1, b2, b3, a1, a2, a3 ); output z; input b1; input b2; input b3; input a1; input a2; input a3; assign z = ~(( b1 | b2|b3 ) & ( a1|a2|a3 )); endmodule //bw_u1_oai221_1x // // module bw_u1_oai221_1x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b1|b2)); endmodule //bw_u1_oai221_2x // // module bw_u1_oai221_2x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b1|b2)); endmodule //bw_u1_oai221_4x // // module bw_u1_oai221_4x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b1|b2)); endmodule //bw_u1_oai221_8x // // module bw_u1_oai221_8x
( z, c1, c2, b1, b2, a ); output z; input c1; input c2; input b1; input b2; input a; assign z = ~(( c1 | c2 ) & ( a ) & (b1|b2)); endmodule //bw_u1_oai222_1x // // module bw_u1_oai222_1x
( z, c1, c2, b1, b2, a1, a2 ); output z; input c1; input c2; input b1; input b2; input a1; input a2; assign z = ~(( c1 | c2 ) & ( a1|a2 ) & (b1|b2)); endmodule //bw_u1_oai222_2x // // module bw_u1_oai222_2x
( z, c1, c2, b1, b2, a1, a2 ); output z; input c1; input c2; input b1; input b2; input a1; input a2; assign z = ~(( c1 | c2 ) & ( a1|a2 ) & (b1|b2)); endmodule //bw_u1_oai222_4x // // module bw_u1_oai222_4x
( z, c1, c2, b1, b2, a1, a2 ); output z; input c1; input c2; input b1; input b2; input a1; input a2; assign z = ~(( c1 | c2 ) & ( a1|a2 ) & (b1|b2)); endmodule //bw_u1_oai311_1x // // module bw_u1_oai311_1x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 | c2|c3 ) & ( a ) & (b)); endmodule //bw_u1_oai311_2x // // module bw_u1_oai311_2x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 | c2|c3 ) & ( a ) & (b)); endmodule //bw_u1_oai311_4x // // module bw_u1_oai311_4x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 | c2 | c3 ) & ( a ) & (b)); endmodule //bw_u1_oai311_8x // // module bw_u1_oai311_8x
( z, c1, c2, c3, b, a ); output z; input c1; input c2; input c3; input b; input a; assign z = ~(( c1 | c2|c3 ) & ( a ) & (b)); endmodule //bw_u1_muxi21_0p6x
module bw_u1_muxi21_0p6x
(z, d0, d1, s); output z; input d0, d1, s; assign z = s ? ~d1 : ~d0; endmodule //bw_u1_muxi21_1x
module bw_u1_muxi21_1x
(z, d0, d1, s); output z; input d0, d1, s; assign z = s ? ~d1 : ~d0; endmodule //bw_u1_muxi21_2x
module bw_u1_muxi21_2x
(z, d0, d1, s); output z; input d0, d1, s; assign z = s ? ~d1 : ~d0; endmodule //bw_u1_muxi21_4x
module bw_u1_muxi21_4x
(z, d0, d1, s); output z; input d0, d1, s; assign z = s ? ~d1 : ~d0; endmodule //bw_u1_muxi21_6x
module bw_u1_muxi21_6x
(z, d0, d1, s); output z; input d0, d1, s; assign z = s ? ~d1 : ~d0; endmodule //bw_u1_muxi31d_4x //
module bw_u1_muxi31d_4x
(z, d0, d1, d2, s0, s1, s2); output z; input d0, d1, d2, s0, s1, s2; zmuxi31d_prim i0 ( z, d0, d1, d2, s0, s1, s2 ); endmodule //bw_u1_muxi41d_4x //
module bw_u1_muxi41d_4x
(z, d0, d1, d2, d3, s0, s1, s2, s3); output z; input d0, d1, d2, d3, s0, s1, s2, s3; zmuxi41d_prim i0 ( z, d0, d1, d2, d3, s0, s1, s2, s3 ); endmodule //bw_u1_muxi41d_6x //
module bw_u1_muxi41d_6x
(z, d0, d1, d2, d3, s0, s1, s2, s3); output z; input d0, d1, d2, d3, s0, s1, s2, s3; zmuxi41d_prim i0 ( z, d0, d1, d2, d3, s0, s1, s2, s3 ); endmodule //bw_u1_xor2_0p6x // // module bw_u1_xor2_0p6x
( z, a, b ); output z; input a; input b; assign z = ( a ^ b ); endmodule //bw_u1_xor2_1x // // module bw_u1_xor2_1x
( z, a, b ); output z; input a; input b; assign z = ( a ^ b ); endmodule //bw_u1_xor2_2x // //
module bw_u1_xor2_2x
( z, a, b ); output z; input a; input b; assign z = ( a ^ b ); endmodule //bw_u1_xor2_4x // //
module bw_u1_xor2_4x
( z, a, b ); output z; input a; input b; assign z = ( a ^ b ); endmodule //bw_u1_xnor2_0p6x // // module bw_u1_xnor2_0p6x
( z, a, b ); output z; input a; input b; assign z = ~( a ^ b ); endmodule //bw_u1_xnor2_1x // // module bw_u1_xnor2_1x
( z, a, b ); output z; input a; input b; assign z = ~( a ^ b ); endmodule //bw_u1_xnor2_2x // //
module bw_u1_xnor2_2x
( z, a, b ); output z; input a; input b; assign z = ~( a ^ b ); endmodule //bw_u1_xnor2_4x // // module bw_u1_xnor2_4x
( z, a, b ); output z; input a; input b; assign z = ~( a ^ b ); endmodule //bw_u1_buf_1x //
module bw_u1_buf_1x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_buf_5x //
module bw_u1_buf_5x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_buf_10x //
module bw_u1_buf_10x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_buf_15x //
... (truncated) module bw_u1_buf_15x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_buf_20x //
module bw_u1_buf_20x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_buf_30x //
... (truncated) module bw_u1_buf_30x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_buf_40x //
module bw_u1_buf_40x
( z, a ); output z; input a; assign z = ( a ); endmodule //bw_u1_ao2222_1x // // module bw_u1_ao2222_1x
( z, a1, a2, b1, b2, c1, c2, d1, d2 ); output z; input a1; input a2; input b1; input b2; input c1; input c2; input d1; input d2; assign z = ((d1&d2) | ( c1 & c2 ) | (b1&b2)| (a1& a2)); endmodule //bw_u1_ao2222_2x // // module bw_u1_ao2222_2x
( z, a1, a2, b1, b2, c1, c2, d1, d2 ); output z; input a1; input a2; input b1; input b2; input c1; input c2; input d1; input d2; assign z = ((d1&d2) | ( c1 & c2 ) | (b1&b2)| (a1& a2)); endmodule //bw_u1_ao2222_4x // // module bw_u1_ao2222_4x
( z, a1, a2, b1, b2, c1, c2, d1, d2 ); output z; input a1; input a2; input b1; input b2; input c1; input c2; input d1; input d2; assign z = ((d1&d2) | ( c1 & c2 ) | (b1&b2)| (a1& a2)); endmodule //////////////////////////////////////////////////////////////////////// // // flipflops { // //////////////////////////////////////////////////////////////////////// // scanable D-flipflop with scanout
module bw_u1_soff_1x
(q, so, ck, d, se, sd); output q, so; input ck, d, se, sd; zsoff_prim i0 ( q, so, ck, d, se, sd ); endmodule
module bw_u1_soff_2x
(q, so, ck, d, se, sd); output q, so; input ck, d, se, sd; zsoff_prim i0 ( q, so, ck, d, se, sd ); endmodule
module bw_u1_soff_4x
(q, so, ck, d, se, sd); output q, so; input ck, d, se, sd; zsoff_prim i0 ( q, so, ck, d, se, sd ); endmodule
module bw_u1_soff_8x
(q, so, ck, d, se, sd); output q, so; input ck, d, se, sd; zsoff_prim i0 ( q, so, ck, d, se, sd ); endmodule // fast scanable D-flipflop with scanout with inverted Q output
module bw_u1_soffi_4x
(q_l, so, ck, d, se, sd); output q_l, so; input ck, d, se, sd; zsoffi_prim i0 ( q_l, so, ck, d, se, sd ); endmodule
module bw_u1_soffi_8x
(q_l, so, ck, d, se, sd); output q_l, so; input ck, d, se, sd; zsoffi_prim i0 ( q_l, so, ck, d, se, sd ); endmodule // scanable D-flipflop with scanout with 2-to-1 input mux
module bw_u1_soffm2_4x
(q, so, ck, d0, d1, s, se, sd); output q, so; input ck, d0, d1, s, se, sd; zsoffm2_prim i0 ( q, so, ck, d0, d1, s, se, sd ); endmodule
module bw_u1_soffm2_8x
(q, so, ck, d0, d1, s, se, sd); output q, so; input ck, d0, d1, s, se, sd; zsoffm2_prim i0 ( q, so, ck, d0, d1, s, se, sd ); endmodule // scanable D-flipflop with scanout with sync reset-bar
module bw_u1_soffr_2x
(q, so, ck, d, se, sd, r_l); output q, so; input ck, d, se, sd, r_l; zsoffr_prim i0 ( q, so, ck, d, se, sd, r_l ); endmodule
... (truncated) module bw_u1_soffr_4x
(q, so, ck, d, se, sd, r_l); output q, so; input ck, d, se, sd, r_l; zsoffr_prim i0 ( q, so, ck, d, se, sd, r_l ); endmodule
module bw_u1_soffr_8x
(q, so, ck, d, se, sd, r_l); output q, so; input ck, d, se, sd, r_l; zsoffr_prim i0 ( q, so, ck, d, se, sd, r_l ); endmodule //bw_u1_soffasr_2x
... (truncated) module bw_u1_soffasr_2x
(q, so, ck, d, r_l, s_l, se, sd); output q, so; input ck, d, r_l, s_l, se, sd; zsoffasr_prim i0 (q, so, ck, d, r_l, s_l, se, sd); endmodule //bw_u1_ckbuf_1p5x
module bw_u1_ckbuf_1p5x
(clk, rclk); output clk; input rclk; buf (clk, rclk); endmodule //bw_u1_ckbuf_3x module bw_u1_ckbuf_3x
(clk, rclk); output clk; input rclk; buf (clk, rclk); endmodule //bw_u1_ckbuf_4p5x module bw_u1_ckbuf_4p5x
(clk, rclk); output clk; input rclk; buf (clk, rclk); endmodule //bw_u1_ckbuf_6x
module bw_u1_ckbuf_6x
(clk, rclk); output clk; input rclk; buf (clk, rclk); endmodule //bw_u1_ckbuf_7x // module bw_u1_ckbuf_7x
(clk, rclk); output clk; input rclk; buf (clk, rclk); endmodule //bw_u1_ckbuf_8x // module bw_u1_ckbuf_8x
(clk, rclk); output clk; input rclk; buf (clk, rclk); endmodule //bw_u1_ckbuf_11x //
module bw_u1_ckbuf_11x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_14x // module bw_u1_ckbuf_14x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_17x // module bw_u1_ckbuf_17x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_19x //
module bw_u1_ckbuf_19x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_22x // module bw_u1_ckbuf_22x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_25x // module bw_u1_ckbuf_25x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_28x //
module bw_u1_ckbuf_28x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_30x //
module bw_u1_ckbuf_30x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_33x //
module bw_u1_ckbuf_33x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule //bw_u1_ckbuf_40x //
module bw_u1_ckbuf_40x
(clk, rclk); output clk; input rclk; assign clk = ( rclk ); endmodule // gated clock buffers
module bw_u1_ckenbuf_6x
(clk, rclk, en_l, tm_l); output clk; input rclk, en_l, tm_l; zckenbuf_prim i0 ( clk, rclk, en_l, tm_l ); endmodule
module bw_u1_ckenbuf_14x
(clk, rclk, en_l, tm_l); output clk; input rclk, en_l, tm_l; zckenbuf_prim i0 ( clk, rclk, en_l, tm_l ); endmodule //////////////////////////////////////////////////////////////////////// // // half cells // //////////////////////////////////////////////////////////////////////// module bw_u1_zhinv_0p6x
(z, a); output z; input a; not (z, a); endmodule module bw_u1_zhinv_1x
(z, a); output z; input a; not (z, a); endmodule module bw_u1_zhinv_1p4x
(z, a); output z; input a; not (z, a); endmodule module bw_u1_zhinv_2x
(z, a); output z; input a; not (z, a); endmodule module bw_u1_zhinv_3x
(z, a); output z; input a; not (z, a); endmodule module bw_u1_zhinv_4x
(z, a); output z; input a; not (z, a); endmodule module bw_u1_zhnand2_0p4x
(z, a, b); output z; input a, b; nand (z, a, b); endmodule module bw_u1_zhnand2_0p6x
(z, a, b); output z; input a, b; nand (z, a, b); endmodule module bw_u1_zhnand2_1x
(z, a, b); output z; input a, b; nand (z, a, b); endmodule module bw_u1_zhnand2_1p4x
(z, a, b); output z; input a, b; nand (z, a, b); endmodule module bw_u1_zhnand2_2x
(z, a, b); output z; input a, b; nand (z, a, b); endmodule module bw_u1_zhnand2_3x
(z, a, b); output z; input a, b; nand (z, a, b); endmodule module bw_u1_zhnand3_0p6x
(z, a, b, c); output z; input a, b, c; nand (z, a, b, c); endmodule module bw_u1_zhnand3_1x
(z, a, b, c); output z; input a, b, c; nand (z, a, b, c); endmodule module bw_u1_zhnand3_2x
(z, a, b, c); output z; input a, b, c; nand (z, a, b, c); endmodule module bw_u1_zhnand4_0p6x
(z, a, b, c, d); output z; input a, b, c, d; nand (z, a, b, c, d); endmodule module bw_u1_zhnand4_1x
(z, a, b, c, d); output z; input a, b, c, d; nand (z, a, b, c, d); endmodule module bw_u1_zhnand4_2x
(z, a, b, c, d); output z; input a, b, c, d; nand (z, a, b, c, d); endmodule module bw_u1_zhnor2_0p6x
(z, a, b); output z; input a, b; nor (z, a, b); endmodule module bw_u1_zhnor2_1x
(z, a, b); output z; input a, b; nor (z, a, b); endmodule module bw_u1_zhnor2_2x
(z, a, b); output z; input a, b; nor (z, a, b); endmodule module bw_u1_zhnor3_0p6x
(z, a, b, c); output z; input