Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
X
x393
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
x393
Commits
13382f62
Commit
13382f62
authored
Jul 28, 2015
by
Alexey Grebenkin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
CVC workarounds
parent
f3df44ab
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
58 additions
and
4 deletions
+58
-4
4096Mb_ddr3_parameters.vh
ddr3/4096Mb_ddr3_parameters.vh
+12
-0
ddr3.v
ddr3/ddr3.v
+36
-3
phy_top.v
memctrl/phy/phy_top.v
+10
-1
No files found.
ddr3/4096Mb_ddr3_parameters.vh
View file @
13382f62
...
@@ -477,10 +477,22 @@
...
@@ -477,10 +477,22 @@
parameter TDQSL = 0.45; // tDQSL tCK DQS input Low Pulse Width
parameter TDQSL = 0.45; // tDQSL tCK DQS input Low Pulse Width
parameter TWPRE = 0.90; // tWPRE tCK DQS Write Preamble
parameter TWPRE = 0.90; // tWPRE tCK DQS Write Preamble
parameter TWPST = 0.30; // tWPST tCK DQS Write Postamble
parameter TWPST = 0.30; // tWPST tCK DQS Write Postamble
`ifdef CVC
integer TZQCS;
integer TZQINIT;
integer TZQOPER;
initial
begin
TZQCS = max( 64, ceil( 80000/TCK_MIN)); // tZQCS tCK ZQ Cal (Short) time
TZQINIT = max(512, ceil(640000/TCK_MIN)); // tZQinit tCK ZQ Cal (Long) time
TZQOPER = max(256, ceil(320000/TCK_MIN)); // tZQoper tCK ZQ Cal (Long) time
end
`else
// Command and Address
// Command and Address
integer TZQCS = max( 64, ceil( 80000/TCK_MIN)); // tZQCS tCK ZQ Cal (Short) time
integer TZQCS = max( 64, ceil( 80000/TCK_MIN)); // tZQCS tCK ZQ Cal (Short) time
integer TZQINIT = max(512, ceil(640000/TCK_MIN)); // tZQinit tCK ZQ Cal (Long) time
integer TZQINIT = max(512, ceil(640000/TCK_MIN)); // tZQinit tCK ZQ Cal (Long) time
integer TZQOPER = max(256, ceil(320000/TCK_MIN)); // tZQoper tCK ZQ Cal (Long) time
integer TZQOPER = max(256, ceil(320000/TCK_MIN)); // tZQoper tCK ZQ Cal (Long) time
`endif
parameter TCCD = 4; // tCCD tCK Cas to Cas command delay
parameter TCCD = 4; // tCCD tCK Cas to Cas command delay
parameter TCCD_DG = 2; // tCCD_DG tCK Cas to Cas command delay to different group
parameter TCCD_DG = 2; // tCCD_DG tCK Cas to Cas command delay to different group
parameter TRAS_MAX = 60e9; // tRAS ps Maximum Active to Precharge command time
parameter TRAS_MAX = 60e9; // tRAS ps Maximum Active to Precharge command time
...
...
ddr3/ddr3.v
View file @
13382f62
...
@@ -551,8 +551,11 @@ module ddr3 (
...
@@ -551,8 +551,11 @@ module ddr3 (
$
display
(
"%m ERROR: BL_MAX parameter must be >= 2.
\n
BL_MAX = %d"
,
BL_MAX
)
;
$
display
(
"%m ERROR: BL_MAX parameter must be >= 2.
\n
BL_MAX = %d"
,
BL_MAX
)
;
if
((
1
<<
BO_BITS
)
>
BL_MAX
)
if
((
1
<<
BO_BITS
)
>
BL_MAX
)
$
display
(
"%m ERROR: 2^BO_BITS cannot be greater than BL_MAX parameter."
)
;
$
display
(
"%m ERROR: 2^BO_BITS cannot be greater than BL_MAX parameter."
)
;
`ifdef
CVC
$
timeformat
(
-
12
,
1
,
" ps"
,
10
)
;
`else
$
timeformat
(
-
12
,
1
,
" ps"
,
1
)
;
$
timeformat
(
-
12
,
1
,
" ps"
,
1
)
;
`endif
seed
=
RANDOM_SEED
;
seed
=
RANDOM_SEED
;
ck_cntr
=
0
;
ck_cntr
=
0
;
...
@@ -653,9 +656,12 @@ module ddr3 (
...
@@ -653,9 +656,12 @@ module ddr3 (
input
integer
index
input
integer
index
)
;
)
;
integer
code
;
integer
code
;
integer
offset
;
integer
offset
;
reg
[
1024
:
1
]
msg
;
reg
[
1024
:
1
]
msg
;
reg
[
RFF_BITS
:
1
]
read_value
;
reg
[
RFF_BITS
:
1
]
read_value
;
`ifdef
CVC
reg
[
RFF_BITS
*
2
+
8
:
1
]
read_str
;
`endif
begin
begin
offset
=
index
*
RFF_CHUNK
;
offset
=
index
*
RFF_CHUNK
;
...
@@ -666,8 +672,12 @@ module ddr3 (
...
@@ -666,8 +672,12 @@ module ddr3 (
$
display
(
"%m: at time %t ERROR: fseek to %d failed"
,
$
time
,
offset
)
;
$
display
(
"%m: at time %t ERROR: fseek to %d failed"
,
$
time
,
offset
)
;
$
finish
;
$
finish
;
end
end
`ifdef
CVC
code
=
$
fgets
(
read_str
,
fd
)
;
code
=
$
sscanf
(
read_str
,
"%h"
,
read_value
)
;
`else
code
=
$
fscanf
(
fd
,
"%z"
,
read_value
)
;
code
=
$
fscanf
(
fd
,
"%z"
,
read_value
)
;
`endif
// $fscanf returns number of items read
// $fscanf returns number of items read
if
(
code
!=
1
)
if
(
code
!=
1
)
begin
begin
...
@@ -685,12 +695,21 @@ module ddr3 (
...
@@ -685,12 +695,21 @@ module ddr3 (
* Use 0 in bit 1 as indicator that invalid data has been read.
* Use 0 in bit 1 as indicator that invalid data has been read.
* A true 0 is encoded as Z.
* A true 0 is encoded as Z.
*/
*/
`ifdef
CVC
if
(
read_value
[
4
:
1
]
===
4'bzzzz
)
// true 0 encoded as Z, data is valid
read_value
[
4
:
1
]
=
4'b0000
;
else
if
(
read_value
[
4
:
1
]
===
4'b0000
)
// read from file section that has not been written
read_value
=
'
hx
;
`else
if
(
read_value
[
1
]
===
1'bz
)
if
(
read_value
[
1
]
===
1'bz
)
// true 0 encoded as Z, data is valid
// true 0 encoded as Z, data is valid
read_value
[
1
]
=
1'b0
;
read_value
[
1
]
=
1'b0
;
else
if
(
read_value
[
1
]
===
1'b0
)
else
if
(
read_value
[
1
]
===
1'b0
)
// read from file section that has not been written
// read from file section that has not been written
read_value
=
'
hx
;
read_value
=
'
hx
;
`endif
read_from_file
=
read_value
;
read_from_file
=
read_value
;
end
end
...
@@ -720,6 +739,15 @@ module ddr3 (
...
@@ -720,6 +739,15 @@ module ddr3 (
$
finish
;
$
finish
;
end
end
`ifdef
CVC
// encode a valid data
if
(
data
[
4
:
1
]
===
4'bzzzz
)
data
[
4
:
1
]
=
4'bxxxx
;
else
if
(
data
[
4
:
1
]
===
4'b0000
)
data
[
4
:
1
]
=
4'bzzzz
;
$
fwrite
(
fd
,
"%h"
,
data
)
;
`else
// encode a valid data
// encode a valid data
if
(
data
[
1
]
===
1'bz
)
if
(
data
[
1
]
===
1'bz
)
data
[
1
]
=
1'bx
;
data
[
1
]
=
1'bx
;
...
@@ -727,6 +755,7 @@ module ddr3 (
...
@@ -727,6 +755,7 @@ module ddr3 (
data
[
1
]
=
1'bz
;
data
[
1
]
=
1'bz
;
$
fwrite
(
fd
,
"%z"
,
data
)
;
$
fwrite
(
fd
,
"%z"
,
data
)
;
`endif
end
end
endtask
endtask
`else
`else
...
@@ -2241,7 +2270,11 @@ module ddr3 (
...
@@ -2241,7 +2270,11 @@ module ddr3 (
$
display
(
"%m: at time %t ERROR: tCK(avg) maximum violation by %f ps."
,
$
time
,
tck_avg
-
TCK_MAX
)
;
$
display
(
"%m: at time %t ERROR: tCK(avg) maximum violation by %f ps."
,
$
time
,
tck_avg
-
TCK_MAX
)
;
// check tCL
// check tCL
`ifdef
CVC
if
((
tm_ck_neg
-
$
time
<
TCL_ABS_MIN
*
tck_avg
)
&&
(
tm_ck_neg
>
$
time
))
`else
if
(
tm_ck_neg
-
$
time
<
TCL_ABS_MIN
*
tck_avg
)
if
(
tm_ck_neg
-
$
time
<
TCL_ABS_MIN
*
tck_avg
)
`endif
$
display
(
"%m: at time %t ERROR: tCL(abs) minimum violation on CLK by %t"
,
$
time
,
TCL_ABS_MIN
*
tck_avg
-
tm_ck_neg
+
$
time
)
;
$
display
(
"%m: at time %t ERROR: tCL(abs) minimum violation on CLK by %t"
,
$
time
,
TCL_ABS_MIN
*
tck_avg
-
tm_ck_neg
+
$
time
)
;
if
(
tcl_avg
<
TCL_AVG_MIN
*
tck_avg
)
if
(
tcl_avg
<
TCL_AVG_MIN
*
tck_avg
)
$
display
(
"%m: at time %t ERROR: tCL(avg) minimum violation on CLK by %t"
,
$
time
,
TCL_AVG_MIN
*
tck_avg
-
tcl_avg
)
;
$
display
(
"%m: at time %t ERROR: tCL(avg) minimum violation on CLK by %t"
,
$
time
,
TCL_AVG_MIN
*
tck_avg
-
tcl_avg
)
;
...
...
memctrl/phy/phy_top.v
View file @
13382f62
...
@@ -296,11 +296,20 @@ BUFIO iclk_bufio_i (.O(sdclk), .I(sdclk_pre) );
...
@@ -296,11 +296,20 @@ BUFIO iclk_bufio_i (.O(sdclk), .I(sdclk_pre) );
BUFG
clk_ref_i
(
.
O
(
clk_ref
)
,
.
I
(
clk_ref_pre
))
;
BUFG
clk_ref_i
(
.
O
(
clk_ref
)
,
.
I
(
clk_ref_pre
))
;
BUFG
mclk_i
(
.
O
(
mclk
)
,.
I
(
mclk_pre
)
)
;
BUFG
mclk_i
(
.
O
(
mclk
)
,.
I
(
mclk_pre
)
)
;
/* Instance template for module mmcm_phase_cntr */
/* Instance template for module mmcm_phase_cntr */
`ifdef
CVC
localparam
real
CLKFBOUT_MULT_REAL
=
CLKFBOUT_MULT
;
localparam
real
CLKIN_PERIOD_REAL
=
CLKIN_PERIOD
;
`endif
mmcm_phase_cntr
#(
mmcm_phase_cntr
#(
.
PHASE_WIDTH
(
PHASE_WIDTH
)
,
.
PHASE_WIDTH
(
PHASE_WIDTH
)
,
.
CLKIN_PERIOD
(
CLKIN_PERIOD
)
,
.
BANDWIDTH
(
BANDWIDTH
)
,
.
BANDWIDTH
(
BANDWIDTH
)
,
`ifdef
CVC
.
CLKFBOUT_MULT_F
(
CLKFBOUT_MULT_REAL
)
,
.
CLKIN_PERIOD
(
CLKIN_PERIOD_REAL
)
,
`else
.
CLKFBOUT_MULT_F
(
CLKFBOUT_MULT
)
,
.
CLKFBOUT_MULT_F
(
CLKFBOUT_MULT
)
,
.
CLKIN_PERIOD
(
CLKIN_PERIOD
)
,
`endif
.
DIVCLK_DIVIDE
(
DIVCLK_DIVIDE
)
,
.
DIVCLK_DIVIDE
(
DIVCLK_DIVIDE
)
,
.
CLKFBOUT_PHASE
(
CLKFBOUT_PHASE
)
,
.
CLKFBOUT_PHASE
(
CLKFBOUT_PHASE
)
,
.
CLKOUT0_PHASE
(
SDCLK_PHASE
)
,
.
CLKOUT0_PHASE
(
SDCLK_PHASE
)
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment