mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 17:29:23 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			406 lines
		
	
	
	
		
			7.7 KiB
		
	
	
	
		
			Verilog
		
	
	
	
	
	
			
		
		
	
	
			406 lines
		
	
	
	
		
			7.7 KiB
		
	
	
	
		
			Verilog
		
	
	
	
	
	
| module inpad (
 | |
|   output Q,
 | |
|   (* iopad_external_pin *)
 | |
|   input P
 | |
| );
 | |
|   specify
 | |
|     (P => Q) = 0;
 | |
|   endspecify
 | |
|   assign Q = P;
 | |
| endmodule
 | |
| 
 | |
| module outpad (
 | |
|   (* iopad_external_pin *)
 | |
|   output P,
 | |
|   input A
 | |
| );
 | |
|   specify
 | |
|     (A => P) = 0;
 | |
|   endspecify
 | |
|   assign P = A;
 | |
| endmodule
 | |
| 
 | |
| module ckpad (
 | |
|   output Q,
 | |
|   (* iopad_external_pin *)
 | |
|   input P
 | |
| );
 | |
|   specify
 | |
|     (P => Q) = 0;
 | |
|   endspecify
 | |
|   assign Q = P;
 | |
| endmodule
 | |
| 
 | |
| module bipad (
 | |
|   input A,
 | |
|   input EN,
 | |
|   output Q,
 | |
|   (* iopad_external_pin *)
 | |
|   inout P
 | |
| );
 | |
|   assign Q = P;
 | |
|   assign P = EN ? A : 1'bz;
 | |
| endmodule
 | |
| 
 | |
| module dff (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
|   initial Q = INIT;
 | |
|   always @(posedge CLK) Q <= D;
 | |
| endmodule
 | |
| 
 | |
| module dffc (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLR
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
|   initial Q = INIT;
 | |
| 
 | |
|   always @(posedge CLK or posedge CLR)
 | |
|     if (CLR) Q <= 1'b0;
 | |
|     else Q <= D;
 | |
| endmodule
 | |
| 
 | |
| module dffp (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK,
 | |
|   (* clkbuf_sink *)
 | |
|   input PRE
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
|   initial Q = INIT;
 | |
| 
 | |
|   always @(posedge CLK or posedge PRE)
 | |
|     if (PRE) Q <= 1'b1;
 | |
|     else Q <= D;
 | |
| endmodule
 | |
| 
 | |
| module dffpc (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLR,
 | |
|   (* clkbuf_sink *)
 | |
|   input PRE
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
|   initial Q = INIT;
 | |
| 
 | |
|   always @(posedge CLK or posedge CLR or posedge PRE)
 | |
|     if (CLR) Q <= 1'b0;
 | |
|     else if (PRE) Q <= 1'b1;
 | |
|     else Q <= D;
 | |
| endmodule
 | |
| 
 | |
| module dffe (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK,
 | |
|   input EN
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
|   initial Q = INIT;
 | |
|   always @(posedge CLK) if (EN) Q <= D;
 | |
| endmodule
 | |
| 
 | |
| module dffec (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK,
 | |
|   input EN,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLR
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
|   initial Q = INIT;
 | |
| 
 | |
|   always @(posedge CLK or posedge CLR)
 | |
|     if (CLR) Q <= 1'b0;
 | |
|     else if (EN) Q <= D;
 | |
| endmodule
 | |
| 
 | |
| (* lib_whitebox *)
 | |
| module dffepc (
 | |
|   output reg Q,
 | |
|   input D,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLK,
 | |
|   input EN,
 | |
|   (* clkbuf_sink *)
 | |
|   input CLR,
 | |
|   (* clkbuf_sink *)
 | |
|   input PRE
 | |
| );
 | |
|   parameter [0:0] INIT = 1'b0;
 | |
| 
 | |
|   specify
 | |
|     if (EN) (posedge CLK => (Q : D)) = 1701; // QCK -> QZ
 | |
|     if (CLR) (CLR => Q) = 967; // QRT -> QZ
 | |
|     if (PRE) (PRE => Q) = 1252; // QST -> QZ
 | |
|     $setup(D, posedge CLK, 216); // QCK -> QDS
 | |
|     $setup(EN, posedge CLK, 590); // QCK -> QEN
 | |
|   endspecify
 | |
| 
 | |
|   initial Q = INIT;
 | |
|   always @(posedge CLK or posedge CLR or posedge PRE)
 | |
|     if (CLR) Q <= 1'b0;
 | |
|     else if (PRE) Q <= 1'b1;
 | |
|     else if (EN) Q <= D;
 | |
| endmodule
 | |
| 
 | |
| //                  FZ       FS F2 (F1 TO 0)
 | |
| (* abc9_box, lib_whitebox *)
 | |
| module AND2I0 (
 | |
|   output Q,
 | |
|   input A, B
 | |
| );
 | |
|   specify
 | |
|     (A => Q) = 698; // FS -> FZ
 | |
|     (B => Q) = 639; // F2 -> FZ
 | |
|   endspecify
 | |
| 
 | |
|   assign Q = A ? B : 0;
 | |
| endmodule
 | |
| 
 | |
| (* abc9_box, lib_whitebox *)
 | |
| module mux2x0 (
 | |
|   output Q,
 | |
|   input S, A, B
 | |
| );
 | |
|   specify
 | |
|     (S => Q) = 698; // FS -> FZ
 | |
|     (A => Q) = 639; // F1 -> FZ
 | |
|     (B => Q) = 639; // F2 -> FZ
 | |
|   endspecify
 | |
| 
 | |
|   assign Q = S ? B : A;
 | |
| endmodule
 | |
| 
 | |
| (* abc9_box, lib_whitebox *)
 | |
| module mux2x1 (
 | |
|   output Q,
 | |
|   input S, A, B
 | |
| );
 | |
|   specify
 | |
|     (S => Q) = 698; // FS -> FZ
 | |
|     (A => Q) = 639; // F1 -> FZ
 | |
|     (B => Q) = 639; // F2 -> FZ
 | |
|   endspecify
 | |
| 
 | |
|   assign Q = S ? B : A;
 | |
| endmodule
 | |
| 
 | |
| (* abc9_box, lib_whitebox *)
 | |
| module mux4x0 (
 | |
|   output Q,
 | |
|   input S0, S1, A, B, C, D
 | |
| );
 | |
|   specify
 | |
|     (S0 => Q) = 1251; // TAB -> TZ
 | |
|     (S1 => Q) = 1406; // TSL -> TZ
 | |
|     (A => Q) = 1699;  // TA1 -> TZ
 | |
|     (B => Q) = 1687;  // TA2 -> TZ
 | |
|     (C => Q) = 1669;  // TB1 -> TZ
 | |
|     (D => Q) = 1679;  // TB2 -> TZ
 | |
|   endspecify
 | |
| 
 | |
|   assign Q = S1 ? (S0 ? D : C) : (S0 ? B : A);
 | |
| endmodule
 | |
| 
 | |
| // S0 BSL TSL
 | |
| // S1 BAB TAB
 | |
| // S2 TBS
 | |
| // A TA1
 | |
| // B TA2
 | |
| // C TB1
 | |
| // D TB2
 | |
| // E BA1
 | |
| // F BA2
 | |
| // G BB1
 | |
| // H BB2
 | |
| // Q CZ
 | |
| (* abc9_box, lib_whitebox *)
 | |
| module mux8x0 (
 | |
|   output Q,
 | |
|   input S0, S1, S2, A, B, C, D, E, F, G, H
 | |
| );
 | |
|   specify
 | |
|     (S0 => Q) = 1593; // ('TSL', 'BSL') -> CZ
 | |
|     (S1 => Q) = 1437; // ('TAB', 'BAB') -> CZ
 | |
|     (S2 => Q) = 995; // TBS -> CZ
 | |
|     (A => Q) = 1887; // TA1 -> CZ
 | |
|     (B => Q) = 1873; // TA2 -> CZ
 | |
|     (C => Q) = 1856; // TB1 -> CZ
 | |
|     (D => Q) = 1860; // TB2 -> CZ
 | |
|     (E => Q) = 1714; // BA1 -> CZ
 | |
|     (F => Q) = 1773; // BA2 -> CZ
 | |
|     (G => Q) = 1749; // BB1 -> CZ
 | |
|     (H => Q) = 1723; // BB2 -> CZ
 | |
|   endspecify
 | |
| 
 | |
|   assign Q = S2 ? (S1 ? (S0 ? H : G) : (S0 ? F : E)) : (S1 ? (S0 ? D : C) : (S0 ? B : A));
 | |
| endmodule
 | |
| 
 | |
| (* blackbox *)
 | |
| (* keep *)
 | |
| module qlal4s3b_cell_macro (
 | |
|   input WB_CLK,
 | |
|   input WBs_ACK,
 | |
|   input [31:0] WBs_RD_DAT,
 | |
|   output [3:0] WBs_BYTE_STB,
 | |
|   output WBs_CYC,
 | |
|   output WBs_WE,
 | |
|   output WBs_RD,
 | |
|   output WBs_STB,
 | |
|   output [16:0] WBs_ADR,
 | |
|   input [3:0] SDMA_Req,
 | |
|   input [3:0] SDMA_Sreq,
 | |
|   output [3:0] SDMA_Done,
 | |
|   output [3:0] SDMA_Active,
 | |
|   input [3:0] FB_msg_out,
 | |
|   input [7:0] FB_Int_Clr,
 | |
|   output FB_Start,
 | |
|   input FB_Busy,
 | |
|   output WB_RST,
 | |
|   output Sys_PKfb_Rst,
 | |
|   output Clk16,
 | |
|   output Clk16_Rst,
 | |
|   output Clk21,
 | |
|   output Clk21_Rst,
 | |
|   output Sys_Pclk,
 | |
|   output Sys_Pclk_Rst,
 | |
|   input Sys_PKfb_Clk,
 | |
|   input [31:0] FB_PKfbData,
 | |
|   output [31:0] WBs_WR_DAT,
 | |
|   input [3:0] FB_PKfbPush,
 | |
|   input FB_PKfbSOF,
 | |
|   input FB_PKfbEOF,
 | |
|   output [7:0] Sensor_Int,
 | |
|   output FB_PKfbOverflow,
 | |
|   output [23:0] TimeStamp,
 | |
|   input Sys_PSel,
 | |
|   input [15:0] SPIm_Paddr,
 | |
|   input SPIm_PEnable,
 | |
|   input SPIm_PWrite,
 | |
|   input [31:0] SPIm_PWdata,
 | |
|   output SPIm_PReady,
 | |
|   output SPIm_PSlvErr,
 | |
|   output [31:0] SPIm_Prdata,
 | |
|   input [15:0] Device_ID,
 | |
|   input [13:0] FBIO_In_En,
 | |
|   input [13:0] FBIO_Out,
 | |
|   input [13:0] FBIO_Out_En,
 | |
|   output [13:0] FBIO_In,
 | |
|   inout [13:0] SFBIO,
 | |
|   input Device_ID_6S,
 | |
|   input Device_ID_4S,
 | |
|   input SPIm_PWdata_26S,
 | |
|   input SPIm_PWdata_24S,
 | |
|   input SPIm_PWdata_14S,
 | |
|   input SPIm_PWdata_11S,
 | |
|   input SPIm_PWdata_0S,
 | |
|   input SPIm_Paddr_8S,
 | |
|   input SPIm_Paddr_6S,
 | |
|   input FB_PKfbPush_1S,
 | |
|   input FB_PKfbData_31S,
 | |
|   input FB_PKfbData_21S,
 | |
|   input FB_PKfbData_19S,
 | |
|   input FB_PKfbData_9S,
 | |
|   input FB_PKfbData_6S,
 | |
|   input Sys_PKfb_ClkS,
 | |
|   input FB_BusyS,
 | |
|   input WB_CLKS
 | |
| );
 | |
| 
 | |
| endmodule
 | |
| 
 | |
| (* abc9_lut=1, lib_whitebox *)
 | |
| module LUT1 (
 | |
|   output O,
 | |
|   input I0
 | |
| );
 | |
|   parameter [1:0] INIT = 0;
 | |
|   parameter EQN = "(I0)";
 | |
| 
 | |
|   // These timings are for PolarPro 3E; other families will need updating.
 | |
|   specify
 | |
|     (I0 => O) = 698; // FS -> FZ
 | |
|   endspecify
 | |
| 
 | |
|   assign O = I0 ? INIT[1] : INIT[0];
 | |
| endmodule
 | |
| 
 | |
| //               TZ        TSL TAB
 | |
| (* abc9_lut=2, lib_whitebox *)
 | |
| module LUT2 (
 | |
|   output O,
 | |
|   input I0, I1
 | |
| );
 | |
|   parameter [3:0] INIT = 4'h0;
 | |
|   parameter EQN = "(I0)";
 | |
| 
 | |
|   // These timings are for PolarPro 3E; other families will need updating.
 | |
|   specify
 | |
|     (I0 => O) = 1251; // TAB -> TZ
 | |
|     (I1 => O) = 1406; // TSL -> TZ
 | |
|   endspecify
 | |
| 
 | |
|   wire [1:0] s1 = I1 ? INIT[3:2] : INIT[1:0];
 | |
|   assign O = I0 ? s1[1] : s1[0];
 | |
| endmodule
 | |
| 
 | |
| (* abc9_lut=2, lib_whitebox *)
 | |
| module LUT3 (
 | |
|   output O,
 | |
|   input I0, I1, I2
 | |
| );
 | |
|   parameter [7:0] INIT = 8'h0;
 | |
|   parameter EQN = "(I0)";
 | |
| 
 | |
|   // These timings are for PolarPro 3E; other families will need updating.
 | |
|   specify
 | |
|     (I0 => O) = 1251; // TAB -> TZ
 | |
|     (I1 => O) = 1406; // TSL -> TZ
 | |
|     (I2 => O) = 1699; // ('TA1', 'TA2', 'TB1', 'TB2') -> TZ
 | |
|   endspecify
 | |
| 
 | |
|   wire [3:0] s2 = I2 ? INIT[7:4] : INIT[3:0];
 | |
|   wire [1:0] s1 = I1 ? s2[3:2] : s2[1:0];
 | |
|   assign O = I0 ? s1[1] : s1[0];
 | |
| endmodule
 | |
| 
 | |
| (* abc9_lut=4, lib_whitebox *)
 | |
| module LUT4 (
 | |
|   output O,
 | |
|   input I0, I1, I2, I3
 | |
| );
 | |
|   parameter [15:0] INIT = 16'h0;
 | |
|   parameter EQN = "(I0)";
 | |
| 
 | |
|   // These timings are for PolarPro 3E; other families will need updating.
 | |
|   specify
 | |
|     (I0 => O) = 995;  // TBS -> CZ
 | |
|     (I1 => O) = 1437; // ('TAB', 'BAB') -> CZ
 | |
|     (I2 => O) = 1593; // ('TSL', 'BSL') -> CZ
 | |
|     (I3 => O) = 1887; // ('TA1', 'TA2', 'TB1', 'TB2', 'BA1', 'BA2', 'BB1', 'BB2') -> CZ
 | |
|   endspecify
 | |
| 
 | |
|   wire [7:0] s3 = I3 ? INIT[15:8] : INIT[7:0];
 | |
|   wire [3:0] s2 = I2 ? s3[7:4] : s3[3:0];
 | |
|   wire [1:0] s1 = I1 ? s2[3:2] : s2[1:0];
 | |
|   assign O = I0 ? s1[1] : s1[0];
 | |
| endmodule
 |