mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 09:24:37 +00:00 
			
		
		
		
	move microchip tests from techlibs/microchip/tests to tests/arch/microchip
This commit is contained in:
		
							parent
							
								
									19d3214861
								
							
						
					
					
						commit
						e3c4791e5b
					
				
					 42 changed files with 0 additions and 0 deletions
				
			
		|  | @ -1,38 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 Registers( | ||||
| 	input clk, | ||||
| 	input en, | ||||
| 	input rst, | ||||
| 	input D, | ||||
| 	output Q | ||||
| ); | ||||
| parameter LOAD_DATA = 1; | ||||
| 
 | ||||
| // active low async reset
 | ||||
| always @(posedge clk, negedge rst) begin | ||||
| 	if (rst == 0) begin | ||||
| 		Q <= LOAD_DATA; | ||||
| 	end else if(en) begin | ||||
| 		Q <= D; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,23 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| # read verilog files | ||||
| read_verilog Registers.v | ||||
| 
 | ||||
| synth_microchip -top Registers -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| # write final outputfile | ||||
| write_verilog -noexpr Registers.vm | ||||
|  | @ -1,34 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 carryout (cout,out,a, b,c); | ||||
| parameter n = 6; | ||||
| parameter k = 2; | ||||
| output reg [k*(n+1)-1:0] out; | ||||
| output reg cout; | ||||
| input [n:0] a; | ||||
| input [n:0] b; | ||||
| input [n-1:0] c; | ||||
| 
 | ||||
| 	always @(a,b,c)  | ||||
| 	begin | ||||
| 		{cout,out} = a * b + c; | ||||
| 		 | ||||
| 	end | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog carryout.v | ||||
| 
 | ||||
| synth_microchip -top carryout -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr carryout.vm | ||||
|  | @ -1,38 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 cascade( | ||||
| 	input signed [5:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [4:0] in_D, | ||||
| 	output signed [11:0] out_P, | ||||
| 
 | ||||
| 	input signed [4:0] casA, | ||||
| 	input signed [4:0] casB | ||||
| 
 | ||||
| ); | ||||
| 
 | ||||
| wire signed [9:0] cascade; | ||||
| // first dsp
 | ||||
| assign cascade = casA * casB; | ||||
| 
 | ||||
| // second dsp
 | ||||
| assign out_P = in_A * (in_B + in_D) + cascade; | ||||
| 
 | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog cascade.v | ||||
| 
 | ||||
| synth_microchip -top cascade -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr cascade.vm | ||||
|  | @ -1,42 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 dff_opt( | ||||
| 	input clk, | ||||
| 	input [1:0] D_comb, | ||||
| 	input [1:0] EN_comb, | ||||
| 	input [1:0] RST_comb, | ||||
| 	output bar | ||||
| ); | ||||
| 
 | ||||
| // DFF with enable that can be merged into D
 | ||||
| 
 | ||||
| reg foo; | ||||
| 
 | ||||
| assign bar = foo; | ||||
| 
 | ||||
| // sync reset
 | ||||
| always@(posedge clk) begin | ||||
| 	if (&RST_comb) begin | ||||
| 		foo <= 0; | ||||
| 	end else begin | ||||
| 		foo <= &D_comb; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| read_verilog dff_opt.v  | ||||
| 
 | ||||
| synth_microchip -top dff_opt -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| # write final outputfile | ||||
| write_verilog -noexpr dff_opt.vm | ||||
|  | @ -1,30 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 full_dsp( | ||||
| 	input signed[5:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [11:0] in_C, | ||||
| 	input signed [4:0] in_D, | ||||
| 
 | ||||
| 	output signed [12:0] out_Y | ||||
| ); | ||||
| 
 | ||||
| assign out_Y = ((in_D + in_B)*in_A)+in_C; | ||||
| 
 | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog full_dsp.v | ||||
| 
 | ||||
| synth_microchip -top full_dsp -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr full_dsp.vm | ||||
|  | @ -1,25 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 large_mult( | ||||
| 	input signed [20:0] in1, | ||||
| 	input signed [17:0] in2, | ||||
| 	output signed [38:0] out1 | ||||
| ); | ||||
| assign out1 = in1 * in2; | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog large_mult.v | ||||
| 
 | ||||
| synth_microchip -top large_mult -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr large_mult.vm | ||||
|  | @ -1,43 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 mac( | ||||
| 	input clk, | ||||
| 	input signed [4:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [4:0] in_D, | ||||
| 	output reg signed [11:0] out_P, | ||||
| 
 | ||||
| 	input srst_P, | ||||
| 
 | ||||
| 	input signed [4:0] casA, | ||||
| 	input signed [4:0] casB | ||||
| 
 | ||||
| ); | ||||
| 
 | ||||
| 
 | ||||
| // sync reset P
 | ||||
| always@(posedge clk) begin | ||||
| 	if (~srst_P) begin | ||||
| 		out_P <= 12'h000; | ||||
| 	end else begin | ||||
| 		out_P <= in_A * (in_B + in_D) + out_P; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,24 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| # read verilog files | ||||
| read_verilog mac.v | ||||
| 
 | ||||
| # run the synth flow, specifies top module and additional parameters | ||||
| synth_microchip -top mac -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| # write final outputfile | ||||
| write_verilog -noexpr mac.vm | ||||
|  | @ -1,30 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 postAdd_mult( | ||||
| 	input signed[17:0] in_A, | ||||
| 	input signed [17:0] in_B, | ||||
| 	input signed [17:0] in_C, | ||||
| 
 | ||||
| 	output signed [35:0] out_Y | ||||
| ); | ||||
| 
 | ||||
| assign out_Y = (in_B*in_A)+in_C; | ||||
| 
 | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog postAdd_mult.v | ||||
| 
 | ||||
| synth_microchip -top postAdd_mult -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr postAdd_mult.vm | ||||
|  | @ -1,32 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 post_adder( | ||||
| 	input signed [5:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [4:0] in_D, | ||||
| 	input signed [11:0] in_C, | ||||
| 
 | ||||
| 	output [12:0] out_Y | ||||
| ); | ||||
| 
 | ||||
| assign out_Y = (in_D + in_B) * in_A + in_C; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog post_adder.v | ||||
| 
 | ||||
| synth_microchip -top post_adder -abc9 -family polarfire | ||||
| 
 | ||||
| write_verilog -noexpr post_adder.vm | ||||
|  | @ -1,30 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 pre_adder_dsp( | ||||
| 	input signed [5:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [4:0] in_D, | ||||
| 
 | ||||
| 	output [11:0] out_Y | ||||
| ); | ||||
| 
 | ||||
| assign out_Y = in_A * (in_B + in_D); | ||||
| 
 | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog pre_adder_dsp.v | ||||
| 
 | ||||
| synth_microchip -top pre_adder_dsp -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr pre_adder_dsp.vm | ||||
|  | @ -1,39 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 ram_SDP(data,waddr,we,clk,q); | ||||
| parameter d_width = 32; | ||||
| parameter addr_width = 8; | ||||
| parameter mem_depth = 256; | ||||
| input [d_width-1:0] data; | ||||
| input [addr_width-1:0] waddr; | ||||
| input we, clk; | ||||
| output reg [d_width-1:0] q; | ||||
| 
 | ||||
| reg [d_width-1:0] mem [mem_depth-1:0]; | ||||
| 
 | ||||
| always @(posedge clk) begin | ||||
| 	if (we) begin  | ||||
| 		mem[waddr] <= data; | ||||
| 	end else begin | ||||
| 		q <= mem[waddr]; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| endmodule | ||||
| 
 | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog ram_SDP.v | ||||
| 
 | ||||
| synth_microchip -top ram_SDP -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr ram_SDP.vm | ||||
|  | @ -1,56 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 ram_TDP (clka,clkb,wea,addra,dataina,qa,web,addrb,datainb,qb); | ||||
| parameter addr_width = 10; | ||||
| parameter data_width = 2; | ||||
| input clka,clkb,wea,web; | ||||
| input [data_width - 1 : 0] dataina,datainb; | ||||
| input [addr_width - 1 : 0] addra,addrb; | ||||
| output reg [data_width - 1 : 0] qa,qb; | ||||
| reg [addr_width - 1 : 0] addra_reg, addrb_reg; | ||||
| reg [data_width - 1 : 0] mem [(2**addr_width) - 1 : 0]; | ||||
| 
 | ||||
| always @ (posedge clka) | ||||
| 	begin | ||||
| 		addra_reg <= addra; | ||||
| 		if(wea) | ||||
| 			mem[addra] <= dataina; | ||||
| 	end | ||||
| 
 | ||||
| always @ (posedge clkb) | ||||
| begin | ||||
| addrb_reg <= addrb; | ||||
| if(web) | ||||
| mem[addrb] <= datainb; | ||||
| end | ||||
| 
 | ||||
| always @ (posedge clka) | ||||
| begin | ||||
| if(~wea) | ||||
| qa <= mem[addra]; | ||||
| else qa <= dataina; | ||||
| end | ||||
| 
 | ||||
| always @ (posedge clkb) | ||||
| begin | ||||
| if(~web) | ||||
| qb <= mem[addrb]; | ||||
| else qb <= datainb; | ||||
| end | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog ram_TDP.v | ||||
| 
 | ||||
| synth_microchip -top ram_TDP -abc9 -family polarfire -noiopad -debug_memory | ||||
| 
 | ||||
| write_verilog -noexpr ram_TDP.vm | ||||
|  | @ -1,29 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 reduce( | ||||
| 	input [7:0] data, | ||||
| 	output Y | ||||
| 
 | ||||
| ); | ||||
| 
 | ||||
| 
 | ||||
| assign Y = ^data; | ||||
| 
 | ||||
| endmodule | ||||
| 
 | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog reduce.v | ||||
| 
 | ||||
| synth_microchip -top reduce -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr reduce.vm | ||||
|  | @ -1,122 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 reg_c( | ||||
| 	input clk, | ||||
| 
 | ||||
| 	// active high
 | ||||
| 	input en_A, | ||||
| 	input en_B, | ||||
| 	input en_D, | ||||
| 	input en_P, | ||||
| 
 | ||||
| 	// active low
 | ||||
| 	input srst_A, | ||||
| 	input srst_B, | ||||
| 	input srst_D, | ||||
| 	input srst_P, | ||||
| 
 | ||||
| 	// active low
 | ||||
| 	input arst_D, | ||||
| 
 | ||||
| 	input srst_C, | ||||
| 	input arst_C, | ||||
| 
 | ||||
| 
 | ||||
| 	input signed [5:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [4:0] in_C, | ||||
| 	input signed [4:0] in_D, | ||||
| 
 | ||||
| 
 | ||||
| 	output reg [11:0] out_P | ||||
| 
 | ||||
| ); | ||||
| 
 | ||||
| 
 | ||||
| // MACC_PA takes active low resets
 | ||||
| wire srst_A_N; | ||||
| wire srst_B_N; | ||||
| wire srst_C_N; | ||||
| wire srst_D_N; | ||||
| wire srst_P_N; | ||||
| assign srst_A_N = ~srst_A; | ||||
| assign srst_B_N = ~srst_B; | ||||
| assign srst_C_N = ~srst_C; | ||||
| assign srst_D_N = ~srst_D; | ||||
| assign srst_P_N = ~srst_P; | ||||
| 
 | ||||
| // input reg
 | ||||
| reg signed [5:0] reg_A; | ||||
| reg signed [4:0] reg_B; | ||||
| reg signed [4:0] reg_C; | ||||
| reg signed [4:0] reg_D; | ||||
| 
 | ||||
| // sync reset A
 | ||||
| always@(posedge clk) begin | ||||
| 	// if (~srst_A_N) begin
 | ||||
| 	if (srst_A_N) begin | ||||
| 		reg_A = 6'b000000; | ||||
| 	end else begin | ||||
| 		reg_A = in_A; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| // sync reset B
 | ||||
| always@(posedge clk) begin | ||||
| 	if (srst_B_N) begin | ||||
| 		reg_B = 5'b00000; | ||||
| 	end else begin | ||||
| 		reg_B = in_B; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| // async reset D
 | ||||
| always@(posedge clk, negedge arst_D) begin | ||||
| 	if (~arst_D) begin | ||||
| 		reg_D = 5'b00000; | ||||
| 	end else begin | ||||
| 		reg_D = in_D; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| // sync reset C
 | ||||
| always@(posedge clk) begin | ||||
| if (srst_C_N) begin | ||||
| 	reg_C = 5'b00000; | ||||
| end else begin | ||||
| 	reg_C = in_C; | ||||
| end | ||||
| end | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| // sync reset P
 | ||||
| always@(posedge clk) begin | ||||
| if (srst_P_N) begin | ||||
| 	out_P = 12'h000; | ||||
| end else begin | ||||
| 	out_P = reg_A * (reg_B + reg_D) + reg_C; | ||||
| end | ||||
| end | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog reg_c.v | ||||
| 
 | ||||
| synth_microchip -top reg_c -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr reg_c.vm | ||||
|  | @ -1,97 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 reg_test( | ||||
| 	input clk, | ||||
| 
 | ||||
| 	// active high
 | ||||
| 	input en_A, | ||||
| 	input en_B, | ||||
| 	input en_D, | ||||
| 	input en_P, | ||||
| 
 | ||||
| 	// active low
 | ||||
| 	input srst_A, | ||||
| 	input srst_B, | ||||
| 	input srst_D, | ||||
| 	input srst_P, | ||||
| 
 | ||||
| 	// active low
 | ||||
| 	input arst_D, | ||||
| 
 | ||||
| 	input signed [5:0] in_A, | ||||
| 	input signed [4:0] in_B, | ||||
| 	input signed [4:0] in_D, | ||||
| 
 | ||||
| 	output reg [11:0] out_P | ||||
| 
 | ||||
| ); | ||||
| 
 | ||||
| 
 | ||||
| // MACC_PA takes active low resets
 | ||||
| wire srst_A_N; | ||||
| wire srst_B_N; | ||||
| wire srst_D_N; | ||||
| wire srst_P_N; | ||||
| assign srst_A_N = ~srst_A; | ||||
| assign srst_B_N = ~srst_B; | ||||
| assign srst_D_N = ~srst_D; | ||||
| assign srst_P_N = ~srst_P; | ||||
| 
 | ||||
| // input reg
 | ||||
| reg signed [5:0] reg_A; | ||||
| reg signed [4:0] reg_B; | ||||
| reg signed [4:0] reg_D; | ||||
| 
 | ||||
| // sync reset A
 | ||||
| always@(posedge clk) begin | ||||
| 	if (srst_A_N) begin | ||||
| 		reg_A = 6'b000000; | ||||
| 	end else begin | ||||
| 		reg_A = in_A; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| // sync reset B
 | ||||
| always@(posedge clk) begin | ||||
| 	if (srst_B_N) begin | ||||
| 		reg_B = 5'b00000; | ||||
| 	end else begin | ||||
| 		reg_B = in_B; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| // async reset D
 | ||||
| always@(posedge clk, negedge arst_D) begin | ||||
| 	if (~arst_D) begin | ||||
| 		reg_D = 5'b00000; | ||||
| 	end else begin | ||||
| 		reg_D = in_D; | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| // sync reset P
 | ||||
| always@(posedge clk) begin | ||||
| 	if (srst_P_N) begin | ||||
| 		out_P = 12'h000; | ||||
| 	end else begin | ||||
| 		out_P = reg_A * (reg_B + reg_D); | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog reg_test.v | ||||
| 
 | ||||
| synth_microchip -top reg_test -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr reg_test.vm | ||||
|  | @ -1,28 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 signed_mult( | ||||
| 	input signed [17:0] in_A, | ||||
| 	input signed [17:0] in_B, | ||||
| 
 | ||||
| 	output signed [35:0] out_Y | ||||
| ); | ||||
| 
 | ||||
| assign out_Y = in_A * in_B; | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog signed_mult.v | ||||
| 
 | ||||
| synth_microchip -top signed_mult -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr signed_mult.vm | ||||
|  | @ -1,37 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 simple_ram (clk,wr,addr,din,dout); | ||||
| input clk; | ||||
| input [19:0] din; | ||||
| input wr; | ||||
| input [9:0] addr; | ||||
| output [19:0] dout; | ||||
| 
 | ||||
| 
 | ||||
| reg [9:0] addr_reg; | ||||
| reg [19:0] mem [0:1023] ; | ||||
| assign dout = mem[addr_reg]; | ||||
| 
 | ||||
| always@(posedge clk) begin | ||||
| 	addr_reg <= addr; | ||||
| 	if(wr) | ||||
| 		mem[addr]<= din; | ||||
| end | ||||
| endmodule | ||||
| 
 | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog simple_ram.v | ||||
| 
 | ||||
| synth_microchip -top simple_ram -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr simple_ram.vm | ||||
|  | @ -1,28 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 unsigned_mult( | ||||
| 	input [10:0] in_A, | ||||
| 	input signed [10:0] in_B, | ||||
| 
 | ||||
| 	output [21:0] out_Y | ||||
| ); | ||||
| 
 | ||||
| assign out_Y = in_A * in_B; | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog unsigned_mult.v | ||||
| 
 | ||||
| synth_microchip -top unsigned_mult -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr unsigned_mult.vm | ||||
|  | @ -1,38 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 uram_ar(data,waddr,we,clk,q); | ||||
| parameter d_width = 27; | ||||
| parameter addr_width = 2; | ||||
| parameter mem_depth = 4; | ||||
| input [d_width-1:0] data; | ||||
| input [addr_width-1:0] waddr; | ||||
| input we, clk; | ||||
| output [d_width-1:0] q; | ||||
| 
 | ||||
| reg [d_width-1:0] mem [mem_depth-1:0]; | ||||
| 
 | ||||
| assign q = mem[waddr]; | ||||
| 
 | ||||
| always @(posedge clk) begin | ||||
| 	if (we)  | ||||
| 		mem[waddr] <= data; | ||||
| 
 | ||||
| end | ||||
| 
 | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog uram_ar.v | ||||
| 
 | ||||
| synth_microchip -top uram_ar -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr uram_ar.vm | ||||
|  | @ -1,32 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 uram_sr(clk, wr, raddr, din, waddr, dout); | ||||
| input clk; | ||||
| input [11:0] din; | ||||
| input wr; | ||||
| input [5:0] waddr, raddr; | ||||
| output [11:0] dout; | ||||
| reg [5:0] raddr_reg; | ||||
| reg [11:0] mem [0:63]; | ||||
| assign dout = mem[raddr_reg]; | ||||
| always@(posedge clk) begin | ||||
| 	raddr_reg <= raddr; if(wr) | ||||
| 	mem[waddr]<= din; | ||||
| end | ||||
| endmodule | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog uram_sr.v | ||||
| 
 | ||||
| synth_microchip -top uram_sr -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr uram_sr.vm | ||||
|  | @ -1,48 +0,0 @@ | |||
| /* | ||||
| ISC License | ||||
| 
 | ||||
| Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| 
 | ||||
| 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 widemux( | ||||
| 	input [3:0] data, | ||||
| 	input S0, | ||||
| 	input S1, | ||||
| 	output Y | ||||
| 
 | ||||
| ); | ||||
| 
 | ||||
| wire A, B; | ||||
| 
 | ||||
| always @ (*) begin  | ||||
| 		if (S0)begin | ||||
| 		A = data[1]; | ||||
| 		B = data[3]; | ||||
| 		end else begin  | ||||
| 		A = data[0]; | ||||
| 		B = data[2]; | ||||
| 	end | ||||
| 
 | ||||
| 	if (S1)begin | ||||
| 		Y = A; | ||||
| 	end else begin | ||||
| 		Y = B; | ||||
| 	end | ||||
| 
 | ||||
| end | ||||
| endmodule | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | @ -1,21 +0,0 @@ | |||
| # ISC License | ||||
| #  | ||||
| # Copyright (C) 2024 Microchip Technology Inc. and its subsidiaries | ||||
| #  | ||||
| # 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. | ||||
| 
 | ||||
| read_verilog widemux.v | ||||
| 
 | ||||
| synth_microchip -top widemux -abc9 -family polarfire -noiopad | ||||
| 
 | ||||
| write_verilog -noexpr widemux.vm | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue