diff options
author | Patrick Urban <patrick.urban@web.de> | 2021-09-24 16:00:59 +0200 |
---|---|---|
committer | Marcelina KoĆcielnicka <mwk@0x04.net> | 2021-11-13 21:53:25 +0100 |
commit | 0a72952d5f259a23f9d1122d936d3d4d60ce224d (patch) | |
tree | 45c12931e95aade5618088a70d2f0187bd1fdeb2 /techlibs | |
parent | cfcc38582a4464b0a0551b842ea7a22c6f9a559d (diff) | |
download | yosys-0a72952d5f259a23f9d1122d936d3d4d60ce224d.tar.gz yosys-0a72952d5f259a23f9d1122d936d3d4d60ce224d.tar.bz2 yosys-0a72952d5f259a23f9d1122d936d3d4d60ce224d.zip |
synth_gatemate: Apply review remarks
* remove unused techmap models in `map_regs.v`
* replace RAM initilization loops with 320-bit-writes
* add script to test targets in top-level Makefile
* remove `MAXWIDTH` parameter and treat both vector widths individually in `mult_map.v`
* iterate over all modules in `gatemate_bramopt` pass
Diffstat (limited to 'techlibs')
-rw-r--r-- | techlibs/gatemate/cells_sim.v | 392 | ||||
-rw-r--r-- | techlibs/gatemate/gatemate_bramopt.cc | 12 | ||||
-rw-r--r-- | techlibs/gatemate/mul_map.v | 23 | ||||
-rw-r--r-- | techlibs/gatemate/reg_map.v | 61 | ||||
-rw-r--r-- | techlibs/gatemate/synth_gatemate.cc | 2 |
5 files changed, 211 insertions, 279 deletions
diff --git a/techlibs/gatemate/cells_sim.v b/techlibs/gatemate/cells_sim.v index 1f6d9d5ef..0c9287b81 100644 --- a/techlibs/gatemate/cells_sim.v +++ b/techlibs/gatemate/cells_sim.v @@ -294,7 +294,7 @@ module CC_DFF #( assign en = (EN_INV) ? ~EN : EN;
assign sr = (SR_INV) ? ~SR : SR;
- initial Q = 1'bX;
+ initial Q = 1'b0;
always @(posedge clk or posedge sr)
begin
@@ -323,7 +323,7 @@ module CC_DLT #( assign en = (G_INV) ? ~G : G;
assign sr = (SR_INV) ? ~SR : SR;
- initial Q = 1'bX;
+ initial Q = 1'b0;
always @(*)
begin
@@ -675,72 +675,70 @@ module CC_BRAM_20K ( $finish();
end
// RAM initialization
- for (i=0; i < 320; i=i+1) begin
- memory[320*0+i] = INIT_00[i];
- memory[320*1+i] = INIT_01[i];
- memory[320*2+i] = INIT_02[i];
- memory[320*3+i] = INIT_03[i];
- memory[320*4+i] = INIT_04[i];
- memory[320*5+i] = INIT_05[i];
- memory[320*6+i] = INIT_06[i];
- memory[320*7+i] = INIT_07[i];
- memory[320*8+i] = INIT_08[i];
- memory[320*9+i] = INIT_09[i];
- memory[320*10+i] = INIT_0A[i];
- memory[320*11+i] = INIT_0B[i];
- memory[320*12+i] = INIT_0C[i];
- memory[320*13+i] = INIT_0D[i];
- memory[320*14+i] = INIT_0E[i];
- memory[320*15+i] = INIT_0F[i];
- memory[320*16+i] = INIT_10[i];
- memory[320*17+i] = INIT_11[i];
- memory[320*18+i] = INIT_12[i];
- memory[320*19+i] = INIT_13[i];
- memory[320*20+i] = INIT_14[i];
- memory[320*21+i] = INIT_15[i];
- memory[320*22+i] = INIT_16[i];
- memory[320*23+i] = INIT_17[i];
- memory[320*24+i] = INIT_18[i];
- memory[320*25+i] = INIT_19[i];
- memory[320*26+i] = INIT_1A[i];
- memory[320*27+i] = INIT_1B[i];
- memory[320*28+i] = INIT_1C[i];
- memory[320*29+i] = INIT_1D[i];
- memory[320*30+i] = INIT_1E[i];
- memory[320*31+i] = INIT_1F[i];
- memory[320*32+i] = INIT_20[i];
- memory[320*33+i] = INIT_21[i];
- memory[320*34+i] = INIT_22[i];
- memory[320*35+i] = INIT_23[i];
- memory[320*36+i] = INIT_24[i];
- memory[320*37+i] = INIT_25[i];
- memory[320*38+i] = INIT_26[i];
- memory[320*39+i] = INIT_27[i];
- memory[320*30+i] = INIT_28[i];
- memory[320*41+i] = INIT_29[i];
- memory[320*42+i] = INIT_2A[i];
- memory[320*43+i] = INIT_2B[i];
- memory[320*44+i] = INIT_2C[i];
- memory[320*45+i] = INIT_2D[i];
- memory[320*46+i] = INIT_2E[i];
- memory[320*47+i] = INIT_2F[i];
- memory[320*48+i] = INIT_30[i];
- memory[320*49+i] = INIT_31[i];
- memory[320*50+i] = INIT_32[i];
- memory[320*51+i] = INIT_33[i];
- memory[320*52+i] = INIT_34[i];
- memory[320*53+i] = INIT_35[i];
- memory[320*54+i] = INIT_36[i];
- memory[320*55+i] = INIT_37[i];
- memory[320*56+i] = INIT_38[i];
- memory[320*57+i] = INIT_39[i];
- memory[320*58+i] = INIT_3A[i];
- memory[320*59+i] = INIT_3B[i];
- memory[320*60+i] = INIT_3C[i];
- memory[320*61+i] = INIT_3D[i];
- memory[320*62+i] = INIT_3E[i];
- memory[320*63+i] = INIT_3F[i];
- end
+ memory[320*0+319:320*0] = INIT_00;
+ memory[320*1+319:320*1] = INIT_01;
+ memory[320*2+319:320*2] = INIT_02;
+ memory[320*3+319:320*3] = INIT_03;
+ memory[320*4+319:320*4] = INIT_04;
+ memory[320*5+319:320*5] = INIT_05;
+ memory[320*6+319:320*6] = INIT_06;
+ memory[320*7+319:320*7] = INIT_07;
+ memory[320*8+319:320*8] = INIT_08;
+ memory[320*9+319:320*9] = INIT_09;
+ memory[320*10+319:320*10] = INIT_0A;
+ memory[320*11+319:320*11] = INIT_0B;
+ memory[320*12+319:320*12] = INIT_0C;
+ memory[320*13+319:320*13] = INIT_0D;
+ memory[320*14+319:320*14] = INIT_0E;
+ memory[320*15+319:320*15] = INIT_0F;
+ memory[320*16+319:320*16] = INIT_10;
+ memory[320*17+319:320*17] = INIT_11;
+ memory[320*18+319:320*18] = INIT_12;
+ memory[320*19+319:320*19] = INIT_13;
+ memory[320*20+319:320*20] = INIT_14;
+ memory[320*21+319:320*21] = INIT_15;
+ memory[320*22+319:320*22] = INIT_16;
+ memory[320*23+319:320*23] = INIT_17;
+ memory[320*24+319:320*24] = INIT_18;
+ memory[320*25+319:320*25] = INIT_19;
+ memory[320*26+319:320*26] = INIT_1A;
+ memory[320*27+319:320*27] = INIT_1B;
+ memory[320*28+319:320*28] = INIT_1C;
+ memory[320*29+319:320*29] = INIT_1D;
+ memory[320*30+319:320*30] = INIT_1E;
+ memory[320*31+319:320*31] = INIT_1F;
+ memory[320*32+319:320*32] = INIT_20;
+ memory[320*33+319:320*33] = INIT_21;
+ memory[320*34+319:320*34] = INIT_22;
+ memory[320*35+319:320*35] = INIT_23;
+ memory[320*36+319:320*36] = INIT_24;
+ memory[320*37+319:320*37] = INIT_25;
+ memory[320*38+319:320*38] = INIT_26;
+ memory[320*39+319:320*39] = INIT_27;
+ memory[320*40+319:320*40] = INIT_28;
+ memory[320*41+319:320*41] = INIT_29;
+ memory[320*42+319:320*42] = INIT_2A;
+ memory[320*43+319:320*43] = INIT_2B;
+ memory[320*44+319:320*44] = INIT_2C;
+ memory[320*45+319:320*45] = INIT_2D;
+ memory[320*46+319:320*46] = INIT_2E;
+ memory[320*47+319:320*47] = INIT_2F;
+ memory[320*48+319:320*48] = INIT_30;
+ memory[320*49+319:320*49] = INIT_31;
+ memory[320*50+319:320*50] = INIT_32;
+ memory[320*51+319:320*51] = INIT_33;
+ memory[320*52+319:320*52] = INIT_34;
+ memory[320*53+319:320*53] = INIT_35;
+ memory[320*54+319:320*54] = INIT_36;
+ memory[320*55+319:320*55] = INIT_37;
+ memory[320*56+319:320*56] = INIT_38;
+ memory[320*57+319:320*57] = INIT_39;
+ memory[320*58+319:320*58] = INIT_3A;
+ memory[320*59+319:320*59] = INIT_3B;
+ memory[320*60+319:320*60] = INIT_3C;
+ memory[320*61+319:320*61] = INIT_3D;
+ memory[320*62+319:320*62] = INIT_3E;
+ memory[320*63+319:320*63] = INIT_3F;
end
// Signal inversion
@@ -1163,136 +1161,134 @@ module CC_BRAM_40K ( $finish();
end
// RAM initialization
- for (i=0; i < 320; i=i+1) begin
- memory[320*0+i] = INIT_00[i];
- memory[320*1+i] = INIT_01[i];
- memory[320*2+i] = INIT_02[i];
- memory[320*3+i] = INIT_03[i];
- memory[320*4+i] = INIT_04[i];
- memory[320*5+i] = INIT_05[i];
- memory[320*6+i] = INIT_06[i];
- memory[320*7+i] = INIT_07[i];
- memory[320*8+i] = INIT_08[i];
- memory[320*9+i] = INIT_09[i];
- memory[320*10+i] = INIT_0A[i];
- memory[320*11+i] = INIT_0B[i];
- memory[320*12+i] = INIT_0C[i];
- memory[320*13+i] = INIT_0D[i];
- memory[320*14+i] = INIT_0E[i];
- memory[320*15+i] = INIT_0F[i];
- memory[320*16+i] = INIT_10[i];
- memory[320*17+i] = INIT_11[i];
- memory[320*18+i] = INIT_12[i];
- memory[320*19+i] = INIT_13[i];
- memory[320*20+i] = INIT_14[i];
- memory[320*21+i] = INIT_15[i];
- memory[320*22+i] = INIT_16[i];
- memory[320*23+i] = INIT_17[i];
- memory[320*24+i] = INIT_18[i];
- memory[320*25+i] = INIT_19[i];
- memory[320*26+i] = INIT_1A[i];
- memory[320*27+i] = INIT_1B[i];
- memory[320*28+i] = INIT_1C[i];
- memory[320*29+i] = INIT_1D[i];
- memory[320*30+i] = INIT_1E[i];
- memory[320*31+i] = INIT_1F[i];
- memory[320*32+i] = INIT_20[i];
- memory[320*33+i] = INIT_21[i];
- memory[320*34+i] = INIT_22[i];
- memory[320*35+i] = INIT_23[i];
- memory[320*36+i] = INIT_24[i];
- memory[320*37+i] = INIT_25[i];
- memory[320*38+i] = INIT_26[i];
- memory[320*39+i] = INIT_27[i];
- memory[320*30+i] = INIT_28[i];
- memory[320*41+i] = INIT_29[i];
- memory[320*42+i] = INIT_2A[i];
- memory[320*43+i] = INIT_2B[i];
- memory[320*44+i] = INIT_2C[i];
- memory[320*45+i] = INIT_2D[i];
- memory[320*46+i] = INIT_2E[i];
- memory[320*47+i] = INIT_2F[i];
- memory[320*48+i] = INIT_30[i];
- memory[320*49+i] = INIT_31[i];
- memory[320*50+i] = INIT_32[i];
- memory[320*51+i] = INIT_33[i];
- memory[320*52+i] = INIT_34[i];
- memory[320*53+i] = INIT_35[i];
- memory[320*54+i] = INIT_36[i];
- memory[320*55+i] = INIT_37[i];
- memory[320*56+i] = INIT_38[i];
- memory[320*57+i] = INIT_39[i];
- memory[320*58+i] = INIT_3A[i];
- memory[320*59+i] = INIT_3B[i];
- memory[320*60+i] = INIT_3C[i];
- memory[320*61+i] = INIT_3D[i];
- memory[320*62+i] = INIT_3E[i];
- memory[320*63+i] = INIT_3F[i];
- memory[320*64+i] = INIT_40[i];
- memory[320*65+i] = INIT_41[i];
- memory[320*66+i] = INIT_42[i];
- memory[320*67+i] = INIT_43[i];
- memory[320*68+i] = INIT_44[i];
- memory[320*69+i] = INIT_45[i];
- memory[320*70+i] = INIT_46[i];
- memory[320*71+i] = INIT_47[i];
- memory[320*72+i] = INIT_48[i];
- memory[320*73+i] = INIT_49[i];
- memory[320*74+i] = INIT_4A[i];
- memory[320*75+i] = INIT_4B[i];
- memory[320*76+i] = INIT_4C[i];
- memory[320*77+i] = INIT_4D[i];
- memory[320*78+i] = INIT_4E[i];
- memory[320*79+i] = INIT_4F[i];
- memory[320*80+i] = INIT_50[i];
- memory[320*81+i] = INIT_51[i];
- memory[320*82+i] = INIT_52[i];
- memory[320*83+i] = INIT_53[i];
- memory[320*84+i] = INIT_54[i];
- memory[320*85+i] = INIT_55[i];
- memory[320*86+i] = INIT_56[i];
- memory[320*87+i] = INIT_57[i];
- memory[320*88+i] = INIT_58[i];
- memory[320*89+i] = INIT_59[i];
- memory[320*90+i] = INIT_5A[i];
- memory[320*91+i] = INIT_5B[i];
- memory[320*92+i] = INIT_5C[i];
- memory[320*93+i] = INIT_5D[i];
- memory[320*94+i] = INIT_5E[i];
- memory[320*95+i] = INIT_5F[i];
- memory[320*96+i] = INIT_60[i];
- memory[320*97+i] = INIT_61[i];
- memory[320*98+i] = INIT_62[i];
- memory[320*99+i] = INIT_63[i];
- memory[320*100+i] = INIT_64[i];
- memory[320*101+i] = INIT_65[i];
- memory[320*102+i] = INIT_66[i];
- memory[320*103+i] = INIT_67[i];
- memory[320*104+i] = INIT_68[i];
- memory[320*105+i] = INIT_69[i];
- memory[320*106+i] = INIT_6A[i];
- memory[320*107+i] = INIT_6B[i];
- memory[320*108+i] = INIT_6C[i];
- memory[320*109+i] = INIT_6D[i];
- memory[320*110+i] = INIT_6E[i];
- memory[320*111+i] = INIT_6F[i];
- memory[320*112+i] = INIT_70[i];
- memory[320*113+i] = INIT_71[i];
- memory[320*114+i] = INIT_72[i];
- memory[320*115+i] = INIT_73[i];
- memory[320*116+i] = INIT_74[i];
- memory[320*117+i] = INIT_75[i];
- memory[320*118+i] = INIT_76[i];
- memory[320*119+i] = INIT_77[i];
- memory[320*120+i] = INIT_78[i];
- memory[320*121+i] = INIT_79[i];
- memory[320*122+i] = INIT_7A[i];
- memory[320*123+i] = INIT_7B[i];
- memory[320*124+i] = INIT_7C[i];
- memory[320*125+i] = INIT_7D[i];
- memory[320*126+i] = INIT_7E[i];
- memory[320*127+i] = INIT_7F[i];
- end
+ memory[320*0+319:320*0] = INIT_00;
+ memory[320*1+319:320*1] = INIT_01;
+ memory[320*2+319:320*2] = INIT_02;
+ memory[320*3+319:320*3] = INIT_03;
+ memory[320*4+319:320*4] = INIT_04;
+ memory[320*5+319:320*5] = INIT_05;
+ memory[320*6+319:320*6] = INIT_06;
+ memory[320*7+319:320*7] = INIT_07;
+ memory[320*8+319:320*8] = INIT_08;
+ memory[320*9+319:320*9] = INIT_09;
+ memory[320*10+319:320*10] = INIT_0A;
+ memory[320*11+319:320*11] = INIT_0B;
+ memory[320*12+319:320*12] = INIT_0C;
+ memory[320*13+319:320*13] = INIT_0D;
+ memory[320*14+319:320*14] = INIT_0E;
+ memory[320*15+319:320*15] = INIT_0F;
+ memory[320*16+319:320*16] = INIT_10;
+ memory[320*17+319:320*17] = INIT_11;
+ memory[320*18+319:320*18] = INIT_12;
+ memory[320*19+319:320*19] = INIT_13;
+ memory[320*20+319:320*20] = INIT_14;
+ memory[320*21+319:320*21] = INIT_15;
+ memory[320*22+319:320*22] = INIT_16;
+ memory[320*23+319:320*23] = INIT_17;
+ memory[320*24+319:320*24] = INIT_18;
+ memory[320*25+319:320*25] = INIT_19;
+ memory[320*26+319:320*26] = INIT_1A;
+ memory[320*27+319:320*27] = INIT_1B;
+ memory[320*28+319:320*28] = INIT_1C;
+ memory[320*29+319:320*29] = INIT_1D;
+ memory[320*30+319:320*30] = INIT_1E;
+ memory[320*31+319:320*31] = INIT_1F;
+ memory[320*32+319:320*32] = INIT_20;
+ memory[320*33+319:320*33] = INIT_21;
+ memory[320*34+319:320*34] = INIT_22;
+ memory[320*35+319:320*35] = INIT_23;
+ memory[320*36+319:320*36] = INIT_24;
+ memory[320*37+319:320*37] = INIT_25;
+ memory[320*38+319:320*38] = INIT_26;
+ memory[320*39+319:320*39] = INIT_27;
+ memory[320*40+319:320*40] = INIT_28;
+ memory[320*41+319:320*41] = INIT_29;
+ memory[320*42+319:320*42] = INIT_2A;
+ memory[320*43+319:320*43] = INIT_2B;
+ memory[320*44+319:320*44] = INIT_2C;
+ memory[320*45+319:320*45] = INIT_2D;
+ memory[320*46+319:320*46] = INIT_2E;
+ memory[320*47+319:320*47] = INIT_2F;
+ memory[320*48+319:320*48] = INIT_30;
+ memory[320*49+319:320*49] = INIT_31;
+ memory[320*50+319:320*50] = INIT_32;
+ memory[320*51+319:320*51] = INIT_33;
+ memory[320*52+319:320*52] = INIT_34;
+ memory[320*53+319:320*53] = INIT_35;
+ memory[320*54+319:320*54] = INIT_36;
+ memory[320*55+319:320*55] = INIT_37;
+ memory[320*56+319:320*56] = INIT_38;
+ memory[320*57+319:320*57] = INIT_39;
+ memory[320*58+319:320*58] = INIT_3A;
+ memory[320*59+319:320*59] = INIT_3B;
+ memory[320*60+319:320*60] = INIT_3C;
+ memory[320*61+319:320*61] = INIT_3D;
+ memory[320*62+319:320*62] = INIT_3E;
+ memory[320*63+319:320*63] = INIT_3F;
+ memory[320*64+319:320*64] = INIT_40;
+ memory[320*65+319:320*65] = INIT_41;
+ memory[320*66+319:320*66] = INIT_42;
+ memory[320*67+319:320*67] = INIT_43;
+ memory[320*68+319:320*68] = INIT_44;
+ memory[320*69+319:320*69] = INIT_45;
+ memory[320*70+319:320*70] = INIT_46;
+ memory[320*71+319:320*71] = INIT_47;
+ memory[320*72+319:320*72] = INIT_48;
+ memory[320*73+319:320*73] = INIT_49;
+ memory[320*74+319:320*74] = INIT_4A;
+ memory[320*75+319:320*75] = INIT_4B;
+ memory[320*76+319:320*76] = INIT_4C;
+ memory[320*77+319:320*77] = INIT_4D;
+ memory[320*78+319:320*78] = INIT_4E;
+ memory[320*79+319:320*79] = INIT_4F;
+ memory[320*80+319:320*80] = INIT_50;
+ memory[320*81+319:320*81] = INIT_51;
+ memory[320*82+319:320*82] = INIT_52;
+ memory[320*83+319:320*83] = INIT_53;
+ memory[320*84+319:320*84] = INIT_54;
+ memory[320*85+319:320*85] = INIT_55;
+ memory[320*86+319:320*86] = INIT_56;
+ memory[320*87+319:320*87] = INIT_57;
+ memory[320*88+319:320*88] = INIT_58;
+ memory[320*89+319:320*89] = INIT_59;
+ memory[320*90+319:320*90] = INIT_5A;
+ memory[320*91+319:320*91] = INIT_5B;
+ memory[320*92+319:320*92] = INIT_5C;
+ memory[320*93+319:320*93] = INIT_5D;
+ memory[320*94+319:320*94] = INIT_5E;
+ memory[320*95+319:320*95] = INIT_5F;
+ memory[320*96+319:320*96] = INIT_60;
+ memory[320*97+319:320*97] = INIT_61;
+ memory[320*98+319:320*98] = INIT_62;
+ memory[320*99+319:320*99] = INIT_63;
+ memory[320*100+319:320*100] = INIT_64;
+ memory[320*101+319:320*101] = INIT_65;
+ memory[320*102+319:320*102] = INIT_66;
+ memory[320*103+319:320*103] = INIT_67;
+ memory[320*104+319:320*104] = INIT_68;
+ memory[320*105+319:320*105] = INIT_69;
+ memory[320*106+319:320*106] = INIT_6A;
+ memory[320*107+319:320*107] = INIT_6B;
+ memory[320*108+319:320*108] = INIT_6C;
+ memory[320*109+319:320*109] = INIT_6D;
+ memory[320*110+319:320*110] = INIT_6E;
+ memory[320*111+319:320*111] = INIT_6F;
+ memory[320*112+319:320*112] = INIT_70;
+ memory[320*113+319:320*113] = INIT_71;
+ memory[320*114+319:320*114] = INIT_72;
+ memory[320*115+319:320*115] = INIT_73;
+ memory[320*116+319:320*116] = INIT_74;
+ memory[320*117+319:320*117] = INIT_75;
+ memory[320*118+319:320*118] = INIT_76;
+ memory[320*119+319:320*119] = INIT_77;
+ memory[320*120+319:320*120] = INIT_78;
+ memory[320*121+319:320*121] = INIT_79;
+ memory[320*122+319:320*122] = INIT_7A;
+ memory[320*123+319:320*123] = INIT_7B;
+ memory[320*124+319:320*124] = INIT_7C;
+ memory[320*125+319:320*125] = INIT_7D;
+ memory[320*126+319:320*126] = INIT_7E;
+ memory[320*127+319:320*127] = INIT_7F;
end
// Signal inversion
diff --git a/techlibs/gatemate/gatemate_bramopt.cc b/techlibs/gatemate/gatemate_bramopt.cc index 9454f471b..bd16ba4c9 100644 --- a/techlibs/gatemate/gatemate_bramopt.cc +++ b/techlibs/gatemate/gatemate_bramopt.cc @@ -134,15 +134,11 @@ struct GateMateBramOptPass : public Pass { } extra_args(args, argidx, design); - Module *module = design->top_module(); - - if (module == nullptr) + for (auto module : design->selected_modules()) { - log_cmd_error("No top module found.\n"); - } - - if (!noglwren) { - proc_glwren(module); + if (!noglwren) { + proc_glwren(module); + } } } } GateMateBramOptPass; diff --git a/techlibs/gatemate/mul_map.v b/techlibs/gatemate/mul_map.v index 123a1e631..026509c75 100644 --- a/techlibs/gatemate/mul_map.v +++ b/techlibs/gatemate/mul_map.v @@ -36,27 +36,28 @@ module \$__MULMXN (A, B, Y); (* force_downto *) output [Y_WIDTH-1:0] Y; - localparam MAXWIDTH = `MAX(A_WIDTH, B_WIDTH) + ((A_SIGNED || B_SIGNED) ? 0 : 1); + localparam A_MAXWIDTH = A_WIDTH + (A_SIGNED ? 0 : 1); + localparam B_MAXWIDTH = B_WIDTH + (B_SIGNED ? 0 : 1); generate if (A_SIGNED) begin: blkA - wire signed [MAXWIDTH-1:0] Aext = $signed(A); + wire signed [A_MAXWIDTH-1:0] Aext = $signed(A); end else begin: blkA - wire [MAXWIDTH-1:0] Aext = A; + wire [A_MAXWIDTH-1:0] Aext = A; end if (B_SIGNED) begin: blkB - wire signed [MAXWIDTH-1:0] Bext = $signed(B); + wire signed [B_MAXWIDTH-1:0] Bext = $signed(B); end else begin: blkB - wire [MAXWIDTH-1:0] Bext = B; + wire [B_MAXWIDTH-1:0] Bext = B; end if (A_WIDTH >= B_WIDTH) begin CC_MULT #( - .A_WIDTH(MAXWIDTH), - .B_WIDTH(MAXWIDTH), - .P_WIDTH(`MIN(Y_WIDTH,MAXWIDTH+MAXWIDTH)), + .A_WIDTH(A_MAXWIDTH), + .B_WIDTH(B_MAXWIDTH), + .P_WIDTH(Y_WIDTH), ) _TECHMAP_REPLACE_ ( .A(blkA.Aext), .B(blkB.Bext), @@ -65,9 +66,9 @@ module \$__MULMXN (A, B, Y); end else begin // swap A,B CC_MULT #( - .A_WIDTH(MAXWIDTH), - .B_WIDTH(MAXWIDTH), - .P_WIDTH(`MIN(Y_WIDTH,MAXWIDTH+MAXWIDTH)), + .A_WIDTH(A_MAXWIDTH), + .B_WIDTH(B_MAXWIDTH), + .P_WIDTH(Y_WIDTH), ) _TECHMAP_REPLACE_ ( .A(blkB.Bext), .B(blkA.Aext), diff --git a/techlibs/gatemate/reg_map.v b/techlibs/gatemate/reg_map.v index 5075adf03..8dc4f672f 100644 --- a/techlibs/gatemate/reg_map.v +++ b/techlibs/gatemate/reg_map.v @@ -17,54 +17,6 @@ *
*/
-(* techmap_celltype = "$_DFF_[NP]_" *)
-module \$_DFF_x_ (input D, C, output Q);
-
- parameter _TECHMAP_CELLTYPE_ = "";
-
- CC_DFF #(
- .CLK_INV((_TECHMAP_CELLTYPE_[15:8] == "N")),
- .EN_INV(1'b0),
- .SR_INV(1'b0),
- .SR_VAL(1'b0)
- ) _TECHMAP_REPLACE_ (.D(D), .EN(1'b1), .CLK(C), .SR(1'b0), .Q(Q));
-
- wire _TECHMAP_REMOVEINIT_Q_ = 1'b1;
-
-endmodule
-
-(* techmap_celltype = "$_DFF_[NP][NP][01]_" *)
-module \$_DFF_xxx_ (input D, C, R, output Q);
-
- parameter _TECHMAP_CELLTYPE_ = "";
-
- CC_DFF #(
- .CLK_INV(_TECHMAP_CELLTYPE_[31:24] == "N"),
- .EN_INV(1'b0),
- .SR_INV(_TECHMAP_CELLTYPE_[23:16] == "N"),
- .SR_VAL(_TECHMAP_CELLTYPE_[15:8] == "1")
- ) _TECHMAP_REPLACE_ (.D(D), .EN(1'b1), .CLK(C), .SR(R), .Q(Q));
-
- wire _TECHMAP_REMOVEINIT_Q_ = 1'b1;
-
-endmodule
-
-(* techmap_celltype = "$_DFFE_[NP][NP]_" *)
-module \$_DFFE_xx_ (input D, C, E, output Q);
-
- parameter _TECHMAP_CELLTYPE_ = "";
-
- CC_DFF #(
- .CLK_INV(_TECHMAP_CELLTYPE_[23:16] == "N"),
- .EN_INV(_TECHMAP_CELLTYPE_[15:8] == "N"),
- .SR_INV(1'b0),
- .SR_VAL(1'b0)
- ) _TECHMAP_REPLACE_ (.D(D), .EN(E), .CLK(C), .SR(1'b0), .Q(Q));
-
- wire _TECHMAP_REMOVEINIT_Q_ = 1'b1;
-
-endmodule
-
(* techmap_celltype = "$_DFFE_[NP][NP][01][NP]_" *)
module \$_DFFE_xxxx_ (input D, C, R, E, output Q);
@@ -81,19 +33,6 @@ module \$_DFFE_xxxx_ (input D, C, R, E, output Q); endmodule
-(* techmap_celltype = "$_DLATCH_[NP]_" *)
-module \$_DLATCH_x_ (input E, D, output Q);
-
- parameter _TECHMAP_CELLTYPE_ = "";
-
- CC_DLT #(
- .G_INV(_TECHMAP_CELLTYPE_[15:8] == "N"),
- .SR_INV(1'b0),
- .SR_VAL(1'b0)
- ) _TECHMAP_REPLACE_ (.D(D), .G(E), .SR(1'b0), .Q(Q));
-
-endmodule
-
(* techmap_celltype = "$_DLATCH_[NP][NP][01]_" *)
module \$_DLATCH_xxx_ (input E, R, D, output Q);
diff --git a/techlibs/gatemate/synth_gatemate.cc b/techlibs/gatemate/synth_gatemate.cc index b570e1e2a..27a2b5bfa 100644 --- a/techlibs/gatemate/synth_gatemate.cc +++ b/techlibs/gatemate/synth_gatemate.cc @@ -305,7 +305,7 @@ struct SynthGateMatePass : public ScriptPass if (check_label("map_regs"))
{
run("opt_clean");
- run("dfflegalize -cell $_DFFE_????_ x -cell $_DLATCH_???_ x");
+ run("dfflegalize -cell $_DFFE_????_ 0 -cell $_DLATCH_???_ 0");
run("techmap -map +/gatemate/reg_map.v");
run("opt_expr -mux_undef");
run("simplemap");
|