https://github.com/lsils/benchmarks
Raw File
Tip revision: 7770275a0e07a27b8ea9f65b6a3f767282fb8226 authored by Alessandro Tempia Calvino on 06 June 2023, 12:30:24 UTC
New best results 2023
Tip revision: 7770275
ctrl.v
module top ( 
    \opcode[0] , \opcode[1] , \opcode[2] , \opcode[3] , \opcode[4] ,
    \op_ext[0] , \op_ext[1] ,
    \sel_reg_dst[0] , \sel_reg_dst[1] , \sel_alu_opB[0] , \sel_alu_opB[1] ,
    \alu_op[0] , \alu_op[1] , \alu_op[2] , \alu_op_ext[0] ,
    \alu_op_ext[1] , \alu_op_ext[2] , \alu_op_ext[3] , halt, reg_write,
    sel_pc_opA, sel_pc_opB, beqz, bnez, bgez, bltz, jump, Cin, invA, invB,
    sign, mem_write, sel_wb  );
  input  \opcode[0] , \opcode[1] , \opcode[2] , \opcode[3] , \opcode[4] ,
    \op_ext[0] , \op_ext[1] ;
  output \sel_reg_dst[0] , \sel_reg_dst[1] , \sel_alu_opB[0] ,
    \sel_alu_opB[1] , \alu_op[0] , \alu_op[1] , \alu_op[2] ,
    \alu_op_ext[0] , \alu_op_ext[1] , \alu_op_ext[2] , \alu_op_ext[3] ,
    halt, reg_write, sel_pc_opA, sel_pc_opB, beqz, bnez, bgez, bltz, jump,
    Cin, invA, invB, sign, mem_write, sel_wb;
  wire n35, n36, n37, n38, n39, n40, n41, n42, n43, n44, n45, n46, n47, n48,
    n50, n51, n52, n53, n54, n55, n56, n57, n58, n59, n60, n61, n63, n64,
    n65, n66, n67, n68, n69, n71, n72, n73, n74, n75, n76, n77, n78, n80,
    n81, n82, n83, n84, n85, n86, n87, n88, n89, n90, n91, n92, n93, n94,
    n95, n96, n97, n99, n100, n101, n102, n103, n104, n106, n107, n108,
    n109, n110, n111, n112, n113, n114, n115, n117, n118, n119, n120, n121,
    n123, n124, n125, n126, n127, n128, n129, n131, n132, n134, n135, n136,
    n137, n139, n140, n141, n142, n143, n145, n146, n147, n148, n149, n150,
    n151, n153, n154, n156, n158, n159, n160, n161, n162, n164, n165, n166,
    n167, n169, n170, n171, n173, n174, n175, n177, n179, n180, n181, n182,
    n183, n184, n185, n186, n188, n189, n190, n191, n192, n193, n194, n195,
    n197, n198, n200, n201, n202, n203, n205, n206, n207;
  assign n35 = \opcode[0]  & ~\opcode[1] ;
  assign n36 = \opcode[3]  & \opcode[4] ;
  assign n37 = n35 & n36;
  assign n38 = \opcode[1]  & \opcode[3] ;
  assign n39 = \opcode[4]  & n38;
  assign n40 = ~n37 & ~n39;
  assign n41 = ~\opcode[2]  & ~n40;
  assign n42 = ~\opcode[1]  & \opcode[3] ;
  assign n43 = \opcode[4]  & n42;
  assign n44 = ~\opcode[3]  & ~\opcode[4] ;
  assign n45 = ~n36 & ~n44;
  assign n46 = \opcode[1]  & ~n45;
  assign n47 = ~n43 & ~n46;
  assign n48 = \opcode[2]  & ~n47;
  assign \sel_reg_dst[0]  = n41 | n48;
  assign n50 = ~\opcode[0]  & ~n36;
  assign n51 = ~\opcode[0]  & ~n50;
  assign n52 = ~\opcode[1]  & ~n51;
  assign n53 = ~\opcode[3]  & ~n44;
  assign n54 = \opcode[1]  & ~n53;
  assign n55 = ~n52 & ~n54;
  assign n56 = ~\opcode[2]  & ~n55;
  assign n57 = ~\opcode[3]  & \opcode[4] ;
  assign n58 = ~\opcode[3]  & ~n57;
  assign n59 = \opcode[1]  & ~n58;
  assign n60 = \opcode[1]  & ~n59;
  assign n61 = \opcode[2]  & ~n60;
  assign \sel_reg_dst[1]  = ~n56 & ~n61;
  assign n63 = ~\opcode[0]  & ~n45;
  assign n64 = \opcode[3]  & ~n36;
  assign n65 = \opcode[0]  & ~n64;
  assign n66 = ~n63 & ~n65;
  assign n67 = \opcode[1]  & ~n66;
  assign n68 = ~n52 & ~n67;
  assign n69 = ~\opcode[2]  & ~n68;
  assign \sel_alu_opB[0]  = ~\opcode[2]  & ~n69;
  assign n71 = ~\opcode[0]  & ~\opcode[3] ;
  assign n72 = ~n57 & n71;
  assign n73 = \opcode[0]  & ~n45;
  assign n74 = ~n72 & ~n73;
  assign n75 = ~\opcode[1]  & ~n74;
  assign n76 = ~n54 & ~n75;
  assign n77 = ~\opcode[2]  & ~n76;
  assign n78 = \opcode[2]  & ~n53;
  assign \sel_alu_opB[1]  = ~n77 & ~n78;
  assign n80 = ~\opcode[0]  & \opcode[3] ;
  assign n81 = \opcode[4]  & \op_ext[0] ;
  assign n82 = n80 & n81;
  assign n83 = \opcode[3]  & ~\op_ext[1] ;
  assign n84 = ~n36 & n83;
  assign n85 = \opcode[3]  & ~\op_ext[0] ;
  assign n86 = ~n36 & n85;
  assign n87 = \opcode[3]  & \op_ext[0] ;
  assign n88 = ~n86 & ~n87;
  assign n89 = \op_ext[1]  & ~n88;
  assign n90 = ~n84 & ~n89;
  assign n91 = \opcode[0]  & ~n90;
  assign n92 = ~n82 & ~n91;
  assign n93 = \opcode[1]  & ~n92;
  assign n94 = ~\opcode[2]  & ~n93;
  assign n95 = \opcode[0]  & ~n53;
  assign n96 = \opcode[0]  & ~n95;
  assign n97 = \opcode[2]  & ~n96;
  assign \alu_op[0]  = ~n94 & ~n97;
  assign n99 = \opcode[3]  & \op_ext[1] ;
  assign n100 = ~n84 & ~n99;
  assign n101 = \opcode[1]  & ~n100;
  assign n102 = ~\opcode[2]  & ~n101;
  assign n103 = \opcode[1]  & ~n54;
  assign n104 = \opcode[2]  & ~n103;
  assign \alu_op[1]  = ~n102 & ~n104;
  assign n106 = ~\opcode[1]  & ~n36;
  assign n107 = ~n44 & n106;
  assign n108 = ~n44 & n50;
  assign n109 = \opcode[0]  & ~n58;
  assign n110 = ~n108 & ~n109;
  assign n111 = \opcode[1]  & ~n110;
  assign n112 = ~n107 & ~n111;
  assign n113 = ~\opcode[2]  & ~n112;
  assign n114 = \opcode[2]  & \opcode[3] ;
  assign n115 = \opcode[4]  & n114;
  assign \alu_op[2]  = n113 | n115;
  assign n117 = ~\opcode[1]  & ~\opcode[2] ;
  assign n118 = ~n52 & n117;
  assign n119 = \opcode[1]  & ~n74;
  assign n120 = ~n37 & ~n119;
  assign n121 = \opcode[2]  & ~n120;
  assign \alu_op_ext[0]  = n118 | n121;
  assign n123 = ~\opcode[0]  & ~n53;
  assign n124 = ~\opcode[0]  & ~n123;
  assign n125 = \opcode[1]  & ~n124;
  assign n126 = \opcode[1]  & ~\opcode[2] ;
  assign n127 = ~n125 & n126;
  assign n128 = \opcode[1]  & \opcode[2] ;
  assign n129 = ~n45 & n128;
  assign \alu_op_ext[1]  = n127 | n129;
  assign n131 = ~n106 & ~n125;
  assign n132 = ~\opcode[2]  & ~n131;
  assign \alu_op_ext[2]  = ~n61 & ~n132;
  assign n134 = ~n80 & ~n109;
  assign n135 = \opcode[1]  & ~n134;
  assign n136 = ~\opcode[2]  & ~n107;
  assign n137 = ~n135 & n136;
  assign \alu_op_ext[3]  = ~n78 & ~n137;
  assign n139 = ~\opcode[0]  & ~n58;
  assign n140 = ~\opcode[0]  & ~n139;
  assign n141 = ~\opcode[1]  & ~n140;
  assign n142 = ~\opcode[1]  & ~n141;
  assign n143 = ~\opcode[2]  & ~n142;
  assign halt = ~\opcode[2]  & ~n143;
  assign n145 = ~\opcode[1]  & ~n134;
  assign n146 = ~n59 & ~n145;
  assign n147 = ~\opcode[2]  & ~n146;
  assign n148 = ~\opcode[1]  & \opcode[4] ;
  assign n149 = \opcode[1]  & ~n64;
  assign n150 = ~n148 & ~n149;
  assign n151 = \opcode[2]  & ~n150;
  assign reg_write = n147 | n151;
  assign n153 = \opcode[0]  & ~n109;
  assign n154 = \opcode[2]  & ~n153;
  assign sel_pc_opA = \opcode[2]  & ~n154;
  assign n156 = \opcode[2]  & ~n140;
  assign sel_pc_opB = \opcode[2]  & ~n156;
  assign n158 = ~\opcode[0]  & ~n64;
  assign n159 = ~\opcode[0]  & ~n158;
  assign n160 = ~\opcode[1]  & ~n159;
  assign n161 = ~\opcode[1]  & ~n160;
  assign n162 = \opcode[2]  & ~n161;
  assign beqz = \opcode[2]  & ~n162;
  assign n164 = \opcode[0]  & ~n65;
  assign n165 = ~\opcode[1]  & ~n164;
  assign n166 = ~\opcode[1]  & ~n165;
  assign n167 = \opcode[2]  & ~n166;
  assign bnez = \opcode[2]  & ~n167;
  assign n169 = \opcode[1]  & ~n164;
  assign n170 = \opcode[1]  & ~n169;
  assign n171 = \opcode[2]  & ~n170;
  assign bgez = \opcode[2]  & ~n171;
  assign n173 = \opcode[1]  & ~n159;
  assign n174 = \opcode[1]  & ~n173;
  assign n175 = \opcode[2]  & ~n174;
  assign bltz = \opcode[2]  & ~n175;
  assign n177 = \opcode[2]  & ~n58;
  assign jump = \opcode[2]  & ~n177;
  assign n179 = \opcode[0]  & \opcode[1] ;
  assign n180 = ~n88 & n179;
  assign n181 = n35 & ~n65;
  assign n182 = ~\opcode[2]  & ~n181;
  assign n183 = ~n180 & n182;
  assign n184 = \opcode[1]  & ~n51;
  assign n185 = ~n106 & ~n184;
  assign n186 = \opcode[2]  & ~n185;
  assign Cin = ~n183 & ~n186;
  assign n188 = \op_ext[0]  & n36;
  assign n189 = ~\op_ext[1]  & ~n188;
  assign n190 = ~\op_ext[1]  & ~n189;
  assign n191 = \opcode[0]  & ~n190;
  assign n192 = \opcode[0]  & ~n191;
  assign n193 = \opcode[1]  & ~n192;
  assign n194 = ~n165 & ~n193;
  assign n195 = ~\opcode[2]  & ~n194;
  assign invA = ~\opcode[2]  & ~n195;
  assign n197 = ~n90 & n179;
  assign n198 = ~\opcode[2]  & ~n197;
  assign invB = ~n186 & ~n198;
  assign n200 = ~\opcode[1]  & ~n124;
  assign n201 = \opcode[1]  & ~n96;
  assign n202 = ~n200 & ~n201;
  assign n203 = ~\opcode[2]  & ~n202;
  assign mem_write = ~\opcode[2]  & ~n203;
  assign n205 = ~\opcode[1]  & ~n96;
  assign n206 = ~\opcode[1]  & ~n205;
  assign n207 = ~\opcode[2]  & ~n206;
  assign sel_wb = ~\opcode[2]  & ~n207;
  assign sign = 1'b1;
endmodule


back to top