Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
elphel-apps-php-extension
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Elphel
elphel-apps-php-extension
Commits
7b7496a5
Commit
7b7496a5
authored
May 08, 2021
by
Andrey Filippov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
added elphel_frame2tf(), elphel_tf2frame()
parent
ec4e33df
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
53 additions
and
6 deletions
+53
-6
elphel_php.c
src/ext/elphel/elphel_php.c
+51
-5
elphel_php.h
src/ext/elphel/elphel_php.h
+2
-1
No files found.
src/ext/elphel/elphel_php.c
View file @
7b7496a5
...
@@ -260,6 +260,8 @@ static zend_function_entry elphel_functions[] = {
...
@@ -260,6 +260,8 @@ static zend_function_entry elphel_functions[] = {
PHP_FE
(
elphel_get_exif_elphel
,
NULL
)
PHP_FE
(
elphel_get_exif_elphel
,
NULL
)
PHP_FE
(
elphel_update_exif
,
NULL
)
PHP_FE
(
elphel_update_exif
,
NULL
)
PHP_FE
(
elphel_get_circbuf_pointers
,
NULL
)
PHP_FE
(
elphel_get_circbuf_pointers
,
NULL
)
PHP_FE
(
elphel_frame2tf
,
NULL
)
PHP_FE
(
elphel_tf2frame
,
NULL
)
{
NULL
,
NULL
,
NULL
}
{
NULL
,
NULL
,
NULL
}
};
};
...
@@ -1080,7 +1082,7 @@ PHP_FUNCTION(elphel_gamma_add_custom)
...
@@ -1080,7 +1082,7 @@ PHP_FUNCTION(elphel_gamma_add_custom)
arr_hash
=
Z_ARRVAL_P
(
arr
);
arr_hash
=
Z_ARRVAL_P
(
arr
);
array_count
=
zend_hash_num_elements
(
arr_hash
);
array_count
=
zend_hash_num_elements
(
arr_hash
);
if
(
array_count
!=
257
)
{
if
(
array_count
!=
257
)
{
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Wrong array length (should be 257) - %d"
,
array_count
);
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Wrong array length (should be 257) - %d"
,
(
int
)
array_count
);
RETURN_LONG
(
-
999
);
RETURN_LONG
(
-
999
);
}
}
hash16
&=
0xffff
;
hash16
&=
0xffff
;
...
@@ -1256,7 +1258,7 @@ PHP_FUNCTION(elphel_gamma_get_raw)
...
@@ -1256,7 +1258,7 @@ PHP_FUNCTION(elphel_gamma_get_raw)
RETURN_NULL
();
RETURN_NULL
();
}
}
if
(
index
>=
GAMMA_CACHE_NUMBER
)
{
if
(
index
>=
GAMMA_CACHE_NUMBER
)
{
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Wrong index (%d >= %d)"
,
index
,
(
int
)
GAMMA_CACHE_NUMBER
);
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Wrong index (%d >= %d)"
,
(
int
)
index
,
(
int
)
GAMMA_CACHE_NUMBER
);
RETURN_NULL
();
RETURN_NULL
();
}
}
packed_gamma_structure
=
(
char
*
)
emalloc
(
sizeof
(
struct
gamma_stuct_t
));
packed_gamma_structure
=
(
char
*
)
emalloc
(
sizeof
(
struct
gamma_stuct_t
));
...
@@ -1313,7 +1315,7 @@ PHP_FUNCTION(elphel_histogram_get_raw)
...
@@ -1313,7 +1315,7 @@ PHP_FUNCTION(elphel_histogram_get_raw)
lseek
(
ELPHEL_G
(
fd_histogram_cache
),
LSEEK_HIST_NEEDED
+
(
needed
&
0xff0
),
SEEK_END
);
/// mask out needed raw (fpga) bits
lseek
(
ELPHEL_G
(
fd_histogram_cache
),
LSEEK_HIST_NEEDED
+
(
needed
&
0xff0
),
SEEK_END
);
/// mask out needed raw (fpga) bits
index
=
lseek
(
ELPHEL_G
(
fd_histogram_cache
),
frame
,
SEEK_SET
);
/// request histograms for frame=frame, wait until available if needed
index
=
lseek
(
ELPHEL_G
(
fd_histogram_cache
),
frame
,
SEEK_SET
);
/// request histograms for frame=frame, wait until available if needed
if
(
index
<
0
)
{
if
(
index
<
0
)
{
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Requested histograms are not available (frame=%ld, needed=0x%x)"
,
frame
,
needed
);
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Requested histograms are not available (frame=%ld, needed=0x%
l
x)"
,
frame
,
needed
);
RETURN_NULL
();
RETURN_NULL
();
}
}
if
(
index
>=
total_hist_entries
)
{
if
(
index
>=
total_hist_entries
)
{
...
@@ -1393,13 +1395,13 @@ PHP_FUNCTION(elphel_histogram_get)
...
@@ -1393,13 +1395,13 @@ PHP_FUNCTION(elphel_histogram_get)
/// verify that histogram is still valid
/// verify that histogram is still valid
if
(
frame
!=
((
struct
histogram_stuct_t
*
)
ELPHEL_G
(
histogram_cache
))[
index
].
frame
)
{
if
(
frame
!=
((
struct
histogram_stuct_t
*
)
ELPHEL_G
(
histogram_cache
))[
index
].
frame
)
{
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Frame changed while retrieving histograms (frame requested=%d, received=%d, index=%d)"
,
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Frame changed while retrieving histograms (frame requested=%d, received=%d, index=%d)"
,
frame
,
(
int
)((
struct
histogram_stuct_t
*
)
ELPHEL_G
(
histogram_cache
))[
index
].
frame
,
index
);
(
int
)
frame
,
(
int
)((
struct
histogram_stuct_t
*
)
ELPHEL_G
(
histogram_cache
))[
index
].
frame
,
(
int
)
index
);
RETURN_NULL
();
RETURN_NULL
();
efree
(
frame_histogram_structure
);
efree
(
frame_histogram_structure
);
}
}
/// verify that selected tables are valid
/// verify that selected tables are valid
if
((
needed
&
frame_histogram_structure
->
valid
)
!=
needed
)
{
if
((
needed
&
frame_histogram_structure
->
valid
)
!=
needed
)
{
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Not all the requested tables are available (frame=%
d needed=0x%x, valid=0x%
x)"
,
php_error_docref
(
NULL
TSRMLS_CC
,
E_ERROR
,
"Not all the requested tables are available (frame=%
ld needed=0x%lx, valid=0x%l
x)"
,
frame
,
needed
,
frame_histogram_structure
->
valid
);
frame
,
needed
,
frame_histogram_structure
->
valid
);
RETURN_NULL
();
RETURN_NULL
();
efree
(
frame_histogram_structure
);
efree
(
frame_histogram_structure
);
...
@@ -2362,6 +2364,50 @@ PHP_FUNCTION(elphel_get_fpga_time) {
...
@@ -2362,6 +2364,50 @@ PHP_FUNCTION(elphel_get_fpga_time) {
dtime
=
ELPHEL_GLOBALPARS
(
0
,
G_SECONDS
)
+
0
.
000001
*
dtime
;
dtime
=
ELPHEL_GLOBALPARS
(
0
,
G_SECONDS
)
+
0
.
000001
*
dtime
;
RETURN_DOUBLE
(
dtime
);
RETURN_DOUBLE
(
dtime
);
}
}
PHP_FUNCTION
(
elphel_frame2tf
)
{
double
cts
=
0
.
0
;
long
port
,
frame
=
0
;
long
cframe
;
double
period_sec
;
// trigger period in seconds
if
(
zend_parse_parameters
(
ZEND_NUM_ARGS
()
TSRMLS_CC
,
"l|l"
,
&
port
,
&
frame
)
==
FAILURE
)
RETURN_NULL
();
if
((
port
<
0
)
||
(
port
>=
SENSOR_PORTS
))
RETURN_NULL
();
// read last compressed frame ts and frame number
cframe
=
ELPHEL_GLOBALPARS
(
port
,
G_COMPRESSOR_FRAME
);
cts
=
ELPHEL_GLOBALPARS
(
port
,
G_COMPRESSOR_SEC
)
+
0
.
000001
*
ELPHEL_GLOBALPARS
(
port
,
G_COMPRESSOR_USEC
);
if
(
frame
>
0
){
// if <=0 (or absent) return last compressed frame
// read trigger period (even for externally triggered slaves this value has to be defined and used for period)
period_sec
=
0
.
00000001
*
(((
struct
framepars_t
*
)
ELPHEL_G
(
framePars
[
port
]))[
cframe
&
PARS_FRAMES_MASK
].
pars
[
P_TRIG_PERIOD
]);
cts
+=
(
frame
-
cframe
)
*
period_sec
;
}
RETURN_DOUBLE
(
cts
);
}
PHP_FUNCTION
(
elphel_tf2frame
)
{
double
dts
=
0
.
0
;
double
cts
=
0
.
0
;
double
delta_ts
;
long
port
;
long
cframe
;
double
period_sec
;
// trigger period in seconds
if
(
zend_parse_parameters
(
ZEND_NUM_ARGS
()
TSRMLS_CC
,
"l|d"
,
&
port
,
&
dts
)
==
FAILURE
)
RETURN_NULL
();
if
((
port
<
0
)
||
(
port
>=
SENSOR_PORTS
))
RETURN_NULL
();
// read last compressed frame ts and frame number
cframe
=
ELPHEL_GLOBALPARS
(
port
,
G_COMPRESSOR_FRAME
);
cts
=
ELPHEL_GLOBALPARS
(
port
,
G_COMPRESSOR_SEC
)
+
0
.
000001
*
ELPHEL_GLOBALPARS
(
port
,
G_COMPRESSOR_USEC
);
if
(
dts
>
0
){
// if <=0 (or absent) return last compressed frame
// read trigger period (even for externally triggered slaves this value has to be defined and used for period)
period_sec
=
0
.
00000001
*
(((
struct
framepars_t
*
)
ELPHEL_G
(
framePars
[
port
]))[
cframe
&
PARS_FRAMES_MASK
].
pars
[
P_TRIG_PERIOD
]);
delta_ts
=
dts
-
cts
+
0
.
5
*
period_sec
;
// for rounding
cframe
+=
(
long
)
(
delta_ts
/
period_sec
);
}
RETURN_LONG
(
cframe
);
}
#if 0
#if 0
static struct framepars_all_t test_structure;
static struct framepars_all_t test_structure;
static void php_elphel_init_globals(zend_elphel_globals *elphel_globals)
static void php_elphel_init_globals(zend_elphel_globals *elphel_globals)
...
...
src/ext/elphel/elphel_php.h
View file @
7b7496a5
...
@@ -116,7 +116,8 @@ PHP_FUNCTION(elphel_get_interframe_meta);
...
@@ -116,7 +116,8 @@ PHP_FUNCTION(elphel_get_interframe_meta);
PHP_FUNCTION
(
elphel_get_exif_elphel
);
PHP_FUNCTION
(
elphel_get_exif_elphel
);
PHP_FUNCTION
(
elphel_get_circbuf_pointers
);
PHP_FUNCTION
(
elphel_get_circbuf_pointers
);
PHP_FUNCTION
(
elphel_update_exif
);
// force to rebuild directory after Exif format was changed Usually done automatically
PHP_FUNCTION
(
elphel_update_exif
);
// force to rebuild directory after Exif format was changed Usually done automatically
PHP_FUNCTION
(
elphel_frame2tf
);
PHP_FUNCTION
(
elphel_tf2frame
);
PHP_MINIT_FUNCTION
(
elphel
);
PHP_MINIT_FUNCTION
(
elphel
);
PHP_MSHUTDOWN_FUNCTION
(
elphel
);
PHP_MSHUTDOWN_FUNCTION
(
elphel
);
...
...
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