diff options
| -rwxr-xr-x | techlibs/achronix/Makefile.inc | 2 | ||||
| -rwxr-xr-x | techlibs/achronix/speedster22i/cells_map.v | 66 | ||||
| -rwxr-xr-x | techlibs/achronix/speedster22i/cells_sim.v | 85 | ||||
| -rwxr-xr-x | techlibs/achronix/synth_achronix.cc (renamed from techlibs/achronix/synth_speedster.cc) | 20 | ||||
| -rw-r--r-- | techlibs/intel/cyclone10/cells_map.v | 20 | ||||
| -rw-r--r-- | techlibs/intel/cycloneiv/cells_map.v | 20 | ||||
| -rw-r--r-- | techlibs/intel/cycloneive/arith_map.v | 51 | ||||
| -rw-r--r-- | techlibs/intel/cycloneive/cells_map.v | 21 | ||||
| -rw-r--r-- | techlibs/intel/cyclonev/cells_map.v | 75 | ||||
| -rw-r--r-- | techlibs/intel/max10/cells_map.v | 24 | ||||
| -rw-r--r-- | techlibs/intel/synth_intel.cc | 27 | 
11 files changed, 233 insertions, 178 deletions
| diff --git a/techlibs/achronix/Makefile.inc b/techlibs/achronix/Makefile.inc index affe0334a..994cf0015 100755 --- a/techlibs/achronix/Makefile.inc +++ b/techlibs/achronix/Makefile.inc @@ -1,5 +1,5 @@ -OBJS += techlibs/achronix/synth_speedster.o +OBJS += techlibs/achronix/synth_achronix.o  $(eval $(call add_share_file,share/achronix/speedster22i/,techlibs/achronix/speedster22i/cells_sim.v))  $(eval $(call add_share_file,share/achronix/speedster22i/,techlibs/achronix/speedster22i/cells_map.v)) diff --git a/techlibs/achronix/speedster22i/cells_map.v b/techlibs/achronix/speedster22i/cells_map.v index 90f87826d..95f5d59c5 100755 --- a/techlibs/achronix/speedster22i/cells_map.v +++ b/techlibs/achronix/speedster22i/cells_map.v @@ -16,53 +16,25 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ -// Normal mode DFF negedge clk, negedge reset -module  \$_DFF_N_ (input D, C, output Q); -   parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); -endmodule -// Normal mode DFF -module  \$_DFF_P_ (input D, C, output Q); -   parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); -endmodule - -// Async Active Low Reset DFF -module  \$_DFF_PN0_ (input D, C, R, output Q); -   parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); -endmodule -// Async Active High Reset DFF -module  \$_DFF_PP0_ (input D, C, R, output Q); -   parameter WYSIWYG="TRUE"; -   wire R_i = ~ R; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); -endmodule -// Async Active Low Reset DFF -module  \$_DFF_PN0_ (input D, C, R, output Q); -   parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); -endmodule -/* */ -module  \$__DFFE_PP0 (input D, C, E, R, output Q); -   parameter WYSIWYG="TRUE"; -   wire E_i = ~ E; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0)); -endmodule +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Achronix eFPGA technology mapping. User must first simulate the generated \ +// > netlist before going to test it on board/custom chip. +// > Input/Output buffers <  // Input buffer map  module \$__inpad (input I, output O);      PADIN _TECHMAP_REPLACE_ (.padout(O), .padin(I));  endmodule -  // Output buffer map  module \$__outpad (input I, output O);      PADOUT _TECHMAP_REPLACE_ (.padout(O), .padin(I), .oe(1'b1));  endmodule +// > end buffers < +// > Look-Up table < +// > VT: I still think Achronix folks would have choosen a better \ +// >     logic architecture.  // LUT Map -/* 0 -> datac -   1 -> cin */  module \$lut (A, Y);     parameter WIDTH  = 0;     parameter LUT    = 0; @@ -70,19 +42,31 @@ module \$lut (A, Y);     output 	     Y;     generate        if (WIDTH == 1) begin -	   assign Y = ~A[0]; // Not need to spend 1 logic cell for such an easy function +	   // VT: This is not consistent and ACE will complain: assign Y = ~A[0]; +         LUT4 #(.lut_function({4{LUT}})) _TECHMAP_REPLACE_  +           (.dout(Y), .din0(A[0]), .din1(1'b0), .din2(1'b0), .din3(1'b0));        end else        if (WIDTH == 2) begin -              LUT4 #(.lut_function({4{LUT}})) _TECHMAP_REPLACE_ (.dout(Y), .din0(A[0]), .din1(A[1]), .din2(1'b0),.din3(1'b0)); +              LUT4 #(.lut_function({4{LUT}})) _TECHMAP_REPLACE_  +                (.dout(Y), .din0(A[0]), .din1(A[1]), .din2(1'b0), .din3(1'b0));        end else        if(WIDTH == 3) begin -	      LUT4 #(.lut_function({2{LUT}})) _TECHMAP_REPLACE_ (.dout(Y), .din0(A[0]), .din1(A[1]), .din2(A[2]),.din3(1'b0)); +	      LUT4 #(.lut_function({2{LUT}})) _TECHMAP_REPLACE_  +                (.dout(Y), .din0(A[0]), .din1(A[1]), .din2(A[2]), .din3(1'b0));        end else        if(WIDTH == 4) begin -             LUT4 #(.lut_function(LUT)) _TECHMAP_REPLACE_ (.dout(Y), .din0(A[0]), .din1(A[1]), .din2(A[2]), .din3(A[3])); +             LUT4 #(.lut_function(LUT)) _TECHMAP_REPLACE_  +               (.dout(Y), .din0(A[0]), .din1(A[1]), .din2(A[2]), .din3(A[3]));        end else  	   wire _TECHMAP_FAIL_ = 1;     endgenerate -endmodule // +endmodule  +// > end LUT < +// > Flops < +// DFF flop +module  \$_DFF_P_ (input D, C, output Q); +   DFF _TECHMAP_REPLACE_  +     (.q(Q), .d(D), .ck(C)); +endmodule  diff --git a/techlibs/achronix/speedster22i/cells_sim.v b/techlibs/achronix/speedster22i/cells_sim.v index 24c57c41a..da23fed7e 100755 --- a/techlibs/achronix/speedster22i/cells_sim.v +++ b/techlibs/achronix/speedster22i/cells_sim.v @@ -16,50 +16,31 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Achronix eFPGA technology sim models. User must first simulate the generated \ +// > netlist before going to test it on board/custom chip. +// > Changelog: 1) Removed unused VCC/GND modules +// >            2) Altera comments here (?). Removed. +// >            3) Reusing LUT sim model, removed wrong wires and parameters. -module VCC (output V); -   assign V = 1'b1; -endmodule // VCC - -module GND (output G); -   assign G = 1'b0; -endmodule // GND - -/* Altera MAX10 devices Input Buffer Primitive */  module PADIN (output padout, input padin);     assign padout = padin; -endmodule // fiftyfivenm_io_ibuf +endmodule -/* Altera MAX10 devices Output Buffer Primitive */  module PADOUT (output padout, input padin, input oe);     assign padout  = padin;     assign oe = oe; -endmodule // fiftyfivenm_io_obuf +endmodule  -/* Altera MAX10 4-input non-fracturable LUT Primitive */  module LUT4 (output dout,               input  din0, din1, din2, din3); -/* Internal parameters which define the behaviour -   of the LUT primitive. -   lut_mask define the lut function, can be expressed in 16-digit bin or hex. -   sum_lutc_input define the type of LUT (combinational | arithmetic). -   dont_touch for retiming || carry options. -   lpm_type for WYSIWYG */ - -parameter lut_function = 16'hFFFF; -//parameter dont_touch = "off"; -//parameter lpm_type = "fiftyfivenm_lcell_comb"; -//parameter sum_lutc_input = "datac"; - -reg [1:0] lut_type; -reg cout_rt; +parameter [15:0] lut_function = 16'hFFFF;  reg combout_rt;  wire dataa_w;  wire datab_w;  wire datac_w;  wire datad_w; -wire cin_w;  assign dataa_w = din0;  assign datab_w = din1; @@ -78,49 +59,21 @@ reg [1:0]   s1;         s1 = datab ?   s2[3:2]  :   s2[1:0];         lut_data = dataa ? s1[1] : s1[0];    end -  endfunction -initial begin -    /*if (sum_lutc_input == "datac")*/ lut_type = 0; -    /*else -    if (sum_lutc_input == "cin")   lut_type = 1; -    else begin -      $error("Error in sum_lutc_input. Parameter %s is not a valid value.\n", sum_lutc_input); -      $finish(); -    end*/ -end -  always @(dataa_w or datab_w or datac_w or datad_w or cin_w) begin -    if (lut_type == 0) begin // logic function -        combout_rt = lut_data(lut_function, dataa_w, datab_w, -                            datac_w, datad_w); -    end -    else if (lut_type == 1) begin // arithmetic function -        combout_rt = lut_data(lut_function, dataa_w, datab_w, -                            cin_w, datad_w); -    end -    cout_rt = lut_data(lut_function, dataa_w, datab_w, cin_w, 'b0); +   combout_rt = lut_data(lut_function, dataa_w, datab_w, +                         datac_w, datad_w);  end -  assign dout = combout_rt & 1'b1; -//assign cout = cout_rt & 1'b1; - -endmodule // fiftyfivenm_lcell_comb - -/* Altera MAX10 D Flip-Flop Primitive */ -// TODO: Implement advanced simulation functions -module dffeas ( output q, -                input d, clk, clrn, prn, ena, -		input asdata, aload, sclr, sload ); - -parameter power_up="dontcare"; -parameter is_wysiwyg="false"; -  reg q; - -  always @(posedge clk) -    q <= d; - +endmodule  + +module DFF (output q, +            input  d, ck); +   reg             q; +   always @(posedge ck) +     q <= d; +     endmodule diff --git a/techlibs/achronix/synth_speedster.cc b/techlibs/achronix/synth_achronix.cc index 3808af6f1..7f4503070 100755 --- a/techlibs/achronix/synth_speedster.cc +++ b/techlibs/achronix/synth_achronix.cc @@ -25,14 +25,14 @@  USING_YOSYS_NAMESPACE  PRIVATE_NAMESPACE_BEGIN -struct SynthIntelPass : public ScriptPass { -  SynthIntelPass() : ScriptPass("synth_speedster", "synthesis for Acrhonix Speedster22i FPGAs.") { } +struct SynthAchronixPass : public ScriptPass { +  SynthAchronixPass() : ScriptPass("synth_achronix", "synthesis for Acrhonix Speedster22i FPGAs.") { }    virtual void help() YS_OVERRIDE    {      //   |---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|      log("\n"); -    log("    synth_speedster [options]\n"); +    log("    synth_achronix [options]\n");      log("\n");      log("This command runs synthesis for Achronix Speedster eFPGAs. This work is still experimental.\n");      log("\n"); @@ -110,7 +110,7 @@ struct SynthIntelPass : public ScriptPass {      if (!design->full_selection())        log_cmd_error("This comannd only operates on fully selected designs!\n"); -    log_header(design, "Executing SYNTH_SPEEDSTER pass.\n"); +    log_header(design, "Executing SYNTH_ACHRONIX pass.\n");      log_push();      run_script(design, run_from, run_to); @@ -146,9 +146,9 @@ struct SynthIntelPass : public ScriptPass {          run("opt -undriven -fine");          run("dffsr2dff");          run("dff2dffe -direct-match $_DFF_*"); -        run("opt -full"); +        run("opt -fine");          run("techmap -map +/techmap.v"); -        run("opt -fast"); +        run("opt -full");          run("clean -purge");          run("setundef -undriven -zero");          if (retime || help_mode) @@ -157,7 +157,7 @@ struct SynthIntelPass : public ScriptPass {      if (check_label("map_luts"))        { -        run("abc -luts 2:2,3,6:5,10,20" + string(retime ? " -dff" : "")); +        run("abc -lut 4" + string(retime ? " -dff" : ""));          run("clean");        } @@ -165,7 +165,7 @@ struct SynthIntelPass : public ScriptPass {        {          run("iopadmap -bits -outpad $__outpad I:O -inpad $__inpad O:I");          run("techmap -map +/achronix/speedster22i/cells_map.v"); -        run("dffinit -ff dffeas Q INIT"); +        // VT: not done yet run("dffinit -highlow -ff DFF q power_up");          run("clean -purge");        } @@ -179,10 +179,10 @@ struct SynthIntelPass : public ScriptPass {      if (check_label("vout"))        {          if (!vout_file.empty() || help_mode) -          run(stringf("write_verilog -nodec -attr2comment -defparam -nohex -renameprefix yosys_ %s", +          run(stringf("write_verilog -nodec -attr2comment -defparam -renameprefix syn_ %s",                        help_mode ? "<file-name>" : vout_file.c_str()));        }    } -} SynthIntelPass; +} SynthAchronixPass;  PRIVATE_NAMESPACE_END diff --git a/techlibs/intel/cyclone10/cells_map.v b/techlibs/intel/cyclone10/cells_map.v index 8ac5a55ec..c2f6f403c 100644 --- a/techlibs/intel/cyclone10/cells_map.v +++ b/techlibs/intel/cyclone10/cells_map.v @@ -16,33 +16,43 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Intel FPGA technology mapping. User must first simulate the generated \ +// > netlist before going to test it on board. +// > Changelog: 1) The missing power_up parameter in the techmap introduces a problem in Quartus mapper. Fixed. +  // Normal mode DFF negedge clk, negedge reset  module  \$_DFF_N_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Normal mode DFF  module  \$_DFF_P_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active Low Reset DFF  module  \$_DFF_PN0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up("power_up")) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active High Reset DFF  module  \$_DFF_PP0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire R_i = ~ R; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  module  \$__DFFE_PP0 (input D, C, E, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire E_i = ~ E; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0));  endmodule  // Input buffer map diff --git a/techlibs/intel/cycloneiv/cells_map.v b/techlibs/intel/cycloneiv/cells_map.v index b991fbae7..191488430 100644 --- a/techlibs/intel/cycloneiv/cells_map.v +++ b/techlibs/intel/cycloneiv/cells_map.v @@ -16,33 +16,43 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Intel FPGA technology mapping. User must first simulate the generated \ +// > netlist before going to test it on board. +// > Changelog: 1) The missing power_up parameter in the techmap introduces a problem in Quartus mapper. Fixed. +  // Normal mode DFF negedge clk, negedge reset  module  \$_DFF_N_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Normal mode DFF  module  \$_DFF_P_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active Low Reset DFF  module  \$_DFF_PN0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up("power_up")) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active High Reset DFF  module  \$_DFF_PP0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire R_i = ~ R; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  module  \$__DFFE_PP0 (input D, C, E, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire E_i = ~ E; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0));  endmodule  // Input buffer map diff --git a/techlibs/intel/cycloneive/arith_map.v b/techlibs/intel/cycloneive/arith_map.v index 634cec789..b3a11272b 100644 --- a/techlibs/intel/cycloneive/arith_map.v +++ b/techlibs/intel/cycloneive/arith_map.v @@ -16,6 +16,48 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +/* TODO: Describe the following mode */ +module fa +  (input  a_c, +   input  b_c, +   input  cin_c, +   output cout_t, +   output sum_x); + +   wire   a_c; +   wire   b_c; +   wire   cout_t; +   wire   cin_c; +   wire   sum_x; +   wire   VCC; + +   assign VCC = 1'b1; +    +   cycloneiv_lcell_comb gen_sum_0 (.combout(sum_x), +                                   .dataa(a_c), +                                   .datab(b_c), +                                   .datac(cin_c), +                                   .datad(VCC)); +   defparam syn__05_.lut_mask = 16'b1001011010010110; +   defparam syn__05_.sum_lutc_input = "datac"; +    +   cycloneiv_lcell_comb gen_cout_0 (.combout(cout_t), +                                    .dataa(cin_c), +                                    .datab(b_c), +                                    .datac(a_c), +                                    .datad(VCC)); +   defparam syn__06_.lut_mask = 16'b1110000011100000; +   defparam syn__06_.sum_lutc_input = "datac"; +    +endmodule // fa + +module f_stage(); +    +endmodule // f_stage + +module f_end(); + +endmodule // f_end  module _80_cycloneive_alu (A, B, CI, BI, X, Y, CO);     parameter A_SIGNED = 0; @@ -41,8 +83,13 @@ module _80_cycloneive_alu (A, B, CI, BI, X, Y, CO);     wire [Y_WIDTH-1:0]   BB = BI ? ~B_buf : B_buf;     wire [Y_WIDTH:0]     C = {CO, CI}; -   cycloneive_lcell_comb #(.lut_mask(16'b0110_0110_1000_1000), .sum_lutc_input("cin")) carry_start  (.cout(CO[0]), .dataa(BB[0]), .datab(1'b1), .datac(1'b1), .datad(1'b1)); -   genvar               i; +   fa f0 (.a_c(AA[0]), +          .b_c(BB[0]), +          .cin_c(C[0]), +          .cout_t(C0[1]), +          .sum_x(Y[0])); +    +   genvar i;     generate for (i = 1; i < Y_WIDTH; i = i + 1) begin:slice        cycloneive_lcell_comb #(.lut_mask(16'b0101_1010_0101_0000), .sum_lutc_input("cin")) arith_cell (.combout(Y[i]), .cout(CO[i]), .dataa(BB[i]), .datab(1'b1), .datac(1'b1), .datad(1'b1), .cin(C[i]));     end endgenerate diff --git a/techlibs/intel/cycloneive/cells_map.v b/techlibs/intel/cycloneive/cells_map.v index bf87f5525..abeb92eef 100644 --- a/techlibs/intel/cycloneive/cells_map.v +++ b/techlibs/intel/cycloneive/cells_map.v @@ -16,32 +16,43 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Intel FPGA technology mapping. User must first simulate the generated \ +// > netlist before going to test it on board. +// > Changelog: 1) The missing power_up parameter in the techmap introduces a problem in Quartus mapper. Fixed. +  // Normal mode DFF negedge clk, negedge reset  module  \$_DFF_N_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Normal mode DFF  module  \$_DFF_P_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule +  // Async Active Low Reset DFF  module  \$_DFF_PN0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up("power_up")) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active High Reset DFF  module  \$_DFF_PP0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire R_i = ~ R; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  module  \$__DFFE_PP0 (input D, C, E, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire E_i = ~ E; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0));  endmodule  // Input buffer map diff --git a/techlibs/intel/cyclonev/cells_map.v b/techlibs/intel/cyclonev/cells_map.v index 9fe8db2da..bd60d4e17 100644 --- a/techlibs/intel/cyclonev/cells_map.v +++ b/techlibs/intel/cyclonev/cells_map.v @@ -16,33 +16,45 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Intel FPGA technology mapping. User must first simulate the generated \ +// > netlist before going to test it on board. +// > Changelog: 1) The missing power_up parameter in the techmap introduces a problem in Quartus mapper. Fixed. +//              2) Cyclone V 7-input LUT function was wrong implemented. Removed abc option to map this function \ +//                 and added the explanation in this file instead. Such function needs to be implemented. +  // Normal mode DFF negedge clk, negedge reset  module  \$_DFF_N_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Normal mode DFF  module  \$_DFF_P_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active Low Reset DFF  module  \$_DFF_PN0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up("power_up")) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active High Reset DFF  module  \$_DFF_PP0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire R_i = ~ R; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  module  \$__DFFE_PP0 (input D, C, E, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire E_i = ~ E; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0));  endmodule  // Input buffer map @@ -61,6 +73,10 @@ module \$lut (A, Y);     parameter LUT    = 0;     input [WIDTH-1:0] A;     output            Y; +   wire              VCC; +   wire              GND; +   assign {VCC,GND} = {1'b1,1'b0}; +        generate        if (WIDTH == 1) begin  	 assign Y = ~A[0]; // Not need to spend 1 logic cell for such an easy function @@ -72,11 +88,11 @@ module \$lut (A, Y);               (.combout(Y),                .dataa(A[0]),                .datab(A[1]), -              .datac(1'b1), -              .datad(1'b1), -              .datae(1'b1), -              .dataf(1'b1), -              .datag(1'b1)); +              .datac(VCC), +              .datad(VCC), +              .datae(VCC), +              .dataf(VCC), +              .datag(VCC));          end          else            if(WIDTH == 3) begin @@ -86,10 +102,10 @@ module \$lut (A, Y);                  .dataa(A[0]),                  .datab(A[1]),                  .datac(A[2]), -                .datad(1'b1), -                .datae(1'b1), -                .dataf(1'b1), -                .datag(1'b1)); +                .datad(VCC), +                .datae(VCC), +                .dataf(VCC), +                .datag(VCC));            end            else              if(WIDTH == 4) begin @@ -100,9 +116,9 @@ module \$lut (A, Y);                    .datab(A[1]),                    .datac(A[2]),                    .datad(A[3]), -                  .datae(1'b1), -                  .dataf(1'b1), -                  .datag(1'b1)); +                  .datae(VCC), +                  .dataf(VCC), +                  .datag(VCC));              end              else                if(WIDTH == 5) begin @@ -114,8 +130,8 @@ module \$lut (A, Y);                      .datac(A[2]),                      .datad(A[3]),                      .datae(A[4]), -                    .dataf(1'b1), -                    .datag(1'b1)); +                    .dataf(VCC), +                    .datag(VCC));                end                else                  if(WIDTH == 6) begin @@ -128,21 +144,16 @@ module \$lut (A, Y);                        .datad(A[3]),                        .datae(A[4]),                        .dataf(A[5]), -                      .datag(1'b1)); +                      .datag(VCC));                  end -                else +                /*else                    if(WIDTH == 7) begin -                     cyclonev_lcell_comb #(.lut_mask(LUT), .shared_arith("off"), .extended_lut("off")) -                     _TECHMAP_REPLACE_ -                       (.combout(Y), -                        .dataa(A[0]), -                        .datab(A[1]), -                        .datac(A[2]), -                        .datad(A[3]), -                        .datae(A[4]), -                        .dataf(A[5]), -                        .datag(A[6])); -                  end +                    TODO: There's not a just 7-input function on Cyclone V, see the following note: +                    **Extended LUT Mode** +                    Use extended LUT mode to implement a specific set of 7-input functions. The set must +                    be a 2-to-1 multiplexer fed by two arbitrary 5-input functions sharing four inputs.  +                    [source](Device Interfaces and Integration Basics for Cyclone V Devices). +                  end*/                    else                       wire _TECHMAP_FAIL_ = 1;     endgenerate diff --git a/techlibs/intel/max10/cells_map.v b/techlibs/intel/max10/cells_map.v index 9229fae51..6d604e072 100644 --- a/techlibs/intel/max10/cells_map.v +++ b/techlibs/intel/max10/cells_map.v @@ -16,43 +16,53 @@   *  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   *   */ +// > c60k28 (Viacheslav, VT) [at] yandex [dot] com +// > Intel FPGA technology mapping. User must first simulate the generated \ +// > netlist before going to test it on board. +// > Changelog: 1) The missing power_up parameter in the techmap introduces a problem in Quartus mapper. Fixed. +  // Normal mode DFF negedge clk, negedge reset  module  \$_DFF_N_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Normal mode DFF  module  \$_DFF_P_ (input D, C, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(1'b1), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active Low Reset DFF  module  \$_DFF_PN0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   parameter power_up=1'bx; +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up("power_up")) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  // Async Active High Reset DFF  module  \$_DFF_PP0_ (input D, C, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire R_i = ~ R; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R_i), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(1'b0), .sload(1'b0));  endmodule  module  \$__DFFE_PP0 (input D, C, E, R, output Q);     parameter WYSIWYG="TRUE"; +   parameter power_up=1'bx;     wire E_i = ~ E; -   dffeas #(.is_wysiwyg(WYSIWYG)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0)); +   dffeas #(.is_wysiwyg(WYSIWYG), .power_up(power_up)) _TECHMAP_REPLACE_ (.d(D), .q(Q), .clk(C), .clrn(R), .prn(1'b1), .ena(1'b1), .asdata(1'b0), .aload(1'b0), .sclr(E_i), .sload(1'b0));  endmodule  // Input buffer map  module \$__inpad (input I, output O); -    fiftyfivenm_io_ibuf _TECHMAP_REPLACE_ (.o(O), .i(I), .ibar(1'b0)); +   fiftyfivenm_io_ibuf _TECHMAP_REPLACE_ (.o(O), .i(I), .ibar(1'b0));  endmodule  // Output buffer map  module \$__outpad (input I, output O); -    fiftyfivenm_io_obuf _TECHMAP_REPLACE_ (.o(O), .i(I), .oe(1'b1)); +   fiftyfivenm_io_obuf _TECHMAP_REPLACE_ (.o(O), .i(I), .oe(1'b1));  endmodule  // LUT Map diff --git a/techlibs/intel/synth_intel.cc b/techlibs/intel/synth_intel.cc index 9e632c861..dfed7a285 100644 --- a/techlibs/intel/synth_intel.cc +++ b/techlibs/intel/synth_intel.cc @@ -36,7 +36,7 @@ struct SynthIntelPass : public ScriptPass {      log("\n");      log("This command runs synthesis for Intel FPGAs.\n");      log("\n"); -    log("    -family < max10 | a10gx | cyclonev | cycloneiv | cycloneive>\n"); +    log("    -family < max10 | a10gx | cyclone10 | cyclonev | cycloneiv | cycloneive>\n");      log("        generate the synthesis netlist for the specified family.\n");      log("        MAX10 is the default target if not family argument specified.\n");      log("        For Cyclone GX devices, use cycloneiv argument; For Cyclone E, use cycloneive.\n"); @@ -49,6 +49,11 @@ struct SynthIntelPass : public ScriptPass {      log("        write the design to the specified Verilog Quartus Mapping File. Writing of an\n");      log("        output file is omitted if this parameter is not specified.\n");      log("\n"); +    log("    -vpr <file>\n"); +    log("        write BLIF files for VPR flow experiments. The synthesized BLIF output file is not\n"); +    log("        compatible with the Quartus flow. Writing of an\n"); +    log("        output file is omitted if this parameter is not specified.\n"); +    log("\n");      log("    -run <from_label>:<to_label>\n");      log("        only run the commands between the labels (see below). an empty\n");      log("        from label is synonymous to 'begin', and empty to label is\n"); @@ -68,7 +73,7 @@ struct SynthIntelPass : public ScriptPass {      log("\n");    } -  string top_opt, family_opt, vout_file; +  string top_opt, family_opt, vout_file, blif_file;    bool retime, flatten, nobram;    virtual void clear_flags() YS_OVERRIDE @@ -76,6 +81,7 @@ struct SynthIntelPass : public ScriptPass {      top_opt = "-auto-top";      family_opt = "max10";      vout_file = ""; +    blif_file = "";      retime = false;      flatten = true;      nobram = false; @@ -101,6 +107,10 @@ struct SynthIntelPass : public ScriptPass {            vout_file = args[++argidx];            continue;          } +        if (args[argidx] == "-vpr" && argidx+1 < args.size()) { +          blif_file = args[++argidx]; +          continue; +        }          if (args[argidx] == "-run" && argidx+1 < args.size()) {            size_t pos = args[argidx+1].find(':');            if (pos == std::string::npos) @@ -198,7 +208,7 @@ struct SynthIntelPass : public ScriptPass {      if (check_label("map_luts"))        {          if(family_opt=="a10gx" || family_opt=="cyclonev") -          run("abc -luts 2:2,3,6:5,10" + string(retime ? " -dff" : "")); +          run("abc -luts 2:2,3,6:5" + string(retime ? " -dff" : ""));          else            run("abc -lut 4" + string(retime ? " -dff" : ""));          run("clean"); @@ -236,7 +246,16 @@ struct SynthIntelPass : public ScriptPass {            run(stringf("write_verilog -attr2comment -defparam -nohex -decimal -renameprefix syn_ %s",                        help_mode ? "<file-name>" : vout_file.c_str()));        } -  } +     +    if (check_label("vpr")) +      { +        if (!blif_file.empty() || help_mode) +          { +            run(stringf("opt_clean -purge")); +            run(stringf("write_blif %s", help_mode ? "<file-name>" : blif_file.c_str())); +          } +      } +  }         } SynthIntelPass;  PRIVATE_NAMESPACE_END | 
