diff options
author | Clifford Wolf <clifford@clifford.at> | 2019-08-07 12:30:52 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-08-07 12:30:52 +0200 |
commit | 4c49ddf36af217d0dfa7dbd9d7e24b4dbc388ba9 (patch) | |
tree | 3247c746f2982ff7ce557d045b1c88eda0cb7089 /techlibs | |
parent | 679bc6507f08cab33de0c46b3a96bfaeab2069f4 (diff) | |
parent | 837cb0a1b9c9a774512481d0812c28f927985e7b (diff) | |
download | yosys-4c49ddf36af217d0dfa7dbd9d7e24b4dbc388ba9.tar.gz yosys-4c49ddf36af217d0dfa7dbd9d7e24b4dbc388ba9.tar.bz2 yosys-4c49ddf36af217d0dfa7dbd9d7e24b4dbc388ba9.zip |
Merge pull request #1249 from mmicko/anlogic_fix
anlogic : Fix alu mapping
Diffstat (limited to 'techlibs')
-rw-r--r-- | techlibs/anlogic/arith_map.v | 24 |
1 files changed, 8 insertions, 16 deletions
diff --git a/techlibs/anlogic/arith_map.v b/techlibs/anlogic/arith_map.v index 11cd140ec..6d6a7ca37 100644 --- a/techlibs/anlogic/arith_map.v +++ b/techlibs/anlogic/arith_map.v @@ -42,10 +42,9 @@ module _80_anlogic_alu (A, B, CI, BI, X, Y, CO); wire [Y_WIDTH-1:0] AA = A_buf; wire [Y_WIDTH-1:0] BB = BI ? ~B_buf : B_buf; wire [Y_WIDTH+1:0] COx; - wire [Y_WIDTH+1:0] C = {COx, CI}; + wire [Y_WIDTH+2:0] C = {COx, CI}; wire dummy; - (* keep *) AL_MAP_ADDER #( .ALUTYPE("ADD_CARRY")) adder_cin ( @@ -55,19 +54,6 @@ module _80_anlogic_alu (A, B, CI, BI, X, Y, CO); genvar i; generate for (i = 0; i < Y_WIDTH; i = i + 1) begin: slice - if(i==Y_WIDTH-1) begin - (* keep *) - AL_MAP_ADDER #( - .ALUTYPE("ADD")) - adder_cout ( - .c(C[Y_WIDTH]), - .o(COx[Y_WIDTH]) - ); - assign CO = COx[Y_WIDTH]; - end - else - begin - (* keep *) AL_MAP_ADDER #( .ALUTYPE("ADD") ) adder_i ( @@ -76,9 +62,15 @@ module _80_anlogic_alu (A, B, CI, BI, X, Y, CO); .c(C[i+1]), .o({COx[i+1],Y[i]}) ); - end end: slice endgenerate /* End implementation */ + AL_MAP_ADDER #( + .ALUTYPE("ADD")) + adder_cout ( + .c(C[Y_WIDTH+1]), + .o(COx[Y_WIDTH+1]) + ); + assign CO = COx[Y_WIDTH+1]; assign X = AA ^ BB; endmodule
\ No newline at end of file |