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
4a5af94e
Commit
4a5af94e
authored
Feb 07, 2009
by
Kaarlo Raiha
Committed by
Jean-Baptiste Kempf
Feb 08, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
adds speaker setup override option
Signed-off-by:
Jean-Baptiste Kempf
<
jb@videolan.org
>
parent
452a4b9f
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
74 additions
and
3 deletions
+74
-3
modules/audio_output/directx.c
modules/audio_output/directx.c
+74
-3
No files found.
modules/audio_output/directx.c
View file @
4a5af94e
...
@@ -25,7 +25,6 @@
...
@@ -25,7 +25,6 @@
* Preamble
* Preamble
*****************************************************************************/
*****************************************************************************/
#ifdef HAVE_CONFIG_H
#ifdef HAVE_CONFIG_H
# include "config.h"
# include "config.h"
#endif
#endif
...
@@ -174,6 +173,8 @@ struct aout_sys_t
...
@@ -174,6 +173,8 @@ struct aout_sys_t
int
i_frame_size
;
/* Size in bytes of one frame */
int
i_frame_size
;
/* Size in bytes of one frame */
int
i_speaker_setup
;
/* Speaker setup override */
bool
b_chan_reorder
;
/* do we need channel reordering */
bool
b_chan_reorder
;
/* do we need channel reordering */
int
pi_chan_table
[
AOUT_CHAN_MAX
];
int
pi_chan_table
[
AOUT_CHAN_MAX
];
uint32_t
i_channel_mask
;
uint32_t
i_channel_mask
;
...
@@ -214,6 +215,10 @@ static void DestroyDSBuffer ( aout_instance_t * );
...
@@ -214,6 +215,10 @@ static void DestroyDSBuffer ( aout_instance_t * );
static
void
*
DirectSoundThread
(
vlc_object_t
*
);
static
void
*
DirectSoundThread
(
vlc_object_t
*
);
static
int
FillBuffer
(
aout_instance_t
*
,
int
,
aout_buffer_t
*
);
static
int
FillBuffer
(
aout_instance_t
*
,
int
,
aout_buffer_t
*
);
/* Speaker setup override options list */
static
const
char
*
const
speaker_list
[]
=
{
"Windows default"
,
"Mono"
,
"Stereo"
,
"Quad"
,
"5.1"
,
"7.1"
};
/*****************************************************************************
/*****************************************************************************
* Module descriptor
* Module descriptor
*****************************************************************************/
*****************************************************************************/
...
@@ -225,6 +230,9 @@ static int FillBuffer ( aout_instance_t *, int, aout_buffer_t * );
...
@@ -225,6 +230,9 @@ static int FillBuffer ( aout_instance_t *, int, aout_buffer_t * );
#define FLOAT_LONGTEXT N_( \
#define FLOAT_LONGTEXT N_( \
"The option allows you to enable or disable the high-quality float32 " \
"The option allows you to enable or disable the high-quality float32 " \
"audio output mode (which is not well supported by some soundcards)." )
"audio output mode (which is not well supported by some soundcards)." )
#define SPEAKER_TEXT N_("Select speaker configuration")
#define SPEAKER_LONGTEXT N_("Select speaker configuration you want to use. " \
"This option doesn't upmix! So NO e.g. Stereo -> 5.1 conversion." )
vlc_module_begin
()
vlc_module_begin
()
set_description
(
N_
(
"DirectX audio output"
)
)
set_description
(
N_
(
"DirectX audio output"
)
)
...
@@ -237,6 +245,10 @@ vlc_module_begin ()
...
@@ -237,6 +245,10 @@ vlc_module_begin ()
DEVICE_LONGTEXT
,
true
)
DEVICE_LONGTEXT
,
true
)
add_bool
(
"directx-audio-float32"
,
0
,
0
,
FLOAT_TEXT
,
add_bool
(
"directx-audio-float32"
,
0
,
0
,
FLOAT_TEXT
,
FLOAT_LONGTEXT
,
true
)
FLOAT_LONGTEXT
,
true
)
add_string
(
"directx-audio-speaker"
,
"Windows default"
,
NULL
,
SPEAKER_TEXT
,
SPEAKER_LONGTEXT
,
true
)
change_string_list
(
speaker_list
,
0
,
0
)
change_need_restart
()
set_callbacks
(
OpenAudio
,
CloseAudio
)
set_callbacks
(
OpenAudio
,
CloseAudio
)
vlc_module_end
()
vlc_module_end
()
...
@@ -249,6 +261,10 @@ static int OpenAudio( vlc_object_t *p_this )
...
@@ -249,6 +261,10 @@ static int OpenAudio( vlc_object_t *p_this )
{
{
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
vlc_value_t
val
;
vlc_value_t
val
;
char
*
psz_speaker
;
int
i
=
0
;
const
char
*
const
*
ppsz_compare
=
speaker_list
;
msg_Dbg
(
p_aout
,
"OpenAudio"
);
msg_Dbg
(
p_aout
,
"OpenAudio"
);
...
@@ -269,6 +285,30 @@ static int OpenAudio( vlc_object_t *p_this )
...
@@ -269,6 +285,30 @@ static int OpenAudio( vlc_object_t *p_this )
/* Retrieve config values */
/* Retrieve config values */
var_Create
(
p_aout
,
"directx-audio-float32"
,
var_Create
(
p_aout
,
"directx-audio-float32"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_aout
,
"directx-audio-speaker"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_this
,
"directx-audio-speaker"
,
&
val
);
psz_speaker
=
val
.
psz_string
;
while
(
*
ppsz_compare
!=
NULL
)
{
if
(
!
strncmp
(
*
ppsz_compare
,
psz_speaker
,
strlen
(
*
ppsz_compare
)
)
)
{
break
;
}
ppsz_compare
++
;
i
++
;
}
if
(
*
ppsz_compare
==
NULL
)
{
msg_Err
(
p_aout
,
"(%s) isn't valid speaker setup option"
,
psz_speaker
);
msg_Err
(
p_aout
,
"Defaulting to Windows default speaker config"
);
i
=
0
;
}
p_aout
->
output
.
p_sys
->
i_speaker_setup
=
i
;
var_Create
(
p_aout
,
"directx-audio-device"
,
var_Create
(
p_aout
,
"directx-audio-device"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_aout
,
"directx-audio-device"
,
&
val
);
var_Get
(
p_aout
,
"directx-audio-device"
,
&
val
);
...
@@ -524,7 +564,7 @@ static void Probe( aout_instance_t * p_aout )
...
@@ -524,7 +564,7 @@ static void Probe( aout_instance_t * p_aout )
is_default_output_set
=
true
;
is_default_output_set
=
true
;
msg_Dbg
(
p_aout
,
"device supports 2 channels (DEFAULT!)"
);
msg_Dbg
(
p_aout
,
"device supports 2 channels (DEFAULT!)"
);
}
}
msg_Dbg
(
p_aout
,
"device supports 2 channels"
);
else
msg_Dbg
(
p_aout
,
"device supports 2 channels"
);
}
}
/* Test for mono support */
/* Test for mono support */
...
@@ -576,6 +616,37 @@ static void Probe( aout_instance_t * p_aout )
...
@@ -576,6 +616,37 @@ static void Probe( aout_instance_t * p_aout )
val
.
i_int
=
AOUT_VAR_STEREO
;
val
.
i_int
=
AOUT_VAR_STEREO
;
break
;
break
;
}
}
/* Check if we want to override speaker config */
switch
(
p_aout
->
output
.
p_sys
->
i_speaker_setup
)
{
case
0
:
/* Default value aka Windows default speaker setup */
break
;
case
1
:
/* Mono */
msg_Dbg
(
p_aout
,
"SpeakerConfig is forced to Mono"
);
val
.
i_int
=
AOUT_VAR_MONO
;
break
;
case
2
:
/* Stereo */
msg_Dbg
(
p_aout
,
"SpeakerConfig is forced to Stereo"
);
val
.
i_int
=
AOUT_VAR_STEREO
;
break
;
case
3
:
/* Quad */
msg_Dbg
(
p_aout
,
"SpeakerConfig is forced to Quad"
);
val
.
i_int
=
AOUT_VAR_2F2R
;
break
;
case
4
:
/* 5.1 */
msg_Dbg
(
p_aout
,
"SpeakerConfig is forced to 5.1"
);
val
.
i_int
=
AOUT_VAR_5_1
;
break
;
case
5
:
/* 7.1 */
msg_Dbg
(
p_aout
,
"SpeakerConfig is forced to 7.1"
);
val
.
i_int
=
AOUT_VAR_7_1
;
break
;
default:
msg_Dbg
(
p_aout
,
"SpeakerConfig is forced to non-existing value"
);
break
;
}
var_Set
(
p_aout
,
"audio-device"
,
val
);
var_Set
(
p_aout
,
"audio-device"
,
val
);
/* Test for SPDIF support */
/* Test for SPDIF support */
...
@@ -670,7 +741,7 @@ static void CloseAudio( vlc_object_t *p_this )
...
@@ -670,7 +741,7 @@ static void CloseAudio( vlc_object_t *p_this )
/* finally release the DirectSound object */
/* finally release the DirectSound object */
if
(
p_sys
->
p_dsobject
)
IDirectSound_Release
(
p_sys
->
p_dsobject
);
if
(
p_sys
->
p_dsobject
)
IDirectSound_Release
(
p_sys
->
p_dsobject
);
/* free DSOUND.DLL */
/* free DSOUND.DLL */
if
(
p_sys
->
hdsound_dll
)
FreeLibrary
(
p_sys
->
hdsound_dll
);
if
(
p_sys
->
hdsound_dll
)
FreeLibrary
(
p_sys
->
hdsound_dll
);
...
...
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