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
64ff56ce
Commit
64ff56ce
authored
9 years ago
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
adjusting constraint attributes in the source
parent
8b0a0f11
master
03931003
CMV300
boson
dct
framepars
lwir
master-initial
mater-next
parallel-sensors
plus_sata
serial-sensors
v1.0
No related merge requests found
Changes
21
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
301 additions
and
152 deletions
+301
-152
.project
.project
+15
-15
com.elphel.vdt.VivadoSynthesis.prefs
.settings/com.elphel.vdt.VivadoSynthesis.prefs
+1
-1
huffman393.v
compressor_jp/huffman393.v
+108
-78
cmd_encod_linear_mux.v
memctrl/cmd_encod_linear_mux.v
+16
-16
cmd_encod_tiled_mux.v
memctrl/cmd_encod_tiled_mux.v
+16
-16
mcntrl_linear_rw.v
memctrl/mcntrl_linear_rw.v
+4
-1
mcntrl_tiled_rw.v
memctrl/mcntrl_tiled_rw.v
+4
-1
byte_lane.v
memctrl/phy/byte_lane.v
+16
-5
cmd_addr.v
memctrl/phy/cmd_addr.v
+8
-2
dq_single.v
memctrl/phy/dq_single.v
+0
-1
system_defines.vh
system_defines.vh
+2
-0
level_cross_clocks.v
util_modules/level_cross_clocks.v
+69
-3
pulse_cross_clock.v
util_modules/pulse_cross_clock.v
+15
-1
idelay_ctrl.v
wrap/idelay_ctrl.v
+3
-1
idelay_fine_pipe.v
wrap/idelay_fine_pipe.v
+4
-1
idelay_nofine.v
wrap/idelay_nofine.v
+4
-1
mmcm_phase_cntr.v
wrap/mmcm_phase_cntr.v
+0
-2
odelay_fine_pipe.v
wrap/odelay_fine_pipe.v
+4
-1
odelay_pipe.v
wrap/odelay_pipe.v
+4
-2
x393.v
x393.v
+6
-4
x393.xdc
x393.xdc
+2
-0
No files found.
.project
View file @
64ff56ce
...
...
@@ -62,77 +62,77 @@
<link>
<name>
vivado_logs/VivadoBitstream.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoBitstream-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoBitstream-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoOpt.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoOpt-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoOpt-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoOptPhys.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoOptPhys-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoOptPhys-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoOptPower.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoOptPower-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoOptPower-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoPlace.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoPlace-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoPlace-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoRoute.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoRoute-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoRoute-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoSynthesis.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoSynthesis-2015072
2180528066
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoSynthesis-2015072
3174740723
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoTimimgSummaryReportImplemented.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimimgSummaryReportImplemented-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimimgSummaryReportImplemented-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoTimimgSummaryReportSynthesis.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimimgSummaryReportSynthesis-2015072
2180528066
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimimgSummaryReportSynthesis-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoTimingReportImplemented.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimingReportImplemented-2015072
2181016920
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimingReportImplemented-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_logs/VivadoTimingReportSynthesis.log
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimingReportSynthesis-2015072
2180528066
.log
</location>
<location>
/home/andrey/git/x393/vivado_logs/VivadoTimingReportSynthesis-2015072
3175509485
.log
</location>
</link>
<link>
<name>
vivado_state/x393-opt-phys.dcp
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_state/x393-opt-phys-2015072
2181016920
.dcp
</location>
<location>
/home/andrey/git/x393/vivado_state/x393-opt-phys-2015072
3175509485
.dcp
</location>
</link>
<link>
<name>
vivado_state/x393-place.dcp
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_state/x393-place-2015072
2181016920
.dcp
</location>
<location>
/home/andrey/git/x393/vivado_state/x393-place-2015072
3175509485
.dcp
</location>
</link>
<link>
<name>
vivado_state/x393-route.dcp
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_state/x393-route-2015072
2181016920
.dcp
</location>
<location>
/home/andrey/git/x393/vivado_state/x393-route-2015072
3175509485
.dcp
</location>
</link>
<link>
<name>
vivado_state/x393-synth.dcp
</name>
<type>
1
</type>
<location>
/home/andrey/git/x393/vivado_state/x393-synth-2015072
2180528066
.dcp
</location>
<location>
/home/andrey/git/x393/vivado_state/x393-synth-2015072
3174740723
.dcp
</location>
</link>
</linkedResources>
</projectDescription>
This diff is collapsed.
Click to expand it.
.settings/com.elphel.vdt.VivadoSynthesis.prefs
View file @
64ff56ce
...
...
@@ -4,6 +4,6 @@ VivadoSynthesis_115_flatten_hierarchy=none
VivadoSynthesis_127_verbose=true
VivadoSynthesis_81_parser_mode=1
VivadoSynthesis_93_OtherProblems=Netlist 29-345<-@\#\#@->Board 49-26<-@\#\#@->
VivadoSynthesis_95_ShowInfo=
tru
e
VivadoSynthesis_95_ShowInfo=
fals
e
com.elphel.store.context.VivadoSynthesis=VivadoSynthesis_102_ConstraintsFiles<-@\#\#@->VivadoSynthesis_95_ShowInfo<-@\#\#@->VivadoSynthesis_115_flatten_hierarchy<-@\#\#@->VivadoSynthesis_101_MaxMsg<-@\#\#@->VivadoSynthesis_127_verbose<-@\#\#@->VivadoSynthesis_93_OtherProblems<-@\#\#@->VivadoSynthesis_81_parser_mode<-@\#\#@->
eclipse.preferences.version=1
This diff is collapsed.
Click to expand it.
compressor_jp/huffman393.v
View file @
64ff56ce
This diff is collapsed.
Click to expand it.
memctrl/cmd_encod_linear_mux.v
View file @
64ff56ce
...
...
@@ -436,7 +436,7 @@ module cmd_encod_linear_mux#(
;
`ifdef
def_scanline_chn0
wire
start0
=
0
|
wire
start0
=
0
`ifdef
def_read_mem_chn0
|
start0_rd
`endif
...
...
@@ -446,7 +446,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn1
wire
start1
=
0
|
wire
start1
=
0
`ifdef
def_read_mem_chn1
|
start1_rd
`endif
...
...
@@ -456,7 +456,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn2
wire
start2
=
0
|
wire
start2
=
0
`ifdef
def_read_mem_chn2
|
start2_rd
`endif
...
...
@@ -466,7 +466,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn3
wire
start3
=
0
|
wire
start3
=
0
`ifdef
def_read_mem_chn3
|
start3_rd
`endif
...
...
@@ -476,7 +476,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn4
wire
start4
=
0
|
wire
start4
=
0
`ifdef
def_read_mem_chn4
|
start4_rd
`endif
...
...
@@ -486,7 +486,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn5
wire
start5
=
0
|
wire
start5
=
0
`ifdef
def_read_mem_chn5
|
start5_rd
`endif
...
...
@@ -496,7 +496,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn6
wire
start6
=
0
|
wire
start6
=
0
`ifdef
def_read_mem_chn6
|
start6_rd
`endif
...
...
@@ -506,7 +506,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn7
wire
start7
=
0
|
wire
start7
=
0
`ifdef
def_read_mem_chn7
|
start7_rd
`endif
...
...
@@ -516,7 +516,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn8
wire
start8
=
0
|
wire
start8
=
0
`ifdef
def_read_mem_chn8
|
start8_rd
`endif
...
...
@@ -526,7 +526,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn9
wire
start9
=
0
|
wire
start9
=
0
`ifdef
def_read_mem_chn9
|
start9_rd
`endif
...
...
@@ -536,7 +536,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn10
wire
start10
=
0
|
wire
start10
=
0
`ifdef
def_read_mem_chn10
|
start10_rd
`endif
...
...
@@ -546,7 +546,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn11
wire
start11
=
0
|
wire
start11
=
0
`ifdef
def_read_mem_chn11
|
start11_rd
`endif
...
...
@@ -556,7 +556,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn12
wire
start12
=
0
|
wire
start12
=
0
`ifdef
def_read_mem_chn12
|
start12_rd
`endif
...
...
@@ -566,7 +566,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn13
wire
start13
=
0
|
wire
start13
=
0
`ifdef
def_read_mem_chn13
|
start13_rd
`endif
...
...
@@ -576,7 +576,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn14
wire
start14
=
0
|
wire
start14
=
0
`ifdef
def_read_mem_chn14
|
start14_rd
`endif
...
...
@@ -586,7 +586,7 @@ module cmd_encod_linear_mux#(
;
`endif
`ifdef
def_scanline_chn15
wire
start15
=
0
|
wire
start15
=
0
`ifdef
def_read_mem_chn15
|
start15_rd
`endif
...
...
This diff is collapsed.
Click to expand it.
memctrl/cmd_encod_tiled_mux.v
View file @
64ff56ce
...
...
@@ -539,7 +539,7 @@ module cmd_encod_tiled_mux #(
;
`ifdef
def_tiled_chn0
wire
start0
=
0
|
wire
start0
=
0
`ifdef
def_read_mem_chn0
|
start0_rd
|
start0_rd32
`endif
...
...
@@ -549,7 +549,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn1
wire
start1
=
0
|
wire
start1
=
0
`ifdef
def_read_mem_chn1
|
start1_rd
|
start1_rd32
`endif
...
...
@@ -559,7 +559,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn2
wire
start2
=
0
|
wire
start2
=
0
`ifdef
def_read_mem_chn2
|
start2_rd
|
start2_rd32
`endif
...
...
@@ -569,7 +569,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn3
wire
start3
=
0
|
wire
start3
=
0
`ifdef
def_read_mem_chn3
|
start3_rd
|
start3_rd32
`endif
...
...
@@ -579,7 +579,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn4
wire
start4
=
0
|
wire
start4
=
0
`ifdef
def_read_mem_chn4
|
start4_rd
|
start4_rd32
`endif
...
...
@@ -589,7 +589,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn5
wire
start5
=
0
|
wire
start5
=
0
`ifdef
def_read_mem_chn5
|
start5_rd
|
start5_rd32
`endif
...
...
@@ -599,7 +599,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn6
wire
start6
=
0
|
wire
start6
=
0
`ifdef
def_read_mem_chn6
|
start6_rd
|
start6_rd32
`endif
...
...
@@ -609,7 +609,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn7
wire
start7
=
0
|
wire
start7
=
0
`ifdef
def_read_mem_chn7
|
start7_rd
|
start7_rd32
`endif
...
...
@@ -619,7 +619,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn8
wire
start8
=
0
|
wire
start8
=
0
`ifdef
def_read_mem_chn8
|
start8_rd
|
start8_rd32
`endif
...
...
@@ -629,7 +629,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn9
wire
start9
=
0
|
wire
start9
=
0
`ifdef
def_read_mem_chn9
|
start9_rd
|
start9_rd32
`endif
...
...
@@ -639,7 +639,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn10
wire
start10
=
0
|
wire
start10
=
0
`ifdef
def_read_mem_chn10
|
start10_rd
|
start10_rd32
`endif
...
...
@@ -649,7 +649,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn11
wire
start11
=
0
|
wire
start11
=
0
`ifdef
def_read_mem_chn11
|
start11_rd
|
start11_rd32
`endif
...
...
@@ -659,7 +659,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn12
wire
start12
=
0
|
wire
start12
=
0
`ifdef
def_read_mem_chn12
|
start12_rd
|
start12_rd32
`endif
...
...
@@ -669,7 +669,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn13
wire
start13
=
0
|
wire
start13
=
0
`ifdef
def_read_mem_chn13
|
start13_rd
|
start13_rd32
`endif
...
...
@@ -679,7 +679,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn14
wire
start14
=
0
|
wire
start14
=
0
`ifdef
def_read_mem_chn14
|
start14_rd
|
start14_rd32
`endif
...
...
@@ -689,7 +689,7 @@ module cmd_encod_tiled_mux #(
;
`endif
`ifdef
def_tiled_chn15
wire
start15
=
0
|
wire
start15
=
0
`ifdef
def_read_mem_chn15
|
start15_rd
|
start15_rd32
`endif
...
...
This diff is collapsed.
Click to expand it.
memctrl/mcntrl_linear_rw.v
View file @
64ff56ce
...
...
@@ -96,7 +96,10 @@ module mcntrl_linear_rw #(
// WARNING: [Synth 8-3936] Found unconnected internal register 'frame_y_reg' and it is trimmed from '16' to '3' bits. [memctrl/mcntrl_linear_rw.v:268]
// Throblem seems to be that frame_y8_r_reg (load of trimmed bits of the frame_y_reg) is (as intended) absorbed into DSP48. The lower 3 bits are used
// outside of the DSP 48. "dont_touch" seems to work here
(
*
keep
=
"true"
*
)
reg
[
FRAME_HEIGHT_BITS
-
1
:
0
]
frame_y
;
// current line number referenced to the frame top
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
[
FRAME_HEIGHT_BITS
-
1
:
0
]
frame_y
;
// current line number referenced to the frame top
reg
[
FRAME_WIDTH_BITS
-
1
:
0
]
frame_x
;
// current column number referenced to the frame left
reg
[
FRAME_HEIGHT_BITS
-
4
:
0
]
frame_y8_r
;
// (13 bits) current row with bank removed, latency2 (to be absorbed when inferred DSP multipler)
reg
[
FRAME_WIDTH_BITS
:
0
]
frame_full_width_r
;
// (14 bit) register to be absorbed by MPY
...
...
This diff is collapsed.
Click to expand it.
memctrl/mcntrl_tiled_rw.v
View file @
64ff56ce
...
...
@@ -110,7 +110,10 @@ module mcntrl_tiled_rw#(
//WARNING: [Synth 8-3936] Found unconnected internal register 'frame_y_reg' and it is trimmed from '16' to '3' bits. [memctrl/mcntrl_tiled_rw.v:307]
// Throblem seems to be that frame_y8_r_reg (load of trimmed bits of the frame_y_reg) is (as intended) absorbed into DSP48. The lower 3 bits are used
// outside of the DSP 48. "dont_touch" seems to work here
(
*
keep
=
"true"
*
)
reg
[
FRAME_HEIGHT_BITS
-
1
:
0
]
frame_y
;
// current line number referenced to the frame top
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
[
FRAME_HEIGHT_BITS
-
1
:
0
]
frame_y
;
// current line number referenced to the frame top
reg
[
FRAME_WIDTH_BITS
-
1
:
0
]
frame_x
;
// current column number referenced to the frame left
reg
[
FRAME_HEIGHT_BITS
-
4
:
0
]
frame_y8_r
;
// (13 bits) current row with bank removed, latency2 (to be absorbed when inferred DSP multipler)
reg
[
FRAME_WIDTH_BITS
:
0
]
frame_full_width_r
;
// (14 bit) register to be absorbed by MPY
...
...
This diff is collapsed.
Click to expand it.
memctrl/phy/byte_lane.v
View file @
64ff56ce
...
...
@@ -55,15 +55,26 @@ module byte_lane #(
input
set
// clk_div synchronous set all delays from previously loaded values
)
;
//(* CLOCK_DEDICATED_ROUTE = "FALSE" *) // does not seem to work
wire
dqs_read
;
wire
iclk
;
// source-synchronous clock (BUFR from DQS)
reg
[
31
:
0
]
din_r
=
0
;
// Preventing register removal of equivalent registers
(
*
keep
=
"true"
*
)
reg
[
3
:
0
]
din_dm_r
=
0
,
din_dqs_r
=
0
,
tin_dq_r
=
4'hf
,
tin_dqs_r
=
4'hf
;
(
*
keep
=
"true"
*
)
reg
[
7
:
0
]
dly_data_r
=
0
;
(
*
keep
=
"true"
*
)
reg
set_r
=
0
;
(
*
keep
=
"true"
*
)
reg
dci_disable_dqs_r
,
dci_disable_dq_r
;
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
[
3
:
0
]
din_dm_r
=
0
,
din_dqs_r
=
0
,
tin_dq_r
=
4'hf
,
tin_dqs_r
=
4'hf
;
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
[
7
:
0
]
dly_data_r
=
0
;
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
set_r
=
0
;
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
dci_disable_dqs_r
,
dci_disable_dq_r
;
reg
[
7
:
0
]
ld_odly
=
8'b0
,
ld_idly
=
8'b0
;
reg
ld_odly_dqs
,
ld_idly_dqs
,
ld_odly_dm
;
BUFR
iclk_i
(
.
O
(
iclk
)
,.
I
(
dqs_read
)
,
.
CLR
(
1'b0
)
,.
CE
(
1'b1
))
;
// OK, works with constraint? Seems now work w/o
...
...
This diff is collapsed.
Click to expand it.
memctrl/phy/cmd_addr.v
View file @
64ff56ce
...
...
@@ -61,8 +61,14 @@ reg [1:0] in_we_r=2'h3, in_ras_r=2'h3, in_cas_r=2'h3, in_cke_r=2'h3, in_odt_r=2
//reg [1:0] in_tri_r=2'h0; // or tri-state on reset?
reg
in_tri_r
=
1'b1
;
// or tri-state on reset?
// Preventing register duplication
(
*
keep
=
"true"
*
)
reg
[
7
:
0
]
dly_data_r
=
0
;
(
*
keep
=
"true"
*
)
reg
set_r
=
0
;
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
[
7
:
0
]
dly_data_r
=
0
;
`ifndef
IGNORE_ATTR
(
*
keep
=
"true"
*
)
`endif
reg
set_r
=
0
;
reg
[
7
:
0
]
ld_dly_cmd
=
8'b0
;
reg
[
ADDRESS_NUMBER
-
1
:
0
]
ld_dly_addr
=
0
;
//wire [ADDRESS_NUMBER-1:0] decode_addr;
...
...
This diff is collapsed.
Click to expand it.
memctrl/phy/dq_single.v
View file @
64ff56ce
...
...
@@ -51,7 +51,6 @@ wire dq_tri;
wire
dq_data_dly
;
wire
dq_dly
;
// keep IOBUF_DCIEN.O to user as output only (UDM/LDM), so the rest of tyhe read channel will be optimized out, but I/O will stay the same
//(* keep = "true" *)
wire
dq_di
;
...
...
This diff is collapsed.
Click to expand it.
system_defines.vh
View file @
64ff56ce
...
...
@@ -5,6 +5,8 @@
`define SHREG_SEQUENTIAL_RESET 1
// synthesis does to recognize global clock as G input of the primitive latch
`undef INFER_LATCHES
// define when using CDC - it does not support them
`undef IGNORE_ATTR
//`define MEMBRIDGE_DEBUG_READ 1
`define use200Mhz 1
`define USE_CMD_ENCOD_TILED_32_RD 1
...
...
This diff is collapsed.
Click to expand it.
util_modules/level_cross_clocks.v
View file @
64ff56ce
...
...
@@ -28,11 +28,77 @@ module level_cross_clocks#(
input
[
WIDTH
-
1
:
0
]
d_in
,
output
[
WIDTH
-
1
:
0
]
d_out
)
;
generate
genvar
i
;
for
(
i
=
0
;
i
<
WIDTH
;
i
=
i
+
1
)
begin
:
level_cross_clock_block
if
(
REGISTER
<=
1
)
level_cross_clocks_ff_bit
level_cross_clocks_single_i
(
// just a single ff (if metastability is not a problem)
.
clk
(
clk
)
,
// input
.
d_in
(
d_in
[
i
])
,
// input
.
d_out
(
d_out
[
i
])
// output
)
;
else
if
(
REGISTER
==
2
)
level_cross_clocks_sync_bit
level_cross_clocks_sync_i
(
// classic 2-register synchronizer
.
clk
(
clk
)
,
// input
.
d_in
(
d_in
[
i
])
,
// input
.
d_out
(
d_out
[
i
])
// output
)
;
else
level_cross_clocks_single_bit
#(
// >2 bits (first two only are synchronizer)
.
REGISTER
(
REGISTER
)
)
level_cross_clocks_single_i
(
.
clk
(
clk
)
,
// input
.
d_in
(
d_in
[
i
])
,
// input
.
d_out
(
d_out
[
i
])
// output
)
;
end
endgenerate
endmodule
module
level_cross_clocks_single_bit
#(
parameter
REGISTER
=
3
// number of registers (>3)
)(
input
clk
,
input
d_in
,
output
d_out
)
;
reg
[
REGISTER
-
3
:
0
]
regs
;
wire
d_sync
;
// after a 2-bit synchronizer
assign
d_out
=
regs
[
REGISTER
-
3
]
;
always
@
(
posedge
clk
)
begin
regs
<=
(
regs
<<
1
)
+
d_sync
;
// | d_in complains about widths mismatch
end
level_cross_clocks_sync_bit
level_cross_clocks_sync_bit_i
(
.
clk
(
clk
)
,
// input
.
d_in
(
d_in
)
,
// input
.
d_out
(
d_sync
)
// output
)
;
endmodule
reg
[
WIDTH
*
REGISTER
-
1
:
0
]
regs
;
assign
d_out
=
regs
[
WIDTH
-
1
:
0
]
;
// Classic 2-bit (exactly) synchronizer
module
level_cross_clocks_sync_bit
(
input
clk
,
input
d_in
,
output
d_out
)
;
`ifndef
IGNORE_ATTR
(
*
ASYNC_REG
=
"TRUE"
*
)
`endif
reg
[
1
:
0
]
sync_zer
;
assign
d_out
=
sync_zer
[
1
]
;
always
@
(
posedge
clk
)
begin
regs
<=
{
d_in
,
regs
[
WIDTH
*
REGISTER
-
1
:
WIDTH
]
};
sync_zer
<=
{
sync_zer
[
0
]
,
d_in
};
end
endmodule
module
level_cross_clocks_ff_bit
(
// just a single FF if REGISTER == 1 (if metastability is not a problem)
input
clk
,
input
d_in
,
output
reg
d_out
)
;
always
@
(
posedge
clk
)
begin
d_out
<=
d_in
;
end
endmodule
This diff is collapsed.
Click to expand it.
util_modules/pulse_cross_clock.v
View file @
64ff56ce
...
...
@@ -33,8 +33,22 @@ module pulse_cross_clock#(
output
busy
)
;
localparam
EXTRA_DLY_SAFE
=
EXTRA_DLY
?
1
:
0
;
reg
in_reg
=
0
;
`ifndef
IGNORE_ATTR
(
*
KEEP
=
"TRUE"
*
)
`endif
reg
in_reg
=
0
;
// can not be ASYNC_REG as it can not be put together with out_reg
//WARNING: [Constraints 18-1079] Register sensors393_i/sensor_channel_block[0].sensor_channel_i/sens_sync_i/pulse_cross_clock_trig_in_pclk_i/in_reg_reg
// and sensors393_i/sensor_channel_block[0].sensor_channel_i/sens_sync_i/pulse_cross_clock_trig_in_pclk_i/out_reg_reg[0] are
//from the same synchronizer and have the ASYNC_REG property set, but could not be placed into the same slice due to constraints
// or mismatched control signals on the registers.
`ifndef
IGNORE_ATTR
(
*
ASYNC_REG
=
"TRUE"
*
)
`endif
reg
[
2
:
0
]
out_reg
=
0
;
`ifndef
IGNORE_ATTR
(
*
ASYNC_REG
=
"TRUE"
*
)
`endif
reg
busy_r
=
0
;
assign
out_pulse
=
out_reg
[
2
]
;
assign
busy
=
busy_r
;
// in_reg;
...
...
This diff is collapsed.
Click to expand it.
wrap/idelay_ctrl.v
View file @
64ff56ce
...
...
@@ -28,8 +28,10 @@ module idelay_ctrl
input
rst
,
output
rdy
)
;
`ifndef
IGNORE_ATTR
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
`endif
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
IDELAYCTRL
idelay_ctrl_i
(
.
RDY
(
rdy
)
,
.
REFCLK
(
refclk
)
,
...
...
This diff is collapsed.
Click to expand it.
wrap/idelay_fine_pipe.v
View file @
64ff56ce
...
...
@@ -49,7 +49,10 @@ module idelay_fine_pipe
if
(
fdly_pre
>
3'h4
)
$
display
(
"ERROR: fine idelay value should be <5, specified %d @ %t"
,
fdly_pre
,
$
time
)
;
end
`endif
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
IDELAYE2_FINEDELAY
`ifndef
IGNORE_ATTR
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
`endif
IDELAYE2_FINEDELAY
#(
.
CINVCTRL_SEL
(
"FALSE"
)
,
.
DELAY_SRC
(
"IDATAIN"
)
,
...
...
This diff is collapsed.
Click to expand it.
wrap/idelay_nofine.v
View file @
64ff56ce
...
...
@@ -34,7 +34,10 @@ module idelay_nofine
input
data_in
,
output
data_out
)
;
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
IDELAYE2
`ifndef
IGNORE_ATTR
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
`endif
IDELAYE2
#(
.
CINVCTRL_SEL
(
"FALSE"
)
,
.
DELAY_SRC
(
"IDATAIN"
)
,
...
...
This diff is collapsed.
Click to expand it.
wrap/mmcm_phase_cntr.v
View file @
64ff56ce
...
...
@@ -108,11 +108,9 @@ module mmcm_phase_cntr#(
reg
[
PHASE_WIDTH
-
1
:
0
]
ps_target
;
reg
ps_busy
=
0
;
// TODO: find out why it was optimized out!
// (* keep = "true" *)
reg
ps_start0
,
ps_start
;
// debugging
assign
ps_ready
=!
ps_busy
&&
locked
&&
!
ps_start0
&&
!
ps_start
;
assign
psen
=
ps_start
&&
(
diff
!=
0
)
;
// wire [PHASE_WIDTH:0] diff= ps_target-ps_dout_r;
// made a difference, so it doesn't seem Vivado extends bits of operands "+", "-"
wire
[
PHASE_WIDTH
:
0
]
diff
=
{
ps_target
[
PHASE_WIDTH
-
1
]
,
ps_target
}-{
ps_dout_r
[
PHASE_WIDTH
-
1
]
,
ps_dout_r
};
assign
ps_dout
=
ps_dout_r
;
...
...
This diff is collapsed.
Click to expand it.
wrap/odelay_fine_pipe.v
View file @
64ff56ce
...
...
@@ -49,7 +49,10 @@ module odelay_fine_pipe
end
`endif
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
ODELAYE2_FINEDELAY
`ifndef
IGNORE_ATTR
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
`endif
ODELAYE2_FINEDELAY
#(
.
CINVCTRL_SEL
(
"FALSE"
)
,
.
DELAY_SRC
(
"ODATAIN"
)
,
...
...
This diff is collapsed.
Click to expand it.
wrap/odelay_pipe.v
View file @
64ff56ce
...
...
@@ -36,8 +36,10 @@ module odelay_pipe
output
data_out
)
;
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
ODELAYE2
#(
`ifndef
IGNORE_ATTR
(
*
IODELAY_GROUP
=
IODELAY_GRP
*
)
`endif
ODELAYE2
#(
.
CINVCTRL_SEL
(
"FALSE"
)
,
.
DELAY_SRC
(
"ODATAIN"
)
,
// .FINEDELAY("ADD_DLY"),
...
...
This diff is collapsed.
Click to expand it.
x393.v
View file @
64ff56ce
...
...
@@ -96,15 +96,17 @@ module x393 #(
// localparam ADDRESS_NUMBER=15;
// localparam COLADDR_NUMBER=10;
// Source for reset and clock
(
*
keep
=
"true"
*
)
`ifndef
IGNORE_ATTR
(
*
KEEP
=
"TRUE"
*
)
`endif
wire
[
3
:
0
]
fclk
;
// PL Clocks [3:0], output
(
*
keep
=
"true"
*
)
`ifndef
IGNORE_ATTR
(
*
KEEP
=
"TRUE"
*
)
`endif
wire
[
3
:
0
]
frst
;
// PL Clocks [3:0], output
// AXI write interface signals
//(* keep = "true" *)
wire
axi_aclk
;
// clock - should be buffered
//(* dont_touch = "true" *)
wire
axi_grst
;
// reset, active high, global (try to get rid of) - trying, removed BUFG
// AXI Write Address
wire
[
31
:
0
]
maxi0_awaddr
;
// AWADDR[31:0], input
...
...
This diff is collapsed.
Click to expand it.
x393.xdc
View file @
64ff56ce
...
...
@@ -31,6 +31,8 @@ set_property is_enabled false [get_drc_checks REQP-1577]
#Synchronous clocking for BRAM (mult_saxi_wr_inbuf_i/ram_var_w_var_r_i/ram_i/RAMB36E1_i) in SDP mode ...
set_property is_enabled false [get_drc_checks REQP-165]
#Useless input. The input pins CE and CLR are not used for BUFR_DIVIDE BYPASS.
set_property is_enabled false [get_drc_checks REQP-14]
# output SDRST, // output SDRST, active low
...
...
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