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
a3412c81
Commit
a3412c81
authored
Aug 20, 2002
by
Sam Hocevar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* ./modules/gui/qnx/*: ported the QNX audio output to the new API, courtesy
of Pascal Levesque.
parent
aeaf6737
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
160 additions
and
67 deletions
+160
-67
AUTHORS
AUTHORS
+1
-1
modules/gui/qnx/aout.c
modules/gui/qnx/aout.c
+157
-54
modules/gui/qnx/vout.c
modules/gui/qnx/vout.c
+2
-12
No files found.
AUTHORS
View file @
a3412c81
...
@@ -276,7 +276,7 @@ S: USA, California
...
@@ -276,7 +276,7 @@ S: USA, California
N: Pascal Levesque
N: Pascal Levesque
E: pascal.levesque@mindready.com
E: pascal.levesque@mindready.com
D: QNX RTOS video output
D: QNX RTOS video output
and audio output
S: Canada, Qubec
S: Canada, Qubec
N: Arkadiusz Lipiec
N: Arkadiusz Lipiec
...
...
modules/gui/qnx/aout.c
View file @
a3412c81
...
@@ -5,6 +5,7 @@
...
@@ -5,6 +5,7 @@
*
*
* Authors: Henri Fallon <henri@videolan.org>
* Authors: Henri Fallon <henri@videolan.org>
* Jon Lech Johansen <jon-vl@nanocrew.net>
* Jon Lech Johansen <jon-vl@nanocrew.net>
* Pascal Levesque <pascal.levesque@mindready.com>
*
*
* This program is free software; you can redistribute it and/or modify
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* it under the terms of the GNU General Public License as published by
...
@@ -29,7 +30,13 @@
...
@@ -29,7 +30,13 @@
#include <stdlib.h>
/* calloc(), malloc(), free() */
#include <stdlib.h>
/* calloc(), malloc(), free() */
#include <vlc/vlc.h>
#include <vlc/vlc.h>
#ifdef HAVE_ALLOCA_H
# include <alloca.h>
#endif
#include <vlc/aout.h>
#include <vlc/aout.h>
#include "aout_internal.h"
#include <sys/asoundlib.h>
#include <sys/asoundlib.h>
...
@@ -38,14 +45,22 @@ struct aout_sys_t
...
@@ -38,14 +45,22 @@ struct aout_sys_t
snd_pcm_t
*
p_pcm_handle
;
snd_pcm_t
*
p_pcm_handle
;
int
i_card
;
int
i_card
;
int
i_device
;
int
i_device
;
byte_t
*
p_silent_buffer
;
vlc_bool_t
b_initialized
;
};
};
#define DEFAULT_FRAME_SIZE 2048
/*****************************************************************************
/*****************************************************************************
* Local prototypes
* Local prototypes
*****************************************************************************/
*****************************************************************************/
static
int
SetFormat
(
aout_thread_t
*
);
int
E_
(
OpenAudio
)
(
vlc_object_t
*
p_this
);
static
int
GetBufInfo
(
aout_thread_t
*
,
int
);
void
E_
(
CloseAudio
)
(
vlc_object_t
*
p_this
);
static
void
Play
(
aout_thread_t
*
,
byte_t
*
,
int
);
static
int
GetBufInfo
(
aout_instance_t
*
);
static
int
SetFormat
(
aout_instance_t
*
);
static
void
Play
(
aout_instance_t
*
);
static
int
QNXaoutThread
(
aout_instance_t
*
);
/*****************************************************************************
/*****************************************************************************
* Open : creates a handle and opens an alsa device
* Open : creates a handle and opens an alsa device
...
@@ -54,42 +69,53 @@ static void Play ( aout_thread_t *, byte_t *, int );
...
@@ -54,42 +69,53 @@ static void Play ( aout_thread_t *, byte_t *, int );
*****************************************************************************/
*****************************************************************************/
int
E_
(
OpenAudio
)(
vlc_object_t
*
p_this
)
int
E_
(
OpenAudio
)(
vlc_object_t
*
p_this
)
{
{
aout_
thread_t
*
p_aout
=
(
aout_thread
_t
*
)
p_this
;
aout_
instance_t
*
p_aout
=
(
aout_instance
_t
*
)
p_this
;
int
i_ret
;
int
i_ret
;
/* allocate structure */
/* allocate structure */
p_aout
->
p_sys
=
malloc
(
sizeof
(
aout_sys_t
)
);
p_aout
->
output
.
p_sys
=
malloc
(
sizeof
(
aout_sys_t
)
);
if
(
p_aout
->
p_sys
==
NULL
)
if
(
p_aout
->
output
.
p_sys
==
NULL
)
{
{
msg_Err
(
p_aout
,
"out of memory"
);
msg_Err
(
p_aout
,
"out of memory"
);
return
(
1
)
;
return
-
1
;
}
}
/* open audio device */
/* open audio device */
if
(
(
i_ret
=
snd_pcm_open_preferred
(
&
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_open_preferred
(
&
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
p_aout
->
p_sys
->
i_card
,
&
p_aout
->
output
.
p_sys
->
i_card
,
&
p_aout
->
p_sys
->
i_device
,
&
p_aout
->
output
.
p_sys
->
i_device
,
SND_PCM_OPEN_PLAYBACK
)
)
<
0
)
SND_PCM_OPEN_PLAYBACK
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to open audio device (%s)"
,
msg_Err
(
p_aout
,
"unable to open audio device (%s)"
,
snd_strerror
(
i_ret
)
);
snd_strerror
(
i_ret
)
);
free
(
p_aout
->
p_sys
);
free
(
p_aout
->
output
.
p_sys
);
return
(
1
)
;
return
-
1
;
}
}
/* disable mmap */
/* disable mmap */
if
(
(
i_ret
=
snd_pcm_plugin_set_disable
(
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_plugin_set_disable
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
PLUGIN_DISABLE_MMAP
)
)
<
0
)
PLUGIN_DISABLE_MMAP
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to disable mmap (%s)"
,
snd_strerror
(
i_ret
)
);
msg_Err
(
p_aout
,
"unable to disable mmap (%s)"
,
snd_strerror
(
i_ret
)
);
Close
(
p_this
);
E_
(
CloseAudio
)(
p_this
);
free
(
p_aout
->
p_sys
);
free
(
p_aout
->
output
.
p_sys
);
return
(
1
);
return
-
1
;
}
/* Create audio thread and wait for its readiness. */
p_aout
->
output
.
p_sys
->
b_initialized
=
VLC_FALSE
;
if
(
vlc_thread_create
(
p_aout
,
"aout"
,
QNXaoutThread
,
VLC_FALSE
)
)
{
msg_Err
(
p_aout
,
"cannot create QNX audio thread (%s)"
,
strerror
(
errno
)
);
E_
(
CloseAudio
)(
p_this
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
}
p_aout
->
pf_setformat
=
SetFormat
;
p_aout
->
output
.
p_sys
->
p_silent_buffer
=
malloc
(
DEFAULT_FRAME_SIZE
*
4
);
p_aout
->
pf_getbufinfo
=
GetBufInfo
;
p_aout
->
pf_play
=
Play
;
p_aout
->
output
.
pf_setformat
=
SetFormat
;
p_aout
->
output
.
pf_play
=
Play
;
return
(
0
);
return
(
0
);
}
}
...
@@ -100,23 +126,26 @@ int E_(OpenAudio)( vlc_object_t *p_this )
...
@@ -100,23 +126,26 @@ int E_(OpenAudio)( vlc_object_t *p_this )
* This function prepares the device, sets the rate, format, the mode
* This function prepares the device, sets the rate, format, the mode
* ("play as soon as you have data"), and buffer information.
* ("play as soon as you have data"), and buffer information.
*****************************************************************************/
*****************************************************************************/
static
int
SetFormat
(
aout_
thread_t
*
p_aout
)
static
int
SetFormat
(
aout_
instance_t
*
p_this
)
{
{
int
i_ret
;
int
i_ret
;
int
i_bytes_per_sample
;
int
i_bytes_per_sample
;
snd_pcm_channel_info_t
pi
;
snd_pcm_channel_info_t
pi
;
snd_pcm_channel_params_t
pp
;
snd_pcm_channel_params_t
pp
;
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
p_aout
->
output
.
p_sys
->
b_initialized
=
VLC_FALSE
;
memset
(
&
pi
,
0
,
sizeof
(
pi
)
);
memset
(
&
pi
,
0
,
sizeof
(
pi
)
);
memset
(
&
pp
,
0
,
sizeof
(
pp
)
);
memset
(
&
pp
,
0
,
sizeof
(
pp
)
);
pi
.
channel
=
SND_PCM_CHANNEL_PLAYBACK
;
pi
.
channel
=
SND_PCM_CHANNEL_PLAYBACK
;
if
(
(
i_ret
=
snd_pcm_plugin_info
(
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_plugin_info
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
pi
)
)
<
0
)
&
pi
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to get plugin info (%s)"
,
msg_Err
(
p_aout
,
"unable to get plugin info (%s)"
,
snd_strerror
(
i_ret
)
);
snd_strerror
(
i_ret
)
);
return
(
1
)
;
return
-
1
;
}
}
pp
.
mode
=
SND_PCM_MODE_BLOCK
;
pp
.
mode
=
SND_PCM_MODE_BLOCK
;
...
@@ -124,14 +153,17 @@ static int SetFormat( aout_thread_t *p_aout )
...
@@ -124,14 +153,17 @@ static int SetFormat( aout_thread_t *p_aout )
pp
.
start_mode
=
SND_PCM_START_FULL
;
pp
.
start_mode
=
SND_PCM_START_FULL
;
pp
.
stop_mode
=
SND_PCM_STOP_STOP
;
pp
.
stop_mode
=
SND_PCM_STOP_STOP
;
pp
.
buf
.
block
.
frags_max
=
1
;
pp
.
buf
.
block
.
frags_max
=
3
;
pp
.
buf
.
block
.
frags_min
=
1
;
pp
.
buf
.
block
.
frags_min
=
1
;
pp
.
format
.
interleave
=
1
;
pp
.
format
.
interleave
=
1
;
pp
.
format
.
rate
=
p_aout
->
i_rate
;
pp
.
format
.
rate
=
p_aout
->
output
.
output
.
i_rate
;
pp
.
format
.
voices
=
p_aout
->
i_channels
;
pp
.
format
.
voices
=
p_aout
->
output
.
output
.
i_channels
;
switch
(
p_aout
->
i_format
)
p_aout
->
output
.
output
.
i_format
=
AOUT_FMT_S16_NE
;
p_aout
->
output
.
i_nb_samples
=
DEFAULT_FRAME_SIZE
;
switch
(
p_aout
->
output
.
output
.
i_format
)
{
{
case
AOUT_FMT_S16_LE
:
case
AOUT_FMT_S16_LE
:
pp
.
format
.
format
=
SND_PCM_SFMT_S16_LE
;
pp
.
format
.
format
=
SND_PCM_SFMT_S16_LE
;
...
@@ -144,27 +176,29 @@ static int SetFormat( aout_thread_t *p_aout )
...
@@ -144,27 +176,29 @@ static int SetFormat( aout_thread_t *p_aout )
break
;
break
;
}
}
pp
.
buf
.
block
.
frag_size
=
pp
.
buf
.
block
.
frag_size
=
p_aout
->
output
.
i_nb_samples
*
(((
s64
)
p_aout
->
i_rate
*
AOUT_BUFFER_DURATION
)
/
1000000
)
*
p_aout
->
output
.
output
.
i_channels
*
p_aout
->
i_channels
*
i_bytes_per_sample
;
i_bytes_per_sample
;
/* set parameters */
/* set parameters */
if
(
(
i_ret
=
snd_pcm_plugin_params
(
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_plugin_params
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
pp
)
)
<
0
)
&
pp
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to set parameters (%s)"
,
snd_strerror
(
i_ret
)
);
msg_Err
(
p_aout
,
"unable to set parameters (%s)"
,
snd_strerror
(
i_ret
)
);
return
(
1
)
;
return
-
1
;
}
}
/* prepare channel */
/* prepare channel */
if
(
(
i_ret
=
snd_pcm_plugin_prepare
(
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_plugin_prepare
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
SND_PCM_CHANNEL_PLAYBACK
)
)
<
0
)
SND_PCM_CHANNEL_PLAYBACK
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to prepare channel (%s)"
,
msg_Err
(
p_aout
,
"unable to prepare channel (%s)"
,
snd_strerror
(
i_ret
)
);
snd_strerror
(
i_ret
)
);
return
(
1
)
;
return
-
1
;
}
}
p_aout
->
output
.
p_sys
->
b_initialized
=
VLC_TRUE
;
return
(
0
);
return
(
0
);
}
}
...
@@ -176,14 +210,14 @@ static int SetFormat( aout_thread_t *p_aout )
...
@@ -176,14 +210,14 @@ static int SetFormat( 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
int
GetBufInfo
(
aout_
thread_t
*
p_aout
,
int
i_buffer_limi
t
)
static
int
GetBufInfo
(
aout_
instance_t
*
p_aou
t
)
{
{
int
i_ret
;
int
i_ret
;
snd_pcm_channel_status_t
status
;
snd_pcm_channel_status_t
status
;
/* get current pcm status */
/* get current pcm status */
memset
(
&
status
,
0
,
sizeof
(
status
)
);
memset
(
&
status
,
0
,
sizeof
(
status
)
);
if
(
(
i_ret
=
snd_pcm_plugin_status
(
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_plugin_status
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
status
)
)
<
0
)
&
status
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to get device status (%s)"
,
msg_Err
(
p_aout
,
"unable to get device status (%s)"
,
...
@@ -196,7 +230,7 @@ static int GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit )
...
@@ -196,7 +230,7 @@ static int GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit )
{
{
case
SND_PCM_STATUS_READY
:
case
SND_PCM_STATUS_READY
:
case
SND_PCM_STATUS_UNDERRUN
:
case
SND_PCM_STATUS_UNDERRUN
:
if
(
(
i_ret
=
snd_pcm_plugin_prepare
(
p_aout
->
p_sys
->
p_pcm_handle
,
if
(
(
i_ret
=
snd_pcm_plugin_prepare
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
SND_PCM_CHANNEL_PLAYBACK
)
)
<
0
)
SND_PCM_CHANNEL_PLAYBACK
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to prepare channel (%s)"
,
msg_Err
(
p_aout
,
"unable to prepare channel (%s)"
,
...
@@ -213,31 +247,100 @@ static int GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit )
...
@@ -213,31 +247,100 @@ static int GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit )
*****************************************************************************
*****************************************************************************
* Plays a sample using the snd_pcm_write function from the alsa API
* Plays a sample using the snd_pcm_write function from the alsa API
*****************************************************************************/
*****************************************************************************/
static
void
Play
(
aout_
thread_t
*
p_aout
,
byte_t
*
buffer
,
int
i_size
)
static
void
Play
(
aout_
instance_t
*
p_aout
)
{
{
int
i_ret
;
if
(
(
i_ret
=
snd_pcm_plugin_write
(
p_aout
->
p_sys
->
p_pcm_handle
,
(
void
*
)
buffer
,
(
size_t
)
i_size
)
)
<=
0
)
{
msg_Err
(
p_aout
,
"unable to write data (%s)"
,
snd_strerror
(
i_ret
)
);
}
}
}
/*****************************************************************************
/*****************************************************************************
* CloseAudio: close the audio device
* CloseAudio: close the audio device
*****************************************************************************/
*****************************************************************************/
static
void
E_
(
CloseAudio
)
(
vlc_object_t
*
p_this
)
void
E_
(
CloseAudio
)
(
vlc_object_t
*
p_this
)
{
{
aout_
thread_t
*
p_aout
=
(
aout_thread
_t
*
)
p_this
;
aout_
instance_t
*
p_aout
=
(
aout_instance
_t
*
)
p_this
;
int
i_ret
;
int
i_ret
;
if
(
(
i_ret
=
snd_pcm_close
(
p_aout
->
p_sys
->
p_pcm_handle
)
)
<
0
)
p_aout
->
b_die
=
1
;
vlc_thread_join
(
p_aout
);
if
(
(
i_ret
=
snd_pcm_close
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
)
)
<
0
)
{
{
msg_Err
(
p_aout
,
"unable to close audio device (%s)"
,
msg_Err
(
p_aout
,
"unable to close audio device (%s)"
,
snd_strerror
(
i_ret
)
);
snd_strerror
(
i_ret
)
);
}
}
free
(
p_aout
->
p_sys
);
free
(
p_aout
->
output
.
p_sys
->
p_silent_buffer
);
free
(
p_aout
->
output
.
p_sys
);
}
}
/*****************************************************************************
* QNXaoutThread: asynchronous thread used to DMA the data to the device
*****************************************************************************/
static
int
QNXaoutThread
(
aout_instance_t
*
p_aout
)
{
struct
aout_sys_t
*
p_sys
=
p_aout
->
output
.
p_sys
;
while
(
!
p_aout
->
b_die
)
{
aout_buffer_t
*
p_buffer
;
int
i_tmp
,
i_size
;
byte_t
*
p_bytes
;
if
(
!
p_sys
->
b_initialized
)
{
msleep
(
THREAD_SLEEP
);
continue
;
}
if
(
p_aout
->
output
.
output
.
i_format
!=
AOUT_FMT_SPDIF
)
{
mtime_t
next_date
=
0
;
/* Get the presentation date of the next write() operation. It
* is equal to the current date + duration of buffered samples.
* Order is important here, since GetBufInfo is believed to take
* more time than mdate(). */
next_date
=
(
mtime_t
)
GetBufInfo
(
p_aout
)
*
1000000
/
p_aout
->
output
.
output
.
i_bytes_per_frame
/
p_aout
->
output
.
output
.
i_rate
*
p_aout
->
output
.
output
.
i_frame_length
;
next_date
+=
mdate
();
p_buffer
=
aout_OutputNextBuffer
(
p_aout
,
next_date
,
VLC_FALSE
);
}
else
{
p_buffer
=
aout_OutputNextBuffer
(
p_aout
,
0
,
VLC_TRUE
);
}
if
(
p_buffer
!=
NULL
)
{
p_bytes
=
p_buffer
->
p_buffer
;
i_size
=
p_buffer
->
i_nb_bytes
;
}
else
{
i_size
=
DEFAULT_FRAME_SIZE
/
p_aout
->
output
.
output
.
i_frame_length
*
p_aout
->
output
.
output
.
i_bytes_per_frame
;
p_bytes
=
p_aout
->
output
.
p_sys
->
p_silent_buffer
;
memset
(
p_bytes
,
0
,
i_size
);
}
i_tmp
=
snd_pcm_plugin_write
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
(
void
*
)
p_bytes
,
(
size_t
)
i_size
);
if
(
i_tmp
<
0
)
{
msg_Err
(
p_aout
,
"write failed (%s)"
,
strerror
(
errno
)
);
}
if
(
p_buffer
!=
NULL
)
{
aout_BufferFree
(
p_buffer
);
}
}
return
0
;
}
modules/gui/qnx/vout.c
View file @
a3412c81
...
@@ -541,16 +541,6 @@ static int QNXInitDisplay( vout_thread_t * p_vout )
...
@@ -541,16 +541,6 @@ static int QNXInitDisplay( vout_thread_t * p_vout )
return
(
1
);
return
(
1
);
}
}
/* switch to normal mode if no overlay support */
// printf("minfo.mode_capabilities1: 0x%x\n", minfo.mode_capabilities1);
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
&&
!
(
minfo
.
mode_capabilities1
&
PgVM_MODE_CAP1_VIDEO_OVERLAY
)
)
{
msg_Err
(
p_vout
,
"no overlay support detected"
);
p_vout
->
p_sys
->
i_mode
=
MODE_NORMAL_MEM
;
}
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
{
{
int
i
=
0
;
int
i
=
0
;
...
...
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