📄 dcfifo_qlk1.tdf
字号:
--dcfifo_mixed_widths CARRY_CHAIN="MANUAL" CARRY_CHAIN_LENGTH=48 DEVICE_FAMILY="Cyclone II" IGNORE_CARRY_BUFFERS="OFF" LPM_NUMWORDS=512 LPM_SHOWAHEAD="OFF" LPM_WIDTH=16 LPM_WIDTH_R=16 LPM_WIDTHU=9 LPM_WIDTHU_R=9 OVERFLOW_CHECKING="ON" RAM_BLOCK_TYPE="M4K" RDSYNC_DELAYPIPE=4 UNDERFLOW_CHECKING="ON" USE_EAB="ON" WRSYNC_DELAYPIPE=4 aclr data q rdclk rdempty rdreq rdusedw wrclk wrfull wrreq wrusedw CYCLONEII_M4K_COMPATIBILITY="ON" INTENDED_DEVICE_FAMILY="Cyclone II" LOW_POWER_MODE="AUTO" lpm_hint="RAM_BLOCK_TYPE=M4K" ALTERA_INTERNAL_OPTIONS=AUTO_SHIFT_REGISTER_RECOGNITION=OFF
--VERSION_BEGIN 7.2 cbx_a_gray2bin 2006:02:28:14:37:30:SJ cbx_a_graycounter 2007:02:22:13:58:22:SJ cbx_altdpram 2007:04:25:14:55:30:SJ cbx_altsyncram 2007:08:27:07:35:30:SJ cbx_cycloneii 2007:06:13:15:47:32:SJ cbx_dcfifo 2007:07:31:10:15:48:SJ cbx_fifo_common 2007:04:09:14:30:26:SJ cbx_flex10ke 2006:01:09:11:13:48:SJ cbx_lpm_add_sub 2007:08:06:16:01:34:SJ cbx_lpm_compare 2007:06:21:15:54:06:SJ cbx_lpm_counter 2007:08:07:01:40:08:SJ cbx_lpm_decode 2007:03:12:19:01:52:SJ cbx_lpm_mux 2007:05:11:14:07:38:SJ cbx_mgl 2007:08:03:15:48:12:SJ cbx_scfifo 2007:04:06:15:45:12:SJ cbx_stratix 2007:05:02:16:27:14:SJ cbx_stratixii 2007:06:28:17:26:26:SJ cbx_stratixiii 2007:06:28:17:15:56:SJ cbx_util_mgl 2007:06:01:06:37:30:SJ VERSION_END
-- Copyright (C) 1991-2007 Altera Corporation
-- Your use of Altera Corporation's design tools, logic functions
-- and other software and tools, and its AMPP partner logic
-- functions, and any output files from any of the foregoing
-- (including device programming or simulation files), and any
-- associated documentation or information are expressly subject
-- to the terms and conditions of the Altera Program License
-- Subscription Agreement, Altera MegaCore Function License
-- Agreement, or other applicable license agreement, including,
-- without limitation, that your use is for the sole purpose of
-- programming logic devices manufactured by Altera and sold by
-- Altera or its authorized distributors. Please refer to the
-- applicable agreement for further details.
FUNCTION a_gray2bin_kdb (gray[9..0])
RETURNS ( bin[9..0]);
FUNCTION a_graycounter_o96 (aclr, clock, cnt_en)
RETURNS ( q[9..0]);
FUNCTION a_graycounter_fgc (aclr, clock, cnt_en)
RETURNS ( q[9..0]);
FUNCTION a_graycounter_egc (aclr, clock, cnt_en)
RETURNS ( q[9..0]);
FUNCTION altsyncram_3731 (aclr1, address_a[8..0], address_b[8..0], addressstall_b, clock0, clock1, clocken1, data_a[15..0], wren_a)
RETURNS ( q_b[15..0]);
FUNCTION dffpipe_mcc (clock, clrn, d[0..0])
RETURNS ( q[0..0]);
FUNCTION dffpipe_oe9 (clock, clrn, d[9..0])
RETURNS ( q[9..0]);
FUNCTION alt_synch_pipe_vd8 (clock, clrn, d[9..0])
RETURNS ( q[9..0]);
FUNCTION alt_synch_pipe_0e8 (clock, clrn, d[9..0])
RETURNS ( q[9..0]);
--synthesis_resources = lut 69 M4K 2 reg 135
OPTIONS ALTERA_INTERNAL_OPTION = "AUTO_SHIFT_REGISTER_RECOGNITION=OFF;REMOVE_DUPLICATE_REGISTERS=OFF;suppress_da_rule_internal=d101;suppress_da_rule_internal=d102;suppress_da_rule_internal=s102;{-to p0addr} POWER_UP_LEVEL=LOW;{ -from ""rdptr_g"" -to ""ws_dgrp|dffpipe10|dffe11a"" }CUT=ON;{ -from ""delayed_wrptr_g"" -to ""rs_dgwp|dffpipe7|dffe8a"" }CUT=ON";
SUBDESIGN dcfifo_qlk1
(
aclr : input;
data[15..0] : input;
q[15..0] : output;
rdclk : input;
rdempty : output;
rdreq : input;
rdusedw[8..0] : output;
wrclk : input;
wrfull : output;
wrreq : input;
wrusedw[8..0] : output;
)
VARIABLE
rdptr_g_gray2bin : a_gray2bin_kdb;
rs_dgwp_gray2bin : a_gray2bin_kdb;
wrptr_g_gray2bin : a_gray2bin_kdb;
ws_dgrp_gray2bin : a_gray2bin_kdb;
rdptr_g1p : a_graycounter_o96;
wrptr_g1p : a_graycounter_fgc;
wrptr_gp : a_graycounter_egc;
fifo_ram : altsyncram_3731;
delayed_wrptr_g[9..0] : dffe;
p0addr : dffe
WITH (
power_up = "low"
);
rdptr_g[9..0] : dffe;
rdaclr : dffpipe_mcc;
rs_brp : dffpipe_oe9;
rs_bwp : dffpipe_oe9;
rs_dgwp : alt_synch_pipe_vd8;
ws_brp : dffpipe_oe9;
ws_bwp : dffpipe_oe9;
ws_dgrp : alt_synch_pipe_0e8;
rdusedw_sub_dataa[9..0] : WIRE;
rdusedw_sub_datab[9..0] : WIRE;
rdusedw_sub_result[9..0] : WIRE;
wrusedw_sub_dataa[9..0] : WIRE;
wrusedw_sub_datab[9..0] : WIRE;
wrusedw_sub_result[9..0] : WIRE;
rdempty_eq_comp_aeb_int : WIRE;
rdempty_eq_comp_aeb : WIRE;
rdempty_eq_comp_dataa[9..0] : WIRE;
rdempty_eq_comp_datab[9..0] : WIRE;
wrfull_eq_comp_aeb_int : WIRE;
wrfull_eq_comp_aeb : WIRE;
wrfull_eq_comp_dataa[9..0] : WIRE;
wrfull_eq_comp_datab[9..0] : WIRE;
int_rdempty : WIRE;
int_wrfull : WIRE;
ram_address_a[8..0] : WIRE;
ram_address_b[8..0] : WIRE;
rdcnt_addr_ena : WIRE;
valid_rdreq : WIRE;
valid_wrreq : WIRE;
wrptr_gs[9..0] : WIRE;
BEGIN
rdptr_g_gray2bin.gray[9..0] = rdptr_g[9..0].q;
rs_dgwp_gray2bin.gray[9..0] = rs_dgwp.q[9..0];
wrptr_g_gray2bin.gray[9..0] = wrptr_gp.q[9..0];
ws_dgrp_gray2bin.gray[9..0] = ws_dgrp.q[9..0];
rdptr_g1p.aclr = (! rdaclr.q[]);
rdptr_g1p.clock = rdclk;
rdptr_g1p.cnt_en = rdcnt_addr_ena;
wrptr_g1p.aclr = aclr;
wrptr_g1p.clock = wrclk;
wrptr_g1p.cnt_en = valid_wrreq;
wrptr_gp.aclr = aclr;
wrptr_gp.clock = wrclk;
wrptr_gp.cnt_en = valid_wrreq;
fifo_ram.aclr1 = aclr;
fifo_ram.address_a[] = ram_address_a[];
fifo_ram.address_b[] = ram_address_b[];
fifo_ram.addressstall_b = (! rdcnt_addr_ena);
fifo_ram.clock0 = wrclk;
fifo_ram.clock1 = rdclk;
fifo_ram.clocken1 = valid_rdreq;
fifo_ram.data_a[] = data[];
fifo_ram.wren_a = valid_wrreq;
delayed_wrptr_g[].clk = wrclk;
delayed_wrptr_g[].clrn = (! aclr);
delayed_wrptr_g[].d = wrptr_gp.q[];
p0addr.clk = rdclk;
p0addr.clrn = rdaclr.q[];
p0addr.d = B"1";
rdptr_g[].clk = rdclk;
rdptr_g[].clrn = (! aclr);
rdptr_g[].d = rdptr_g1p.q[];
rdptr_g[].ena = valid_rdreq;
rdaclr.clock = (! rdclk);
rdaclr.clrn = (! aclr);
rdaclr.d[] = B"1";
rs_brp.clock = rdclk;
rs_brp.clrn = (! aclr);
rs_brp.d[] = rdptr_g_gray2bin.bin[];
rs_bwp.clock = rdclk;
rs_bwp.clrn = (! aclr);
rs_bwp.d[] = rs_dgwp_gray2bin.bin[];
rs_dgwp.clock = rdclk;
rs_dgwp.clrn = (! aclr);
rs_dgwp.d[] = delayed_wrptr_g[].q;
ws_brp.clock = wrclk;
ws_brp.clrn = (! aclr);
ws_brp.d[] = ws_dgrp_gray2bin.bin[];
ws_bwp.clock = wrclk;
ws_bwp.clrn = (! aclr);
ws_bwp.d[] = wrptr_g_gray2bin.bin[];
ws_dgrp.clock = wrclk;
ws_dgrp.clrn = (! aclr);
ws_dgrp.d[] = rdptr_g[].q;
rdusedw_sub_result[] = rdusedw_sub_dataa[] - rdusedw_sub_datab[];
rdusedw_sub_dataa[] = rs_bwp.q[];
rdusedw_sub_datab[] = rs_brp.q[];
wrusedw_sub_result[] = wrusedw_sub_dataa[] - wrusedw_sub_datab[];
wrusedw_sub_dataa[] = ws_bwp.q[];
wrusedw_sub_datab[] = ws_brp.q[];
IF (rdempty_eq_comp_dataa[] == rdempty_eq_comp_datab[]) THEN
rdempty_eq_comp_aeb_int = VCC;
ELSE
rdempty_eq_comp_aeb_int = GND;
END IF;
rdempty_eq_comp_aeb = rdempty_eq_comp_aeb_int;
rdempty_eq_comp_dataa[] = rs_dgwp.q[];
rdempty_eq_comp_datab[] = rdptr_g[].q;
IF (wrfull_eq_comp_dataa[] == wrfull_eq_comp_datab[]) THEN
wrfull_eq_comp_aeb_int = VCC;
ELSE
wrfull_eq_comp_aeb_int = GND;
END IF;
wrfull_eq_comp_aeb = wrfull_eq_comp_aeb_int;
wrfull_eq_comp_dataa[] = ws_dgrp.q[];
wrfull_eq_comp_datab[] = wrptr_gs[];
int_rdempty = rdempty_eq_comp_aeb;
int_wrfull = wrfull_eq_comp_aeb;
q[] = fifo_ram.q_b[];
ram_address_a[] = ( (wrptr_gp.q[9..9] $ wrptr_gp.q[8..8]), wrptr_gp.q[7..0]);
ram_address_b[] = ( (rdptr_g1p.q[9..9] $ rdptr_g1p.q[8..8]), rdptr_g1p.q[7..0]);
rdcnt_addr_ena = (valid_rdreq # (! p0addr.q));
rdempty = int_rdempty;
rdusedw[] = ( rdusedw_sub_result[8..0]);
valid_rdreq = (rdreq & (! int_rdempty));
valid_wrreq = (wrreq & (! int_wrfull));
wrfull = int_wrfull;
wrptr_gs[] = ( (! wrptr_gp.q[9..9]), (! wrptr_gp.q[8..8]), wrptr_gp.q[7..0]);
wrusedw[] = ( wrusedw_sub_result[8..0]);
END;
--VALID FILE
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -