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
5a9a6342
Commit
5a9a6342
authored
Mar 01, 2018
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
hispi v03930100, 1704, added SOF mask to disable while setting up
interface
parent
2dcd8eb3
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
24 additions
and
11 deletions
+24
-11
fpga_version.vh
fpga_version.vh
+4
-1
x393_export_c.py
py393/x393_export_c.py
+1
-0
sens_sync.v
sensor/sens_sync.v
+19
-10
x393_hispi.bit
x393_hispi.bit
+0
-0
No files found.
fpga_version.vh
View file @
5a9a6342
...
...
@@ -36,7 +36,10 @@
* with at least one of the Free Software programs.
*/
parameter FPGA_VERSION = 32'h039300fd; // serial - 17.4 - monitor lanes barrel (0..3)
parameter FPGA_VERSION = 32'h03930100; // serial - 17.4 - disabling SOF when setting interface
// parameter FPGA_VERSION = 32'h039300ff; // serial - 15.3 - same, suspected bitstream problems
// parameter FPGA_VERSION = 32'h039300fe; // serial - 17.4 - same, suspected bitstream problems no timing errors
// parameter FPGA_VERSION = 32'h039300fd; // serial - 17.4 - monitor lanes barrel (0..3)
// parameter FPGA_VERSION = 32'h039300fc; // serial - 17.4 - skipping first lines? pclk dsp1->dsp2 3*54ps
// parameter FPGA_VERSION = 32'h039300fb; // serial - 17.4 - serial, adding trigger control, lanes_alive (violated xclk by 0.004)
// parameter FPGA_VERSION = 32'h039300fa; // serial - 15.3 - serial, modifying lens_flat - timing met
...
...
py393/x393_export_c.py
View file @
5a9a6342
...
...
@@ -1967,6 +1967,7 @@ class X393ExportC(object):
def
_enc_sens_sync_mult
(
self
):
dw
=
[]
dw
.
append
((
"mult_frames"
,
0
,
vrlg
.
SENS_SYNC_FBITS
,
0
,
"Number of frames to combine into one minus 1 (0 - single,1 - two frames...)"
))
dw
.
append
((
"dis_sof"
,
vrlg
.
SENS_SYNC_FBITS
,
1
,
0
,
"disable SOF (while setting up sensor interface to prevent stray SOF)"
))
return
dw
def
_enc_sens_sync_late
(
self
):
...
...
sensor/sens_sync.v
View file @
5a9a6342
...
...
@@ -43,6 +43,7 @@ module sens_sync#(
parameter
SENS_SYNC_MASK
=
'h7fc
,
// 2 locations reserved for control/status (if they will be needed)
parameter
SENS_SYNC_MULT
=
'h2
,
// relative register address to write number of frames to combine in one (minus 1, '0' - each farme)
// 'hffff - disable frames generation !
parameter
SENS_SYNC_LATE
=
'h3
,
// number of lines to delay late frame sync
parameter
SENS_SYNC_FBITS
=
16
,
// number of bits in a frame counter for linescan mode
parameter
SENS_SYNC_LBITS
=
16
,
// number of bits in a line counter for sof_late output (limited by eof)
...
...
@@ -76,7 +77,8 @@ module sens_sync#(
reg
[
SENS_SYNC_LBITS
-
1
:
0
]
line_dly_pclk
=
SENS_SYNC_LATE_DFLT
;
// sub-frame number ("linescan" mode)
reg
[
SENS_SYNC_FBITS
-
1
:
0
]
sub_frames_left
;
// sub-frame number ("linescan" mode)
reg
[
SENS_SYNC_FBITS
-
1
:
0
]
lines_left
;
//Number of lines left to generate sof_late
reg
[
DATA_WIDTH
-
1
:
0
]
cmd_data_r
;
// reg [DATA_WIDTH-1:0] cmd_data_r;
reg
[
DATA_WIDTH
:
0
]
cmd_data_r
;
// 1<<16 - disable SOF
wire
[
31
:
0
]
cmd_data
;
wire
[
1
:
0
]
cmd_a
;
wire
cmd_we
;
...
...
@@ -99,16 +101,21 @@ module sens_sync#(
reg
[
SENS_SYNC_MINBITS
-
1
:
0
]
period_cntr
;
reg
period_dly
;
// runnning counter to enforce > min period
reg
en_pclk
;
reg
dis_frame_sync
;
// @pclk disable frame sync generation (during interface set up to prevent stray fs)
wire
sof_in_masked
=
!
dis_frame_sync
&&
sof_in
;
assign
set_data_mclk
=
cmd_we
&&
((
cmd_a
==
SENS_SYNC_MULT
)
||
(
cmd_a
==
SENS_SYNC_LATE
))
;
assign
zero_frames_left
=
!
(
|
sub_frames_left
)
;
assign
hact_single
=
hact
&&
!
hact_r
;
assign
last_line
=
!
(
|
lines_left
)
;
assign
pre_sof_late
=
sof_dly
&&
(
eof_in
||
(
hact_single
&&
last_line
))
;
assign
trig
=
trig_r
;
assign
pre_sof_out
=
sof_in
&&
zero_frames_left
&&
!
period_dly
&&
(
en_vacts_free
||
trig_r
||
overdue
)
;
assign
pre_sof_out
=
sof_in
_masked
&&
zero_frames_left
&&
!
period_dly
&&
(
en_vacts_free
||
trig_r
||
overdue
)
;
always
@
(
posedge
mclk
)
begin
if
(
set_data_mclk
)
cmd_data_r
<=
cmd_data
[
DATA_WIDTH
-
1
:
0
]
;
// if (set_data_mclk) cmd_data_r <= cmd_data[DATA_WIDTH-1:0];
if
(
set_data_mclk
)
cmd_data_r
<=
cmd_data
[
DATA_WIDTH
:
0
]
;
if
(
set_data_mclk
)
cmd_a_r
<=
cmd_a
;
end
...
...
@@ -116,14 +123,16 @@ module sens_sync#(
en_pclk
<=
en
;
if
(
set_data_pclk
&&
(
cmd_a_r
==
SENS_SYNC_MULT
))
if
(
set_data_pclk
&&
(
cmd_a_r
==
SENS_SYNC_MULT
))
begin
// sub_frames_pclk <= cmd_data_r[SENS_SYNC_FBITS-1:0];
sub_frames_pclk
<=
cmd_data_r
[
SENS_SYNC_FBITS
-
1
:
0
]
;
dis_frame_sync
<=
cmd_data_r
[
SENS_SYNC_FBITS
]
;
end
if
(
set_data_pclk
&&
(
cmd_a_r
==
SENS_SYNC_LATE
))
line_dly_pclk
<=
cmd_data_r
[
SENS_SYNC_LBITS
-
1
:
0
]
;
if
(
!
en
||
(
sof_in
&&
zero_frames_left
))
sub_frames_left
<=
sub_frames_pclk
;
else
if
(
sof_in
)
sub_frames_left
<=
sub_frames_left
-
1
;
if
(
!
en
||
(
sof_in
_masked
&&
zero_frames_left
))
sub_frames_left
<=
sub_frames_pclk
;
else
if
(
sof_in
_masked
)
sub_frames_left
<=
sub_frames_left
-
1
;
// if (!en) hact_r <= hact;
hact_r
<=
hact
||
!
en
;
...
...
@@ -138,13 +147,13 @@ module sens_sync#(
trigger_mode_pclk
<=
trigger_mode
;
if
(
!
trigger_mode_pclk
||
!
en
)
en_vacts_free
<=
1'b1
;
else
if
(
sof_in
)
en_vacts_free
<=
1'b0
;
else
if
(
sof_in
_masked
)
en_vacts_free
<=
1'b0
;
if
(
pre_sof_out
||
!
trigger_mode_pclk
)
overdue
<=
1'b0
;
else
if
(
trig_in_pclk
)
overdue
<=
trig_r
;
if
(
!
en
||
!
trigger_mode_pclk
||
sof_in
)
trig_r
<=
0
;
else
if
(
trig_in_pclk
)
trig_r
<=
~
trig_r
;
if
(
!
en
||
!
trigger_mode_pclk
||
sof_in
_masked
)
trig_r
<=
0
;
else
if
(
trig_in_pclk
)
trig_r
<=
~
trig_r
;
// enforce minimal frame period (applies to both normal and delayed pulse (Make it only in free-running mode?)
if
(
!
en
||
!
(
&
period_cntr
))
period_dly
<=
0
;
...
...
x393_hispi.bit
View file @
5a9a6342
No preview for this file type
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