Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
10dd2acc
Commit
10dd2acc
authored
Oct 31, 2012
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
aout: match module life cycle to the object life cycle
In other words, keep the module loaded whenever the aout exists.
parent
ea9c43c2
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
69 additions
and
82 deletions
+69
-82
src/audio_output/common.c
src/audio_output/common.c
+64
-9
src/audio_output/dec.c
src/audio_output/dec.c
+3
-6
src/audio_output/output.c
src/audio_output/output.c
+2
-67
No files found.
src/audio_output/common.c
View file @
10dd2acc
...
@@ -55,6 +55,41 @@ static int var_Copy (vlc_object_t *src, const char *name, vlc_value_t prev,
...
@@ -55,6 +55,41 @@ static int var_Copy (vlc_object_t *src, const char *name, vlc_value_t prev,
return
var_Set
(
dst
,
name
,
value
);
return
var_Set
(
dst
,
name
,
value
);
}
}
/**
* Supply or update the current custom ("hardware") volume.
* @note This only makes sense after calling aout_VolumeHardInit().
* @param volume current custom volume
*
* @warning The caller (i.e. the audio output plug-in) is responsible for
* interlocking and synchronizing call to this function and to the
* audio_output_t.volume_set callback. This ensures that VLC gets correct
* volume information (possibly with a latency).
*/
static
void
aout_VolumeNotify
(
audio_output_t
*
aout
,
float
volume
)
{
var_SetFloat
(
aout
,
"volume"
,
volume
);
}
static
void
aout_MuteNotify
(
audio_output_t
*
aout
,
bool
mute
)
{
var_SetBool
(
aout
,
"mute"
,
mute
);
}
static
void
aout_PolicyNotify
(
audio_output_t
*
aout
,
bool
cork
)
{
(
cork
?
var_IncInteger
:
var_DecInteger
)
(
aout
->
p_parent
,
"corks"
);
}
static
int
aout_GainNotify
(
audio_output_t
*
aout
,
float
gain
)
{
aout_owner_t
*
owner
=
aout_owner
(
aout
);
aout_assert_locked
(
aout
);
aout_volume_SetVolume
(
owner
->
volume
,
gain
);
/* XXX: ideally, return -1 if format cannot be amplified */
return
0
;
}
#undef aout_New
#undef aout_New
/*****************************************************************************
/*****************************************************************************
* aout_New: initialize aout structure
* aout_New: initialize aout structure
...
@@ -70,12 +105,33 @@ audio_output_t *aout_New( vlc_object_t * p_parent )
...
@@ -70,12 +105,33 @@ audio_output_t *aout_New( vlc_object_t * p_parent )
aout_owner_t
*
owner
=
aout_owner
(
aout
);
aout_owner_t
*
owner
=
aout_owner
(
aout
);
vlc_mutex_init
(
&
owner
->
lock
);
vlc_mutex_init
(
&
owner
->
lock
);
owner
->
module
=
NULL
;
vlc_object_set_destructor
(
aout
,
aout_Destructor
);
owner
->
input
=
NULL
;
owner
->
input
=
NULL
;
/* Audio output module callbacks */
var_Create
(
aout
,
"volume"
,
VLC_VAR_FLOAT
);
var_AddCallback
(
aout
,
"volume"
,
var_Copy
,
p_parent
);
var_Create
(
aout
,
"mute"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_AddCallback
(
aout
,
"mute"
,
var_Copy
,
p_parent
);
aout
->
event
.
volume_report
=
aout_VolumeNotify
;
aout
->
event
.
mute_report
=
aout_MuteNotify
;
aout
->
event
.
policy_report
=
aout_PolicyNotify
;
aout
->
event
.
gain_request
=
aout_GainNotify
;
/* Audio output module initialization */
aout
->
start
=
NULL
;
aout
->
stop
=
NULL
;
aout
->
volume_set
=
NULL
;
aout
->
volume_set
=
NULL
;
aout
->
mute_set
=
NULL
;
aout
->
mute_set
=
NULL
;
vlc_object_set_destructor
(
aout
,
aout_Destructor
);
owner
->
module
=
module_need
(
aout
,
"audio output"
,
"$aout"
,
false
);
if
(
owner
->
module
==
NULL
)
{
msg_Err
(
aout
,
"no suitable audio output module"
);
vlc_object_release
(
aout
);
return
NULL
;
}
/*
/*
* Persistent audio output variables
* Persistent audio output variables
...
@@ -84,11 +140,6 @@ audio_output_t *aout_New( vlc_object_t * p_parent )
...
@@ -84,11 +140,6 @@ audio_output_t *aout_New( vlc_object_t * p_parent )
module_config_t
*
cfg
;
module_config_t
*
cfg
;
char
*
str
;
char
*
str
;
var_Create
(
aout
,
"volume"
,
VLC_VAR_FLOAT
);
var_AddCallback
(
aout
,
"volume"
,
var_Copy
,
p_parent
);
var_Create
(
aout
,
"mute"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_AddCallback
(
aout
,
"mute"
,
var_Copy
,
p_parent
);
/* Visualizations */
/* Visualizations */
var_Create
(
aout
,
"visual"
,
VLC_VAR_STRING
|
VLC_VAR_HASCHOICE
);
var_Create
(
aout
,
"visual"
,
VLC_VAR_STRING
|
VLC_VAR_HASCHOICE
);
text
.
psz_string
=
_
(
"Visualizations"
);
text
.
psz_string
=
_
(
"Visualizations"
);
...
@@ -161,7 +212,6 @@ audio_output_t *aout_New( vlc_object_t * p_parent )
...
@@ -161,7 +212,6 @@ audio_output_t *aout_New( vlc_object_t * p_parent )
text
.
psz_string
=
_
(
"Audio visualizations"
);
text
.
psz_string
=
_
(
"Audio visualizations"
);
var_Change
(
aout
,
"audio-visual"
,
VLC_VAR_SETTEXT
,
&
text
,
NULL
);
var_Change
(
aout
,
"audio-visual"
,
VLC_VAR_SETTEXT
,
&
text
,
NULL
);
/* Replay gain */
/* Replay gain */
var_Create
(
aout
,
"audio-replay-gain-mode"
,
var_Create
(
aout
,
"audio-replay-gain-mode"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
...
@@ -184,7 +234,12 @@ void aout_Destroy (audio_output_t *aout)
...
@@ -184,7 +234,12 @@ void aout_Destroy (audio_output_t *aout)
{
{
aout_owner_t
*
owner
=
aout_owner
(
aout
);
aout_owner_t
*
owner
=
aout_owner
(
aout
);
assert
(
owner
->
module
==
NULL
);
aout_lock
(
aout
);
module_unneed
(
aout
,
owner
->
module
);
/* Protect against late call from intf.c */
aout
->
volume_set
=
NULL
;
aout
->
mute_set
=
NULL
;
aout_unlock
(
aout
);
var_DelCallback
(
aout
,
"mute"
,
var_Copy
,
aout
->
p_parent
);
var_DelCallback
(
aout
,
"mute"
,
var_Copy
,
aout
->
p_parent
);
var_SetFloat
(
aout
,
"volume"
,
-
1
.
f
);
var_SetFloat
(
aout
,
"volume"
,
-
1
.
f
);
...
...
src/audio_output/dec.c
View file @
10dd2acc
...
@@ -71,7 +71,6 @@ int aout_DecNew( audio_output_t *p_aout,
...
@@ -71,7 +71,6 @@ int aout_DecNew( audio_output_t *p_aout,
/* TODO: reduce lock scope depending on decoder's real need */
/* TODO: reduce lock scope depending on decoder's real need */
aout_lock
(
p_aout
);
aout_lock
(
p_aout
);
assert
(
owner
->
module
==
NULL
);
/* Create the audio output stream */
/* Create the audio output stream */
var_Destroy
(
p_aout
,
"audio-device"
);
var_Destroy
(
p_aout
,
"audio-device"
);
...
@@ -117,11 +116,9 @@ void aout_DecDelete (audio_output_t *p_aout)
...
@@ -117,11 +116,9 @@ void aout_DecDelete (audio_output_t *p_aout)
aout_InputDelete
(
p_aout
,
input
);
aout_InputDelete
(
p_aout
,
input
);
owner
->
input
=
NULL
;
owner
->
input
=
NULL
;
if
(
likely
(
owner
->
module
!=
NULL
))
aout_OutputDelete
(
p_aout
);
{
aout_volume_Delete
(
owner
->
volume
);
aout_OutputDelete
(
p_aout
);
aout_volume_Delete
(
owner
->
volume
);
}
var_Destroy
(
p_aout
,
"audio-device"
);
var_Destroy
(
p_aout
,
"audio-device"
);
var_Destroy
(
p_aout
,
"stereo-mode"
);
var_Destroy
(
p_aout
,
"stereo-mode"
);
...
...
src/audio_output/output.c
View file @
10dd2acc
...
@@ -25,52 +25,13 @@
...
@@ -25,52 +25,13 @@
# include "config.h"
# include "config.h"
#endif
#endif
#include <math.h>
#include <vlc_common.h>
#include <vlc_common.h>
#include <vlc_aout.h>
#include <vlc_aout.h>
#include <vlc_aout_intf.h>
#include <vlc_cpu.h>
#include <vlc_cpu.h>
#include <vlc_modules.h>
#include "libvlc.h"
#include "libvlc.h"
#include "aout_internal.h"
#include "aout_internal.h"
/**
* Supply or update the current custom ("hardware") volume.
* @note This only makes sense after calling aout_VolumeHardInit().
* @param volume current custom volume
*
* @warning The caller (i.e. the audio output plug-in) is responsible for
* interlocking and synchronizing call to this function and to the
* audio_output_t.volume_set callback. This ensures that VLC gets correct
* volume information (possibly with a latency).
*/
static
void
aout_OutputVolumeReport
(
audio_output_t
*
aout
,
float
volume
)
{
var_SetFloat
(
aout
,
"volume"
,
volume
);
}
static
void
aout_OutputMuteReport
(
audio_output_t
*
aout
,
bool
mute
)
{
var_SetBool
(
aout
,
"mute"
,
mute
);
}
static
void
aout_OutputPolicyReport
(
audio_output_t
*
aout
,
bool
cork
)
{
(
cork
?
var_IncInteger
:
var_DecInteger
)
(
aout
->
p_parent
,
"corks"
);
}
static
int
aout_OutputGainRequest
(
audio_output_t
*
aout
,
float
gain
)
{
aout_owner_t
*
owner
=
aout_owner
(
aout
);
aout_assert_locked
(
aout
);
aout_volume_SetVolume
(
owner
->
volume
,
gain
);
/* XXX: ideally, return -1 if format cannot be amplified */
return
0
;
}
/*****************************************************************************
/*****************************************************************************
* aout_OutputNew : allocate a new output and rework the filter pipeline
* aout_OutputNew : allocate a new output and rework the filter pipeline
*****************************************************************************
*****************************************************************************
...
@@ -85,24 +46,9 @@ int aout_OutputNew (audio_output_t *aout, const audio_sample_format_t *fmtp)
...
@@ -85,24 +46,9 @@ int aout_OutputNew (audio_output_t *aout, const audio_sample_format_t *fmtp)
aout_assert_locked
(
aout
);
aout_assert_locked
(
aout
);
aout
->
event
.
volume_report
=
aout_OutputVolumeReport
;
aout
->
event
.
mute_report
=
aout_OutputMuteReport
;
aout
->
event
.
policy_report
=
aout_OutputPolicyReport
;
aout
->
event
.
gain_request
=
aout_OutputGainRequest
;
/* Find the best output plug-in. */
owner
->
module
=
module_need
(
aout
,
"audio output"
,
"$aout"
,
false
);
if
(
owner
->
module
==
NULL
)
{
msg_Err
(
aout
,
"no suitable audio output module"
);
return
-
1
;
}
if
(
aout
->
start
(
aout
,
&
fmt
))
if
(
aout
->
start
(
aout
,
&
fmt
))
{
{
msg_Err
(
aout
,
"module not functional"
);
msg_Err
(
aout
,
"module not functional"
);
module_unneed
(
aout
,
owner
->
module
);
owner
->
module
=
NULL
;
return
-
1
;
return
-
1
;
}
}
...
@@ -195,8 +141,7 @@ int aout_OutputNew (audio_output_t *aout, const audio_sample_format_t *fmtp)
...
@@ -195,8 +141,7 @@ int aout_OutputNew (audio_output_t *aout, const audio_sample_format_t *fmtp)
&
owner
->
mixer_format
,
&
fmt
)
<
0
)
&
owner
->
mixer_format
,
&
fmt
)
<
0
)
{
{
msg_Err
(
aout
,
"couldn't create audio output pipeline"
);
msg_Err
(
aout
,
"couldn't create audio output pipeline"
);
module_unneed
(
aout
,
owner
->
module
);
aout_OutputDelete
(
aout
);
owner
->
module
=
NULL
;
return
-
1
;
return
-
1
;
}
}
return
0
;
return
0
;
...
@@ -211,16 +156,9 @@ void aout_OutputDelete (audio_output_t *aout)
...
@@ -211,16 +156,9 @@ void aout_OutputDelete (audio_output_t *aout)
aout_assert_locked
(
aout
);
aout_assert_locked
(
aout
);
if
(
owner
->
module
==
NULL
)
return
;
var_DelCallback
(
aout
,
"stereo-mode"
,
aout_ChannelsRestart
,
NULL
);
var_DelCallback
(
aout
,
"stereo-mode"
,
aout_ChannelsRestart
,
NULL
);
if
(
aout
->
stop
!=
NULL
)
if
(
aout
->
stop
!=
NULL
)
aout
->
stop
(
aout
);
aout
->
stop
(
aout
);
module_unneed
(
aout
,
owner
->
module
);
aout
->
volume_set
=
NULL
;
aout
->
mute_set
=
NULL
;
owner
->
module
=
NULL
;
aout_FiltersDestroyPipeline
(
owner
->
filters
,
owner
->
nb_filters
);
aout_FiltersDestroyPipeline
(
owner
->
filters
,
owner
->
nb_filters
);
}
}
...
@@ -243,10 +181,7 @@ void aout_OutputPlay (audio_output_t *aout, block_t *block)
...
@@ -243,10 +181,7 @@ void aout_OutputPlay (audio_output_t *aout, block_t *block)
return
;
return
;
}
}
if
(
likely
(
owner
->
module
!=
NULL
))
aout
->
play
(
aout
,
block
,
&
drift
);
aout
->
play
(
aout
,
block
,
&
drift
);
else
block_Release
(
block
);
/**
/**
* Notifies the audio input of the drift from the requested audio
* Notifies the audio input of the drift from the requested audio
* playback timestamp (@ref block_t.i_pts) to the anticipated playback time
* playback timestamp (@ref block_t.i_pts) to the anticipated playback time
...
...
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