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
3b6a46b8
Commit
3b6a46b8
authored
Jun 06, 2004
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* access/*: use var_* helpers.
* access/vcd/ clean up.
parent
e34b5beb
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
173 additions
and
252 deletions
+173
-252
modules/access/cdda.c
modules/access/cdda.c
+5
-11
modules/access/directory.c
modules/access/directory.c
+6
-7
modules/access/file.c
modules/access/file.c
+7
-12
modules/access/ftp.c
modules/access/ftp.c
+13
-18
modules/access/http.c
modules/access/http.c
+11
-23
modules/access/mms/mmsh.c
modules/access/mms/mmsh.c
+5
-11
modules/access/mms/mmstu.c
modules/access/mms/mmstu.c
+5
-10
modules/access/tcp.c
modules/access/tcp.c
+1
-3
modules/access/udp.c
modules/access/udp.c
+7
-11
modules/access/vcd/vcd.c
modules/access/vcd/vcd.c
+113
-146
No files found.
modules/access/cdda.c
View file @
3b6a46b8
...
...
@@ -46,12 +46,12 @@ static void Close( vlc_object_t * );
vlc_module_begin
();
set_description
(
_
(
"Audio CD input"
)
);
set_capability
(
"access2"
,
10
);
set_callbacks
(
Open
,
Close
);
add_usage_hint
(
N_
(
"[cdda:][device][@[track]]"
)
);
add_integer
(
"cdda-caching"
,
DEFAULT_PTS_DELAY
/
1000
,
NULL
,
CACHING_TEXT
,
CACHING_LONGTEXT
,
VLC_TRUE
);
set_capability
(
"access2"
,
10
);
set_callbacks
(
Open
,
Close
);
add_shortcut
(
"cdda"
);
add_shortcut
(
"cddasimple"
);
vlc_module_end
();
...
...
@@ -98,7 +98,6 @@ static int Open( vlc_object_t *p_this )
int
i
;
int
i_title
=
0
;
vcddev_t
*
vcddev
;
vlc_value_t
val
;
/* Command line: cdda://[dev_path][@title] */
if
(
(
psz
=
strchr
(
psz_dup
,
'@'
)
)
)
...
...
@@ -117,10 +116,7 @@ static int Open( vlc_object_t *p_this )
return
VLC_EGENERIC
;
var_Create
(
p_access
,
"cd-audio"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"cd-audio"
,
&
val
);
psz_dup
=
val
.
psz_string
;
psz_dup
=
var_CreateGetString
(
p_access
,
"cd-audio"
);
if
(
*
psz_dup
==
'\0'
)
{
free
(
psz_dup
);
...
...
@@ -361,7 +357,6 @@ static int Control( access_t *p_access, int i_query, va_list args )
int
*
pi_int
;
int64_t
*
pi_64
;
input_title_t
***
ppp_title
;
vlc_value_t
val
;
int
i
;
switch
(
i_query
)
...
...
@@ -383,8 +378,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"cdda-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"cdda-caching"
)
*
I64C
(
1000
);
break
;
/* */
...
...
modules/access/directory.c
View file @
3b6a46b8
...
...
@@ -164,8 +164,8 @@ static int ReadNull( access_t *p_access, uint8_t *p_buffer, int i_len)
*****************************************************************************/
static
int
Read
(
access_t
*
p_access
,
uint8_t
*
p_buffer
,
int
i_len
)
{
char
*
psz_name
=
0
;
vlc_value_t
val
;
char
*
psz_name
=
NULL
;
char
*
psz
;
int
i_mode
,
i_pos
;
playlist_t
*
p_playlist
=
...
...
@@ -190,13 +190,12 @@ static int Read( access_t *p_access, uint8_t *p_buffer, int i_len)
}
/* Initialize structure */
var_Create
(
p_access
,
"recursive"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"recursive"
,
&
val
);
if
(
*
val
.
psz_string
==
'\0'
||
!
strncmp
(
val
.
psz_string
,
"none"
,
4
)
)
psz
=
var_CreateGetString
(
p_access
,
"recursive"
);
if
(
*
psz
==
'\0'
||
!
strncmp
(
psz
,
"none"
,
4
)
)
{
i_mode
=
MODE_NONE
;
}
else
if
(
!
strncmp
(
val
.
psz_string
,
"collapse"
,
8
)
)
else
if
(
!
strncmp
(
psz
,
"collapse"
,
8
)
)
{
i_mode
=
MODE_COLLAPSE
;
}
...
...
@@ -204,7 +203,7 @@ static int Read( access_t *p_access, uint8_t *p_buffer, int i_len)
{
i_mode
=
MODE_EXPAND
;
}
free
(
val
.
psz_string
);
free
(
psz
);
/* Make sure we are deleted when we are done */
p_playlist
->
pp_items
[
p_playlist
->
i_index
]
->
b_autodeletion
=
VLC_TRUE
;
...
...
modules/access/file.c
View file @
3b6a46b8
...
...
@@ -129,15 +129,14 @@ static int Open( vlc_object_t *p_this )
{
access_t
*
p_access
=
(
access_t
*
)
p_this
;
access_sys_t
*
p_sys
;
char
*
psz_name
=
p_access
->
psz_path
;
char
*
psz_name
=
p_access
->
psz_path
;
char
*
psz
;
#ifdef HAVE_SYS_STAT_H
int
i_stat
;
struct
stat
stat_info
;
#endif
vlc_bool_t
b_stdin
;
vlc_value_t
val
;
file_entry_t
*
p_file
;
...
...
@@ -251,12 +250,10 @@ static int Open( vlc_object_t *p_this )
p_file
->
psz_name
=
strdup
(
psz_name
);
TAB_APPEND
(
p_sys
->
i_file
,
p_sys
->
file
,
p_file
);
var_Create
(
p_access
,
"file-cat"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"file-cat"
,
&
val
);
if
(
*
val
.
psz_string
)
psz
=
var_CreateGetString
(
p_access
,
"file-cat"
);
if
(
*
psz
)
{
char
*
psz_parser
=
psz_name
=
val
.
psz_string
;
char
*
psz_parser
=
psz_name
=
psz
;
int64_t
i_size
;
while
(
psz_name
&&
*
psz_name
)
...
...
@@ -292,7 +289,7 @@ static int Open( vlc_object_t *p_this )
if
(
psz_name
)
psz_name
++
;
}
}
free
(
val
.
psz_string
);
free
(
psz
);
return
VLC_SUCCESS
;
}
...
...
@@ -515,7 +512,6 @@ static int Control( access_t *p_access, int i_query, va_list args )
vlc_bool_t
*
pb_bool
;
int
*
pi_int
;
int64_t
*
pi_64
;
vlc_value_t
val
;
switch
(
i_query
)
{
...
...
@@ -540,8 +536,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"file-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"file-caching"
)
*
I64C
(
1000
);
break
;
/* */
case
ACCESS_SET_PAUSE_STATE
:
...
...
modules/access/ftp.c
View file @
3b6a46b8
...
...
@@ -94,7 +94,6 @@ static int Open( vlc_object_t *p_this )
access_t
*
p_access
=
(
access_t
*
)
p_this
;
access_sys_t
*
p_sys
;
char
*
psz
;
vlc_value_t
val
;
int
i_answer
;
char
*
psz_arg
;
...
...
@@ -158,15 +157,14 @@ static int Open( vlc_object_t *p_this )
msg_Dbg
(
p_access
,
"connection accepted (%d)"
,
i_answer
);
var_Create
(
p_access
,
"ftp-user"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"ftp-user"
,
&
val
);
if
(
ftp_SendCommand
(
p_access
,
"USER %s"
,
val
.
psz_string
)
<
0
||
psz
=
var_CreateGetString
(
p_access
,
"ftp-user"
);
if
(
ftp_SendCommand
(
p_access
,
"USER %s"
,
psz
)
<
0
||
ftp_ReadCommand
(
p_access
,
&
i_answer
,
NULL
)
<
0
)
{
if
(
val
.
psz_string
)
free
(
val
.
psz_string
);
free
(
psz
);
goto
exit_error
;
}
if
(
val
.
psz_string
)
free
(
val
.
psz_string
);
free
(
psz
);
switch
(
i_answer
/
100
)
{
...
...
@@ -175,15 +173,14 @@ static int Open( vlc_object_t *p_this )
break
;
case
3
:
msg_Dbg
(
p_access
,
"password needed"
);
var_Create
(
p_access
,
"ftp-pwd"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"ftp-pwd"
,
&
val
);
if
(
ftp_SendCommand
(
p_access
,
"PASS %s"
,
val
.
psz_string
)
<
0
||
psz
=
var_CreateGetString
(
p_access
,
"ftp-pwd"
);
if
(
ftp_SendCommand
(
p_access
,
"PASS %s"
,
psz
)
<
0
||
ftp_ReadCommand
(
p_access
,
&
i_answer
,
NULL
)
<
0
)
{
if
(
val
.
psz_string
)
free
(
val
.
psz_string
);
free
(
psz
);
goto
exit_error
;
}
if
(
val
.
psz_string
)
free
(
val
.
psz_string
);
free
(
psz
);
switch
(
i_answer
/
100
)
{
...
...
@@ -192,17 +189,15 @@ static int Open( vlc_object_t *p_this )
break
;
case
3
:
msg_Dbg
(
p_access
,
"account needed"
);
var_Create
(
p_access
,
"ftp-account"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"ftp-account"
,
&
val
);
psz
=
var_CreateGetString
(
p_access
,
"ftp-account"
);
if
(
ftp_SendCommand
(
p_access
,
"ACCT %s"
,
val
.
psz_string
)
<
0
||
psz
)
<
0
||
ftp_ReadCommand
(
p_access
,
&
i_answer
,
NULL
)
<
0
)
{
if
(
val
.
psz_string
)
free
(
val
.
psz_string
);
free
(
psz
);
goto
exit_error
;
}
if
(
val
.
psz_string
)
free
(
val
.
psz_string
);
free
(
psz
);
if
(
i_answer
/
100
!=
2
)
{
...
...
@@ -372,7 +367,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"ftp-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"ftp-caching"
)
*
I64C
(
1000
)
;
break
;
/* */
...
...
modules/access/http.c
View file @
3b6a46b8
...
...
@@ -129,7 +129,7 @@ static int Open ( vlc_object_t *p_this )
{
access_t
*
p_access
=
(
access_t
*
)
p_this
;
access_sys_t
*
p_sys
;
vlc_value_t
val
;
char
*
psz
;
/* First set ipv4/ipv6 */
var_Create
(
p_access
,
"ipv4"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
...
...
@@ -137,6 +137,7 @@ static int Open ( vlc_object_t *p_this )
if
(
*
p_access
->
psz_access
)
{
vlc_value_t
val
;
/* Find out which shortcut was used */
if
(
!
strncmp
(
p_access
->
psz_access
,
"http4"
,
6
)
)
{
...
...
@@ -191,27 +192,19 @@ static int Open ( vlc_object_t *p_this )
}
if
(
!
p_sys
->
psz_user
||
*
p_sys
->
psz_user
==
'\0'
)
{
var_Create
(
p_access
,
"http-user"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"http-user"
,
&
val
);
p_sys
->
psz_user
=
val
.
psz_string
;
var_Create
(
p_access
,
"http-pwd"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"http-pwd"
,
&
val
);
p_sys
->
psz_passwd
=
val
.
psz_string
;
p_sys
->
psz_user
=
var_CreateGetString
(
p_access
,
"http-user"
);
p_sys
->
psz_passwd
=
var_CreateGetString
(
p_access
,
"http-pwd"
);
}
/* Do user agent */
var_Create
(
p_access
,
"http-user-agent"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"http-user-agent"
,
&
val
);
p_sys
->
psz_user_agent
=
val
.
psz_string
;
p_sys
->
psz_user_agent
=
var_CreateGetString
(
p_access
,
"http-user-agent"
);
/* Check proxy */
var_Create
(
p_access
,
"http-proxy"
,
VLC_VAR_STRING
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"http-proxy"
,
&
val
);
if
(
val
.
psz_string
&&
*
val
.
psz_string
)
psz
=
var_CreateGetString
(
p_access
,
"http-proxy"
);
if
(
*
psz
)
{
p_sys
->
b_proxy
=
VLC_TRUE
;
vlc_UrlParse
(
&
p_sys
->
proxy
,
val
.
psz_string
,
0
);
vlc_UrlParse
(
&
p_sys
->
proxy
,
psz
,
0
);
}
else
{
...
...
@@ -219,17 +212,12 @@ static int Open ( vlc_object_t *p_this )
if
(
psz_proxy
&&
*
psz_proxy
)
{
p_sys
->
b_proxy
=
VLC_TRUE
;
vlc_UrlParse
(
&
p_sys
->
proxy
,
val
.
psz_string
,
0
);
vlc_UrlParse
(
&
p_sys
->
proxy
,
psz_proxy
,
0
);
}
if
(
psz_proxy
)
{
free
(
psz_proxy
);
}
}
if
(
val
.
psz_string
)
{
free
(
val
.
psz_string
);
}
free
(
psz
);
if
(
p_sys
->
b_proxy
)
{
...
...
@@ -497,7 +485,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"http-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"http-caching"
)
*
1000
;
break
;
/* */
...
...
modules/access/mms/mmsh.c
View file @
3b6a46b8
...
...
@@ -66,7 +66,6 @@ int E_(MMSHOpen)( access_t *p_access )
{
access_sys_t
*
p_sys
;
char
*
psz_location
=
NULL
;
vlc_value_t
val
;
/* init p_sys */
...
...
@@ -145,9 +144,6 @@ int E_(MMSHOpen)( access_t *p_access )
p_access
->
info
.
i_size
=
p_sys
->
asfh
.
i_file_size
;
}
/* Update default_pts to a suitable value for mms access */
var_Get
(
p_access
,
"mms-caching"
,
&
val
);
return
VLC_SUCCESS
;
}
...
...
@@ -171,7 +167,6 @@ static int Control( access_t *p_access, int i_query, va_list args )
vlc_bool_t
*
pb_bool
;
int
*
pi_int
;
int64_t
*
pi_64
;
vlc_value_t
val
;
switch
(
i_query
)
{
...
...
@@ -195,8 +190,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"mms-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"mms-caching"
)
*
I64C
(
1000
);
break
;
/* */
...
...
@@ -531,10 +525,10 @@ static int Describe( access_t *p_access, char **ppsz_location )
p_sys
->
asfh
.
i_min_data_packet_size
);
E_
(
asf_StreamSelect
)(
&
p_sys
->
asfh
,
config_GetInt
(
p_access
,
"mms-maxbitrate"
),
config_GetInt
(
p_access
,
"mms-all"
),
config_GetInt
(
p_access
,
"audio"
),
config_GetInt
(
p_access
,
"video"
)
);
var_CreateGetInteger
(
p_access
,
"mms-maxbitrate"
),
var_CreateGetInteger
(
p_access
,
"mms-all"
),
var_CreateGetInteger
(
p_access
,
"audio"
),
var_CreateGetInteger
(
p_access
,
"video"
)
);
return
VLC_SUCCESS
;
...
...
modules/access/mms/mmstu.c
View file @
3b6a46b8
...
...
@@ -120,7 +120,6 @@ int E_(MMSTUOpen)( access_t *p_access )
access_sys_t
*
p_sys
;
int
i_proto
;
int
i_status
;
vlc_value_t
val
;
/* Set up p_access */
p_access
->
pf_read
=
Read
;
...
...
@@ -215,10 +214,6 @@ int E_(MMSTUOpen)( access_t *p_access )
vlc_UrlClean
(
&
p_sys
->
url
);
return
VLC_EGENERIC
;
}
/* Update default_pts to a suitable value for mms access */
var_Get
(
p_access
,
"mms-caching"
,
&
val
);
return
VLC_SUCCESS
;
}
...
...
@@ -272,7 +267,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"mms-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"mms-caching"
)
*
I64C
(
1000
)
;
break
;
/* */
...
...
@@ -748,10 +743,10 @@ static int MMSOpen( access_t *p_access, vlc_url_t *p_url, int i_proto )
E_
(
asf_HeaderParse
)(
&
p_sys
->
asfh
,
p_sys
->
p_header
,
p_sys
->
i_header
);
E_
(
asf_StreamSelect
)(
&
p_sys
->
asfh
,
config_GetInt
(
p_access
,
"mms-maxbitrate"
),
config_GetInt
(
p_access
,
"mms-all"
),
config_GetInt
(
p_access
,
"audio"
),
config_GetInt
(
p_access
,
"video"
)
);
var_CreateGetInteger
(
p_access
,
"mms-maxbitrate"
),
var_CreateGetInteger
(
p_access
,
"mms-all"
),
var_CreateGetInteger
(
p_access
,
"audio"
),
var_CreateGetInteger
(
p_access
,
"video"
)
);
/* *** now select stream we want to receive *** */
/* TODO take care of stream bitrate TODO */
...
...
modules/access/tcp.c
View file @
3b6a46b8
...
...
@@ -172,7 +172,6 @@ static int Control( access_t *p_access, int i_query, va_list args )
vlc_bool_t
*
pb_bool
;
int
*
pi_int
;
int64_t
*
pi_64
;
vlc_value_t
val
;
switch
(
i_query
)
{
...
...
@@ -199,8 +198,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"tcp-caching"
,
&
val
);
*
pi_64
=
val
.
i_int
*
1000
;
*
pi_64
=
(
int64_t
)
var_GetInteger
(
p_access
,
"tcp-caching"
)
*
I64C
(
1000
);
break
;
/* */
...
...
modules/access/udp.c
View file @
3b6a46b8
...
...
@@ -103,7 +103,6 @@ static int Open( vlc_object_t *p_this )
char
*
psz_bind_port
=
""
;
int
i_bind_port
=
0
;
int
i_server_port
=
0
;
vlc_value_t
val
;
/* First set ipv4/ipv6 */
...
...
@@ -112,6 +111,7 @@ static int Open( vlc_object_t *p_this )
if
(
*
p_access
->
psz_access
)
{
vlc_value_t
val
;
/* Find out which shortcut was used */
if
(
!
strncmp
(
p_access
->
psz_access
,
"udp4"
,
6
)
||
!
strncmp
(
p_access
->
psz_access
,
"rtp4"
,
6
))
...
...
@@ -201,9 +201,7 @@ static int Open( vlc_object_t *p_this )
i_server_port
=
strtol
(
psz_server_port
,
NULL
,
10
);
if
(
(
i_bind_port
=
strtol
(
psz_bind_port
,
NULL
,
10
)
)
==
0
)
{
var_Create
(
p_access
,
"server-port"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"server-port"
,
&
val
);
i_bind_port
=
val
.
i_int
;
i_bind_port
=
var_CreateGetInteger
(
p_access
,
"server-port"
);
}
msg_Dbg
(
p_access
,
"opening server=%s:%d local=%s:%d"
,
...
...
@@ -234,13 +232,11 @@ static int Open( vlc_object_t *p_this )
free
(
psz_name
);
/* FIXME */
var_Create
(
p_access
,
"mtu"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"mtu"
,
&
val
);
p_sys
->
i_mtu
=
val
.
i_int
>
0
?
val
.
i_int
:
1500
;
/* a
void problem */
p_sys
->
i_mtu
=
var_CreateGetInteger
(
p_access
,
"mtu"
);
if
(
p_sys
->
i_mtu
<=
1
)
p_sys
->
i_mtu
=
1500
;
/* A
void problem */
var_Create
(
p_access
,
"udp-auto-mtu"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
var_Get
(
p_access
,
"udp-auto-mtu"
,
&
val
);
p_sys
->
b_auto_mtu
=
val
.
b_bool
;
p_sys
->
b_auto_mtu
=
var_CreateGetBool
(
p_access
,
"udp-auto-mtu"
);;
/* Update default_pts to a suitable value for udp access */
var_Create
(
p_access
,
"udp-caching"
,
VLC_VAR_INTEGER
|
VLC_VAR_DOINHERIT
);
...
...
@@ -290,7 +286,7 @@ static int Control( access_t *p_access, int i_query, va_list args )
case
ACCESS_GET_PTS_DELAY
:
pi_64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
var_Get
(
p_access
,
"udp-caching"
,
&
val
);
*
pi_64
=
va
l
.
i_int
*
1000
;
*
pi_64
=
va
r_GetInteger
(
p_access
,
"udp-caching"
)
*
1000
;
break
;
/* */
...
...
modules/access/vcd/vcd.c
View file @
3b6a46b8
...
...
@@ -2,7 +2,7 @@
* vcd.c : VCD input module for vlc
*****************************************************************************
* Copyright (C) 2000-2004 VideoLAN
* $Id
: vcd.c,v 1.25 2004/01/25 17:31:22 gbazin Exp
$
* $Id$
*
* Author: Johan Bilien <jobi@via.ecp.fr>
*
...
...
@@ -24,30 +24,37 @@
/*****************************************************************************
* Preamble
*****************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <vlc/vlc.h>
#include <vlc/input.h>
#include "../../demux/mpeg/system.h"
#include "cdrom.h"
/*****************************************************************************
* Module descriptior
*****************************************************************************/
static
int
Open
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
#ifdef HAVE_UNISTD_H
# include <unistd.h>
#endif
vlc_module_begin
();
set_description
(
_
(
"VCD input"
)
);
set_capability
(
"access"
,
80
);
set_callbacks
(
Open
,
Close
);
#include <string.h>
add_usage_hint
(
N_
(
"[vcd:][device][@[title][,[chapter]]]"
)
);
add_shortcut
(
"svcd"
);
vlc_module_end
();
#include "cdrom.h"
/*****************************************************************************
* Local prototypes
*****************************************************************************/
/* how many blocks VCDRead will read in each loop */
#define VCD_BLOCKS_ONCE 20
#define VCD_DATA_ONCE (VCD_BLOCKS_ONCE * VCD_DATA_SIZE)
/*****************************************************************************
* thread_vcd_data_t: VCD information
*****************************************************************************/
typedef
struct
thread_vcd_data_s
struct
access_sys_t
{
vcddev_t
*
vcddev
;
/* vcd device descriptor */
int
i_nb_tracks
;
/* Nb of tracks (titles) */
...
...
@@ -58,111 +65,77 @@ typedef struct thread_vcd_data_s
int
*
p_entries
;
/* Entry points */
vlc_bool_t
b_valid_ep
;
/* Valid entry points flag */
vlc_bool_t
b_end_of_track
;
/* If the end of track was reached */
};
}
thread_vcd_data_t
;
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
int
VCDOpen
(
vlc_object_t
*
);
static
void
VCDClose
(
vlc_object_t
*
);
static
int
VCDRead
(
input_thread_t
*
,
byte_t
*
,
size_t
);
static
void
VCDSeek
(
input_thread_t
*
,
off_t
);
static
int
VCDSetArea
(
input_thread_t
*
,
input_area_t
*
);
static
int
VCDSetProgram
(
input_thread_t
*
,
pgrm_descriptor_t
*
);
static
int
VCDEntryPoints
(
input_thread_t
*
);
/*****************************************************************************
* Module descriptior
*****************************************************************************/
vlc_module_begin
();
set_description
(
_
(
"VCD input"
)
);
set_capability
(
"access"
,
80
);
set_callbacks
(
VCDOpen
,
VCDClose
);
add_shortcut
(
"svcd"
);
vlc_module_end
();
/*
* Data reading functions
*/
/*****************************************************************************
* VCDOpen: open vcd
*****************************************************************************/
static
int
VCD
Open
(
vlc_object_t
*
p_this
)
static
int
Open
(
vlc_object_t
*
p_this
)
{
input_thread_t
*
p_input
=
(
input_thread_t
*
)
p_this
;
char
*
psz_orig
;
char
*
psz_parser
;
char
*
psz_source
;
char
*
psz_next
;
thread_vcd_data_t
*
p_vcd
;
input_thread_t
*
p_input
=
(
input_thread_t
*
)
p_this
;
access_sys_t
*
p_sys
;
char
*
psz_dup
=
strdup
(
p_input
->
psz_name
);
char
*
psz
;
int
i
;
input_area_t
*
p_area
;
int
i_title
=
1
;
int
i_chapter
=
1
;
int
i_title
=
0
;
int
i_chapter
=
0
;
vcddev_t
*
vcddev
;
/* parse the options passed in command line : */
psz_orig
=
psz_parser
=
psz_source
=
strdup
(
p_input
->
psz_name
);
if
(
!
psz_orig
)
{
return
(
-
1
);
}
while
(
*
psz_parser
&&
*
psz_parser
!=
'@'
)
/* Command line: vcd://[dev_path][@title[,chapter]] */
if
(
(
psz
=
strchr
(
psz_dup
,
'@'
)
)
)
{
psz_parser
++
;
}
if
(
*
psz_parser
==
'@'
)
{
/* Found options */
*
psz_parser
=
'\0'
;
++
psz_parser
;
*
psz
++
=
'\0'
;
i_title
=
(
int
)
strtol
(
psz_parser
,
&
psz_next
,
1
0
);
if
(
*
psz
_next
)
i_title
=
strtol
(
psz
,
&
psz
,
0
);
if
(
*
psz
)
{
psz_parser
=
psz_next
+
1
;
i_chapter
=
(
int
)
strtol
(
psz_parser
,
&
psz_next
,
10
);
i_chapter
=
strtol
(
psz
,
&
psz
,
0
);
}
i_title
=
i_title
>
0
?
i_title
:
1
;
i_chapter
=
i_chapter
>
0
?
i_chapter
:
1
;
}
if
(
!*
psz_source
)
if
(
*
psz_dup
==
'\0'
)
{
if
(
!
p_input
->
psz_access
)
free
(
psz_dup
);
/* Only when selected */
if
(
*
p_input
->
psz_access
==
'\0'
)
return
VLC_EGENERIC
;
psz_dup
=
var_CreateGetString
(
p_input
,
"vcd"
);
if
(
*
psz_dup
==
'\0'
)
{
free
(
psz_
orig
);
return
-
1
;
free
(
psz_
dup
);
return
VLC_EGENERIC
;
}
psz_source
=
config_GetPsz
(
p_input
,
"vcd"
);
if
(
!
psz_source
)
return
-
1
;
}
/* Open VCD */
if
(
!
(
vcddev
=
ioctl_Open
(
p_this
,
psz_
source
))
)
if
(
!
(
vcddev
=
ioctl_Open
(
p_this
,
psz_
dup
))
)
{
msg_Warn
(
p_input
,
"could not open %s"
,
psz_
source
);
free
(
psz_
source
);
return
-
1
;
msg_Warn
(
p_input
,
"could not open %s"
,
psz_
dup
);
free
(
psz_
dup
);
return
VLC_EGENERIC
;
}
p_
vcd
=
malloc
(
sizeof
(
thread_vcd_data
_t
)
);
if
(
p_
vcd
==
NULL
)
p_
sys
=
malloc
(
sizeof
(
access_sys
_t
)
);
if
(
p_
sys
==
NULL
)
{
msg_Err
(
p_input
,
"out of memory"
);
free
(
psz_
source
);
return
-
1
;
free
(
psz_
dup
);
return
VLC_EGENERIC
;
}
free
(
psz_
source
);
free
(
psz_
dup
);
p_
vcd
->
vcddev
=
vcddev
;
p_input
->
p_access_data
=
(
void
*
)
p_
vcd
;
p_
sys
->
vcddev
=
vcddev
;
p_input
->
p_access_data
=
(
void
*
)
p_
sys
;
p_input
->
i_mtu
=
VCD_DATA_ONCE
;
...
...
@@ -174,34 +147,34 @@ static int VCDOpen( vlc_object_t *p_this )
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
/* We read the Table Of Content information */
p_
vcd
->
i_nb_tracks
=
ioctl_GetTracksMap
(
VLC_OBJECT
(
p_input
),
p_
vcd
->
vcddev
,
&
p_vcd
->
p_sectors
);
if
(
p_
vcd
->
i_nb_tracks
<
0
)
p_
sys
->
i_nb_tracks
=
ioctl_GetTracksMap
(
VLC_OBJECT
(
p_input
),
p_
sys
->
vcddev
,
&
p_sys
->
p_sectors
);
if
(
p_
sys
->
i_nb_tracks
<
0
)
msg_Err
(
p_input
,
"unable to count tracks"
);
else
if
(
p_
vcd
->
i_nb_tracks
<=
1
)
else
if
(
p_
sys
->
i_nb_tracks
<=
1
)
msg_Err
(
p_input
,
"no movie tracks found"
);
if
(
p_
vcd
->
i_nb_tracks
<=
1
)
if
(
p_
sys
->
i_nb_tracks
<=
1
)
{
ioctl_Close
(
p_this
,
p_
vcd
->
vcddev
);
free
(
p_
vcd
);
ioctl_Close
(
p_this
,
p_
sys
->
vcddev
);
free
(
p_
sys
);
return
-
1
;
}
/* Allocate the entry points table */
p_
vcd
->
p_entries
=
malloc
(
p_vcd
->
i_nb_tracks
*
sizeof
(
int
)
);
p_
sys
->
p_entries
=
malloc
(
p_sys
->
i_nb_tracks
*
sizeof
(
int
)
);
if
(
p_
vcd
->
p_entries
==
NULL
)
if
(
p_
sys
->
p_entries
==
NULL
)
{
msg_Err
(
p_input
,
"not enough memory"
);
ioctl_Close
(
p_this
,
p_
vcd
->
vcddev
);
free
(
p_
vcd
);
ioctl_Close
(
p_this
,
p_
sys
->
vcddev
);
free
(
p_
sys
);
}
/* Set stream and area data */
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
/* Initialize ES structures */
input_InitStream
(
p_input
,
sizeof
(
stream_ps_data_t
)
);
input_InitStream
(
p_input
,
0
);
/* disc input method */
p_input
->
stream
.
i_method
=
INPUT_METHOD_VCD
;
...
...
@@ -209,14 +182,14 @@ static int VCDOpen( vlc_object_t *p_this )
p_input
->
stream
.
i_area_nb
=
1
;
#define area p_input->stream.pp_areas
for
(
i
=
1
;
i
<
p_
vcd
->
i_nb_tracks
;
i
++
)
for
(
i
=
1
;
i
<
p_
sys
->
i_nb_tracks
;
i
++
)
{
/* Titles are Program Chains */
input_AddArea
(
p_input
,
i
,
1
);
/* Absolute start offset and size */
area
[
i
]
->
i_start
=
(
off_t
)
p_
vcd
->
p_sectors
[
i
]
*
(
off_t
)
VCD_DATA_SIZE
;
area
[
i
]
->
i_size
=
(
off_t
)(
p_
vcd
->
p_sectors
[
i
+
1
]
-
p_vcd
->
p_sectors
[
i
])
area
[
i
]
->
i_start
=
(
off_t
)
p_
sys
->
p_sectors
[
i
]
*
(
off_t
)
VCD_DATA_SIZE
;
area
[
i
]
->
i_size
=
(
off_t
)(
p_
sys
->
p_sectors
[
i
+
1
]
-
p_sys
->
p_sectors
[
i
])
*
(
off_t
)
VCD_DATA_SIZE
;
/* Default Chapter */
...
...
@@ -228,13 +201,13 @@ static int VCDOpen( vlc_object_t *p_this )
}
#undef area
p_area
=
p_input
->
stream
.
pp_areas
[
__MIN
(
i_title
,
p_
vcd
->
i_nb_tracks
-
1
)];
p_area
=
p_input
->
stream
.
pp_areas
[
__MIN
(
i_title
,
p_
sys
->
i_nb_tracks
-
1
)];
p_
vcd
->
b_valid_ep
=
1
;
p_
sys
->
b_valid_ep
=
1
;
if
(
VCDEntryPoints
(
p_input
)
<
0
)
{
msg_Warn
(
p_input
,
"could not read entry points, will not use them"
);
p_
vcd
->
b_valid_ep
=
0
;
p_
sys
->
b_valid_ep
=
0
;
}
VCDSetArea
(
p_input
,
p_area
);
...
...
@@ -257,13 +230,13 @@ static int VCDOpen( vlc_object_t *p_this )
/*****************************************************************************
* VCDClose: closes vcd
*****************************************************************************/
static
void
VCD
Close
(
vlc_object_t
*
p_this
)
static
void
Close
(
vlc_object_t
*
p_this
)
{
input_thread_t
*
p_input
=
(
input_thread_t
*
)
p_this
;
thread_vcd_data_t
*
p_vcd
=
(
thread_vcd_data_t
*
)
p_input
->
p_access_data
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
ioctl_Close
(
p_this
,
p_
vcd
->
vcddev
);
free
(
p_
vcd
);
ioctl_Close
(
p_this
,
p_
sys
->
vcddev
);
free
(
p_
sys
);
}
/*****************************************************************************
...
...
@@ -275,13 +248,13 @@ static void VCDClose( vlc_object_t *p_this )
static
int
VCDRead
(
input_thread_t
*
p_input
,
byte_t
*
p_buffer
,
size_t
i_len
)
{
thread_vcd_data_t
*
p_vcd
;
access_sys_t
*
p_sys
;
int
i_blocks
;
int
i_index
;
int
i_read
;
byte_t
p_last_sector
[
VCD_DATA_SIZE
];
p_
vcd
=
(
thread_vcd_data_t
*
)
p_input
->
p_access_data
;
p_
sys
=
p_input
->
p_access_data
;
i_read
=
0
;
...
...
@@ -291,20 +264,20 @@ static int VCDRead( input_thread_t * p_input, byte_t * p_buffer,
for
(
i_index
=
0
;
i_index
<
i_blocks
;
i_index
++
)
{
if
(
ioctl_ReadSectors
(
VLC_OBJECT
(
p_input
),
p_
vcd
->
vcddev
,
p_
vcd
->
i_sector
,
p_buffer
+
i_index
*
VCD_DATA_SIZE
,
1
,
if
(
ioctl_ReadSectors
(
VLC_OBJECT
(
p_input
),
p_
sys
->
vcddev
,
p_
sys
->
i_sector
,
p_buffer
+
i_index
*
VCD_DATA_SIZE
,
1
,
VCD_TYPE
)
<
0
)
{
msg_Err
(
p_input
,
"could not read sector %d"
,
p_
vcd
->
i_sector
);
msg_Err
(
p_input
,
"could not read sector %d"
,
p_
sys
->
i_sector
);
return
-
1
;
}
p_
vcd
->
i_sector
++
;
if
(
p_
vcd
->
i_sector
==
p_vcd
->
p_sectors
[
p_vcd
->
i_track
+
1
]
)
p_
sys
->
i_sector
++
;
if
(
p_
sys
->
i_sector
==
p_sys
->
p_sectors
[
p_sys
->
i_track
+
1
]
)
{
input_area_t
*
p_area
;
if
(
p_
vcd
->
i_track
>=
p_vcd
->
i_nb_tracks
-
1
)
if
(
p_
sys
->
i_track
>=
p_sys
->
i_nb_tracks
-
1
)
return
0
;
/* EOF */
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
...
...
@@ -319,7 +292,7 @@ static int VCDRead( input_thread_t * p_input, byte_t * p_buffer,
}
/* Update chapter */
else
if
(
p_
vcd
->
b_valid_ep
&&
else
if
(
p_
sys
->
b_valid_ep
&&
/* FIXME kludge so that read does not update chapter
* when a manual chapter change was requested and not
* yet accomplished */
...
...
@@ -331,8 +304,8 @@ static int VCDRead( input_thread_t * p_input, byte_t * p_buffer,
i_entry
=
p_input
->
stream
.
p_selected_area
->
i_plugin_data
/* 1st entry point of the track (area)*/
+
p_input
->
stream
.
p_selected_area
->
i_part
-
1
;
if
(
i_entry
+
1
<
p_
vcd
->
i_entries_nb
&&
p_
vcd
->
i_sector
>=
p_vcd
->
p_entries
[
i_entry
+
1
]
)
if
(
i_entry
+
1
<
p_
sys
->
i_entries_nb
&&
p_
sys
->
i_sector
>=
p_sys
->
p_entries
[
i_entry
+
1
]
)
{
vlc_value_t
val
;
...
...
@@ -352,10 +325,10 @@ static int VCDRead( input_thread_t * p_input, byte_t * p_buffer,
if
(
i_len
%
VCD_DATA_SIZE
)
/* this should not happen */
{
if
(
ioctl_ReadSectors
(
VLC_OBJECT
(
p_input
),
p_
vcd
->
vcddev
,
p_
vcd
->
i_sector
,
p_last_sector
,
1
,
VCD_TYPE
)
<
0
)
if
(
ioctl_ReadSectors
(
VLC_OBJECT
(
p_input
),
p_
sys
->
vcddev
,
p_
sys
->
i_sector
,
p_last_sector
,
1
,
VCD_TYPE
)
<
0
)
{
msg_Err
(
p_input
,
"could not read sector %d"
,
p_
vcd
->
i_sector
);
msg_Err
(
p_input
,
"could not read sector %d"
,
p_
sys
->
i_sector
);
return
-
1
;
}
...
...
@@ -382,11 +355,9 @@ static int VCDSetProgram( input_thread_t * p_input,
****************************************************************************/
static
int
VCDSetArea
(
input_thread_t
*
p_input
,
input_area_t
*
p_area
)
{
thread_vcd_data_t
*
p_vcd
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
vlc_value_t
val
;
p_vcd
=
(
thread_vcd_data_t
*
)
p_input
->
p_access_data
;
/* we can't use the interface slider until initilization is complete */
p_input
->
stream
.
b_seekable
=
0
;
...
...
@@ -403,8 +374,8 @@ static int VCDSetArea( input_thread_t * p_input, input_area_t * p_area )
/* Change the current track */
/* The first track is not a valid one */
p_
vcd
->
i_track
=
p_area
->
i_id
;
p_
vcd
->
i_sector
=
p_vcd
->
p_sectors
[
p_vcd
->
i_track
];
p_
sys
->
i_track
=
p_area
->
i_id
;
p_
sys
->
i_sector
=
p_sys
->
p_sectors
[
p_sys
->
i_track
];
/* Update the navigation variables without triggering a callback */
val
.
i_int
=
p_area
->
i_id
;
...
...
@@ -417,18 +388,18 @@ static int VCDSetArea( input_thread_t * p_input, input_area_t * p_area )
}
}
if
(
p_
vcd
->
b_valid_ep
)
if
(
p_
sys
->
b_valid_ep
)
{
int
i_entry
=
p_area
->
i_plugin_data
/* 1st entry point of
the track (area)*/
+
p_area
->
i_part
-
1
;
p_
vcd
->
i_sector
=
p_vcd
->
p_entries
[
i_entry
];
p_
sys
->
i_sector
=
p_sys
->
p_entries
[
i_entry
];
}
else
p_
vcd
->
i_sector
=
p_vcd
->
p_sectors
[
p_vcd
->
i_track
];
p_
sys
->
i_sector
=
p_sys
->
p_sectors
[
p_sys
->
i_track
];
p_input
->
stream
.
p_selected_area
->
i_tell
=
(
off_t
)
p_
vcd
->
i_sector
*
(
off_t
)
VCD_DATA_SIZE
(
off_t
)
p_
sys
->
i_sector
*
(
off_t
)
VCD_DATA_SIZE
-
p_input
->
stream
.
p_selected_area
->
i_start
;
/* warn interface that something has changed */
...
...
@@ -447,22 +418,20 @@ static int VCDSetArea( input_thread_t * p_input, input_area_t * p_area )
****************************************************************************/
static
void
VCDSeek
(
input_thread_t
*
p_input
,
off_t
i_off
)
{
thread_vcd_data_t
*
p_vcd
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
unsigned
int
i_index
;
p_vcd
=
(
thread_vcd_data_t
*
)
p_input
->
p_access_data
;
p_vcd
->
i_sector
=
p_vcd
->
p_sectors
[
p_vcd
->
i_track
]
p_sys
->
i_sector
=
p_sys
->
p_sectors
[
p_sys
->
i_track
]
+
i_off
/
(
off_t
)
VCD_DATA_SIZE
;
vlc_mutex_lock
(
&
p_input
->
stream
.
stream_lock
);
#define p_area p_input->stream.p_selected_area
/* Find chapter */
if
(
p_
vcd
->
b_valid_ep
)
if
(
p_
sys
->
b_valid_ep
)
{
for
(
i_index
=
2
;
i_index
<=
p_area
->
i_part_nb
;
i_index
++
)
{
if
(
p_
vcd
->
i_sector
<
p_vcd
->
p_entries
[
p_area
->
i_plugin_data
if
(
p_
sys
->
i_sector
<
p_sys
->
p_entries
[
p_area
->
i_plugin_data
+
i_index
-
1
]
)
{
vlc_value_t
val
;
...
...
@@ -480,7 +449,7 @@ static void VCDSeek( input_thread_t * p_input, off_t i_off )
#undef p_area
p_input
->
stream
.
p_selected_area
->
i_tell
=
(
off_t
)
p_
vcd
->
i_sector
*
(
off_t
)
VCD_DATA_SIZE
(
off_t
)
p_
sys
->
i_sector
*
(
off_t
)
VCD_DATA_SIZE
-
p_input
->
stream
.
p_selected_area
->
i_start
;
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
}
...
...
@@ -490,15 +459,13 @@ static void VCDSeek( input_thread_t * p_input, off_t i_off )
*****************************************************************************/
static
int
VCDEntryPoints
(
input_thread_t
*
p_input
)
{
thread_vcd_data_t
*
p_vcd
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
byte_t
*
p_sector
;
entries_sect_t
entries
;
uint16_t
i_nb
;
int
i
,
i_entry_index
=
0
;
int
i_previous_track
=
-
1
;
p_vcd
=
(
thread_vcd_data_t
*
)
p_input
->
p_access_data
;
p_sector
=
malloc
(
VCD_DATA_SIZE
*
sizeof
(
byte_t
)
);
if
(
p_sector
==
NULL
)
{
...
...
@@ -506,7 +473,7 @@ static int VCDEntryPoints( input_thread_t * p_input )
return
-
1
;
}
if
(
ioctl_ReadSectors
(
VLC_OBJECT
(
p_input
),
p_
vcd
->
vcddev
,
if
(
ioctl_ReadSectors
(
VLC_OBJECT
(
p_input
),
p_
sys
->
vcddev
,
VCD_ENTRIES_SECTOR
,
p_sector
,
1
,
VCD_TYPE
)
<
0
)
{
msg_Err
(
p_input
,
"could not read entry points sector"
);
...
...
@@ -523,8 +490,8 @@ static int VCDEntryPoints( input_thread_t * p_input )
return
(
-
1
);
}
p_
vcd
->
p_entries
=
malloc
(
sizeof
(
int
)
*
i_nb
);
if
(
p_
vcd
->
p_entries
==
NULL
)
p_
sys
->
p_entries
=
malloc
(
sizeof
(
int
)
*
i_nb
);
if
(
p_
sys
->
p_entries
==
NULL
)
{
msg_Err
(
p_input
,
"not enough memory for entry points treatment"
);
return
-
1
;
...
...
@@ -534,11 +501,11 @@ static int VCDEntryPoints( input_thread_t * p_input )
&&
strncmp
(
entries
.
psz_id
,
"ENTRYSVD"
,
sizeof
(
entries
.
psz_id
)
))
{
msg_Err
(
p_input
,
"unrecognized entry points format"
);
free
(
p_
vcd
->
p_entries
);
free
(
p_
sys
->
p_entries
);
return
-
1
;
}
p_
vcd
->
i_entries_nb
=
0
;
p_
sys
->
i_entries_nb
=
0
;
#define i_track BCD_TO_BIN(entries.entry[i].i_track)
/* Reset the i_part_nb for each track */
...
...
@@ -554,7 +521,7 @@ static int VCDEntryPoints( input_thread_t * p_input )
{
if
(
i_track
<=
p_input
->
stream
.
i_area_nb
)
{
p_
vcd
->
p_entries
[
i_entry_index
]
=
p_
sys
->
p_entries
[
i_entry_index
]
=
(
MSF_TO_LBA2
(
BCD_TO_BIN
(
entries
.
entry
[
i
].
msf
.
minute
),
BCD_TO_BIN
(
entries
.
entry
[
i
].
msf
.
second
),
BCD_TO_BIN
(
entries
.
entry
[
i
].
msf
.
frame
)
));
...
...
@@ -568,10 +535,10 @@ static int VCDEntryPoints( input_thread_t * p_input )
i_previous_track
=
i_track
;
}
msg_Dbg
(
p_input
,
"entry point %i begins at LBA: %i"
,
i_entry_index
,
p_
vcd
->
p_entries
[
i_entry_index
]
);
i_entry_index
,
p_
sys
->
p_entries
[
i_entry_index
]
);
i_entry_index
++
;
p_
vcd
->
i_entries_nb
++
;
p_
sys
->
i_entries_nb
++
;
}
else
msg_Warn
(
p_input
,
"wrong track number found in entry points"
);
...
...
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