mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	Merge pull request #337 from dh73/master
Add initial support for both MAX10 and Cyclone IV (E|GX) FPGAs
This commit is contained in:
		
						commit
						7791888703
					
				
					 25 changed files with 2255 additions and 0 deletions
				
			
		
							
								
								
									
										4
									
								
								examples/intel/DE2i-150/quartus_compile/de2i.qpf
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								examples/intel/DE2i-150/quartus_compile/de2i.qpf
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | |||
| QUARTUS_VERSION = "16.1" | ||||
| # Revisions | ||||
| 
 | ||||
| PROJECT_REVISION = "de2i" | ||||
							
								
								
									
										1099
									
								
								examples/intel/DE2i-150/quartus_compile/de2i.qsf
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1099
									
								
								examples/intel/DE2i-150/quartus_compile/de2i.qsf
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										7
									
								
								examples/intel/DE2i-150/quartus_compile/runme_quartus
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								examples/intel/DE2i-150/quartus_compile/runme_quartus
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,7 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| export REV="de2i" | ||||
| 
 | ||||
| quartus_map -c $REV top && \ | ||||
|     quartus_fit -c $REV top && \ | ||||
| 	    quartus_asm -c $REV top | ||||
							
								
								
									
										2
									
								
								examples/intel/DE2i-150/run_cycloneiv
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								examples/intel/DE2i-150/run_cycloneiv
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | |||
| #/bin/env bash | ||||
| yosys -p "synth_intel -family cycloneiv -top top -vout top.vqm" top.v sevenseg.v | ||||
							
								
								
									
										25
									
								
								examples/intel/DE2i-150/sevenseg.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								examples/intel/DE2i-150/sevenseg.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| module sevenseg ( output reg [6:0] HEX0, | ||||
|                   input      [3:0] SW ); | ||||
| 
 | ||||
|    always @(*) begin | ||||
|      case(SW) | ||||
|         4'h1: HEX0 = 7'b1111001;	 | ||||
| 	4'h2: HEX0 = 7'b0100100; 	 | ||||
| 	4'h3: HEX0 = 7'b0110000; 	 | ||||
| 	4'h4: HEX0 = 7'b0011001; 	 | ||||
| 	4'h5: HEX0 = 7'b0010010; 	 | ||||
| 	4'h6: HEX0 = 7'b0000010; 	 | ||||
| 	4'h7: HEX0 = 7'b1111000; 	 | ||||
| 	4'h8: HEX0 = 7'b0000000; 	 | ||||
| 	4'h9: HEX0 = 7'b0011000; 	 | ||||
| 	4'ha: HEX0 = 7'b0001000; | ||||
| 	4'hb: HEX0 = 7'b0000011; | ||||
| 	4'hc: HEX0 = 7'b1000110; | ||||
| 	4'hd: HEX0 = 7'b0100001; | ||||
| 	4'he: HEX0 = 7'b0000110; | ||||
| 	4'hf: HEX0 = 7'b0001110; | ||||
| 	4'h0: HEX0 = 7'b1000000; | ||||
|      endcase // case (SW) | ||||
|    end  | ||||
|     | ||||
| endmodule | ||||
							
								
								
									
										15
									
								
								examples/intel/DE2i-150/top.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								examples/intel/DE2i-150/top.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | |||
| `default_nettype none | ||||
| module top ( output wire [6:0] HEX0, HEX1, HEX2, HEX3, HEX4, HEX5, HEX6, HEX7, | ||||
|              input  wire [15:0] SW ); | ||||
|               | ||||
|    | ||||
|     sevenseg UUD0 (.HEX0(HEX0), .SW(4'h7)); | ||||
|     sevenseg UUD1 (.HEX0(HEX1), .SW(4'h1)); | ||||
|     sevenseg UUD2 (.HEX0(HEX2), .SW(4'h0)); | ||||
|     sevenseg UUD3 (.HEX0(HEX3), .SW(4'h2)); | ||||
|     sevenseg UUD4 (.HEX0(HEX4), .SW(SW[3:0])); | ||||
|     sevenseg UUD5 (.HEX0(HEX5), .SW(SW[7:4])); | ||||
|     sevenseg UUD6 (.HEX0(HEX6), .SW(SW[11:8])); | ||||
|     sevenseg UUD7 (.HEX0(HEX7), .SW(SW[15:12])); | ||||
|      | ||||
| endmodule | ||||
							
								
								
									
										1
									
								
								examples/intel/MAX10/run_max10
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								examples/intel/MAX10/run_max10
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| yosys -p "synth_intel -family max10 -top top -vout top.vqm" top.v sevenseg.v | ||||
							
								
								
									
										5
									
								
								examples/intel/MAX10/runme_postsynth
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								examples/intel/MAX10/runme_postsynth
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| iverilog -D POST_IMPL -o verif_post -s tb_top tb_top.v top.vqm $(yosys-config --datdir/altera_intel/max10/cells_comb_max10.v) | ||||
| vvp -N verif_post | ||||
| 
 | ||||
							
								
								
									
										25
									
								
								examples/intel/MAX10/sevenseg.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								examples/intel/MAX10/sevenseg.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| module sevenseg ( output reg [6:0] HEX0, | ||||
|                   input      [3:0] SW ); | ||||
| 
 | ||||
|    always @(*) begin | ||||
|      case(SW) | ||||
|         4'h1: HEX0 = 7'b1111001;	 | ||||
| 	4'h2: HEX0 = 7'b0100100; 	 | ||||
| 	4'h3: HEX0 = 7'b0110000; 	 | ||||
| 	4'h4: HEX0 = 7'b0011001; 	 | ||||
| 	4'h5: HEX0 = 7'b0010010; 	 | ||||
| 	4'h6: HEX0 = 7'b0000010; 	 | ||||
| 	4'h7: HEX0 = 7'b1111000; 	 | ||||
| 	4'h8: HEX0 = 7'b0000000; 	 | ||||
| 	4'h9: HEX0 = 7'b0011000; 	 | ||||
| 	4'ha: HEX0 = 7'b0001000; | ||||
| 	4'hb: HEX0 = 7'b0000011; | ||||
| 	4'hc: HEX0 = 7'b1000110; | ||||
| 	4'hd: HEX0 = 7'b0100001; | ||||
| 	4'he: HEX0 = 7'b0000110; | ||||
| 	4'hf: HEX0 = 7'b0001110; | ||||
| 	4'h0: HEX0 = 7'b1000000; | ||||
|      endcase // case (SW) | ||||
|    end  | ||||
|     | ||||
| endmodule | ||||
							
								
								
									
										15
									
								
								examples/intel/MAX10/top.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								examples/intel/MAX10/top.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | |||
| `default_nettype none | ||||
| module top ( output wire [6:0] HEX0, HEX1, HEX2, HEX3, HEX4, HEX5, HEX6, HEX7, | ||||
|              input  wire [15:0] SW ); | ||||
|               | ||||
|    | ||||
|     sevenseg UUD0 (.HEX0(HEX0), .SW(4'h7)); | ||||
|     sevenseg UUD1 (.HEX0(HEX1), .SW(4'h1)); | ||||
|     sevenseg UUD2 (.HEX0(HEX2), .SW(4'h0)); | ||||
|     sevenseg UUD3 (.HEX0(HEX3), .SW(4'h2)); | ||||
|     sevenseg UUD4 (.HEX0(HEX4), .SW(SW[3:0])); | ||||
|     sevenseg UUD5 (.HEX0(HEX5), .SW(SW[7:4])); | ||||
|     sevenseg UUD6 (.HEX0(HEX6), .SW(SW[11:8])); | ||||
|     sevenseg UUD7 (.HEX0(HEX7), .SW(SW[15:12])); | ||||
|      | ||||
| endmodule | ||||
							
								
								
									
										6
									
								
								examples/intel/asicworld_lfsr/README
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								examples/intel/asicworld_lfsr/README
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,6 @@ | |||
| Source of the files: | ||||
| http://www.asic-world.com/examples/verilog/lfsr.html | ||||
| 
 | ||||
| Run first: runme_presynth | ||||
| Generate output netlist with run_max10 or run_cycloneiv | ||||
| Then, check with: runme_postsynth | ||||
							
								
								
									
										35
									
								
								examples/intel/asicworld_lfsr/lfsr_updown.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								examples/intel/asicworld_lfsr/lfsr_updown.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| `default_nettype none | ||||
| module lfsr_updown ( | ||||
| clk       ,   // Clock input | ||||
| reset     ,   // Reset input | ||||
| enable    ,   // Enable input | ||||
| up_down   ,   // Up Down input | ||||
| count     ,   // Count output | ||||
| overflow      // Overflow output | ||||
| ); | ||||
| 
 | ||||
|  input clk; | ||||
|  input reset; | ||||
|  input enable;  | ||||
|  input up_down; | ||||
| 
 | ||||
|  output [7 : 0] count; | ||||
|  output overflow; | ||||
| 
 | ||||
|  reg [7 : 0] count; | ||||
| 
 | ||||
|  assign overflow = (up_down) ? (count == {{7{1'b0}}, 1'b1}) :  | ||||
|                                (count == {1'b1, {7{1'b0}}}) ; | ||||
| 
 | ||||
|  always @(posedge clk) | ||||
|  if (reset)  | ||||
|     count <= {7{1'b0}}; | ||||
|  else if (enable) begin | ||||
|     if (up_down) begin | ||||
|       count <= {~(^(count & 8'b01100011)),count[7:1]}; | ||||
|     end else begin | ||||
|       count <= {count[5:0],~(^(count &  8'b10110001))}; | ||||
|     end | ||||
|  end | ||||
| 
 | ||||
| endmodule | ||||
							
								
								
									
										34
									
								
								examples/intel/asicworld_lfsr/lfsr_updown_tb.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								examples/intel/asicworld_lfsr/lfsr_updown_tb.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,34 @@ | |||
| module tb(); | ||||
|  reg clk; | ||||
|  reg reset; | ||||
|  reg enable; | ||||
|  reg up_down; | ||||
| 
 | ||||
|  wire [7 : 0] count; | ||||
|  wire overflow; | ||||
| 
 | ||||
| initial begin | ||||
|   $monitor("rst %b en %b updown %b cnt %b overflow %b", | ||||
|      reset,enable,up_down,count, overflow); | ||||
|   clk = 0; | ||||
|   reset = 1; | ||||
|   enable = 0; | ||||
|   up_down = 0; | ||||
|   #10 reset = 0; | ||||
|   #1 enable = 1; | ||||
|   #20 up_down = 1; | ||||
|   #30 $finish; | ||||
| end | ||||
| 
 | ||||
| always #1 clk = ~clk; | ||||
| 
 | ||||
| lfsr_updown U( | ||||
| .clk      ( clk      ), | ||||
| .reset    ( reset    ), | ||||
| .enable   ( enable   ), | ||||
| .up_down  ( up_down  ), | ||||
| .count    ( count    ), | ||||
| .overflow ( overflow ) | ||||
| ); | ||||
| 
 | ||||
| endmodule  | ||||
							
								
								
									
										2
									
								
								examples/intel/asicworld_lfsr/run_cycloneiv
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										2
									
								
								examples/intel/asicworld_lfsr/run_cycloneiv
									
										
									
									
									
										Executable file
									
								
							|  | @ -0,0 +1,2 @@ | |||
| #!/bin/env bash | ||||
| yosys -p "synth_intel -family cycloneiv -top lfsr_updown -vout top.vqm" lfsr_updown.v | ||||
							
								
								
									
										2
									
								
								examples/intel/asicworld_lfsr/run_max10
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										2
									
								
								examples/intel/asicworld_lfsr/run_max10
									
										
									
									
									
										Executable file
									
								
							|  | @ -0,0 +1,2 @@ | |||
| #!/bin/env bash | ||||
| yosys -p "synth_intel -family max10 -top lfsr_updown -vout top.vqm" lfsr_updown.v | ||||
							
								
								
									
										5
									
								
								examples/intel/asicworld_lfsr/runme_postsynth
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										5
									
								
								examples/intel/asicworld_lfsr/runme_postsynth
									
										
									
									
									
										Executable file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| iverilog -D POST_IMPL -o verif_post -s tb lfsr_updown_tb.v top.vqm $(yosys-config --datdir/altera_intel/max10/cells_comb_max10.v) | ||||
| vvp -N verif_post | ||||
| 
 | ||||
							
								
								
									
										5
									
								
								examples/intel/asicworld_lfsr/runme_presynth
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										5
									
								
								examples/intel/asicworld_lfsr/runme_presynth
									
										
									
									
									
										Executable file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| iverilog -o presynth lfsr_updown_tb.v lfsr_updown.v &&\ | ||||
| 
 | ||||
| vvp -N presynth | ||||
							
								
								
									
										10
									
								
								techlibs/altera_intel/Makefile.inc
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								techlibs/altera_intel/Makefile.inc
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | |||
| 
 | ||||
| OBJS += techlibs/altera_intel/synth_intel.o | ||||
| 
 | ||||
| #$(eval $(call add_share_file,share/altera_intel,techlibs/altera_intel/lpm_functions.v))
 | ||||
| $(eval $(call add_share_file,share/altera_intel/max10,techlibs/altera_intel/max10/cells_comb_max10.v)) | ||||
| $(eval $(call add_share_file,share/altera_intel/cycloneiv,techlibs/altera_intel/cycloneiv/cells_comb_cycloneiv.v)) | ||||
| $(eval $(call add_share_file,share/altera_intel/max10,techlibs/altera_intel/max10/cells_map_max10.v)) | ||||
| $(eval $(call add_share_file,share/altera_intel/cycloneiv,techlibs/altera_intel/cycloneiv/cells_map_cycloneiv.v)) | ||||
| #$(eval $(call add_share_file,share/altera_intel/max10,techlibs/altera_intel/max10/cells_arith_max10.v))
 | ||||
| 
 | ||||
							
								
								
									
										128
									
								
								techlibs/altera_intel/cycloneiv/cells_comb_cycloneiv.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								techlibs/altera_intel/cycloneiv/cells_comb_cycloneiv.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,128 @@ | |||
| /* | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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 IV (GX) devices Input Buffer Primitive */ | ||||
| module cycloneiv_io_ibuf (output o, input i, input ibar); | ||||
|    assign ibar = ibar; | ||||
|    assign o    = i; | ||||
| endmodule // fiftyfivenm_io_ibuf | ||||
| 
 | ||||
| /* Altera Cyclone IV (GX)  devices Output Buffer Primitive */ | ||||
| module cycloneiv_io_obuf (output o, input i, input oe); | ||||
|    assign o  = i; | ||||
|    assign oe = oe; | ||||
| endmodule // fiftyfivenm_io_obuf | ||||
| 
 | ||||
| /* Altera MAX10 4-input non-fracturable LUT Primitive */  | ||||
| module cycloneiv_lcell_comb (output combout, cout, | ||||
|                              input dataa, datab, datac, datad, cin); | ||||
| 
 | ||||
| /* 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_mask = 16'hFFFF; | ||||
| parameter dont_touch = "off"; | ||||
| parameter lpm_type = "cycloneiv_lcell_comb"; | ||||
| parameter sum_lutc_input = "datac"; | ||||
|    | ||||
| reg [1:0] lut_type;   | ||||
| reg cout_rt; | ||||
| reg combout_rt; | ||||
| wire dataa_w; | ||||
| wire datab_w; | ||||
| wire datac_w; | ||||
| wire datad_w; | ||||
| wire cin_w; | ||||
| 
 | ||||
| assign dataa_w = dataa; | ||||
| assign datab_w = datab; | ||||
| assign datac_w = datac; | ||||
| assign datad_w = datad; | ||||
| 
 | ||||
| function lut_data; | ||||
| 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]; | ||||
|        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_mask, dataa_w, datab_w,  | ||||
|                             datac_w, datad_w); | ||||
|     end | ||||
|     else if (lut_type == 1) begin // arithmetic function | ||||
|         combout_rt = lut_data(lut_mask, dataa_w, datab_w,  | ||||
|                             cin_w, datad_w); | ||||
|     end | ||||
|     cout_rt = lut_data(lut_mask, dataa_w, datab_w, cin_w, 'b0); | ||||
| end | ||||
| 
 | ||||
| assign combout = combout_rt & 1'b1; | ||||
| assign cout = cout_rt & 1'b1; | ||||
| 
 | ||||
| endmodule // cycloneiv_lcell_comb | ||||
| 
 | ||||
| /* Altera Cyclone IV 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 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
							
								
								
									
										61
									
								
								techlibs/altera_intel/cycloneiv/cells_map_cycloneiv.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								techlibs/altera_intel/cycloneiv/cells_map_cycloneiv.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,61 @@ | |||
| /* | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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. | ||||
|  * | ||||
|  */ | ||||
|   | ||||
| // Flip-flop D | ||||
| module  \$_DFF_P_ (input D, input 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 // | ||||
| 
 | ||||
| // Input buffer map | ||||
| module \$__inpad (input I, output O); | ||||
|     cycloneiv_io_ibuf _TECHMAP_REPLACE_ (.o(O), .i(I), .ibar(1'b0)); | ||||
| endmodule  | ||||
| 
 | ||||
| // Output buffer map    | ||||
| module \$__outpad (input I, output O); | ||||
|     cycloneiv_io_obuf _TECHMAP_REPLACE_ (.o(O), .i(I), .oe(1'b1)); | ||||
| endmodule  | ||||
| 
 | ||||
| // LUT Map | ||||
| /* 0 -> datac | ||||
|    1 -> cin */ | ||||
| module \$lut (A, Y); | ||||
|    parameter WIDTH  = 0; | ||||
|    parameter LUT    = 0; | ||||
|    input [WIDTH-1:0] A; | ||||
|    output 	     Y; | ||||
|    generate  | ||||
|       if (WIDTH == 1) begin | ||||
| 	   assign Y = ~A[0]; // Not need to spend 1 logic cell for such an easy function | ||||
|       end else | ||||
|       if (WIDTH == 2) begin | ||||
|            cycloneiv_lcell_comb #(.lut_mask({4{LUT}}), .sum_lutc_input("datac")) _TECHMAP_REPLACE_ (.combout(Y), .dataa(A[0]), .datab(A[1]), .datac(1'b1),.datad(1'b1)); | ||||
|       end else | ||||
|       if(WIDTH == 3) begin  | ||||
| 	   cycloneiv_lcell_comb #(.lut_mask({2{LUT}}), .sum_lutc_input("datac")) _TECHMAP_REPLACE_ (.combout(Y), .dataa(A[0]), .datab(A[1]), .datac(A[2]),.datad(1'b1)); | ||||
|       end else | ||||
|       if(WIDTH == 4) begin | ||||
| 	   cycloneiv_lcell_comb #(.lut_mask(LUT), .sum_lutc_input("datac")) _TECHMAP_REPLACE_ (.combout(Y), .dataa(A[0]), .datab(A[1]), .datac(A[2]),.datad(A[3])); | ||||
|       end else | ||||
| 	   wire _TECHMAP_FAIL_ = 1; | ||||
|    endgenerate | ||||
| endmodule // | ||||
| 
 | ||||
| 	     | ||||
							
								
								
									
										319
									
								
								techlibs/altera_intel/lpm_functions.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										319
									
								
								techlibs/altera_intel/lpm_functions.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,319 @@ | |||
| /* | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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. | ||||
|  * | ||||
|  */ | ||||
|   | ||||
| // NOTE: This is still WIP. | ||||
| (* techmap_celltype = "$altpll" *) | ||||
| module _80_altpll_altera  ( input [1:0] inclk,  | ||||
| 			    input       fbin,  | ||||
| 			    input       pllena,  | ||||
| 			    input       clkswitch,  | ||||
| 			    input       areset,  | ||||
| 			    input       pfdena,  | ||||
| 			    input       clkena,  | ||||
| 			    input       extclkena,  | ||||
| 			    input       scanclk,  | ||||
| 			    input 	scanaclr,  | ||||
| 			    input       scanclkena,  | ||||
| 			    input       scanread,  | ||||
| 			    input       scanwrite,  | ||||
| 			    input       scandata,  | ||||
| 			    input       phasecounterselect,  | ||||
| 			    input       phaseupdown, | ||||
| 			    input       phasestep, | ||||
| 			    input       configupdate, | ||||
| 			    inout       fbmimicbidir, | ||||
| 			     | ||||
| 			    output [width_clock-1:0] clk,  | ||||
| 			    output [3:0]             extclk,      | ||||
| 			    output [1:0]             clkbad,      | ||||
| 			    output 	             enable0,      | ||||
| 			    output 		     enable1,      | ||||
| 			    output 		     activeclock,  | ||||
| 			    output 		     clkloss,      | ||||
| 			    output 		     locked,       | ||||
| 			    output 		     scandataout,  | ||||
| 			    output 		     scandone,     | ||||
| 			    output 		     sclkout0,     | ||||
| 			    output 		     sclkout1,     | ||||
| 			    output 	             phasedone, | ||||
| 			    output 		     vcooverrange, | ||||
| 			    output 		     vcounderrange, | ||||
| 			    output 		     fbout, | ||||
| 			    output 		     fref, | ||||
| 			    output 		     icdrclk ); | ||||
| 			     | ||||
| 			    parameter   intended_device_family    = "MAX 10"; | ||||
| 			    parameter   operation_mode            = "NORMAL"; | ||||
| 			    parameter   pll_type                  = "AUTO"; | ||||
| 			    parameter   qualify_conf_done         = "OFF"; | ||||
| 			    parameter   compensate_clock          = "CLK0"; | ||||
| 			    parameter   scan_chain                = "LONG"; | ||||
| 			    parameter   primary_clock             = "inclk0"; | ||||
| 			    parameter   inclk0_input_frequency    = 1000; | ||||
| 			    parameter   inclk1_input_frequency    = 0; | ||||
| 			    parameter   gate_lock_signal          = "NO"; | ||||
| 			    parameter   gate_lock_counter         = 0; | ||||
| 			    parameter   lock_high                 = 1; | ||||
| 			    parameter   lock_low                  = 0; | ||||
| 			    parameter   valid_lock_multiplier     = 1; | ||||
| 			    parameter   invalid_lock_multiplier   = 5; | ||||
| 			    parameter   switch_over_type          = "AUTO"; | ||||
| 			    parameter   switch_over_on_lossclk    = "OFF" ; | ||||
| 			    parameter   switch_over_on_gated_lock = "OFF" ; | ||||
| 			    parameter   enable_switch_over_counter = "OFF"; | ||||
| 			    parameter   switch_over_counter       = 0; | ||||
| 			    parameter   feedback_source           = "EXTCLK0" ; | ||||
| 			    parameter   bandwidth                 = 0; | ||||
| 			    parameter   bandwidth_type            = "UNUSED"; | ||||
| 			    parameter   lpm_hint                  = "UNUSED"; | ||||
| 			    parameter   spread_frequency          = 0; | ||||
| 			    parameter   down_spread               = "0.0"; | ||||
| 			    parameter   self_reset_on_gated_loss_lock = "OFF"; | ||||
| 			    parameter   self_reset_on_loss_lock = "OFF"; | ||||
| 			    parameter   lock_window_ui           = "0.05"; | ||||
| 			    parameter   width_clock              = 6; | ||||
| 			    parameter   width_phasecounterselect = 4; | ||||
| 			    parameter   charge_pump_current_bits = 9999; | ||||
| 			    parameter   loop_filter_c_bits = 9999; | ||||
| 			    parameter   loop_filter_r_bits = 9999; | ||||
| 			    parameter   scan_chain_mif_file = "UNUSED"; | ||||
| 			    parameter   clk9_multiply_by        = 1; | ||||
| 			    parameter   clk8_multiply_by        = 1; | ||||
| 			    parameter   clk7_multiply_by        = 1; | ||||
| 			    parameter   clk6_multiply_by        = 1; | ||||
| 			    parameter   clk5_multiply_by        = 1; | ||||
| 			    parameter   clk4_multiply_by        = 1; | ||||
| 			    parameter   clk3_multiply_by        = 1; | ||||
| 			    parameter   clk2_multiply_by        = 1; | ||||
| 			    parameter   clk1_multiply_by        = 1; | ||||
| 			    parameter   clk0_multiply_by        = 1; | ||||
| 			    parameter   clk9_divide_by          = 1; | ||||
| 			    parameter   clk8_divide_by          = 1; | ||||
| 			    parameter   clk7_divide_by          = 1; | ||||
| 			    parameter   clk6_divide_by          = 1; | ||||
| 			    parameter   clk5_divide_by          = 1; | ||||
| 			    parameter   clk4_divide_by          = 1; | ||||
| 			    parameter   clk3_divide_by          = 1; | ||||
| 			    parameter   clk2_divide_by          = 1; | ||||
| 			    parameter   clk1_divide_by          = 1; | ||||
| 			    parameter   clk0_divide_by          = 1; | ||||
| 			    parameter   clk9_phase_shift        = "0"; | ||||
| 			    parameter   clk8_phase_shift        = "0"; | ||||
| 			    parameter   clk7_phase_shift        = "0"; | ||||
| 			    parameter   clk6_phase_shift        = "0"; | ||||
| 			    parameter   clk5_phase_shift        = "0"; | ||||
| 			    parameter   clk4_phase_shift        = "0"; | ||||
| 			    parameter   clk3_phase_shift        = "0"; | ||||
| 			    parameter   clk2_phase_shift        = "0"; | ||||
| 			    parameter   clk1_phase_shift        = "0"; | ||||
| 			    parameter   clk0_phase_shift        = "0"; | ||||
| 			     | ||||
| 			    parameter   clk9_duty_cycle         = 50; | ||||
| 			    parameter   clk8_duty_cycle         = 50; | ||||
| 			    parameter   clk7_duty_cycle         = 50; | ||||
| 			    parameter   clk6_duty_cycle         = 50; | ||||
| 			    parameter   clk5_duty_cycle         = 50; | ||||
| 			    parameter   clk4_duty_cycle         = 50; | ||||
| 			    parameter   clk3_duty_cycle         = 50; | ||||
| 			    parameter   clk2_duty_cycle         = 50; | ||||
| 			    parameter   clk1_duty_cycle         = 50; | ||||
| 			    parameter   clk0_duty_cycle         = 50; | ||||
| 
 | ||||
| 			    parameter   clk9_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk8_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk7_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk6_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk5_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk4_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk3_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk2_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk1_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk0_use_even_counter_mode    = "OFF"; | ||||
| 			    parameter   clk9_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk8_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk7_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk6_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk5_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk4_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk3_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk2_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk1_use_even_counter_value   = "OFF"; | ||||
| 			    parameter   clk0_use_even_counter_value   = "OFF"; | ||||
| 
 | ||||
| 			    parameter   clk2_output_frequency   = 0; | ||||
| 			    parameter   clk1_output_frequency   = 0; | ||||
| 			    parameter   clk0_output_frequency   = 0; | ||||
| 
 | ||||
| 			    parameter   vco_min             = 0; | ||||
| 			    parameter   vco_max             = 0; | ||||
| 			    parameter   vco_center          = 0; | ||||
| 			    parameter   pfd_min             = 0; | ||||
| 			    parameter   pfd_max             = 0; | ||||
| 			    parameter   m_initial           = 1; | ||||
| 			    parameter   m                   = 0;  | ||||
| 			    parameter   n                   = 1; | ||||
| 			    parameter   m2                  = 1; | ||||
| 			    parameter   n2                  = 1; | ||||
| 			    parameter   ss                  = 0; | ||||
| 			    parameter   l0_high             = 1; | ||||
| 			    parameter   l1_high             = 1; | ||||
| 			    parameter   g0_high             = 1; | ||||
| 			    parameter   g1_high             = 1; | ||||
| 			    parameter   g2_high             = 1; | ||||
| 			    parameter   g3_high             = 1; | ||||
| 			    parameter   e0_high             = 1; | ||||
| 			    parameter   e1_high             = 1; | ||||
| 			    parameter   e2_high             = 1; | ||||
| 			    parameter   e3_high             = 1; | ||||
| 			    parameter   l0_low              = 1; | ||||
| 			    parameter   l1_low              = 1; | ||||
| 			    parameter   g0_low              = 1; | ||||
| 			    parameter   g1_low              = 1; | ||||
| 			    parameter   g2_low              = 1; | ||||
| 			    parameter   g3_low              = 1; | ||||
| 			    parameter   e0_low              = 1; | ||||
| 			    parameter   e1_low              = 1; | ||||
| 			    parameter   e2_low              = 1; | ||||
| 			    parameter   e3_low              = 1; | ||||
| 			    parameter   l0_initial          = 1; | ||||
| 			    parameter   l1_initial          = 1; | ||||
| 			    parameter   g0_initial          = 1; | ||||
| 			    parameter   g1_initial          = 1; | ||||
| 			    parameter   g2_initial          = 1; | ||||
| 			    parameter   g3_initial          = 1; | ||||
| 			    parameter   e0_initial          = 1; | ||||
| 			    parameter   e1_initial          = 1; | ||||
| 			    parameter   e2_initial          = 1; | ||||
| 			    parameter   e3_initial          = 1; | ||||
| 			    parameter   l0_mode             = "bypass"; | ||||
| 			    parameter   l1_mode             = "bypass"; | ||||
| 			    parameter   g0_mode             = "bypass"; | ||||
| 			    parameter   g1_mode             = "bypass"; | ||||
| 			    parameter   g2_mode             = "bypass"; | ||||
| 			    parameter   g3_mode             = "bypass"; | ||||
| 			    parameter   e0_mode             = "bypass"; | ||||
| 			    parameter   e1_mode             = "bypass"; | ||||
| 			    parameter   e2_mode             = "bypass"; | ||||
| 			    parameter   e3_mode             = "bypass"; | ||||
| 			    parameter   l0_ph               = 0; | ||||
| 			    parameter   l1_ph               = 0; | ||||
| 			    parameter   g0_ph               = 0; | ||||
| 			    parameter   g1_ph               = 0; | ||||
| 			    parameter   g2_ph               = 0; | ||||
| 			    parameter   g3_ph               = 0; | ||||
| 			    parameter   e0_ph               = 0; | ||||
| 			    parameter   e1_ph               = 0; | ||||
| 			    parameter   e2_ph               = 0; | ||||
| 			    parameter   e3_ph               = 0; | ||||
| 			    parameter   m_ph                = 0; | ||||
| 			    parameter   l0_time_delay       = 0; | ||||
| 			    parameter   l1_time_delay       = 0; | ||||
| 			    parameter   g0_time_delay       = 0; | ||||
| 			    parameter   g1_time_delay       = 0; | ||||
| 			    parameter   g2_time_delay       = 0; | ||||
| 			    parameter   g3_time_delay       = 0; | ||||
| 			    parameter   e0_time_delay       = 0; | ||||
| 			    parameter   e1_time_delay       = 0; | ||||
| 			    parameter   e2_time_delay       = 0; | ||||
| 			    parameter   e3_time_delay       = 0; | ||||
| 			    parameter   m_time_delay        = 0; | ||||
| 			    parameter   n_time_delay        = 0; | ||||
| 			    parameter   extclk3_counter     = "e3" ; | ||||
| 			    parameter   extclk2_counter     = "e2" ; | ||||
| 			    parameter   extclk1_counter     = "e1" ; | ||||
| 			    parameter   extclk0_counter     = "e0" ; | ||||
| 			    parameter   clk9_counter        = "c9" ; | ||||
| 			    parameter   clk8_counter        = "c8" ; | ||||
| 			    parameter   clk7_counter        = "c7" ; | ||||
| 			    parameter   clk6_counter        = "c6" ; | ||||
| 			    parameter   clk5_counter        = "l1" ; | ||||
| 			    parameter   clk4_counter        = "l0" ; | ||||
| 			    parameter   clk3_counter        = "g3" ; | ||||
| 			    parameter   clk2_counter        = "g2" ; | ||||
| 			    parameter   clk1_counter        = "g1" ; | ||||
| 			    parameter   clk0_counter        = "g0" ; | ||||
| 			    parameter   enable0_counter     = "l0"; | ||||
| 			    parameter   enable1_counter     = "l0"; | ||||
| 			    parameter   charge_pump_current = 2; | ||||
| 			    parameter   loop_filter_r       = "1.0"; | ||||
| 			    parameter   loop_filter_c       = 5; | ||||
| 			    parameter   vco_post_scale      = 0; | ||||
| 			    parameter   vco_frequency_control = "AUTO"; | ||||
| 			    parameter   vco_phase_shift_step = 0; | ||||
| 			    parameter   lpm_type            = "altpll"; | ||||
| 
 | ||||
| 			    parameter port_clkena0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkena1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkena2 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkena3 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkena4 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkena5 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclkena0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclkena1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclkena2 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclkena3 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclk0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclk1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclk2 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_extclk3 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk2 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk3 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk4 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk5 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk6 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk7 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk8 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clk9 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scandata = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scandataout = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scandone = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_sclkout1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_sclkout0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkbad0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkbad1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_activeclock = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkloss = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_inclk1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_inclk0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_fbin = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_fbout = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_pllena = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_clkswitch = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_areset = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_pfdena = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scanclk = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scanaclr = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scanread = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scanwrite = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_enable0 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_enable1 = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_locked = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_configupdate = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_phasecounterselect = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_phasedone = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_phasestep = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_phaseupdown = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_vcooverrange = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_vcounderrange = "PORT_CONNECTIVITY"; | ||||
| 			    parameter port_scanclkena = "PORT_CONNECTIVITY"; | ||||
| 			    parameter using_fbmimicbidir_port = "ON"; | ||||
| 
 | ||||
| endmodule | ||||
							
								
								
									
										62
									
								
								techlibs/altera_intel/max10/cells_arith_max10.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								techlibs/altera_intel/max10/cells_arith_max10.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,62 @@ | |||
| /* | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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. | ||||
|  * | ||||
|  */ | ||||
| 
 | ||||
| // NOTE: This is still WIP. | ||||
| (* techmap_celltype = "$alu" *) | ||||
| module _80_altera_max10_alu (A, B, CI, BI, X, Y, CO); | ||||
|    parameter A_SIGNED = 0; | ||||
|    parameter B_SIGNED = 0; | ||||
|    parameter A_WIDTH  = 1; | ||||
|    parameter B_WIDTH  = 1; | ||||
|    parameter Y_WIDTH  = 1; | ||||
|    parameter LUT      = 0; | ||||
|     | ||||
|    input [A_WIDTH-1:0] A; | ||||
|    input [B_WIDTH-1:0] B; | ||||
|    output [Y_WIDTH-1:0] X, Y; | ||||
| 
 | ||||
|    input 		CI, BI; | ||||
|    output [Y_WIDTH-1:0] CO; | ||||
| 
 | ||||
|    wire 		_TECHMAP_FAIL_ = Y_WIDTH <= 2; | ||||
| 
 | ||||
|    wire                 tempcombout; | ||||
|    wire [Y_WIDTH-1:0] 	A_buf, B_buf; | ||||
|    \$pos #(.A_SIGNED(A_SIGNED), .A_WIDTH(A_WIDTH), .Y_WIDTH(Y_WIDTH)) A_conv (.A(A), .Y(A_buf)); | ||||
|    \$pos #(.A_SIGNED(B_SIGNED), .A_WIDTH(B_WIDTH), .Y_WIDTH(Y_WIDTH)) B_conv (.A(B), .Y(B_buf)); | ||||
| 
 | ||||
|    wire [Y_WIDTH-1:0] AA = A_buf; | ||||
|    wire [Y_WIDTH-1:0] BB = BI ? ~B_buf : B_buf; | ||||
|    wire [Y_WIDTH-1:0] C = {CO, CI}; | ||||
|     | ||||
|    genvar i; | ||||
| 	generate for (i = 0; i < Y_WIDTH; i = i + 1) begin:slice | ||||
| 	   fiftyfivenm_lcell_comb #(.lut_mask(LUT), .sum_lutc_input("cin")) _TECHMAP_REPLACE_  | ||||
| 	                                                                             ( .dataa(AA),  | ||||
| 										       .datab(BB),  | ||||
| 										       .datac(C),  | ||||
| 										       .datad(1'b0),  | ||||
| 										       .cin(C[i]),  | ||||
| 										       .cout(CO[i]), | ||||
| 										       .combout(Y[i]) ); | ||||
| 	  end: slice | ||||
| 	endgenerate | ||||
|   assign X = C; | ||||
| endmodule | ||||
|     | ||||
							
								
								
									
										128
									
								
								techlibs/altera_intel/max10/cells_comb_max10.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								techlibs/altera_intel/max10/cells_comb_max10.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,128 @@ | |||
| /* | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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 MAX10 devices Input Buffer Primitive */  | ||||
| module fiftyfivenm_io_ibuf (output o, input i, input ibar); | ||||
|    assign ibar = ibar; | ||||
|    assign o    = i; | ||||
| endmodule // fiftyfivenm_io_ibuf | ||||
| 
 | ||||
| /* Altera MAX10 devices Output Buffer Primitive */ | ||||
| module fiftyfivenm_io_obuf (output o, input i, input oe); | ||||
|    assign o  = i; | ||||
|    assign oe = oe; | ||||
| endmodule // fiftyfivenm_io_obuf | ||||
| 
 | ||||
| /* Altera MAX10 4-input non-fracturable LUT Primitive */  | ||||
| module fiftyfivenm_lcell_comb (output combout, cout, | ||||
|                                input  dataa, datab, datac, datad, cin); | ||||
|                                 | ||||
| /* 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_mask = 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; | ||||
| reg combout_rt; | ||||
| wire dataa_w; | ||||
| wire datab_w; | ||||
| wire datac_w; | ||||
| wire datad_w; | ||||
| wire cin_w; | ||||
| 
 | ||||
| assign dataa_w = dataa; | ||||
| assign datab_w = datab; | ||||
| assign datac_w = datac; | ||||
| assign datad_w = datad; | ||||
| 
 | ||||
| function lut_data; | ||||
| 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]; | ||||
|        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_mask, dataa_w, datab_w,  | ||||
|                             datac_w, datad_w); | ||||
|     end | ||||
|     else if (lut_type == 1) begin // arithmetic function | ||||
|         combout_rt = lut_data(lut_mask, dataa_w, datab_w,  | ||||
|                             cin_w, datad_w); | ||||
|     end | ||||
|     cout_rt = lut_data(lut_mask, dataa_w, datab_w, cin_w, 'b0); | ||||
| end | ||||
| 
 | ||||
| assign combout = 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 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
							
								
								
									
										61
									
								
								techlibs/altera_intel/max10/cells_map_max10.v
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								techlibs/altera_intel/max10/cells_map_max10.v
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,61 @@ | |||
| /* | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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. | ||||
|  * | ||||
|  */ | ||||
|   | ||||
| // Flip-flop D | ||||
| module  \$_DFF_P_ (input D, input 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 // | ||||
| 
 | ||||
| // Input buffer map | ||||
| module \$__inpad (input I, output O); | ||||
|     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)); | ||||
| endmodule  | ||||
| 
 | ||||
| // LUT Map | ||||
| /* 0 -> datac | ||||
|    1 -> cin */ | ||||
| module \$lut (A, Y); | ||||
|    parameter WIDTH  = 0; | ||||
|    parameter LUT    = 0; | ||||
|    input [WIDTH-1:0] A; | ||||
|    output 	     Y; | ||||
|    generate  | ||||
|       if (WIDTH == 1) begin | ||||
| 	   assign Y = ~A[0]; // Not need to spend 1 logic cell for such an easy function | ||||
|       end else | ||||
|       if (WIDTH == 2) begin | ||||
|            fiftyfivenm_lcell_comb #(.lut_mask({4{LUT}}), .sum_lutc_input("datac")) _TECHMAP_REPLACE_ (.combout(Y), .dataa(A[0]), .datab(A[1]), .datac(1'b1),.datad(1'b1)); | ||||
|       end else | ||||
|       if(WIDTH == 3) begin  | ||||
| 	   fiftyfivenm_lcell_comb #(.lut_mask({2{LUT}}), .sum_lutc_input("datac")) _TECHMAP_REPLACE_ (.combout(Y), .dataa(A[0]), .datab(A[1]), .datac(A[2]),.datad(1'b1)); | ||||
|       end else | ||||
|       if(WIDTH == 4) begin | ||||
| 	   fiftyfivenm_lcell_comb #(.lut_mask(LUT), .sum_lutc_input("datac")) _TECHMAP_REPLACE_ (.combout(Y), .dataa(A[0]), .datab(A[1]), .datac(A[2]),.datad(A[3])); | ||||
|       end else | ||||
| 	   wire _TECHMAP_FAIL_ = 1; | ||||
|    endgenerate | ||||
| endmodule // | ||||
| 
 | ||||
| 	     | ||||
							
								
								
									
										199
									
								
								techlibs/altera_intel/synth_intel.cc
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										199
									
								
								techlibs/altera_intel/synth_intel.cc
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,199 @@ | |||
| /*
 | ||||
|  *  yosys -- Yosys Open SYnthesis Suite | ||||
|  * | ||||
|  *  Copyright (C) 2012  Clifford Wolf <clifford@clifford.at> | ||||
|  * | ||||
|  *  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. | ||||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #include "kernel/register.h" | ||||
| #include "kernel/celltypes.h" | ||||
| #include "kernel/rtlil.h" | ||||
| #include "kernel/log.h" | ||||
| 
 | ||||
| USING_YOSYS_NAMESPACE | ||||
| PRIVATE_NAMESPACE_BEGIN | ||||
| 
 | ||||
| struct SynthIntelPass : public ScriptPass { | ||||
| 	SynthIntelPass() : ScriptPass("synth_intel", "synthesis for Intel (Altera) FPGAs.") { } | ||||
| 
 | ||||
| 	virtual void help() YS_OVERRIDE | ||||
| 	{ | ||||
| 		//   |---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|---v---|
 | ||||
| 		log("\n"); | ||||
| 		log("    synth_intel [options]\n"); | ||||
| 		log("\n"); | ||||
| 		log("This command runs synthesis for Intel FPGAs. This work is still experimental.\n"); | ||||
| 		log("\n"); | ||||
| 		log("    -family < max10 | cycloneiv >\n"); | ||||
| 		log("        generate the synthesis netlist for the specified family.\n"); | ||||
| 		log("        MAX10 is the default target if not family argument specified \n"); | ||||
| 		log("\n"); | ||||
| 		log("    -top <module>\n"); | ||||
| 		log("        use the specified module as top module (default='top')\n"); | ||||
| 		log("\n"); | ||||
| 		log("    -vout <file>\n"); | ||||
| 		log("        write the design to the specified Verilog netlist file. 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"); | ||||
| 		log("        synonymous to the end of the command list.\n"); | ||||
| 		log("\n"); | ||||
| 		log("    -retime\n"); | ||||
| 		log("        run 'abc' with -dff option\n"); | ||||
| 		log("\n"); | ||||
| 		log("\n"); | ||||
| 		log("The following commands are executed by this synthesis command:\n"); | ||||
| 		help_script(); | ||||
| 		log("\n"); | ||||
| 	} | ||||
| 
 | ||||
|         string top_opt, family_opt, vout_file; | ||||
| 	bool retime; | ||||
| 
 | ||||
| 	virtual void clear_flags() YS_OVERRIDE | ||||
| 	{ | ||||
| 		top_opt = "-auto-top"; | ||||
|                 family_opt = "max10"; | ||||
| 		vout_file = ""; | ||||
| 		retime = false; | ||||
| 	} | ||||
| 
 | ||||
| 	virtual void execute(std::vector<std::string> args, RTLIL::Design *design) YS_OVERRIDE | ||||
| 	{ | ||||
| 	  string run_from, run_to; | ||||
| 		clear_flags(); | ||||
| 
 | ||||
| 		size_t argidx; | ||||
| 		for (argidx = 1; argidx < args.size(); argidx++) | ||||
| 		{ | ||||
| 		        if (args[argidx] == "-family" && argidx+1 < args.size()) { | ||||
| 				family_opt = args[++argidx]; | ||||
| 				continue; | ||||
| 			} | ||||
| 			if (args[argidx] == "-top" && argidx+1 < args.size()) { | ||||
| 				top_opt = "-top " + args[++argidx]; | ||||
| 				continue; | ||||
| 			} | ||||
| 			if (args[argidx] == "-vout" && argidx+1 < args.size()) { | ||||
| 				vout_file = args[++argidx]; | ||||
| 				continue; | ||||
| 			} | ||||
| 			if (args[argidx] == "-run" && argidx+1 < args.size()) { | ||||
| 				size_t pos = args[argidx+1].find(':'); | ||||
| 				if (pos == std::string::npos) | ||||
| 					break; | ||||
| 				run_from = args[++argidx].substr(0, pos); | ||||
| 				run_to = args[argidx].substr(pos+1); | ||||
| 				continue; | ||||
| 			} | ||||
| 			if (args[argidx] == "-retime") { | ||||
| 				retime = true; | ||||
| 				continue; | ||||
| 			} | ||||
| 			break; | ||||
| 		} | ||||
| 		extra_args(args, argidx, design); | ||||
| 
 | ||||
| 		if (!design->full_selection()) | ||||
| 			log_cmd_error("This comannd only operates on fully selected designs!\n"); | ||||
| 		 | ||||
|                 if (family_opt != "max10" && family_opt !="cycloneiv" ) | ||||
| 		  log_cmd_error("Invalid or not family specified: '%s'\n", family_opt.c_str()); | ||||
| 
 | ||||
| 		log_header(design, "Executing SYNTH_INTEL pass.\n"); | ||||
| 		log_push(); | ||||
| 
 | ||||
| 		run_script(design, run_from, run_to); | ||||
| 
 | ||||
| 		log_pop(); | ||||
| 	} | ||||
| 
 | ||||
| 	virtual void script() YS_OVERRIDE | ||||
| 	{ | ||||
| 	  if (check_label("begin")) | ||||
| 	  { | ||||
| 		  if(check_label("family") && family_opt=="max10") | ||||
| 		  { | ||||
| 			run("read_verilog -lib +/altera_intel/max10/cells_comb_max10.v"); | ||||
| 			run(stringf("hierarchy -check %s", help_mode ? "-top <top>" : top_opt.c_str())); | ||||
| 		  } | ||||
| 		  else | ||||
| 		  { | ||||
| 		      run("read_verilog -lib +/altera_intel/cycloneiv/cells_comb_cycloneiv.v"); | ||||
| 		      run(stringf("hierarchy -check %s", help_mode ? "-top <top>" : top_opt.c_str())); | ||||
| 		  } | ||||
| 	  } | ||||
| 
 | ||||
| 		if (check_label("flatten")) | ||||
| 		{ | ||||
| 			run("proc"); | ||||
| 			run("flatten"); | ||||
| 			run("tribuf -logic"); | ||||
| 			run("deminout"); | ||||
| 		} | ||||
| 
 | ||||
| 		if (check_label("coarse")) | ||||
| 		{ | ||||
| 			run("synth -run coarse"); | ||||
| 		} | ||||
| 
 | ||||
| 		if (check_label("fine")) | ||||
| 		{ | ||||
| 		        run("opt -fast -full"); | ||||
| 			run("memory_map"); | ||||
| 			run("opt -full"); | ||||
| 			run("techmap -map +/techmap.v"); | ||||
|                         run("opt -fast"); | ||||
| 			run("clean -purge"); | ||||
| 			run("setundef -undriven -zero"); | ||||
| 			if (retime || help_mode) | ||||
| 				run("abc -dff", "(only if -retime)"); | ||||
| 		} | ||||
| 
 | ||||
| 		if (check_label("map_luts")) | ||||
| 		{ | ||||
| 		        run("abc -lut 4"); | ||||
| 			run("clean"); | ||||
| 		} | ||||
| 
 | ||||
| 		if (check_label("map_cells")) | ||||
| 		{ | ||||
| 			run("iopadmap -bits -outpad $__outpad I:O -inpad $__inpad O:I"); | ||||
| 			if(family_opt=="max10") | ||||
| 			  run("techmap -map +/altera_intel/max10/cells_map_max10.v"); | ||||
| 			else | ||||
| 			  run("techmap -map +/altera_intel/cycloneiv/cells_map_cycloneiv.v"); | ||||
| 			run("clean -purge"); | ||||
| 		} | ||||
| 
 | ||||
| 		if (check_label("check")) | ||||
| 		{ | ||||
| 			run("hierarchy -check"); | ||||
| 			run("stat"); | ||||
| 			run("check -noinit"); | ||||
| 		} | ||||
| 
 | ||||
| 		if (check_label("vout")) | ||||
| 		{ | ||||
| 			if (!vout_file.empty() || help_mode) | ||||
| 				run(stringf("write_verilog -nodec -attr2comment -defparam -nohex -renameprefix yosys_ %s", | ||||
| 						help_mode ? "<file-name>" : vout_file.c_str())); | ||||
| 		} | ||||
| 	} | ||||
| } SynthIntelPass; | ||||
| 
 | ||||
| PRIVATE_NAMESPACE_END | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue