diff options
| author | Clifford Wolf <clifford@clifford.at> | 2018-04-01 15:32:47 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-04-01 15:32:47 +0200 | 
| commit | 2b00c1dbd6b916aae6f97191d34b786a316c706e (patch) | |
| tree | 3e18d4f7bf01599380c8f7050f398a9b74cd6f8e /techlibs/intel/cyclone10 | |
| parent | 93985d91b1d3e4dacf6de5563fc56f82d9123d38 (diff) | |
| parent | efed2420d686c35f79c4f68e56b460f8e534a6ea (diff) | |
| download | yosys-2b00c1dbd6b916aae6f97191d34b786a316c706e.tar.gz yosys-2b00c1dbd6b916aae6f97191d34b786a316c706e.tar.bz2 yosys-2b00c1dbd6b916aae6f97191d34b786a316c706e.zip | |
Merge pull request #522 from c60k28/master
Fixed broken Quartus backend on dffeas init value, and other updates.
Diffstat (limited to 'techlibs/intel/cyclone10')
| -rw-r--r-- | techlibs/intel/cyclone10/cells_map.v | 20 | 
1 files changed, 15 insertions, 5 deletions
| 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 | 
