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
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
Show 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
)
/* Command line: vcd://[dev_path][@title[,chapter]] */
if
(
(
psz
=
strchr
(
psz_dup
,
'@'
)
)
)
{
return
(
-
1
);
}
*
psz
++
=
'\0'
;
while
(
*
psz_parser
&&
*
psz_parser
!=
'@'
)
i_title
=
strtol
(
psz
,
&
psz
,
0
);
if
(
*
psz
)
{
psz_parser
++
;
i_chapter
=
strtol
(
psz
,
&
psz
,
0
);
}
}
if
(
*
psz_parser
==
'@'
)
{
/* Found options */
*
psz_parser
=
'\0'
;
++
psz_parser
;
i_title
=
(
int
)
strtol
(
psz_parser
,
&
psz_next
,
10
);
if
(
*
psz_next
)
if
(
*
psz_dup
==
'\0'
)
{
psz_parser
=
psz_next
+
1
;
i_chapter
=
(
int
)
strtol
(
psz_parser
,
&
psz_next
,
10
);
}
free
(
psz_dup
);
i_title
=
i_title
>
0
?
i_title
:
1
;
i
_chapter
=
i_chapter
>
0
?
i_chapter
:
1
;
}
/* Only when selected */
i
f
(
*
p_input
->
psz_access
==
'\0'
)
return
VLC_EGENERIC
;
if
(
!*
psz_source
)
{
if
(
!
p_input
->
psz_access
)
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