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
c352d28f
Commit
c352d28f
authored
Dec 11, 2007
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Do not use p_input->p->i_rate directly (no functionnality change yet)
parent
89be7cad
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
24 additions
and
18 deletions
+24
-18
src/input/clock.c
src/input/clock.c
+5
-5
src/input/es_out.c
src/input/es_out.c
+13
-7
src/input/input.c
src/input/input.c
+2
-2
src/input/input_internal.h
src/input/input_internal.h
+4
-4
No files found.
src/input/clock.c
View file @
c352d28f
...
@@ -115,7 +115,7 @@ static void ClockNewRef( input_clock_t *cl,
...
@@ -115,7 +115,7 @@ static void ClockNewRef( input_clock_t *cl,
* discontinuity
* discontinuity
*****************************************************************************/
*****************************************************************************/
void
input_ClockInit
(
input_thread_t
*
p_input
,
void
input_ClockInit
(
input_thread_t
*
p_input
,
input_clock_t
*
cl
,
vlc_bool_t
b_master
,
int
i_cr_average
)
input_clock_t
*
cl
,
vlc_bool_t
b_master
,
int
i_cr_average
,
int
i_rate
)
{
{
cl
->
i_synchro_state
=
SYNCHRO_START
;
cl
->
i_synchro_state
=
SYNCHRO_START
;
...
@@ -126,7 +126,7 @@ void input_ClockInit( input_thread_t *p_input,
...
@@ -126,7 +126,7 @@ void input_ClockInit( input_thread_t *p_input,
cl
->
sysdate_ref
=
0
;
cl
->
sysdate_ref
=
0
;
cl
->
delta_cr
=
0
;
cl
->
delta_cr
=
0
;
cl
->
i_delta_cr_residue
=
0
;
cl
->
i_delta_cr_residue
=
0
;
cl
->
i_rate
=
p_input
->
p
->
i_rate
;
cl
->
i_rate
=
i_rate
;
cl
->
i_cr_average
=
i_cr_average
;
cl
->
i_cr_average
=
i_cr_average
;
...
@@ -165,7 +165,7 @@ void input_ClockSetPCR( input_thread_t *p_input,
...
@@ -165,7 +165,7 @@ void input_ClockSetPCR( input_thread_t *p_input,
* warning from the stream control facilities (dd-edited
* warning from the stream control facilities (dd-edited
* stream ?). */
* stream ?). */
msg_Warn
(
p_input
,
"clock gap, unexpected stream discontinuity"
);
msg_Warn
(
p_input
,
"clock gap, unexpected stream discontinuity"
);
input_ClockInit
(
p_input
,
cl
,
cl
->
b_master
,
cl
->
i_cr_average
);
input_ClockInit
(
p_input
,
cl
,
cl
->
b_master
,
cl
->
i_cr_average
,
cl
->
i_rate
);
/* Feed synchro with a new reference point. */
/* Feed synchro with a new reference point. */
msg_Warn
(
p_input
,
"feeding synchro with a new reference point trying to recover from clock gap"
);
msg_Warn
(
p_input
,
"feeding synchro with a new reference point trying to recover from clock gap"
);
ClockNewRef
(
cl
,
i_clock
,
ClockNewRef
(
cl
,
i_clock
,
...
@@ -233,12 +233,12 @@ mtime_t input_ClockGetTS( input_thread_t * p_input,
...
@@ -233,12 +233,12 @@ mtime_t input_ClockGetTS( input_thread_t * p_input,
/*****************************************************************************
/*****************************************************************************
* input_ClockSetRate:
* input_ClockSetRate:
*****************************************************************************/
*****************************************************************************/
void
input_ClockSetRate
(
input_thread_t
*
p_input
,
input_clock_t
*
cl
)
void
input_ClockSetRate
(
input_thread_t
*
p_input
,
input_clock_t
*
cl
,
int
i_rate
)
{
{
/* Move the reference point */
/* Move the reference point */
if
(
cl
->
i_synchro_state
==
SYNCHRO_OK
)
if
(
cl
->
i_synchro_state
==
SYNCHRO_OK
)
ClockNewRef
(
cl
,
cl
->
last_cr
,
cl
->
last_sysdate
);
ClockNewRef
(
cl
,
cl
->
last_cr
,
cl
->
last_sysdate
);
cl
->
i_rate
=
p_input
->
p
->
i_rate
;
cl
->
i_rate
=
i_rate
;
}
}
src/input/es_out.c
View file @
c352d28f
...
@@ -128,6 +128,9 @@ struct es_out_sys_t
...
@@ -128,6 +128,9 @@ struct es_out_sys_t
/* delay */
/* delay */
int64_t
i_audio_delay
;
int64_t
i_audio_delay
;
int64_t
i_spu_delay
;
int64_t
i_spu_delay
;
/* Rate used to rescale ES ts */
int
i_rate
;
};
};
static
es_out_id_t
*
EsOutAdd
(
es_out_t
*
,
es_format_t
*
);
static
es_out_id_t
*
EsOutAdd
(
es_out_t
*
,
es_format_t
*
);
...
@@ -169,7 +172,7 @@ static inline int EsOutGetClosedCaptionsChannel( vlc_fourcc_t fcc )
...
@@ -169,7 +172,7 @@ static inline int EsOutGetClosedCaptionsChannel( vlc_fourcc_t fcc )
/*****************************************************************************
/*****************************************************************************
* input_EsOutNew:
* input_EsOutNew:
*****************************************************************************/
*****************************************************************************/
es_out_t
*
input_EsOutNew
(
input_thread_t
*
p_input
)
es_out_t
*
input_EsOutNew
(
input_thread_t
*
p_input
,
int
i_rate
)
{
{
es_out_t
*
out
=
malloc
(
sizeof
(
es_out_t
)
);
es_out_t
*
out
=
malloc
(
sizeof
(
es_out_t
)
);
es_out_sys_t
*
p_sys
=
malloc
(
sizeof
(
es_out_sys_t
)
);
es_out_sys_t
*
p_sys
=
malloc
(
sizeof
(
es_out_sys_t
)
);
...
@@ -250,6 +253,8 @@ es_out_t *input_EsOutNew( input_thread_t *p_input )
...
@@ -250,6 +253,8 @@ es_out_t *input_EsOutNew( input_thread_t *p_input )
p_sys
->
i_audio_delay
=
0
;
p_sys
->
i_audio_delay
=
0
;
p_sys
->
i_spu_delay
=
0
;
p_sys
->
i_spu_delay
=
0
;
p_sys
->
i_rate
=
i_rate
;
return
out
;
return
out
;
}
}
...
@@ -344,15 +349,16 @@ static void EsOutDiscontinuity( es_out_t *out, vlc_bool_t b_flush, vlc_bool_t b_
...
@@ -344,15 +349,16 @@ static void EsOutDiscontinuity( es_out_t *out, vlc_bool_t b_flush, vlc_bool_t b_
input_DecoderDiscontinuity
(
es
->
p_dec
,
b_flush
);
input_DecoderDiscontinuity
(
es
->
p_dec
,
b_flush
);
}
}
}
}
void
input_EsOutChangeRate
(
es_out_t
*
out
)
void
input_EsOutChangeRate
(
es_out_t
*
out
,
int
i_rate
)
{
{
es_out_sys_t
*
p_sys
=
out
->
p_sys
;
es_out_sys_t
*
p_sys
=
out
->
p_sys
;
int
i
;
int
i
;
p_sys
->
i_rate
=
i_rate
;
EsOutDiscontinuity
(
out
,
VLC_FALSE
,
VLC_FALSE
);
EsOutDiscontinuity
(
out
,
VLC_FALSE
,
VLC_FALSE
);
for
(
i
=
0
;
i
<
p_sys
->
i_pgrm
;
i
++
)
for
(
i
=
0
;
i
<
p_sys
->
i_pgrm
;
i
++
)
input_ClockSetRate
(
p_sys
->
p_input
,
&
p_sys
->
pgrm
[
i
]
->
clock
);
input_ClockSetRate
(
p_sys
->
p_input
,
&
p_sys
->
pgrm
[
i
]
->
clock
,
i_rate
);
}
}
void
input_EsOutSetDelay
(
es_out_t
*
out
,
int
i_cat
,
int64_t
i_delay
)
void
input_EsOutSetDelay
(
es_out_t
*
out
,
int
i_cat
,
int64_t
i_delay
)
...
@@ -575,7 +581,7 @@ static es_out_pgrm_t *EsOutProgramAdd( es_out_t *out, int i_group )
...
@@ -575,7 +581,7 @@ static es_out_pgrm_t *EsOutProgramAdd( es_out_t *out, int i_group )
p_pgrm
->
psz_now_playing
=
NULL
;
p_pgrm
->
psz_now_playing
=
NULL
;
p_pgrm
->
psz_publisher
=
NULL
;
p_pgrm
->
psz_publisher
=
NULL
;
p_pgrm
->
p_epg
=
NULL
;
p_pgrm
->
p_epg
=
NULL
;
input_ClockInit
(
p_input
,
&
p_pgrm
->
clock
,
VLC_FALSE
,
p_input
->
p
->
input
.
i_cr_average
);
input_ClockInit
(
p_input
,
&
p_pgrm
->
clock
,
VLC_FALSE
,
p_input
->
p
->
input
.
i_cr_average
,
p_sys
->
i_rate
);
/* Append it */
/* Append it */
TAB_APPEND
(
p_sys
->
i_pgrm
,
p_sys
->
pgrm
,
p_pgrm
);
TAB_APPEND
(
p_sys
->
i_pgrm
,
p_sys
->
pgrm
,
p_pgrm
);
...
@@ -1414,13 +1420,13 @@ static int EsOutSend( es_out_t *out, es_out_id_t *es, block_t *p_block )
...
@@ -1414,13 +1420,13 @@ static int EsOutSend( es_out_t *out, es_out_id_t *es, block_t *p_block )
}
}
}
}
p_block
->
i_rate
=
p_
input
->
p
->
i_rate
;
p_block
->
i_rate
=
p_
sys
->
i_rate
;
/* TODO handle mute */
/* TODO handle mute */
if
(
es
->
p_dec
&&
if
(
es
->
p_dec
&&
(
es
->
fmt
.
i_cat
!=
AUDIO_ES
||
(
es
->
fmt
.
i_cat
!=
AUDIO_ES
||
(
p_
input
->
p
->
i_rate
>=
INPUT_RATE_DEFAULT
/
AOUT_MAX_INPUT_RATE
&&
(
p_
sys
->
i_rate
>=
INPUT_RATE_DEFAULT
/
AOUT_MAX_INPUT_RATE
&&
p_
input
->
p
->
i_rate
<=
INPUT_RATE_DEFAULT
*
AOUT_MAX_INPUT_RATE
)
)
)
p_
sys
->
i_rate
<=
INPUT_RATE_DEFAULT
*
AOUT_MAX_INPUT_RATE
)
)
)
{
{
vlc_bool_t
pb_cc
[
4
];
vlc_bool_t
pb_cc
[
4
];
vlc_bool_t
b_cc_new
=
VLC_FALSE
;
vlc_bool_t
b_cc_new
=
VLC_FALSE
;
...
...
src/input/input.c
View file @
c352d28f
...
@@ -866,7 +866,7 @@ static int Init( input_thread_t * p_input )
...
@@ -866,7 +866,7 @@ static int Init( input_thread_t * p_input )
}
}
/* Create es out */
/* Create es out */
p_input
->
p
->
p_es_out
=
input_EsOutNew
(
p_input
);
p_input
->
p
->
p_es_out
=
input_EsOutNew
(
p_input
,
p_input
->
p
->
i_rate
);
es_out_Control
(
p_input
->
p
->
p_es_out
,
ES_OUT_SET_ACTIVE
,
VLC_FALSE
);
es_out_Control
(
p_input
->
p
->
p_es_out
,
ES_OUT_SET_ACTIVE
,
VLC_FALSE
);
es_out_Control
(
p_input
->
p
->
p_es_out
,
ES_OUT_SET_MODE
,
ES_OUT_MODE_NONE
);
es_out_Control
(
p_input
->
p
->
p_es_out
,
ES_OUT_SET_MODE
,
ES_OUT_MODE_NONE
);
...
@@ -1745,7 +1745,7 @@ static vlc_bool_t Control( input_thread_t *p_input, int i_type,
...
@@ -1745,7 +1745,7 @@ static vlc_bool_t Control( input_thread_t *p_input, int i_type,
p_input
->
p
->
i_rate
=
i_rate
;
p_input
->
p
->
i_rate
=
i_rate
;
input_EsOutChangeRate
(
p_input
->
p
->
p_es_out
);
input_EsOutChangeRate
(
p_input
->
p
->
p_es_out
,
i_rate
);
b_force_update
=
VLC_TRUE
;
b_force_update
=
VLC_TRUE
;
}
}
...
...
src/input/input_internal.h
View file @
c352d28f
...
@@ -268,11 +268,11 @@ int input_DecoderGetCcState( decoder_t *, vlc_bool_t *pb_decode, int i_ch
...
@@ -268,11 +268,11 @@ int input_DecoderGetCcState( decoder_t *, vlc_bool_t *pb_decode, int i_ch
void
input_DecoderIsCcPresent
(
decoder_t
*
,
vlc_bool_t
pb_present
[
4
]
);
void
input_DecoderIsCcPresent
(
decoder_t
*
,
vlc_bool_t
pb_present
[
4
]
);
/* es_out.c */
/* es_out.c */
es_out_t
*
input_EsOutNew
(
input_thread_t
*
);
es_out_t
*
input_EsOutNew
(
input_thread_t
*
,
int
i_rate
);
void
input_EsOutDelete
(
es_out_t
*
);
void
input_EsOutDelete
(
es_out_t
*
);
es_out_id_t
*
input_EsOutGetFromID
(
es_out_t
*
,
int
i_id
);
es_out_id_t
*
input_EsOutGetFromID
(
es_out_t
*
,
int
i_id
);
void
input_EsOutSetDelay
(
es_out_t
*
,
int
i_cat
,
int64_t
);
void
input_EsOutSetDelay
(
es_out_t
*
,
int
i_cat
,
int64_t
);
void
input_EsOutChangeRate
(
es_out_t
*
);
void
input_EsOutChangeRate
(
es_out_t
*
,
int
);
void
input_EsOutChangeState
(
es_out_t
*
);
void
input_EsOutChangeState
(
es_out_t
*
);
void
input_EsOutChangePosition
(
es_out_t
*
);
void
input_EsOutChangePosition
(
es_out_t
*
);
vlc_bool_t
input_EsOutDecodersEmpty
(
es_out_t
*
);
vlc_bool_t
input_EsOutDecodersEmpty
(
es_out_t
*
);
...
@@ -306,11 +306,11 @@ typedef struct
...
@@ -306,11 +306,11 @@ typedef struct
int
i_delta_cr_residue
;
int
i_delta_cr_residue
;
}
input_clock_t
;
}
input_clock_t
;
void
input_ClockInit
(
input_thread_t
*
,
input_clock_t
*
,
vlc_bool_t
b_master
,
int
i_cr_average
);
void
input_ClockInit
(
input_thread_t
*
,
input_clock_t
*
,
vlc_bool_t
b_master
,
int
i_cr_average
,
int
i_rate
);
void
input_ClockSetPCR
(
input_thread_t
*
,
input_clock_t
*
,
mtime_t
);
void
input_ClockSetPCR
(
input_thread_t
*
,
input_clock_t
*
,
mtime_t
);
void
input_ClockResetPCR
(
input_thread_t
*
,
input_clock_t
*
);
void
input_ClockResetPCR
(
input_thread_t
*
,
input_clock_t
*
);
mtime_t
input_ClockGetTS
(
input_thread_t
*
,
input_clock_t
*
,
mtime_t
);
mtime_t
input_ClockGetTS
(
input_thread_t
*
,
input_clock_t
*
,
mtime_t
);
void
input_ClockSetRate
(
input_thread_t
*
,
input_clock_t
*
cl
);
void
input_ClockSetRate
(
input_thread_t
*
,
input_clock_t
*
cl
,
int
i_rate
);
/* Subtitles */
/* Subtitles */
char
**
subtitles_Detect
(
input_thread_t
*
,
char
*
path
,
const
char
*
fname
);
char
**
subtitles_Detect
(
input_thread_t
*
,
char
*
path
,
const
char
*
fname
);
...
...
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