diff options
author | Clifford Wolf <clifford@clifford.at> | 2018-12-05 09:08:04 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-05 09:08:04 -0800 |
commit | 1a260ce89b79f0d4c2092f725b48583bd5e7bc41 (patch) | |
tree | bef82baea6124458d7acc43bddbcfa990ee81876 /techlibs/anlogic/cells_sim.v | |
parent | 2d98db73e39f17865ae26cdd00cf7c112521649f (diff) | |
parent | 43030db5fff285de85096aaf5578b0548659f6b7 (diff) | |
download | yosys-1a260ce89b79f0d4c2092f725b48583bd5e7bc41.tar.gz yosys-1a260ce89b79f0d4c2092f725b48583bd5e7bc41.tar.bz2 yosys-1a260ce89b79f0d4c2092f725b48583bd5e7bc41.zip |
Merge pull request #712 from mmicko/anlogic-support
Initial support for Anlogic FPGA
Diffstat (limited to 'techlibs/anlogic/cells_sim.v')
-rw-r--r-- | techlibs/anlogic/cells_sim.v | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/techlibs/anlogic/cells_sim.v b/techlibs/anlogic/cells_sim.v new file mode 100644 index 000000000..60a367928 --- /dev/null +++ b/techlibs/anlogic/cells_sim.v @@ -0,0 +1,103 @@ +module AL_MAP_SEQ ( + output q, + input ce, + input clk, + input sr, + input d +); + parameter DFFMODE = "FF"; //FF,LATCH + parameter REGSET = "RESET"; //RESET/SET + parameter SRMUX = "SR"; //SR/INV + parameter SRMODE = "SYNC"; //SYNC/ASYNC +endmodule + +module AL_MAP_LUT1 ( + output o, + input a +); + parameter [1:0] INIT = 2'h0; + parameter EQN = "(A)"; + assign Y = INIT >> A; +endmodule + +module AL_MAP_LUT2 ( + output o, + input a, + input b +); + parameter [3:0] INIT = 4'h0; + parameter EQN = "(A)"; + assign o = INIT >> {b, a}; +endmodule + +module AL_MAP_LUT3 ( + output o, + input a, + input b, + input c +); + parameter [7:0] INIT = 8'h0; + parameter EQN = "(A)"; + assign o = INIT >> {c, b, a}; +endmodule + +module AL_MAP_LUT4 ( + output o, + input a, + input b, + input c, + input d +); + parameter [15:0] INIT = 16'h0; + parameter EQN = "(A)"; + assign o = INIT >> {d, c, b, a}; +endmodule + +module AL_MAP_LUT5 ( + output o, + input a, + input b, + input c, + input d, + input e +); + parameter [31:0] INIT = 32'h0; + parameter EQN = "(A)"; + assign o = INIT >> {e, d, c, b, a}; +endmodule + + +module AL_MAP_LUT6 ( + output o, + input a, + input b, + input c, + input d, + input e, + input f +); + parameter [63:0] INIT = 64'h0; + parameter EQN = "(A)"; + assign o = INIT >> {f, e, d, c, b, a}; +endmodule + +module AL_MAP_ALU2B ( + input cin, + input a0, b0, c0, d0, + input a1, b1, c1, d1, + output s0, s1, cout +); + parameter [15:0] INIT0 = 16'h0000; + parameter [15:0] INIT1 = 16'h0000; + parameter FUNC0 = "NO"; + parameter FUNC1 = "NO"; +endmodule + +module AL_MAP_ADDER ( + input a, + input b, + input c, + output [1:0] o +); + parameter ALUTYPE = "ADD"; +endmodule |