FUNCTIONfunc_tech_sel_ddr(g_technology:NATURAL;g_ddr3,g_ddr4:t_c_tech_ddr)RETURNt_c_tech_ddr;-- Select DDR3 or DDR4 dependent on the technology
FUNCTIONfunc_tech_sel_ddr(g_technology:NATURAL;g_ddr3,g_ddr4:t_c_tech_ddr)RETURNt_c_tech_ddr;-- Select DDR3 or DDR4 dependent on the technology
FUNCTIONfunc_tech_sel_ddr(g_sel:BOOLEAN;a,b:t_c_tech_ddr)RETURNt_c_tech_ddr;-- Select DDR dependent on the boolean
FUNCTIONfunc_tech_ddr_dq_address_w(c_ddr:t_c_tech_ddr)RETURNNATURAL;-- return DDR address width for the DQ data at the PHY mts rate
FUNCTIONfunc_tech_ddr_dq_address_w(c_ddr:t_c_tech_ddr)RETURNNATURAL;-- return DDR address width for the DQ data at the PHY mts rate
FUNCTIONfunc_tech_ddr_ctlr_address_w(c_ddr:t_c_tech_ddr)RETURNNATURAL;-- return DDR address width for the controller data at the by rsl=4 reduced rate
FUNCTIONfunc_tech_ddr_ctlr_address_w(c_ddr:t_c_tech_ddr)RETURNNATURAL;-- return DDR address width for the controller data at the by rsl=4 reduced rate
...
@@ -69,12 +70,25 @@ PACKAGE tech_ddr_pkg IS
...
@@ -69,12 +70,25 @@ PACKAGE tech_ddr_pkg IS
-- a a
-- a a
-- name mts master rank a row col ba dq dqs dm dbi bg ck cke cs cs_w odt term rsl rsl_w cqd burst burst_w
-- name mts master rank a row col ba dq dqs dm dbi bg ck cke cs cs_w odt term rsl rsl_w cqd burst burst_w
CONSTANTc_tech_ddr3_max:t_c_tech_ddr:=("none",800,TRUE,"DUAL ",16,16,10,3,64,8,8,0,0,2,2,2,1,2,14,4,2,4,64,7);-- maximum ranges for record field definitions
CONSTANTc_tech_ddr3_max:t_c_tech_ddr:=("none",800,TRUE,"DUAL ",16,16,10,3,64,8,8,0,0,2,2,2,1,2,14,4,2,4,64,7);-- maximum ranges for record field definitions
CONSTANTc_tech_ddr3_sim_8k:t_c_tech_ddr:=("DDR3",800,TRUE,"DUAL ",10,1,10,3,64,8,8,0,0,2,2,2,1,2,14,4,2,4,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col - rsl_w)
CONSTANTc_tech_ddr3_sim_16k:t_c_tech_ddr:=("DDR3",800,TRUE,"DUAL ",10,2,10,3,64,8,8,0,0,2,2,2,1,2,14,4,2,4,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col - rsl_w)
CONSTANTc_tech_ddr3_sim_128k:t_c_tech_ddr:=("DDR3",800,TRUE,"DUAL ",10,5,10,3,64,8,8,0,0,2,2,2,1,2,14,4,2,4,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col - rsl_w)
CONSTANTc_tech_ddr3_sim_1m:t_c_tech_ddr:=("DDR3",800,TRUE,"DUAL ",10,8,10,3,64,8,8,0,0,2,2,2,1,2,14,4,2,4,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col - rsl_w)
CONSTANTc_tech_ddr4_max:t_c_tech_ddr:=("none",1600,TRUE,"DUAL ",17,15,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- maximum ranges for record field definitions
CONSTANTc_tech_ddr4_max:t_c_tech_ddr:=("none",1600,TRUE,"DUAL ",17,15,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- maximum ranges for record field definitions
CONSTANTc_tech_ddr4_sim_4k:t_c_tech_ddr:=("DDR4",800,TRUE,"DUAL ",10,1,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col + bg_w - rsl_w)
CONSTANTc_tech_ddr4_sim_8k:t_c_tech_ddr:=("DDR4",800,TRUE,"DUAL ",10,2,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col + bg_w - rsl_w)
CONSTANTc_tech_ddr4_sim_16k:t_c_tech_ddr:=("DDR4",800,TRUE,"DUAL ",10,3,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col + bg_w - rsl_w)
CONSTANTc_tech_ddr4_sim_128k:t_c_tech_ddr:=("DDR4",800,TRUE,"DUAL ",10,6,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col + bg_w - rsl_w)
CONSTANTc_tech_ddr4_sim_1m:t_c_tech_ddr:=("DDR4",800,TRUE,"DUAL ",10,9,10,2,72,9,0,9,2,1,1,1,0,1,0,8,3,8,64,7);-- use a_row to set nof ctrl addr = 2**(cs_w + ba + a_row + a_col + bg_w - rsl_w)
-- if c_ddr.name="DDR4" THEN RETURN 32; END IF; -- FIXME: temporary fix from Leon to fix quartus width error in /home/hiemstra/svn/UniBoard_FP7/RadioHDL/trunk/libraries/base/common/src/vhdl/common_fifo_dc_mixed_widths.vhd Line=153