Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
86074bb4
Commit
86074bb4
authored
Dec 16, 2012
by
Felix Paul Kühne
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
auhal: implement Pause for the 2.1 aout API
parent
bd8d2bad
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
10 deletions
+27
-10
modules/audio_output/auhal.c
modules/audio_output/auhal.c
+27
-10
No files found.
modules/audio_output/auhal.c
View file @
86074bb4
...
@@ -108,8 +108,9 @@ static int OpenSPDIF (audio_output_t *, audio_sample_format_t
...
@@ -108,8 +108,9 @@ static int OpenSPDIF (audio_output_t *, audio_sample_format_t
static
void
Close
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
static
void
PlayAnalog
(
audio_output_t
*
,
block_t
*
);
static
void
PlayAnalog
(
audio_output_t
*
,
block_t
*
);
static
void
FlushAnalog
(
audio_output_t
*
aout
,
bool
wait
);
static
void
FlushAnalog
(
audio_output_t
*
,
bool
);
static
int
TimeGet
(
audio_output_t
*
aout
,
mtime_t
*
);
static
void
PauseAnalog
(
audio_output_t
*
,
bool
,
mtime_t
);
static
int
TimeGet
(
audio_output_t
*
,
mtime_t
*
);
static
void
Probe
(
audio_output_t
*
);
static
void
Probe
(
audio_output_t
*
);
...
@@ -291,6 +292,7 @@ static int OpenAnalog(audio_output_t *p_aout, audio_sample_format_t *fmt)
...
@@ -291,6 +292,7 @@ static int OpenAnalog(audio_output_t *p_aout, audio_sample_format_t *fmt)
AudioChannelLayout
*
layout
;
AudioChannelLayout
*
layout
;
AudioChannelLayout
new_layout
;
AudioChannelLayout
new_layout
;
AURenderCallbackStruct
input
;
AURenderCallbackStruct
input
;
p_aout
->
sys
->
chans_to_reorder
=
0
;
/* Lets go find our Component */
/* Lets go find our Component */
desc
.
componentType
=
kAudioUnitType_Output
;
desc
.
componentType
=
kAudioUnitType_Output
;
...
@@ -594,7 +596,7 @@ static int OpenAnalog(audio_output_t *p_aout, audio_sample_format_t *fmt)
...
@@ -594,7 +596,7 @@ static int OpenAnalog(audio_output_t *p_aout, audio_sample_format_t *fmt)
p_aout
->
time_get
=
TimeGet
;
p_aout
->
time_get
=
TimeGet
;
p_aout
->
play
=
PlayAnalog
;
p_aout
->
play
=
PlayAnalog
;
p_aout
->
pause
=
NULL
;
p_aout
->
pause
=
PauseAnalog
;
p_aout
->
flush
=
FlushAnalog
;
p_aout
->
flush
=
FlushAnalog
;
return
true
;
return
true
;
...
@@ -1216,11 +1218,11 @@ static void PlayAnalog (audio_output_t * p_aout, block_t * p_block)
...
@@ -1216,11 +1218,11 @@ static void PlayAnalog (audio_output_t * p_aout, block_t * p_block)
/* Do the channel reordering */
/* Do the channel reordering */
if
(
p_sys
->
chans_to_reorder
)
if
(
p_sys
->
chans_to_reorder
)
{
{
aout_ChannelReorder
(
p_block
->
p_buffer
,
aout_ChannelReorder
(
p_block
->
p_buffer
,
p_block
->
i_buffer
,
p_block
->
i_buffer
,
p_sys
->
chans_to_reorder
,
p_sys
->
chans_to_reorder
,
p_sys
->
chan_table
,
p_sys
->
chan_table
,
32
);
32
);
}
}
/* Render audio into buffer */
/* Render audio into buffer */
...
@@ -1239,10 +1241,20 @@ static void PlayAnalog (audio_output_t * p_aout, block_t * p_block)
...
@@ -1239,10 +1241,20 @@ static void PlayAnalog (audio_output_t * p_aout, block_t * p_block)
block_Release
(
p_block
);
block_Release
(
p_block
);
}
}
static
void
PauseAnalog
(
audio_output_t
*
p_aout
,
bool
pause
,
mtime_t
date
)
{
VLC_UNUSED
(
date
);
if
(
pause
)
AudioOutputUnitStop
(
p_aout
->
sys
->
au_unit
);
else
AudioOutputUnitStart
(
p_aout
->
sys
->
au_unit
);
}
static
void
FlushAnalog
(
audio_output_t
*
p_aout
,
bool
wait
)
static
void
FlushAnalog
(
audio_output_t
*
p_aout
,
bool
wait
)
{
{
if
(
!
wait
)
/* we just flush the device, no need to flush the circular buffer, since this will lead to noise only */
AudioUnitReset
(
p_aout
->
sys
->
au_unit
,
kAudioUnitScope_Global
,
0
);
AudioUnitReset
(
p_aout
->
sys
->
au_unit
,
kAudioUnitScope_Global
,
0
);
}
}
static
int
TimeGet
(
audio_output_t
*
p_aout
,
mtime_t
*
delay
)
static
int
TimeGet
(
audio_output_t
*
p_aout
,
mtime_t
*
delay
)
...
@@ -1279,6 +1291,11 @@ static OSStatus RenderCallbackAnalog(vlc_object_t *p_obj,
...
@@ -1279,6 +1291,11 @@ static OSStatus RenderCallbackAnalog(vlc_object_t *p_obj,
/* Pull audio from buffer */
/* Pull audio from buffer */
int32_t
availableBytes
;
int32_t
availableBytes
;
Float32
*
buffer
=
TPCircularBufferTail
(
&
p_sys
->
circular_buffer
,
&
availableBytes
);
Float32
*
buffer
=
TPCircularBufferTail
(
&
p_sys
->
circular_buffer
,
&
availableBytes
);
/* check if we have enough data */
if
(
!
availableBytes
)
return
noErr
;
memcpy
(
targetBuffer
,
buffer
,
__MIN
(
bytesToCopy
,
availableBytes
));
memcpy
(
targetBuffer
,
buffer
,
__MIN
(
bytesToCopy
,
availableBytes
));
TPCircularBufferConsume
(
&
p_sys
->
circular_buffer
,
__MIN
(
bytesToCopy
,
availableBytes
));
TPCircularBufferConsume
(
&
p_sys
->
circular_buffer
,
__MIN
(
bytesToCopy
,
availableBytes
));
...
...
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