Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
32981e8c
Commit
32981e8c
authored
Mar 08, 2002
by
Arnaud de Bossoreille de Ribou
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Audio output ALSA: spdif support.
parent
3c15ad37
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
36 additions
and
7 deletions
+36
-7
plugins/alsa/aout_alsa.c
plugins/alsa/aout_alsa.c
+33
-6
src/audio_output/aout_spdif.c
src/audio_output/aout_spdif.c
+3
-1
No files found.
plugins/alsa/aout_alsa.c
View file @
32981e8c
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* aout_alsa.c : Alsa functions library
* aout_alsa.c : Alsa functions library
*****************************************************************************
*****************************************************************************
* Copyright (C) 2000-2001 VideoLAN
* Copyright (C) 2000-2001 VideoLAN
* $Id: aout_alsa.c,v 1.2
8 2002/02/24 22:06:50 sam
Exp $
* $Id: aout_alsa.c,v 1.2
9 2002/03/08 00:26:07 bozo
Exp $
*
*
* Authors: Henri Fallon <henri@videolan.org> - Original Author
* Authors: Henri Fallon <henri@videolan.org> - Original Author
* Jeffrey Baker <jwbaker@acm.org> - Port to ALSA 1.0 API
* Jeffrey Baker <jwbaker@acm.org> - Port to ALSA 1.0 API
...
@@ -70,6 +70,7 @@ static int aout_Open( aout_thread_t *p_aout )
...
@@ -70,6 +70,7 @@ static int aout_Open( aout_thread_t *p_aout )
{
{
int
i_open_returns
;
int
i_open_returns
;
char
str_alsadev
[
128
];
/* Allocate structures */
/* Allocate structures */
p_aout
->
p_sys
=
malloc
(
sizeof
(
aout_sys_t
)
);
p_aout
->
p_sys
=
malloc
(
sizeof
(
aout_sys_t
)
);
...
@@ -80,10 +81,25 @@ static int aout_Open( aout_thread_t *p_aout )
...
@@ -80,10 +81,25 @@ static int aout_Open( aout_thread_t *p_aout )
return
(
1
);
return
(
1
);
}
}
if
(
p_aout
->
i_format
!=
AOUT_FMT_AC3
)
{
strcpy
(
str_alsadev
,
"default"
);
}
else
{
unsigned
char
s
[
4
];
s
[
0
]
=
IEC958_AES0_CON_EMPHASIS_NONE
|
IEC958_AES0_NONAUDIO
;
s
[
1
]
=
IEC958_AES1_CON_ORIGINAL
|
IEC958_AES1_CON_PCM_CODER
;
s
[
2
]
=
0
;
s
[
3
]
=
IEC958_AES3_CON_FS_48000
;
sprintf
(
str_alsadev
,
"iec958:AES0=0x%x,AES1=0x%x,AES2=0x%x,AES3=0x%x"
,
s
[
0
],
s
[
1
],
s
[
2
],
s
[
3
]
);
}
/* Open device */
/* Open device */
if
(
(
i_open_returns
=
snd_pcm_open
(
&
(
p_aout
->
p_sys
->
p_alsa_handle
),
if
(
(
i_open_returns
=
snd_pcm_open
(
&
(
p_aout
->
p_sys
->
p_alsa_handle
),
"default"
,
str_alsadev
,
SND_PCM_STREAM_PLAYBACK
,
0
)
)
)
SND_PCM_STREAM_PLAYBACK
,
0
)
)
>
0
)
{
{
intf_ErrMsg
(
"aout error: could not open ALSA device (%s)"
,
intf_ErrMsg
(
"aout error: could not open ALSA device (%s)"
,
snd_strerror
(
i_open_returns
)
);
snd_strerror
(
i_open_returns
)
);
...
@@ -112,6 +128,9 @@ static int aout_SetFormat( aout_thread_t *p_aout )
...
@@ -112,6 +128,9 @@ static int aout_SetFormat( aout_thread_t *p_aout )
snd_pcm_hw_params_alloca
(
&
p_hw
);
snd_pcm_hw_params_alloca
(
&
p_hw
);
snd_pcm_sw_params_alloca
(
&
p_sw
);
snd_pcm_sw_params_alloca
(
&
p_sw
);
/* default value for snd_pcm_hw_params_set_buffer_time_near() */
p_aout
->
p_sys
->
buffer_time
=
AOUT_BUFFER_DURATION
;
switch
(
p_aout
->
i_format
)
switch
(
p_aout
->
i_format
)
{
{
case
AOUT_FMT_S16_LE
:
case
AOUT_FMT_S16_LE
:
...
@@ -119,6 +138,13 @@ static int aout_SetFormat( aout_thread_t *p_aout )
...
@@ -119,6 +138,13 @@ static int aout_SetFormat( aout_thread_t *p_aout )
p_aout
->
p_sys
->
bytes_per_sample
=
2
;
p_aout
->
p_sys
->
bytes_per_sample
=
2
;
break
;
break
;
case
AOUT_FMT_AC3
:
i_format
=
SND_PCM_FORMAT_S16_LE
;
p_aout
->
p_sys
->
bytes_per_sample
=
2
;
/* buffer_time must be 500000 to avoid a system crash */
p_aout
->
p_sys
->
buffer_time
=
500000
;
break
;
default:
default:
i_format
=
SND_PCM_FORMAT_S16_BE
;
i_format
=
SND_PCM_FORMAT_S16_BE
;
p_aout
->
p_sys
->
bytes_per_sample
=
2
;
p_aout
->
p_sys
->
bytes_per_sample
=
2
;
...
@@ -171,7 +197,8 @@ static int aout_SetFormat( aout_thread_t *p_aout )
...
@@ -171,7 +197,8 @@ static int aout_SetFormat( aout_thread_t *p_aout )
p_aout
->
p_sys
->
rate
=
i_rv
;
p_aout
->
p_sys
->
rate
=
i_rv
;
i_rv
=
snd_pcm_hw_params_set_buffer_time_near
(
p_aout
->
p_sys
->
p_alsa_handle
,
i_rv
=
snd_pcm_hw_params_set_buffer_time_near
(
p_aout
->
p_sys
->
p_alsa_handle
,
p_hw
,
AOUT_BUFFER_DURATION
,
p_hw
,
p_aout
->
p_sys
->
buffer_time
,
0
);
0
);
if
(
i_rv
<
0
)
if
(
i_rv
<
0
)
{
{
...
@@ -235,7 +262,7 @@ static void aout_HandleXrun(aout_thread_t *p_aout)
...
@@ -235,7 +262,7 @@ static void aout_HandleXrun(aout_thread_t *p_aout)
intf_ErrMsg
(
"aout error: resetting output after buffer underrun"
);
intf_ErrMsg
(
"aout error: resetting output after buffer underrun"
);
i_rv
=
snd_pcm_reset
(
p_aout
->
p_sys
->
p_alsa_handle
);
//
i_rv = snd_pcm_reset( p_aout->p_sys->p_alsa_handle );
i_rv
=
snd_pcm_prepare
(
p_aout
->
p_sys
->
p_alsa_handle
);
i_rv
=
snd_pcm_prepare
(
p_aout
->
p_sys
->
p_alsa_handle
);
if
(
i_rv
<
0
)
if
(
i_rv
<
0
)
{
{
...
@@ -253,7 +280,7 @@ static void aout_HandleXrun(aout_thread_t *p_aout)
...
@@ -253,7 +280,7 @@ static void aout_HandleXrun(aout_thread_t *p_aout)
* of data to play, it switches to the "underrun" status. It has to
* of data to play, it switches to the "underrun" status. It has to
* be flushed and re-prepared
* be flushed and re-prepared
*****************************************************************************/
*****************************************************************************/
static
long
aout_GetBufInfo
(
aout_thread_t
*
p_aout
,
int
i_buffer_limit
)
static
int
aout_GetBufInfo
(
aout_thread_t
*
p_aout
,
int
i_buffer_limit
)
{
{
snd_pcm_status_t
*
p_status
;
snd_pcm_status_t
*
p_status
;
int
i_alsa_get_status_returns
;
int
i_alsa_get_status_returns
;
...
...
src/audio_output/aout_spdif.c
View file @
32981e8c
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* aout_spdif.c: AC3 passthrough output
* aout_spdif.c: AC3 passthrough output
*****************************************************************************
*****************************************************************************
* Copyright (C) 2001 VideoLAN
* Copyright (C) 2001 VideoLAN
* $Id: aout_spdif.c,v 1.2
4 2002/02/27 22:57:10 sam
Exp $
* $Id: aout_spdif.c,v 1.2
5 2002/03/08 00:26:07 bozo
Exp $
*
*
* Authors: Michel Kaempf <maxx@via.ecp.fr>
* Authors: Michel Kaempf <maxx@via.ecp.fr>
* Stphane Borel <stef@via.ecp.fr>
* Stphane Borel <stef@via.ecp.fr>
...
@@ -109,6 +109,8 @@ void aout_SpdifThread( aout_thread_t * p_aout )
...
@@ -109,6 +109,8 @@ void aout_SpdifThread( aout_thread_t * p_aout )
}
}
m_old
=
m_play
;
m_old
=
m_play
;
p_aout
->
pf_getbufinfo
(
p_aout
,
0
);
p_aout
->
pf_play
(
p_aout
,
(
byte_t
*
)
p_aout
->
buffer
,
p_aout
->
pf_play
(
p_aout
,
(
byte_t
*
)
p_aout
->
buffer
,
SPDIF_FRAME_SIZE
);
SPDIF_FRAME_SIZE
);
}
}
...
...
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