mirror of
https://github.com/YosysHQ/yosys
synced 2025-10-24 00:14:36 +00:00
s/((Claire|Xen|Xenia|Clifford)\s+)+(Wolf|Xen)\s+<(claire|clifford)@(symbioticeda.com|clifford.at|yosyshq.com)>/Claire Xenia Wolf <claire@yosyshq.com>/gi; s/((Nina|Nak|N\.)\s+)+Engelhardt\s+<nak@(symbioticeda.com|yosyshq.com)>/N. Engelhardt <nak@yosyshq.com>/gi; s/((David)\s+)+Shah\s+<(dave|david)@(symbioticeda.com|yosyshq.com|ds0.me)>/David Shah <dave@ds0.me>/gi; s/((Miodrag)\s+)+Milanovic\s+<(miodrag|micko)@(symbioticeda.com|yosyshq.com)>/Miodrag Milanovic <micko@yosyshq.com>/gi; s,https?://www.clifford.at/yosys/,http://yosyshq.net/yosys/,g;
168 lines
5.4 KiB
Verilog
168 lines
5.4 KiB
Verilog
/*
|
|
* yosys -- Yosys Open SYnthesis Suite
|
|
*
|
|
* Copyright (C) 2012 Claire Xenia Wolf <claire@yosyshq.com>
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*
|
|
*/
|
|
module VCC (output V);
|
|
assign V = 1'b1;
|
|
endmodule // VCC
|
|
|
|
module GND (output G);
|
|
assign G = 1'b0;
|
|
endmodule // GND
|
|
|
|
/* Altera Cyclone V devices Input Buffer Primitive */
|
|
module cyclonev_io_ibuf
|
|
(output o,
|
|
(* iopad_external_pin *) input i,
|
|
(* iopad_external_pin *) input ibar,
|
|
input dynamicterminationcontrol);
|
|
|
|
parameter differential_mode = "false";
|
|
parameter bus_hold = "false";
|
|
parameter simulate_z_as = "Z";
|
|
parameter lpm_type = "cyclonev_io_ibuf";
|
|
|
|
assign o = i;
|
|
endmodule // cyclonev_io_ibuf
|
|
|
|
/* Altera Cyclone V devices Output Buffer Primitive */
|
|
module cyclonev_io_obuf
|
|
((* iopad_external_pin *) output o,
|
|
input i, oe, dynamicterminationcontrol,
|
|
input [15:0] seriesterminationcontrol, parallelterminationcontrol,
|
|
input devoe,
|
|
(* iopad_external_pin *) output obar);
|
|
|
|
parameter open_drain_output = "false";
|
|
parameter bus_hold = "false";
|
|
parameter shift_series_termination_control = "false";
|
|
parameter sim_dynamic_termination_control_is_connected = "false";
|
|
parameter lpm_type = "cyclonev_io_obuf";
|
|
|
|
assign o = oe ? i : 1'bz;
|
|
endmodule // cyclonev_io_obuf
|
|
|
|
/* Altera Cyclone V LUT Primitive */
|
|
module cyclonev_lcell_comb
|
|
(output combout, cout, sumout, shareout,
|
|
input dataa, datab, datac, datad,
|
|
input datae, dataf, datag, cin,
|
|
input sharein);
|
|
|
|
parameter lut_mask = 64'hFFFFFFFFFFFFFFFF;
|
|
parameter dont_touch = "off";
|
|
parameter lpm_type = "cyclonev_lcell_comb";
|
|
parameter shared_arith = "off";
|
|
parameter extended_lut = "off";
|
|
|
|
// Internal variables
|
|
// Sub mask for fragmented LUTs
|
|
wire [15:0] mask_a, mask_b, mask_c, mask_d;
|
|
// Independent output for fragmented LUTs
|
|
wire output_0, output_1, output_2, output_3;
|
|
// Extended mode uses mux to define the output
|
|
wire mux_0, mux_1;
|
|
// Input for hold the shared LUT mode value
|
|
wire shared_lut_alm;
|
|
|
|
// Simulation model of 4-input LUT
|
|
function lut4;
|
|
input [15:0] mask;
|
|
input dataa, datab, datac, datad;
|
|
reg [7:0] s3;
|
|
reg [3:0] s2;
|
|
reg [1:0] s1;
|
|
begin
|
|
s3 = datad ? mask[15:8] : mask[7:0];
|
|
s2 = datac ? s3[7:4] : s3[3:0];
|
|
s1 = datab ? s2[3:2] : s2[1:0];
|
|
lut4 = dataa ? s1[1] : s1[0];
|
|
end
|
|
endfunction // lut4
|
|
|
|
// Simulation model of 5-input LUT
|
|
function lut5;
|
|
input [31:0] mask; // wp-01003.pdf, page 3: "a 5-LUT can be built with two 4-LUTs and a multiplexer.
|
|
input dataa, datab, datac, datad, datae;
|
|
reg upper_lut_value;
|
|
reg lower_lut_value;
|
|
begin
|
|
upper_lut_value = lut4(mask[31:16], dataa, datab, datac, datad);
|
|
lower_lut_value = lut4(mask[15:0], dataa, datab, datac, datad);
|
|
lut5 = (datae) ? upper_lut_value : lower_lut_value;
|
|
end
|
|
endfunction // lut5
|
|
|
|
// Simulation model of 6-input LUT
|
|
function lut6;
|
|
input [63:0] mask;
|
|
input dataa, datab, datac, datad, datae, dataf;
|
|
reg upper_lut_value;
|
|
reg lower_lut_value;
|
|
reg out_0, out_1, out_2, out_3;
|
|
begin
|
|
upper_lut_value = lut5(mask[63:32], dataa, datab, datac, datad, datae);
|
|
lower_lut_value = lut5(mask[31:0], dataa, datab, datac, datad, datae);
|
|
lut6 = (dataf) ? upper_lut_value : lower_lut_value;
|
|
end
|
|
endfunction // lut6
|
|
|
|
assign {mask_a, mask_b, mask_c, mask_d} = {lut_mask[15:0], lut_mask[31:16], lut_mask[47:32], lut_mask[63:48]};
|
|
`ifdef ADVANCED_ALM
|
|
always @(*) begin
|
|
if(extended_lut == "on")
|
|
shared_lut_alm = datag;
|
|
else
|
|
shared_lut_alm = datac;
|
|
// Build the ALM behaviour
|
|
out_0 = lut4(mask_a, dataa, datab, datac, datad);
|
|
out_1 = lut4(mask_b, dataa, datab, shared_lut_alm, datad);
|
|
out_2 = lut4(mask_c, dataa, datab, datac, datad);
|
|
out_3 = lut4(mask_d, dataa, datab, shared_lut_alm, datad);
|
|
end
|
|
`else
|
|
`ifdef DEBUG
|
|
initial $display("Advanced ALM lut combine is not implemented yet");
|
|
`endif
|
|
`endif
|
|
endmodule // cyclonev_lcell_comb
|
|
|
|
|
|
/* Altera D Flip-Flop Primitive */
|
|
module dffeas
|
|
(output q,
|
|
input d, clk, clrn, prn, ena,
|
|
input asdata, aload, sclr, sload);
|
|
|
|
// Timing simulation is not covered
|
|
parameter power_up="dontcare";
|
|
parameter is_wysiwyg="false";
|
|
|
|
reg q_tmp;
|
|
wire reset;
|
|
reg [7:0] debug_net;
|
|
|
|
assign reset = (prn && sclr && ~clrn && ena);
|
|
assign q = q_tmp & 1'b1;
|
|
|
|
always @(posedge clk, posedge aload) begin
|
|
if(reset) q_tmp <= 0;
|
|
else q_tmp <= d;
|
|
end
|
|
assign q = q_tmp;
|
|
|
|
endmodule // dffeas
|