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
321d5550
Commit
321d5550
authored
Nov 28, 2004
by
Gildas Bazin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* modules/demux/mp4/mp4.c: couple of fixes for audio demuxing.
parent
e02be51a
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
19 additions
and
19 deletions
+19
-19
modules/demux/mp4/mp4.c
modules/demux/mp4/mp4.c
+19
-19
No files found.
modules/demux/mp4/mp4.c
View file @
321d5550
...
@@ -1915,58 +1915,58 @@ static int MP4_TrackSampleSize( mp4_track_t *p_track )
...
@@ -1915,58 +1915,58 @@ static int MP4_TrackSampleSize( mp4_track_t *p_track )
if
(
p_track
->
i_sample_size
==
0
)
if
(
p_track
->
i_sample_size
==
0
)
{
{
/* most simple case */
/* most simple case */
return
(
p_track
->
p_sample_size
[
p_track
->
i_sample
]
)
;
return
p_track
->
p_sample_size
[
p_track
->
i_sample
]
;
}
}
if
(
p_track
->
fmt
.
i_cat
!=
AUDIO_ES
)
if
(
p_track
->
fmt
.
i_cat
!=
AUDIO_ES
)
{
{
return
(
p_track
->
i_sample_size
)
;
return
p_track
->
i_sample_size
;
}
}
if
(
p_track
->
i_sample_size
!=
1
)
if
(
p_track
->
i_sample_size
!=
1
)
{
{
//msg_Warn( p_demux, "SampleSize != 1" );
//msg_Warn( p_demux, "SampleSize != 1" );
return
(
p_track
->
i_sample_size
)
;
return
p_track
->
i_sample_size
;
}
}
p_soun
=
p_track
->
p_sample
->
data
.
p_sample_soun
;
p_soun
=
p_track
->
p_sample
->
data
.
p_sample_soun
;
if
(
p_soun
->
i_qt_version
==
1
)
if
(
p_soun
->
i_qt_version
==
1
)
{
{
i_size
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_count
/
p_soun
->
i_sample_per_packet
*
p_soun
->
i_bytes_per_frame
;
i_size
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_count
/
p_soun
->
i_sample_per_packet
*
p_soun
->
i_bytes_per_frame
;
}
}
else
else
{
{
/* FIXME */
/* FIXME */
int
i_samples
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_count
-
int
i_samples
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_count
-
(
p_track
->
i_sample
-
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_first
);
(
p_track
->
i_sample
-
if
(
i_samples
>
QT_V0_MAX_SAMPLES
)
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_first
);
{
i_samples
=
QT_V0_MAX_SAMPLES
;
if
(
i_samples
>
QT_V0_MAX_SAMPLES
)
i_samples
=
QT_V0_MAX_SAMPLES
;
}
i_size
=
i_samples
*
p_soun
->
i_channelcount
*
p_soun
->
i_samplesize
/
8
;
i_size
=
i_samples
*
p_soun
->
i_channelcount
*
p_soun
->
i_samplesize
/
8
;
}
}
//fprintf( stderr, "size=%d\n", i_size );
//fprintf( stderr, "size=%d\n", i_size );
return
(
i_size
)
;
return
i_size
;
}
}
static
uint64_t
MP4_TrackGetPos
(
mp4_track_t
*
p_track
)
static
uint64_t
MP4_TrackGetPos
(
mp4_track_t
*
p_track
)
{
{
unsigned
int
i_sample
;
unsigned
int
i_sample
;
uint64_t
i_pos
;
uint64_t
i_pos
;
i_pos
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_offset
;
i_pos
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_offset
;
if
(
p_track
->
i_sample_size
)
if
(
p_track
->
i_sample_size
)
{
{
MP4_Box_data_sample_soun_t
*
p_soun
=
p_track
->
p_sample
->
data
.
p_sample_soun
;
MP4_Box_data_sample_soun_t
*
p_soun
=
p_track
->
p_sample
->
data
.
p_sample_soun
;
if
(
p_soun
->
i_qt_version
==
0
)
if
(
p_soun
->
i_qt_version
==
0
)
{
{
i_pos
+=
(
p_track
->
i_sample
-
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_first
)
*
i_pos
+=
(
p_track
->
i_sample
-
p_soun
->
i_channelcount
*
p_soun
->
i_samplesize
/
8
;
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_first
)
*
p_track
->
i_sample_size
;
}
}
else
else
{
{
...
@@ -1977,16 +1977,16 @@ static uint64_t MP4_TrackGetPos( mp4_track_t *p_track )
...
@@ -1977,16 +1977,16 @@ static uint64_t MP4_TrackGetPos( mp4_track_t *p_track )
else
else
{
{
for
(
i_sample
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_first
;
for
(
i_sample
=
p_track
->
chunk
[
p_track
->
i_chunk
].
i_sample_first
;
i_sample
<
p_track
->
i_sample
;
i_sample
++
)
i_sample
<
p_track
->
i_sample
;
i_sample
++
)
{
{
i_pos
+=
p_track
->
p_sample_size
[
i_sample
];
i_pos
+=
p_track
->
p_sample_size
[
i_sample
];
}
}
}
}
return
(
i_pos
);
return
i_pos
;
}
}
static
int
MP4_TrackNextSample
(
demux_t
*
p_demux
,
mp4_track_t
*
p_track
)
static
int
MP4_TrackNextSample
(
demux_t
*
p_demux
,
mp4_track_t
*
p_track
)
{
{
if
(
p_track
->
fmt
.
i_cat
==
AUDIO_ES
&&
if
(
p_track
->
fmt
.
i_cat
==
AUDIO_ES
&&
...
...
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