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
5f782bc3
Commit
5f782bc3
authored
Nov 11, 2003
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* all: use es_format_t and es_out_*. (Not well tested yet...)
parent
a7a7e709
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
125 additions
and
307 deletions
+125
-307
modules/demux/a52sys.c
modules/demux/a52sys.c
+8
-29
modules/demux/aac.c
modules/demux/aac.c
+8
-28
modules/demux/asf/asf.c
modules/demux/asf/asf.c
+52
-153
modules/demux/au.c
modules/demux/au.c
+57
-97
No files found.
modules/demux/a52sys.c
View file @
5f782bc3
...
...
@@ -2,7 +2,7 @@
* a52.c : Raw a52 Stream input module for vlc
*****************************************************************************
* Copyright (C) 2001 VideoLAN
* $Id: a52sys.c,v 1.
6 2003/09/12 16:26:40
fenrir Exp $
* $Id: a52sys.c,v 1.
7 2003/11/11 00:37:59
fenrir Exp $
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
...
...
@@ -55,7 +55,7 @@ struct demux_sys_t
{
mtime_t
i_time
;
es_
descriptor_t
*
p_es
;
es_
out_id_t
*
p_es
;
};
static
inline
int
HeaderCheck
(
const
uint8_t
*
p
)
...
...
@@ -76,7 +76,7 @@ static int HeaderInfo( const uint8_t * p,
int
*
pi_frame_size
);
/*****************************************************************************
* Open: initializes A
AC
demux structures
* Open: initializes A
52
demux structures
*****************************************************************************/
static
int
Open
(
vlc_object_t
*
p_this
)
{
...
...
@@ -88,6 +88,8 @@ static int Open( vlc_object_t * p_this )
module_t
*
p_id3
;
es_format_t
fmt
;
if
(
p_input
->
psz_demux
&&
!
strncmp
(
p_input
->
psz_demux
,
"a52"
,
3
)
)
{
...
...
@@ -166,28 +168,11 @@ static int Open( vlc_object_t * p_this )
msg_Err
(
p_input
,
"cannot init stream"
);
goto
error
;
}
if
(
input_AddProgram
(
p_input
,
0
,
0
)
==
NULL
)
{
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
msg_Err
(
p_input
,
"cannot add program"
);
goto
error
;
}
p_input
->
stream
.
pp_programs
[
0
]
->
b_is_ok
=
0
;
p_input
->
stream
.
p_selected_program
=
p_input
->
stream
.
pp_programs
[
0
];
p_input
->
stream
.
i_mux_rate
=
0
/
50
;
p_sys
->
p_es
=
input_AddES
(
p_input
,
p_input
->
stream
.
p_selected_program
,
1
,
AUDIO_ES
,
NULL
,
0
);
p_sys
->
p_es
->
i_stream_id
=
1
;
p_sys
->
p_es
->
i_fourcc
=
VLC_FOURCC
(
'a'
,
'5'
,
'2'
,
' '
);
input_SelectES
(
p_input
,
p_sys
->
p_es
);
p_input
->
stream
.
p_selected_program
->
b_is_ok
=
1
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
es_format_Init
(
&
fmt
,
AUDIO_ES
,
VLC_FOURCC
(
'a'
,
'5'
,
'2'
,
' '
)
);
p_sys
->
p_es
=
es_out_Add
(
p_input
->
p_es_out
,
&
fmt
);
return
VLC_SUCCESS
;
error:
...
...
@@ -265,14 +250,8 @@ static int Demux( input_thread_t * p_input )
p_input
->
stream
.
p_selected_program
,
p_sys
->
i_time
*
9
/
100
);
if
(
!
p_sys
->
p_es
->
p_decoder_fifo
)
{
msg_Err
(
p_input
,
"no audio decoder"
);
input_DeletePES
(
p_input
->
p_method_data
,
p_pes
);
return
(
-
1
);
}
es_out_Send
(
p_input
->
p_es_out
,
p_sys
->
p_es
,
p_pes
);
input_DecodePES
(
p_sys
->
p_es
->
p_decoder_fifo
,
p_pes
);
p_sys
->
i_time
+=
(
mtime_t
)
1000000
*
(
mtime_t
)
1536
/
(
mtime_t
)
i_sample_rate
;
...
...
modules/demux/aac.c
View file @
5f782bc3
...
...
@@ -2,7 +2,7 @@
* aac.c : Raw aac Stream input module for vlc
*****************************************************************************
* Copyright (C) 2001 VideoLAN
* $Id: aac.c,v 1.
4 2003/09/12 16:26:40
fenrir Exp $
* $Id: aac.c,v 1.
5 2003/11/11 00:37:59
fenrir Exp $
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
...
...
@@ -56,7 +56,7 @@ struct demux_sys_t
{
mtime_t
i_time
;
es_
descriptor_t
*
p_es
;
es_
out_id_t
*
p_es
;
};
static
int
i_aac_samplerate
[
16
]
=
...
...
@@ -100,6 +100,8 @@ static int Open( vlc_object_t * p_this )
module_t
*
p_id3
;
es_format_t
fmt
;
if
(
p_input
->
psz_demux
&&
!
strncmp
(
p_input
->
psz_demux
,
"aac"
,
3
)
)
{
...
...
@@ -181,28 +183,12 @@ static int Open( vlc_object_t * p_this )
msg_Err
(
p_input
,
"cannot init stream"
);
goto
error
;
}
if
(
input_AddProgram
(
p_input
,
0
,
0
)
==
NULL
)
{
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
msg_Err
(
p_input
,
"cannot add program"
);
goto
error
;
}
p_input
->
stream
.
pp_programs
[
0
]
->
b_is_ok
=
0
;
p_input
->
stream
.
p_selected_program
=
p_input
->
stream
.
pp_programs
[
0
];
p_input
->
stream
.
i_mux_rate
=
0
/
50
;
p_sys
->
p_es
=
input_AddES
(
p_input
,
p_input
->
stream
.
p_selected_program
,
1
,
AUDIO_ES
,
NULL
,
0
);
p_sys
->
p_es
->
i_stream_id
=
1
;
p_sys
->
p_es
->
i_fourcc
=
VLC_FOURCC
(
'm'
,
'p'
,
'4'
,
'a'
);
input_SelectES
(
p_input
,
p_sys
->
p_es
);
p_input
->
stream
.
p_selected_program
->
b_is_ok
=
1
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
es_format_Init
(
&
fmt
,
AUDIO_ES
,
VLC_FOURCC
(
'm'
,
'p'
,
'4'
,
'a'
)
);
p_sys
->
p_es
=
es_out_Add
(
p_input
->
p_es_out
,
&
fmt
);
return
VLC_SUCCESS
;
error:
...
...
@@ -279,14 +265,8 @@ static int Demux( input_thread_t * p_input )
p_input
->
stream
.
p_selected_program
,
p_sys
->
i_time
*
9
/
100
);
if
(
!
p_sys
->
p_es
->
p_decoder_fifo
)
{
msg_Err
(
p_input
,
"no audio decoder"
);
input_DeletePES
(
p_input
->
p_method_data
,
p_pes
);
return
(
-
1
);
}
es_out_Send
(
p_input
->
p_es_out
,
p_sys
->
p_es
,
p_pes
);
input_DecodePES
(
p_sys
->
p_es
->
p_decoder_fifo
,
p_pes
);
p_sys
->
i_time
+=
(
mtime_t
)
1000000
*
(
mtime_t
)
AAC_FRAME_SAMPLES
(
h
)
/
(
mtime_t
)
AAC_SAMPLE_RATE
(
h
);
...
...
modules/demux/asf/asf.c
View file @
5f782bc3
...
...
@@ -2,7 +2,7 @@
* asf.c : ASFv01 file input module for vlc
*****************************************************************************
* Copyright (C) 2002-2003 VideoLAN
* $Id: asf.c,v 1.3
8 2003/09/12 16:26:40
fenrir Exp $
* $Id: asf.c,v 1.3
9 2003/11/11 00:37:59
fenrir Exp $
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
...
...
@@ -54,7 +54,9 @@ static int Demux ( input_thread_t * );
typedef
struct
asf_stream_s
{
int
i_cat
;
es_descriptor_t
*
p_es
;
es_out_id_t
*
p_es
;
asf_object_stream_properties_t
*
p_sp
;
mtime_t
i_time
;
...
...
@@ -93,7 +95,6 @@ static int Open( vlc_object_t * p_this )
demux_sys_t
*
p_sys
;
unsigned
int
i_stream
;
unsigned
int
i
;
asf_object_content_description_t
*
p_cd
;
vlc_bool_t
b_seekable
;
...
...
@@ -148,7 +149,6 @@ static int Open( vlc_object_t * p_this )
msg_Dbg
(
p_input
,
"found %d streams"
,
p_sys
->
i_streams
);
/* create one program */
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
if
(
input_InitStream
(
p_input
,
0
)
==
-
1
)
{
...
...
@@ -156,13 +156,6 @@ static int Open( vlc_object_t * p_this )
msg_Err
(
p_input
,
"cannot init stream"
);
goto
error
;
}
if
(
input_AddProgram
(
p_input
,
0
,
0
)
==
NULL
)
{
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
msg_Err
(
p_input
,
"cannot add program"
);
goto
error
;
}
p_input
->
stream
.
p_selected_program
=
p_input
->
stream
.
pp_programs
[
0
];
p_input
->
stream
.
i_mux_rate
=
0
;
/* updated later */
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
...
...
@@ -184,109 +177,61 @@ static int Open( vlc_object_t * p_this )
p_stream
->
p_sp
=
p_sp
;
p_stream
->
p_es
=
NULL
;
if
(
ASF_CmpGUID
(
&
p_sp
->
i_stream_type
,
&
asf_object_stream_type_audio
)
)
if
(
ASF_CmpGUID
(
&
p_sp
->
i_stream_type
,
&
asf_object_stream_type_audio
)
&&
p_sp
->
i_type_specific_data_length
>=
sizeof
(
WAVEFORMATEX
)
-
2
)
{
int
i_codec
;
if
(
p_sp
->
p_type_specific_data
)
{
i_codec
=
GetWLE
(
p_sp
->
p_type_specific_data
);
}
else
es_format_t
fmt
;
uint8_t
*
p_data
=
p_sp
->
p_type_specific_data
;
es_format_Init
(
&
fmt
,
AUDIO_ES
,
0
);
wf_tag_to_fourcc
(
GetWLE
(
&
p_data
[
0
]
),
&
fmt
.
i_codec
,
NULL
);
fmt
.
audio
.
i_channels
=
GetWLE
(
&
p_data
[
2
]
);
fmt
.
audio
.
i_samplerate
=
GetDWLE
(
&
p_data
[
4
]
);
fmt
.
audio
.
i_bitrate
=
GetDWLE
(
&
p_data
[
8
]
)
*
8
;
fmt
.
audio
.
i_blockalign
=
GetWLE
(
&
p_data
[
12
]
);
fmt
.
audio
.
i_bitspersample
=
GetWLE
(
&
p_data
[
14
]
);
if
(
p_sp
->
i_type_specific_data_length
>
sizeof
(
WAVEFORMATEX
)
)
{
i_codec
=
-
1
;
fmt
.
i_extra_type
=
ES_EXTRA_TYPE_WAVEFORMATEX
;
fmt
.
i_extra
=
__MIN
(
GetWLE
(
&
p_data
[
16
]
),
p_sp
->
i_type_specific_data_length
-
sizeof
(
WAVEFORMATEX
)
);
fmt
.
p_extra
=
malloc
(
fmt
.
i_extra
);
memcpy
(
fmt
.
p_extra
,
&
p_data
[
sizeof
(
WAVEFORMATEX
)],
fmt
.
i_extra
);
}
p_stream
->
i_cat
=
AUDIO_ES
;
p_stream
->
p_es
=
input_AddES
(
p_input
,
p_input
->
stream
.
p_selected_program
,
p_sp
->
i_stream_number
,
AUDIO_ES
,
NULL
,
0
);
p_stream
->
p_es
=
es_out_Add
(
p_input
->
p_es_out
,
&
fmt
);
msg_Dbg
(
p_input
,
"adding new audio stream(codec:0x%x,ID:%d)"
,
i_codec
,
p_sp
->
i_stream_number
);
wf_tag_to_fourcc
(
i_codec
,
&
p_stream
->
p_es
->
i_fourcc
,
NULL
);
if
(
p_sp
->
i_type_specific_data_length
>
0
)
{
WAVEFORMATEX
*
p_wf
;
size_t
i_size
;
uint8_t
*
p_data
;
i_size
=
p_sp
->
i_type_specific_data_length
;
p_wf
=
malloc
(
i_size
);
p_stream
->
p_es
->
p_waveformatex
=
(
void
*
)
p_wf
;
p_data
=
p_sp
->
p_type_specific_data
;
p_wf
->
wFormatTag
=
GetWLE
(
p_data
);
p_wf
->
nChannels
=
GetWLE
(
p_data
+
2
);
p_wf
->
nSamplesPerSec
=
GetDWLE
(
p_data
+
4
);
p_wf
->
nAvgBytesPerSec
=
GetDWLE
(
p_data
+
8
);
p_wf
->
nBlockAlign
=
GetWLE
(
p_data
+
12
);
p_wf
->
wBitsPerSample
=
GetWLE
(
p_data
+
14
);
p_wf
->
cbSize
=
__MIN
(
GetWLE
(
p_data
+
16
),
i_size
-
sizeof
(
WAVEFORMATEX
));
if
(
p_wf
->
cbSize
>
0
)
{
memcpy
(
&
p_wf
[
1
],
p_data
+
sizeof
(
WAVEFORMATEX
),
p_wf
->
cbSize
);
}
}
"added new audio stream(codec:0x%x,ID:%d)"
,
GetWLE
(
p_data
),
p_sp
->
i_stream_number
);
}
else
if
(
ASF_CmpGUID
(
&
p_sp
->
i_stream_type
,
&
asf_object_stream_type_video
)
)
else
if
(
ASF_CmpGUID
(
&
p_sp
->
i_stream_type
,
&
asf_object_stream_type_video
)
&&
p_sp
->
i_type_specific_data_length
>=
11
+
sizeof
(
BITMAPINFOHEADER
)
)
{
p_stream
->
i_cat
=
VIDEO_ES
;
p_stream
->
p_es
=
input_AddES
(
p_input
,
p_input
->
stream
.
p_selected_program
,
p_sp
->
i_stream_number
,
VIDEO_ES
,
NULL
,
0
);
es_format_t
fmt
;
uint8_t
*
p_data
=
&
p_sp
->
p_type_specific_data
[
11
];
msg_Dbg
(
p_input
,
"adding new video stream(ID:%d)"
,
p_sp
->
i_stream_number
);
if
(
p_sp
->
p_type_specific_data
)
{
p_stream
->
p_es
->
i_fourcc
=
VLC_FOURCC
(
p_sp
->
p_type_specific_data
[
27
],
p_sp
->
p_type_specific_data
[
28
],
p_sp
->
p_type_specific_data
[
29
],
p_sp
->
p_type_specific_data
[
30
]
);
}
else
es_format_Init
(
&
fmt
,
VIDEO_ES
,
VLC_FOURCC
(
p_data
[
16
],
p_data
[
17
],
p_data
[
18
],
p_data
[
19
]
)
);
fmt
.
video
.
i_width
=
GetDWLE
(
p_data
+
4
);
fmt
.
video
.
i_height
=
GetDWLE
(
p_data
+
8
);
if
(
p_sp
->
i_type_specific_data_length
>
11
+
sizeof
(
BITMAPINFOHEADER
)
)
{
p_stream
->
p_es
->
i_fourcc
=
VLC_FOURCC
(
'u'
,
'n'
,
'd'
,
'f'
);
}
if
(
p_sp
->
i_type_specific_data_length
>
11
)
{
BITMAPINFOHEADER
*
p_bih
;
size_t
i_size
;
uint8_t
*
p_data
;
i_size
=
p_sp
->
i_type_specific_data_length
-
11
;
p_bih
=
malloc
(
i_size
);
p_stream
->
p_es
->
p_bitmapinfoheader
=
(
void
*
)
p_bih
;
p_data
=
p_sp
->
p_type_specific_data
+
11
;
p_bih
->
biSize
=
GetDWLE
(
p_data
);
p_bih
->
biWidth
=
GetDWLE
(
p_data
+
4
);
p_bih
->
biHeight
=
GetDWLE
(
p_data
+
8
);
p_bih
->
biPlanes
=
GetDWLE
(
p_data
+
12
);
p_bih
->
biBitCount
=
GetDWLE
(
p_data
+
14
);
p_bih
->
biCompression
=
GetDWLE
(
p_data
+
16
);
p_bih
->
biSizeImage
=
GetDWLE
(
p_data
+
20
);
p_bih
->
biXPelsPerMeter
=
GetDWLE
(
p_data
+
24
);
p_bih
->
biYPelsPerMeter
=
GetDWLE
(
p_data
+
28
);
p_bih
->
biClrUsed
=
GetDWLE
(
p_data
+
32
);
p_bih
->
biClrImportant
=
GetDWLE
(
p_data
+
36
);
if
(
i_size
>
sizeof
(
BITMAPINFOHEADER
)
)
{
memcpy
(
&
p_bih
[
1
],
p_data
+
sizeof
(
BITMAPINFOHEADER
),
i_size
-
sizeof
(
BITMAPINFOHEADER
)
);
}
fmt
.
i_extra_type
=
ES_EXTRA_TYPE_BITMAPINFOHEADER
;
fmt
.
i_extra
=
__MIN
(
GetDWLE
(
p_data
),
p_sp
->
i_type_specific_data_length
-
11
-
sizeof
(
BITMAPINFOHEADER
)
);
fmt
.
p_extra
=
malloc
(
fmt
.
i_extra
);
memcpy
(
fmt
.
p_extra
,
&
p_data
[
sizeof
(
BITMAPINFOHEADER
)],
fmt
.
i_extra
);
}
p_stream
->
i_cat
=
VIDEO_ES
;
p_stream
->
p_es
=
es_out_Add
(
p_input
->
p_es_out
,
&
fmt
);
msg_Dbg
(
p_input
,
"added new video stream(ID:%d)"
,
p_sp
->
i_stream_number
);
}
else
{
...
...
@@ -294,16 +239,8 @@ static int Open( vlc_object_t * p_this )
msg_Dbg
(
p_input
,
"ignoring unknown stream(ID:%d)"
,
p_sp
->
i_stream_number
);
}
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
if
(
p_stream
->
p_es
)
{
input_SelectES
(
p_input
,
p_stream
->
p_es
);
}
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
}
p_sys
->
i_data_begin
=
p_sys
->
p_root
->
p_data
->
i_object_pos
+
50
;
if
(
p_sys
->
p_root
->
p_data
->
i_object_size
!=
0
)
{
/* local file */
...
...
@@ -346,11 +283,6 @@ static int Open( vlc_object_t * p_this )
}
}
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
p_input
->
stream
.
p_selected_program
->
b_is_ok
=
1
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
/* We add all info about this stream */
p_cat
=
input_InfoCategory
(
p_input
,
"Asf"
);
if
(
p_sys
->
i_length
>
0
)
...
...
@@ -379,6 +311,8 @@ static int Open( vlc_object_t * p_this )
input_AddInfo
(
p_cat
,
_
(
"Rating"
),
p_cd
->
psz_rating
);
}
#if 0
/* FIXME to port to new way */
for( i_stream = 0, i = 0; i < 128; i++ )
{
asf_stream_t *tk = p_sys->stream[i];
...
...
@@ -420,17 +354,11 @@ static int Open( vlc_object_t * p_this )
input_AddInfo( p_cat, _("Resolution"), "%dx%d",
p_bih->biWidth, p_bih->biHeight );
input_AddInfo
(
p_cat
,
_
(
"Planes"
),
"%d"
,
p_bih
->
biPlanes
);
input_AddInfo
(
p_cat
,
_
(
"Bits Per Pixel"
),
"%d"
,
p_bih
->
biBitCount
);
input_AddInfo
(
p_cat
,
_
(
"Image Size"
),
"%d"
,
p_bih
->
biSizeImage
);
input_AddInfo
(
p_cat
,
_
(
"X pixels per meter"
),
"%d"
,
p_bih
->
biXPelsPerMeter
);
input_AddInfo
(
p_cat
,
_
(
"Y pixels per meter"
),
"%d"
,
p_bih
->
biYPelsPerMeter
);
}
i_stream++;
}
#endif
return
VLC_SUCCESS
;
...
...
@@ -449,23 +377,6 @@ static int Demux( input_thread_t *p_input )
demux_sys_t
*
p_sys
=
p_input
->
p_demux_data
;
vlc_bool_t
b_play_audio
;
int
i
;
vlc_bool_t
b_stream
;
b_stream
=
VLC_FALSE
;
for
(
i
=
0
;
i
<
128
;
i
++
)
{
if
(
p_sys
->
stream
[
i
]
&&
p_sys
->
stream
[
i
]
->
p_es
&&
p_sys
->
stream
[
i
]
->
p_es
->
p_decoder_fifo
)
{
b_stream
=
VLC_TRUE
;
}
}
if
(
!
b_stream
)
{
msg_Warn
(
p_input
,
"no stream selected, exiting..."
);
return
(
0
);
}
/* catch seek from user */
if
(
p_input
->
stream
.
p_selected_program
->
i_synchro_state
==
SYNCHRO_REINIT
)
...
...
@@ -586,7 +497,7 @@ static mtime_t GetMoviePTS( demux_sys_t *p_sys )
for
(
i_stream
=
0
;
i_stream
<
128
;
i_stream
++
)
{
#define p_stream p_sys->stream[i_stream]
if
(
p_stream
&&
p_stream
->
p_es
&&
p_stream
->
p_es
->
p_decoder_fifo
&&
p_stream
->
i_time
>
0
)
if
(
p_stream
&&
p_stream
->
p_es
&&
p_stream
->
i_time
>
0
)
{
if
(
i_time
<
0
)
{
...
...
@@ -801,7 +712,7 @@ static int DemuxPacket( input_thread_t *p_input, vlc_bool_t b_play_audio )
continue
;
// over payload
}
if
(
!
p_stream
->
p_es
||
!
p_stream
->
p_es
->
p_decoder_fifo
)
if
(
!
p_stream
->
p_es
)
{
i_skip
+=
i_payload_data_length
;
continue
;
...
...
@@ -832,19 +743,7 @@ static int DemuxPacket( input_thread_t *p_input, vlc_bool_t b_play_audio )
/* send complete packet to decoder */
if
(
p_stream
->
p_pes
->
i_pes_size
>
0
)
{
if
(
p_stream
->
p_es
->
p_decoder_fifo
&&
(
b_play_audio
||
p_stream
->
i_cat
!=
AUDIO_ES
)
)
{
p_stream
->
p_pes
->
i_rate
=
p_input
->
stream
.
control
.
i_rate
;
input_DecodePES
(
p_stream
->
p_es
->
p_decoder_fifo
,
p_stream
->
p_pes
);
}
else
{
input_DeletePES
(
p_input
->
p_method_data
,
p_stream
->
p_pes
);
}
es_out_Send
(
p_input
->
p_es_out
,
p_stream
->
p_es
,
p_stream
->
p_pes
);
p_stream
->
p_pes
=
NULL
;
}
}
...
...
modules/demux/au.c
View file @
5f782bc3
...
...
@@ -2,7 +2,7 @@
* au.c : au file input module for vlc
*****************************************************************************
* Copyright (C) 2001-2003 VideoLAN
* $Id: au.c,v 1.
7 2003/09/12 16:26:40
fenrir Exp $
* $Id: au.c,v 1.
8 2003/11/11 00:37:59
fenrir Exp $
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
...
...
@@ -93,11 +93,11 @@ typedef struct
struct
demux_sys_t
{
au_t
au
;
WAVEFORMATEX
wf
;
mtime_t
i_time
;
es_descriptor_t
*
p_es
;
es_format_t
fmt
;
es_out_id_t
*
p_es
;
int
i_frame_size
;
mtime_t
i_frame_length
;
...
...
@@ -114,8 +114,6 @@ static int Open( vlc_object_t * p_this )
uint8_t
*
p_peek
;
vlc_fourcc_t
i_fourcc
;
int
i_cat
;
/* a little test to see if it's a au file */
...
...
@@ -170,105 +168,92 @@ static int Open( vlc_object_t * p_this )
}
/* Create WAVEFORMATEX structure */
p_sys
->
wf
.
nChannels
=
p_sys
->
au
.
i_channels
;
p_sys
->
wf
.
nSamplesPerSec
=
p_sys
->
au
.
i_sample_rate
;
p_sys
->
wf
.
cbSize
=
0
;
es_format_Init
(
&
p_sys
->
fmt
,
AUDIO_ES
,
0
);
p_sys
->
fmt
.
audio
.
i_channels
=
p_sys
->
au
.
i_channels
;
p_sys
->
fmt
.
audio
.
i_samplerate
=
p_sys
->
au
.
i_sample_rate
;
switch
(
p_sys
->
au
.
i_encoding
)
{
case
AU_ALAW_8
:
/* 8-bit ISDN A-law */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_ALAW
;
// FIXME ??
p_sys
->
wf
.
wBitsPerSample
=
8
;
p_sys
->
wf
.
nBlockAlign
=
1
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'l'
,
'a'
,
'w'
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'l'
,
'a'
,
'w'
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
8
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
1
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_MULAW_8
:
/* 8-bit ISDN u-law */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_MULAW
;
// FIXME ??
p_sys
->
wf
.
wBitsPerSample
=
8
;
p_sys
->
wf
.
nBlockAlign
=
1
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'u'
,
'l'
,
'a'
,
'w'
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'u'
,
'l'
,
'a'
,
'w'
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
8
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
1
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_LINEAR_8
:
/* 8-bit linear PCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_PCM
;
p_sys
->
wf
.
wBitsPerSample
=
8
;
p_sys
->
wf
.
nBlockAlign
=
1
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
8
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
1
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_LINEAR_16
:
/* 16-bit linear PCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_PCM
;
p_sys
->
wf
.
wBitsPerSample
=
16
;
p_sys
->
wf
.
nBlockAlign
=
2
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
16
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
2
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_LINEAR_24
:
/* 24-bit linear PCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_PCM
;
p_sys
->
wf
.
wBitsPerSample
=
24
;
p_sys
->
wf
.
nBlockAlign
=
3
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
24
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
3
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_LINEAR_32
:
/* 32-bit linear PCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_PCM
;
p_sys
->
wf
.
wBitsPerSample
=
32
;
p_sys
->
wf
.
nBlockAlign
=
4
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
't'
,
'w'
,
'o'
,
's'
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
32
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
4
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_FLOAT
:
/* 32-bit IEEE floating point */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_UNKNOWN
;
p_sys
->
wf
.
wBitsPerSample
=
32
;
p_sys
->
wf
.
nBlockAlign
=
4
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_FLOAT
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_FLOAT
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
32
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
4
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_DOUBLE
:
/* 64-bit IEEE floating point */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_UNKNOWN
;
p_sys
->
wf
.
wBitsPerSample
=
64
;
p_sys
->
wf
.
nBlockAlign
=
8
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_DOUBLE
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_DOUBLE
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
64
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
8
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_PCM
;
break
;
case
AU_ADPCM_G721
:
/* 4-bit CCITT g.721 ADPCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_UNKNOWN
;
p_sys
->
wf
.
wBitsPerSample
=
0
;
p_sys
->
wf
.
nBlockAlign
=
0
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G721
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G721
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
0
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
0
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_ADPCM
;
break
;
case
AU_ADPCM_G722
:
/* CCITT g.722 ADPCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_UNKNOWN
;
p_sys
->
wf
.
wBitsPerSample
=
0
;
p_sys
->
wf
.
nBlockAlign
=
0
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G722
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G722
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
0
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
0
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_ADPCM
;
break
;
case
AU_ADPCM_G723_3
:
/* CCITT g.723 3-bit ADPCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_UNKNOWN
;
p_sys
->
wf
.
wBitsPerSample
=
0
;
p_sys
->
wf
.
nBlockAlign
=
0
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G723_3
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G723_3
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
0
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
0
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_ADPCM
;
break
;
case
AU_ADPCM_G723_5
:
/* CCITT g.723 5-bit ADPCM */
p_sys
->
wf
.
wFormatTag
=
WAVE_FORMAT_UNKNOWN
;
p_sys
->
wf
.
wBitsPerSample
=
0
;
p_sys
->
wf
.
nBlockAlign
=
0
*
p_sys
->
wf
.
nChannels
;
i_fourcc
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G723_5
);
p_sys
->
fmt
.
i_codec
=
VLC_FOURCC
(
'a'
,
'u'
,
0
,
AU_ADPCM_G723_5
);
p_sys
->
fmt
.
audio
.
i_bitspersample
=
0
;
p_sys
->
fmt
.
audio
.
i_blockalign
=
0
*
p_sys
->
fmt
.
audio
.
i_channels
;
i_cat
=
AU_CAT_ADPCM
;
break
;
...
...
@@ -277,9 +262,9 @@ static int Open( vlc_object_t * p_this )
i_cat
=
AU_CAT_UNKNOWN
;
goto
error
;
}
p_sys
->
wf
.
nAvgBytesPerSec
=
p_sys
->
wf
.
nSamplesPerSec
*
p_sys
->
wf
.
nChannels
*
p_sys
->
wf
.
wBitsPerSample
/
8
;
p_sys
->
fmt
.
audio
.
i_bitrate
=
p_sys
->
fmt
.
audio
.
i_samplerate
*
p_sys
->
fmt
.
audio
.
i_channels
*
p_sys
->
fmt
.
audio
.
i_bitspersample
;
if
(
i_cat
==
AU_CAT_UNKNOWN
||
i_cat
==
AU_CAT_ADPCM
)
{
...
...
@@ -294,27 +279,26 @@ static int Open( vlc_object_t * p_this )
int
i_samples
,
i_modulo
;
/* read samples for 50ms of */
i_samples
=
__MAX
(
p_sys
->
wf
.
nSamplesPerSec
/
20
,
1
);
i_samples
=
__MAX
(
p_sys
->
fmt
.
audio
.
i_samplerate
/
20
,
1
);
p_sys
->
i_frame_size
=
i_samples
*
p_sys
->
wf
.
nChannels
*
(
(
p_sys
->
wf
.
wBitsPerS
ample
+
7
)
/
8
);
p_sys
->
i_frame_size
=
i_samples
*
p_sys
->
fmt
.
audio
.
i_channels
*
(
(
p_sys
->
fmt
.
audio
.
i_bitspers
ample
+
7
)
/
8
);
if
(
p_sys
->
wf
.
nBlockA
lign
>
0
)
if
(
p_sys
->
fmt
.
audio
.
i_blocka
lign
>
0
)
{
if
(
(
i_modulo
=
p_sys
->
i_frame_size
%
p_sys
->
wf
.
nBlockA
lign
)
!=
0
)
if
(
(
i_modulo
=
p_sys
->
i_frame_size
%
p_sys
->
fmt
.
audio
.
i_blocka
lign
)
!=
0
)
{
p_sys
->
i_frame_size
+=
p_sys
->
wf
.
nBlockA
lign
-
i_modulo
;
p_sys
->
i_frame_size
+=
p_sys
->
fmt
.
audio
.
i_blocka
lign
-
i_modulo
;
}
}
p_sys
->
i_frame_length
=
(
mtime_t
)
1000000
*
(
mtime_t
)
i_samples
/
(
mtime_t
)
p_sys
->
wf
.
nSamplesPerSec
;
(
mtime_t
)
p_sys
->
fmt
.
audio
.
i_samplerate
;
p_input
->
pf_demux
=
DemuxPCM
;
p_input
->
pf_demux_control
=
demux_vaControlDefault
;
}
/* create one program */
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
if
(
input_InitStream
(
p_input
,
0
)
==
-
1
)
{
...
...
@@ -322,29 +306,10 @@ static int Open( vlc_object_t * p_this )
msg_Err
(
p_input
,
"cannot init stream"
);
goto
error
;
}
if
(
input_AddProgram
(
p_input
,
0
,
0
)
==
NULL
)
{
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
msg_Err
(
p_input
,
"cannot add program"
);
goto
error
;
}
p_input
->
stream
.
p_selected_program
=
p_input
->
stream
.
pp_programs
[
0
];
p_input
->
stream
.
i_mux_rate
=
p_sys
->
wf
.
nAvgBytesPerSec
/
50
;
p_sys
->
p_es
=
input_AddES
(
p_input
,
p_input
->
stream
.
p_selected_program
,
0x01
,
AUDIO_ES
,
NULL
,
0
);
p_sys
->
p_es
->
i_stream_id
=
0x01
;
p_sys
->
p_es
->
i_fourcc
=
i_fourcc
;
p_sys
->
p_es
->
p_waveformatex
=
malloc
(
sizeof
(
WAVEFORMATEX
)
);
memcpy
(
p_sys
->
p_es
->
p_waveformatex
,
&
p_sys
->
wf
,
sizeof
(
WAVEFORMATEX
)
);
input_SelectES
(
p_input
,
p_sys
->
p_es
);
p_input
->
stream
.
p_selected_program
->
b_is_ok
=
1
;
p_input
->
stream
.
i_mux_rate
=
p_sys
->
fmt
.
audio
.
i_bitrate
/
50
/
8
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
p_sys
->
p_es
=
es_out_Add
(
p_input
->
p_es_out
,
&
p_sys
->
fmt
);
return
VLC_SUCCESS
;
error:
...
...
@@ -366,9 +331,9 @@ static int DemuxPCM( input_thread_t *p_input )
{
int64_t
i_pos
=
stream_Tell
(
p_input
->
s
);
if
(
p_sys
->
wf
.
nBlockA
lign
!=
0
)
if
(
p_sys
->
fmt
.
audio
.
i_blocka
lign
!=
0
)
{
i_pos
+=
p_sys
->
wf
.
nBlockAlign
-
i_pos
%
p_sys
->
wf
.
nBlockA
lign
;
i_pos
+=
p_sys
->
fmt
.
audio
.
i_blockalign
-
i_pos
%
p_sys
->
fmt
.
audio
.
i_blocka
lign
;
if
(
stream_Seek
(
p_input
->
s
,
i_pos
)
)
{
msg_Err
(
p_input
,
"Seek failed(cannot resync)"
);
...
...
@@ -390,15 +355,10 @@ static int DemuxPCM( input_thread_t *p_input )
p_input
->
stream
.
p_selected_program
,
p_sys
->
i_time
*
9
/
100
);
if
(
!
p_sys
->
p_es
->
p_decoder_fifo
)
{
msg_Err
(
p_input
,
"no audio decoder"
);
input_DeletePES
(
p_input
->
p_method_data
,
p_pes
);
return
(
-
1
);
}
es_out_Send
(
p_input
->
p_es_out
,
p_sys
->
p_es
,
p_pes
);
input_DecodePES
(
p_sys
->
p_es
->
p_decoder_fifo
,
p_pes
);
p_sys
->
i_time
+=
p_sys
->
i_frame_length
;
return
(
1
);
}
...
...
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