diff options
author | Dan Ravensloft <dan.ravensloft@gmail.com> | 2020-04-25 17:25:59 +0100 |
---|---|---|
committer | Marcelina KoĆcielnicka <mwk@0x04.net> | 2020-07-05 05:39:20 +0200 |
commit | b004f0901873962ba4a6fd3e12c7bc0cc1e04032 (patch) | |
tree | 16d1bceb58a8b58690b5ba849173bfeef015bd4e /techlibs/intel_alm/common/dsp_map.v | |
parent | 01772dec8c13fb331df439319f4619b6292d6409 (diff) | |
download | yosys-b004f0901873962ba4a6fd3e12c7bc0cc1e04032.tar.gz yosys-b004f0901873962ba4a6fd3e12c7bc0cc1e04032.tar.bz2 yosys-b004f0901873962ba4a6fd3e12c7bc0cc1e04032.zip |
intel_alm: DSP inference
Diffstat (limited to 'techlibs/intel_alm/common/dsp_map.v')
-rw-r--r-- | techlibs/intel_alm/common/dsp_map.v | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/techlibs/intel_alm/common/dsp_map.v b/techlibs/intel_alm/common/dsp_map.v new file mode 100644 index 000000000..d1bc25e65 --- /dev/null +++ b/techlibs/intel_alm/common/dsp_map.v @@ -0,0 +1,49 @@ +module __MUL27X27(A, B, Y); + +parameter A_SIGNED = 1; +parameter B_SIGNED = 1; +parameter A_WIDTH = 27; +parameter B_WIDTH = 27; +parameter Y_WIDTH = 54; + +input [A_WIDTH-1:0] A; +input [B_WIDTH-1:0] B; +output [Y_WIDTH-1:0] Y; + +MISTRAL_MUL27X27 _TECHMAP_REPLACE_ (.A(A), .B(B), .Y(Y)); + +endmodule + + +module __MUL18X18(A, B, Y); + +parameter A_SIGNED = 1; +parameter B_SIGNED = 1; +parameter A_WIDTH = 18; +parameter B_WIDTH = 18; +parameter Y_WIDTH = 36; + +input [A_WIDTH-1:0] A; +input [B_WIDTH-1:0] B; +output [Y_WIDTH-1:0] Y; + +MISTRAL_MUL18X18 _TECHMAP_REPLACE_ (.A(A), .B(B), .Y(Y)); + +endmodule + + +module __MUL9X9(A, B, Y); + +parameter A_SIGNED = 1; +parameter B_SIGNED = 1; +parameter A_WIDTH = 9; +parameter B_WIDTH = 9; +parameter Y_WIDTH = 18; + +input [A_WIDTH-1:0] A; +input [B_WIDTH-1:0] B; +output [Y_WIDTH-1:0] Y; + +MISTRAL_MUL9X9 _TECHMAP_REPLACE_ (.A(A), .B(B), .Y(Y)); + +endmodule |