Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-1.1
Commits
7bb31a1f
Commit
7bb31a1f
authored
Dec 03, 2009
by
Jakob Leben
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
jack: use real latency for buffer date
parent
be84ae0b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
3 deletions
+32
-3
modules/audio_output/jack.c
modules/audio_output/jack.c
+32
-3
No files found.
modules/audio_output/jack.c
View file @
7bb31a1f
...
@@ -54,6 +54,7 @@ struct aout_sys_t
...
@@ -54,6 +54,7 @@ struct aout_sys_t
jack_port_t
**
p_jack_ports
;
jack_port_t
**
p_jack_ports
;
jack_sample_t
**
p_jack_buffers
;
jack_sample_t
**
p_jack_buffers
;
unsigned
int
i_channels
;
unsigned
int
i_channels
;
jack_nframes_t
latency
;
};
};
/*****************************************************************************
/*****************************************************************************
...
@@ -63,6 +64,7 @@ static int Open ( vlc_object_t * );
...
@@ -63,6 +64,7 @@ static int Open ( vlc_object_t * );
static
void
Close
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
static
void
Play
(
aout_instance_t
*
);
static
void
Play
(
aout_instance_t
*
);
static
int
Process
(
jack_nframes_t
i_frames
,
void
*
p_arg
);
static
int
Process
(
jack_nframes_t
i_frames
,
void
*
p_arg
);
static
int
GraphChange
(
void
*
p_arg
);
#define AUTO_CONNECT_OPTION "jack-auto-connect"
#define AUTO_CONNECT_OPTION "jack-auto-connect"
#define AUTO_CONNECT_TEXT N_("Automatically connect to writable clients")
#define AUTO_CONNECT_TEXT N_("Automatically connect to writable clients")
...
@@ -112,6 +114,7 @@ static int Open( vlc_object_t *p_this )
...
@@ -112,6 +114,7 @@ static int Open( vlc_object_t *p_this )
goto
error_out
;
goto
error_out
;
}
}
p_aout
->
output
.
p_sys
=
p_sys
;
p_aout
->
output
.
p_sys
=
p_sys
;
p_sys
->
latency
=
0
;
/* Connect to the JACK server */
/* Connect to the JACK server */
snprintf
(
psz_name
,
sizeof
(
psz_name
),
"vlc_%d"
,
getpid
());
snprintf
(
psz_name
,
sizeof
(
psz_name
),
"vlc_%d"
,
getpid
());
...
@@ -128,6 +131,7 @@ static int Open( vlc_object_t *p_this )
...
@@ -128,6 +131,7 @@ static int Open( vlc_object_t *p_this )
/* Set the process callback */
/* Set the process callback */
jack_set_process_callback
(
p_sys
->
p_jack_client
,
Process
,
p_aout
);
jack_set_process_callback
(
p_sys
->
p_jack_client
,
Process
,
p_aout
);
jack_set_graph_order_callback
(
p_sys
->
p_jack_client
,
GraphChange
,
p_aout
);
p_aout
->
output
.
pf_play
=
Play
;
p_aout
->
output
.
pf_play
=
Play
;
aout_VolumeSoftInit
(
p_aout
);
aout_VolumeSoftInit
(
p_aout
);
...
@@ -249,9 +253,9 @@ int Process( jack_nframes_t i_frames, void *p_arg )
...
@@ -249,9 +253,9 @@ int Process( jack_nframes_t i_frames, void *p_arg )
struct
aout_sys_t
*
p_sys
=
p_aout
->
output
.
p_sys
;
struct
aout_sys_t
*
p_sys
=
p_aout
->
output
.
p_sys
;
jack_sample_t
*
p_src
=
NULL
;
jack_sample_t
*
p_src
=
NULL
;
/* we assume that data we send to jack now will be played one buffer size samples
jack_nframes_t
dframes
=
p_sys
->
latency
after the start of this jack cycle */
-
jack_frames_since_cycle_start
(
p_sys
->
p_jack_client
);
jack_nframes_t
dframes
=
i_frames
-
jack_frames_since_cycle_start
(
p_sys
->
p_jack_client
);
jack_time_t
dtime
=
dframes
*
1000
*
1000
/
jack_get_sample_rate
(
p_sys
->
p_jack_client
);
jack_time_t
dtime
=
dframes
*
1000
*
1000
/
jack_get_sample_rate
(
p_sys
->
p_jack_client
);
mtime_t
play_date
=
mdate
()
+
(
mtime_t
)
(
dtime
);
mtime_t
play_date
=
mdate
()
+
(
mtime_t
)
(
dtime
);
...
@@ -299,6 +303,31 @@ int Process( jack_nframes_t i_frames, void *p_arg )
...
@@ -299,6 +303,31 @@ int Process( jack_nframes_t i_frames, void *p_arg )
return
0
;
return
0
;
}
}
/*****************************************************************************
* GraphChange: callback when JACK reorders it's process graph.
We update latency information.
*****************************************************************************/
static
int
GraphChange
(
void
*
p_arg
)
{
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_arg
;
struct
aout_sys_t
*
p_sys
=
p_aout
->
output
.
p_sys
;
unsigned
int
i
;
jack_nframes_t
port_latency
;
p_sys
->
latency
=
0
;
for
(
i
=
0
;
i
<
p_sys
->
i_channels
;
++
i
)
{
port_latency
=
jack_port_get_total_latency
(
p_sys
->
p_jack_client
,
p_sys
->
p_jack_ports
[
i
]
);
p_sys
->
latency
=
__MAX
(
p_sys
->
latency
,
port_latency
);
}
msg_Dbg
(
p_aout
,
"JACK graph reordered. Our maximum latency=%d."
,
p_sys
->
latency
);
return
0
;
}
/*****************************************************************************
/*****************************************************************************
* Play: nothing to do
* Play: nothing to do
...
...
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