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
cba3cc1c
Commit
cba3cc1c
authored
Jan 23, 2015
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
continue on initial x393 with a memory controller
parent
f948ab8f
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
631 additions
and
269 deletions
+631
-269
address_map.txt
address_map.txt
+34
-11
ddr_refresh.v
memctrl/ddr_refresh.v
+7
-2
memctrl16.v
memctrl/memctrl16.v
+239
-43
scheduler16.v
memctrl/scheduler16.v
+9
-18
mcontr_sequencer.v
phy/mcontr_sequencer.v
+11
-5
x393.v
x393.v
+331
-190
No files found.
address_map.txt
View file @
cba3cc1c
...
@@ -2,18 +2,28 @@
...
@@ -2,18 +2,28 @@
parameter MCONTR_PHY_0BIT_ADDR = 'h020, // address to set sequnecer channel and run (4 LSB-s - channel)
parameter MCONTR_PHY_0BIT_ADDR = 'h020, // address to set sequnecer channel and run (4 LSB-s - channel)
parameter MCONTR_PHY_0BIT_ADDR_MASK = 'h3f0, // address mask to generate sequencer channel/run
parameter MCONTR_PHY_0BIT_ADDR_MASK = 'h3f0, // address mask to generate sequencer channel/run
0x1020 - DLY_SET // 0 bits -set pre-programmed delays
0x1020 - DLY_SET // 0 bits -set pre-programmed delays
0x1024..1025 - CMDA_EN // 0 bits -
enable/dis
able command/address outputs
0x1024..1025 - CMDA_EN // 0 bits -
disable/en
able command/address outputs
0x1026..1027 - SDRST_ACT // 0 bits -
enable/dis
able active-low reset signal to DDR3 memory
0x1026..1027 - SDRST_ACT // 0 bits -
disable/en
able active-low reset signal to DDR3 memory
0x1028..1029 - CKE_EN // 0 bits -
enable/dis
able CKE signal to memory
0x1028..1029 - CKE_EN // 0 bits -
disable/en
able CKE signal to memory
0x102a..102b - DCI_RST // 0 bits -
enable/dis
able CKE signal to memory
0x102a..102b - DCI_RST // 0 bits -
disable/en
able CKE signal to memory
0x102c..102d - DLY_RST // 0 bits -
enable/dis
able CKE signal to memory
0x102c..102d - DLY_RST // 0 bits -
disable/en
able CKE signal to memory
parameter MCONTR_PHY_0BIT_DLY_SET = 'h0, // set pre-programmed delays
parameter MCONTR_PHY_0BIT_DLY_SET = 'h0, // set pre-programmed delays
parameter MCONTR_PHY_0BIT_CMDA_EN = 'h4, //
enable/dis
able command/address outputs
parameter MCONTR_PHY_0BIT_CMDA_EN = 'h4, //
disable/en
able command/address outputs
parameter MCONTR_PHY_0BIT_SDRST_ACT = 'h6, //
enable/dis
able active-low reset signal to DDR3 memory
parameter MCONTR_PHY_0BIT_SDRST_ACT = 'h6, //
disable/en
able active-low reset signal to DDR3 memory
parameter MCONTR_PHY_0BIT_CKE_EN = 'h8, //
enable/dis
able CKE signal to memory
parameter MCONTR_PHY_0BIT_CKE_EN = 'h8, //
disable/en
able CKE signal to memory
parameter MCONTR_PHY_0BIT_DCI_RST = 'ha, //
enable/dis
able CKE signal to memory
parameter MCONTR_PHY_0BIT_DCI_RST = 'ha, //
disable/en
able CKE signal to memory
parameter MCONTR_PHY_0BIT_DLY_RST = 'hc, //
enable/dis
able CKE signal to memory
parameter MCONTR_PHY_0BIT_DLY_RST = 'hc, //
disable/en
able CKE signal to memory
0x1030..1037 - 0-bit memory cotroller (set/reset)
parameter MCONTR_TOP_0BIT_ADDR = 'h030, // address to turn on/off memory controller features
parameter MCONTR_TOP_0BIT_ADDR_MASK = 'h3f8, // address mask to generate sequencer channel/run
0x1030..1031 - MCONTR_EN // 0 bits, disable/enable memory controller
0x1032..1033 - REFRESH_EN // 0 bits, disable/enable memory refresh
0x1034..1037 - reserved
parameter MCONTR_TOP_0BIT_MCONTR_EN = 'h0, // set pre-programmed delays
parameter MCONTR_TOP_0BIT_REFRESH_EN = 'h2, // disable/enable command/address outputs
0x1040..107f - 16-bit data
0x1040..107f - 16-bit data
0x1050..1057: MCONTR_PHY16
0x1050..1057: MCONTR_PHY16
parameter MCONTR_PHY_16BIT_ADDR = 'h050, // address to set sequnecer channel and run (4 LSB-s - channel)
parameter MCONTR_PHY_16BIT_ADDR = 'h050, // address to set sequnecer channel and run (4 LSB-s - channel)
...
@@ -31,12 +41,25 @@
...
@@ -31,12 +41,25 @@
0x1060..106f: arbiter priority data
0x1060..106f: arbiter priority data
parameter MCONTR_ARBIT_ADDR = 'h060, // Address to set channel priorities
parameter MCONTR_ARBIT_ADDR = 'h060, // Address to set channel priorities
parameter MCONTR_ARBIT_ADDR_MASK = 'h3f0, // Address mask to set channel priorities
parameter MCONTR_ARBIT_ADDR_MASK = 'h3f0, // Address mask to set channel priorities
0x1070..1077 - 16-bit top memory controller:
parameter MCONTR_TOP_16BIT_ADDR = 'h070, // address to set mcontr top control registers
parameter MCONTR_TOP_16BIT_ADDR_MASK = 'h3f8, // address mask to set mcontr top control registers
0x1070 - MCONTR_CHN_EN // 16 bits per-channel enable (want/need requests)
0x1071 - REFRESH_PERIOD // 8-bit refresh period
0x1072 - REFRESH_ADDRESS // 10 bits
0x1073 - STATUS_CNTRL // 8 bits - write to status control (and debug?)
parameter MCONTR_TOP_16BIT_CHN_EN = 'h0, // 16 bits per-channel enable (want/need requests)
parameter MCONTR_TOP_16BIT_REFRESH_PERIOD = 'h1, // 8-bit refresh period
parameter MCONTR_TOP_16BIT_REFRESH_ADDRESS= 'h2, // 10 bits refresh address in the sequencer (PL) memory
parameter MCONTR_TOP_16BIT_STATUS_CNTRL= 'h3, // 8 bits - write to status control (and debug?)
// Status read address
// Status read address
parameter STATUS_ADDR = 'h1400, // AXI write address of status read registers
parameter STATUS_ADDR = 'h1400, // AXI write address of status read registers
parameter STATUS_ADDR_MASK = 'h1400, // AXI write address of status registers
parameter STATUS_ADDR_MASK = 'h1400, // AXI write address of status registers
parameter STATUS_DEPTH= 8, // 256 cells, maybe just 16..64 are enough?
parameter STATUS_DEPTH= 8, // 256 cells, maybe just 16..64 are enough?
parameter MCONTR_PHY_STATUS_REG_ADDR= 'h0, // 8 or less bits: status register address to use for memory controller phy
parameter MCONTR_PHY_STATUS_REG_ADDR= 'h0, // 8 or less bits: status register address to use for memory controller phy
parameter MCONTR_TOP_STATUS_REG_ADDR= 'h1, // 8 or less bits: status register address to use for memory controller
================================ OLD =======================================================
================================ OLD =======================================================
Control addresses (in original ddrc_test01)
Control addresses (in original ddrc_test01)
...
...
memctrl/ddr_refresh.v
View file @
cba3cc1c
...
@@ -23,6 +23,7 @@
...
@@ -23,6 +23,7 @@
module
ddr_refresh
(
module
ddr_refresh
(
input
rst
,
input
rst
,
input
clk
,
input
clk
,
input
en
,
input
[
7
:
0
]
refresh_period
,
// in 16*clk, 0 - disable refresh, turn off requests
input
[
7
:
0
]
refresh_period
,
// in 16*clk, 0 - disable refresh, turn off requests
input
set
,
// and reset counters
input
set
,
// and reset counters
output
reg
want
,
// turns off next cycle after grant (or stays on if more are needed)
output
reg
want
,
// turns off next cycle after grant (or stays on if more are needed)
...
@@ -36,8 +37,12 @@ module ddr_refresh(
...
@@ -36,8 +37,12 @@ module ddr_refresh(
wire
over
=
(
period_cntr
==
0
)
&&
cry
;
wire
over
=
(
period_cntr
==
0
)
&&
cry
;
reg
refresh_due
;
reg
refresh_due
;
reg
en_refresh
;
reg
en_refresh
;
reg
en_r
;
always
@
(
posedge
rst
or
posedge
clk
)
begin
always
@
(
posedge
rst
or
posedge
clk
)
begin
if
(
rst
)
en_r
<=
0
;
else
en_r
<=
en
;
if
(
rst
)
en_refresh
<=
0
;
if
(
rst
)
en_refresh
<=
0
;
else
if
(
set
)
en_refresh
<=
(
refresh_period
!=
0
)
;
else
if
(
set
)
en_refresh
<=
(
refresh_period
!=
0
)
;
...
@@ -63,10 +68,10 @@ module ddr_refresh(
...
@@ -63,10 +68,10 @@ module ddr_refresh(
else
if
(
!
refresh_due
&&
grant
)
pending_rq
<=
pending_rq
-
1
;
else
if
(
!
refresh_due
&&
grant
)
pending_rq
<=
pending_rq
-
1
;
if
(
rst
)
want
<=
0
;
if
(
rst
)
want
<=
0
;
else
want
<=
en_refresh
&&
(
pending_rq
!=
0
)
;
else
want
<=
en_refresh
&&
en_r
&&
(
pending_rq
!=
0
)
;
if
(
rst
)
need
<=
0
;
if
(
rst
)
need
<=
0
;
else
need
<=
en_refresh
&&
(
pending_rq
[
4
:
3
]
!=
0
)
;
else
need
<=
en_refresh
&&
en_r
&&
(
pending_rq
[
4
:
3
]
!=
0
)
;
end
end
endmodule
endmodule
memctrl/memctrl16.v
View file @
cba3cc1c
This diff is collapsed.
Click to expand it.
memctrl/scheduler16.v
View file @
cba3cc1c
...
@@ -25,8 +25,9 @@ module scheduler16 #(
...
@@ -25,8 +25,9 @@ module scheduler16 #(
)(
)(
input
rst
,
input
rst
,
input
clk
,
input
clk
,
input
[
15
:
0
]
want_rq
,
// both want_rq and need_rq should go inactive after being granted
input
[
width
-
1
:
0
]
chn_en
,
// channel enable mask
input
[
15
:
0
]
need_rq
,
input
[
width
-
1
:
0
]
want_rq
,
// both want_rq and need_rq should go inactive after being granted
input
[
width
-
1
:
0
]
need_rq
,
input
en_schedul
,
// needs to be disabled before next access can be scheduled
input
en_schedul
,
// needs to be disabled before next access can be scheduled
output
need
,
// granted access is "needed" one, not just "wanted"
output
need
,
// granted access is "needed" one, not just "wanted"
output
grant
,
// single-cycle granted channel access
output
grant
,
// single-cycle granted channel access
...
@@ -36,18 +37,13 @@ module scheduler16 #(
...
@@ -36,18 +37,13 @@ module scheduler16 #(
input
[
width
-
1
:
0
]
pgm_data
,
// priority data for the channel
input
[
width
-
1
:
0
]
pgm_data
,
// priority data for the channel
input
pgm_en
// enable programming priority data (use different clock?)
input
pgm_en
// enable programming priority data (use different clock?)
)
;
)
;
// reg [width-1:0] pri00,pri01,pri02,pri03,pri04,pri05,pri06,pri07,pri08,pri09,pri10,pri11,pri12,pri13,pri14,pri15;
reg
[
width
*
16
-
1
:
0
]
pri_reg
;
reg
[
width
*
16
-
1
:
0
]
pri_reg
;
reg
[
15
:
0
]
want_conf
,
need_conf
,
need_want_conf
;
reg
[
15
:
0
]
want_conf
,
need_conf
,
need_want_conf
;
// wire new_want,new_need;
// wire event_w;
wire
[
15
:
0
]
want_set
,
need_set
;
wire
[
15
:
0
]
want_set
,
need_set
;
reg
[
15
:
0
]
want_set_r
,
need_set_r
;
reg
[
15
:
0
]
want_set_r
,
need_set_r
;
// reg event_r, want_r;
reg
need_r
;
reg
need_r
;
reg
[
width
*
16
-
1
:
0
]
sched_state
;
reg
[
width
*
16
-
1
:
0
]
sched_state
;
wire
need_some
=|
need_rq
;
wire
need_some
=|
(
need_rq
&
&
chn_en
)
;
// wire want_some=| want_rq;
wire
[
15
:
0
]
next_want_conf
,
next_need_conf
;
wire
[
15
:
0
]
next_want_conf
,
next_need_conf
;
wire
[
3
:
0
]
index
;
// channel index to select
wire
[
3
:
0
]
index
;
// channel index to select
wire
index_valid
;
// selected index valid ("needed" or "wanted")
wire
index_valid
;
// selected index valid ("needed" or "wanted")
...
@@ -55,9 +51,8 @@ module scheduler16 #(
...
@@ -55,9 +51,8 @@ module scheduler16 #(
reg
grant_sent
;
// turns on after grant, until en_schedul is de-asserted
reg
grant_sent
;
// turns on after grant, until en_schedul is de-asserted
reg
[
3
:
0
]
grant_chn_r
;
reg
[
3
:
0
]
grant_chn_r
;
wire
grant_w
;
wire
grant_w
;
// assign event_w=new_want | new_need;
assign
next_want_conf
=
(
want_conf
&
want_rq
&
chn_en
)
|
want_set
;
assign
next_want_conf
=
(
want_conf
&
want_rq
)
|
want_set
;
assign
next_need_conf
=
(
need_conf
&
need_rq
&
chn_en
)
|
need_set
;
assign
next_need_conf
=
(
need_conf
&
need_rq
)
|
need_set
;
assign
grant
=
grant_r
;
assign
grant
=
grant_r
;
assign
grant_chn
=
grant_chn_r
;
assign
grant_chn
=
grant_chn_r
;
assign
grant_w
=
en_schedul
&&
index_valid
&&
!
grant_sent
;
assign
grant_w
=
en_schedul
&&
index_valid
&&
!
grant_sent
;
...
@@ -72,15 +67,13 @@ module scheduler16 #(
...
@@ -72,15 +67,13 @@ module scheduler16 #(
endgenerate
endgenerate
pri1hot16
i_pri1hot16_want
(
pri1hot16
i_pri1hot16_want
(
.
in
(
want_rq
&
~
want_conf
)
,
.
in
(
want_rq
&
~
want_conf
&
chn_en
)
,
.
out
(
want_set
)
,
.
out
(
want_set
)
,
.
some
())
;
.
some
())
;
// .some(new_want));
pri1hot16
i_pri1hot16_need
(
pri1hot16
i_pri1hot16_need
(
.
in
(
need_rq
&
~
need_conf
)
,
.
in
(
need_rq
&
~
need_conf
&
chn_en
)
,
.
out
(
need_set
)
,
.
out
(
need_set
)
,
.
some
())
;
.
some
())
;
// .some(new_need));
always
@
(
posedge
rst
or
posedge
clk
)
begin
always
@
(
posedge
rst
or
posedge
clk
)
begin
if
(
rst
)
begin
if
(
rst
)
begin
...
@@ -95,12 +88,10 @@ module scheduler16 #(
...
@@ -95,12 +88,10 @@ module scheduler16 #(
always
@
(
posedge
clk
)
begin
always
@
(
posedge
clk
)
begin
want_set_r
<=
want_set
;
want_set_r
<=
want_set
;
need_set_r
<=
need_set
;
need_set_r
<=
need_set
;
//event_r <= event_w;
//want_r<= want_some;
need_r
<=
need_some
;
need_r
<=
need_some
;
end
end
// TODO: want remains, need is removed (both need and want should be deactivated on grant!)
// TODO: want remains, need is removed (both need and want should be deactivated on grant!)
// Block that sets initi
la
process state and increments it on every change of the requests
// Block that sets initi
al
process state and increments it on every change of the requests
generate
generate
genvar
i1
;
genvar
i1
;
for
(
i1
=
0
;
i1
<
16
;
i1
=
i1
+
1
)
begin
:
sched_state_block
for
(
i1
=
0
;
i1
<
16
;
i1
=
i1
+
1
)
begin
:
sched_state_block
...
...
phy/mcontr_sequencer.v
View file @
cba3cc1c
...
@@ -22,8 +22,13 @@
...
@@ -22,8 +22,13 @@
module
mcontr_sequencer
#(
module
mcontr_sequencer
#(
//command interface parameters
//command interface parameters
parameter
DLY_LD
=
'h080
,
// address to generate delay load
//0x1080..10ff - 8- bit data - to set various delay values
parameter
DLY_LD
=
'h080
,
// address to generate delay load
parameter
DLY_LD_MASK
=
'h380
,
// address mask to generate delay load
parameter
DLY_LD_MASK
=
'h380
,
// address mask to generate delay load
// 0x1080..109f - set delay for SDD0-SDD7
// 0x10a0..10bf - set delay for SDD8-SDD15
// 0x10c0..10df - set delay for SD_CMDA
// 0x10e0 - set delay for MMCM
//0x1000..103f - 0- bit data (set/reset)
//0x1000..103f - 0- bit data (set/reset)
parameter
MCONTR_PHY_0BIT_ADDR
=
'h020
,
// address to set sequnecer channel and run (4 LSB-s - channel)
parameter
MCONTR_PHY_0BIT_ADDR
=
'h020
,
// address to set sequnecer channel and run (4 LSB-s - channel)
parameter
MCONTR_PHY_0BIT_ADDR_MASK
=
'h3f0
,
// address mask to generate sequencer channel/run
parameter
MCONTR_PHY_0BIT_ADDR_MASK
=
'h3f0
,
// address mask to generate sequencer channel/run
...
@@ -126,7 +131,7 @@ module mcontr_sequencer #(
...
@@ -126,7 +131,7 @@ module mcontr_sequencer #(
input
run_seq
,
// start controller sequence (will and with !ddr_rst for stable mclk)
input
run_seq
,
// start controller sequence (will and with !ddr_rst for stable mclk)
output
run_done
,
// controller sequence finished
output
run_done
,
// controller sequence finished
output
run_busy
,
// controller sequence in progress
output
run_busy
,
// controller sequence in progress
output
mcontr_reset
,
// == ddr_reset that also resets sequencer
// programming interface
// programming interface
input
[
7
:
0
]
cmd_ad
,
// byte-serial command address/data (up to 6 bytes: AL-AH-D0-D1-D2-D3
input
[
7
:
0
]
cmd_ad
,
// byte-serial command address/data (up to 6 bytes: AL-AH-D0-D1-D2-D3
input
cmd_stb
,
// strobe (with first byte) for the command a/d
input
cmd_stb
,
// strobe (with first byte) for the command a/d
...
@@ -146,7 +151,7 @@ module mcontr_sequencer #(
...
@@ -146,7 +151,7 @@ module mcontr_sequencer #(
// Address/data sync to negedge mclk!, any latency OK - just generate DONE appropriately (through the sequencer with delay?
// Address/data sync to negedge mclk!, any latency OK - just generate DONE appropriately (through the sequencer with delay?
output
ext_buf_wr
,
output
ext_buf_wr
,
output
[
6
:
0
]
ext_buf_waddr
,
// valid with ext_buf_wr
output
[
6
:
0
]
ext_buf_waddr
,
// valid with ext_buf_wr
output
[
3
:
0
]
ext_buf_wchn
,
// ==run_chn_d valid 1 cycle ahead o
p
f ext_buf_wr!, maybe not needed - will be generated externally
output
[
3
:
0
]
ext_buf_wchn
,
// ==run_chn_d valid 1 cycle ahead of ext_buf_wr!, maybe not needed - will be generated externally
output
[
63
:
0
]
ext_buf_wdata
,
// valid with ext_buf_wr
output
[
63
:
0
]
ext_buf_wdata
,
// valid with ext_buf_wr
// temporary debug data
// temporary debug data
output
[
11
:
0
]
tmp_debug
output
[
11
:
0
]
tmp_debug
...
@@ -244,6 +249,7 @@ module mcontr_sequencer #(
...
@@ -244,6 +249,7 @@ module mcontr_sequencer #(
phy_dci_ready
,
phy_dci_ready
,
tmp_debug_a
[
7
:
0
]
};
tmp_debug_a
[
7
:
0
]
};
assign
mcontr_reset
=
ddr_rst
;
// to reset controller
assign
run_done
=
sequence_done
;
assign
run_done
=
sequence_done
;
assign
run_busy
=
cmd_busy
[
0
]
;
//earliest
assign
run_busy
=
cmd_busy
[
0
]
;
//earliest
assign
pause
=
cmd_fetch
?
(
phy_cmd_add_pause
||
(
phy_cmd_nop
&&
(
pause_len
!=
0
)))
:
(
cmd_busy
[
2
]
&&
(
pause_cntr
[
CMD_PAUSE_BITS
-
1
:
1
]
!=
0
))
;
assign
pause
=
cmd_fetch
?
(
phy_cmd_add_pause
||
(
phy_cmd_nop
&&
(
pause_len
!=
0
)))
:
(
cmd_busy
[
2
]
&&
(
pause_cntr
[
CMD_PAUSE_BITS
-
1
:
1
]
!=
0
))
;
...
@@ -296,7 +302,7 @@ module mcontr_sequencer #(
...
@@ -296,7 +302,7 @@ module mcontr_sequencer #(
.
stb
(
cmd_stb
)
,
// input
.
stb
(
cmd_stb
)
,
// input
.
addr
(
phy_0bit_addr
)
,
// output[15:0]
.
addr
(
phy_0bit_addr
)
,
// output[15:0]
.
data
()
,
// output[31:0]
.
data
()
,
// output[31:0]
.
we
(
phy_0bit_we
)
// output
.
we
(
phy_0bit_we
)
// output
)
;
)
;
assign
set
=
phy_0bit_we
&&
(
phy_0bit_addr
==
MCONTR_PHY_0BIT_DLY_SET
)
;
assign
set
=
phy_0bit_we
&&
(
phy_0bit_addr
==
MCONTR_PHY_0BIT_DLY_SET
)
;
...
@@ -331,7 +337,7 @@ module mcontr_sequencer #(
...
@@ -331,7 +337,7 @@ module mcontr_sequencer #(
.
stb
(
cmd_stb
)
,
// input
.
stb
(
cmd_stb
)
,
// input
.
addr
(
phy_16bit_addr
)
,
// output[15:0]
.
addr
(
phy_16bit_addr
)
,
// output[15:0]
.
data
(
phy_16bit_data
)
,
// output[31:0]
.
data
(
phy_16bit_data
)
,
// output[31:0]
.
we
(
phy_16bit_we
)
// output
.
we
(
phy_16bit_we
)
// output
)
;
)
;
wire
set_patterns
;
wire
set_patterns
;
wire
set_patterns_tri
;
wire
set_patterns_tri
;
...
...
x393.v
View file @
cba3cc1c
This diff is collapsed.
Click to expand it.
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