diff options
| author | Marcelina KoĆcielnicka <mwk@0x04.net> | 2020-05-18 18:15:03 +0200 | 
|---|---|---|
| committer | Marcelina KoĆcielnicka <mwk@0x04.net> | 2020-05-19 01:42:40 +0200 | 
| commit | aee439360bba642dcbffe5b803aa9a994b11d183 (patch) | |
| tree | a5c15b4a6172ea3ff651f88174fff7d5269ad1c2 /techlibs/intel/max10 | |
| parent | 2d573a0ff680eb9f38358943fbf134f765ba1451 (diff) | |
| download | yosys-aee439360bba642dcbffe5b803aa9a994b11d183.tar.gz yosys-aee439360bba642dcbffe5b803aa9a994b11d183.tar.bz2 yosys-aee439360bba642dcbffe5b803aa9a994b11d183.zip | |
Add force_downto and force_upto wire attributes.
Fixes #2058.
Diffstat (limited to 'techlibs/intel/max10')
| -rw-r--r-- | techlibs/intel/max10/cells_arith.v | 6 | ||||
| -rw-r--r-- | techlibs/intel/max10/cells_map.v | 1 | 
2 files changed, 7 insertions, 0 deletions
| diff --git a/techlibs/intel/max10/cells_arith.v b/techlibs/intel/max10/cells_arith.v index e2194cbd7..8529706a7 100644 --- a/techlibs/intel/max10/cells_arith.v +++ b/techlibs/intel/max10/cells_arith.v @@ -26,8 +26,11 @@ module _80_altera_max10_alu (A, B, CI, BI, X, Y, CO);     parameter B_WIDTH  = 1;     parameter Y_WIDTH  = 1; +	(* force_downto *)  	input [A_WIDTH-1:0] A; +	(* force_downto *)  	input [B_WIDTH-1:0] B; +	(* force_downto *)  	output [Y_WIDTH-1:0] X, Y;  	input CI, BI; @@ -36,11 +39,14 @@ module _80_altera_max10_alu (A, B, CI, BI, X, Y, CO);  	wire _TECHMAP_FAIL_ = Y_WIDTH <= 4; +	(* force_downto *)  	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)); +	(* force_downto *)  	wire [Y_WIDTH-1:0] AA = A_buf; +	(* force_downto *)  	wire [Y_WIDTH-1:0] BB = BI ? ~B_buf : B_buf;  	//wire [Y_WIDTH:0] C = {CO, CI};          wire [Y_WIDTH+1:0] COx; diff --git a/techlibs/intel/max10/cells_map.v b/techlibs/intel/max10/cells_map.v index 6d604e072..6a4072049 100644 --- a/techlibs/intel/max10/cells_map.v +++ b/techlibs/intel/max10/cells_map.v @@ -71,6 +71,7 @@ endmodule  module \$lut (A, Y);     parameter WIDTH  = 0;     parameter LUT    = 0; +   (* force_downto *)     input [WIDTH-1:0] A;     output            Y;     generate | 
