Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
a64ee2c3
Commit
a64ee2c3
authored
Apr 25, 2005
by
Steve Lhomme
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mkv.cpp: add support for new DVD commands, add more debug messages
parent
aa10b381
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
217 additions
and
29 deletions
+217
-29
modules/demux/mkv.cpp
modules/demux/mkv.cpp
+217
-29
No files found.
modules/demux/mkv.cpp
View file @
a64ee2c3
...
@@ -343,8 +343,9 @@ const binary MATROSKA_DVD_LEVEL_CN = 0x08;
...
@@ -343,8 +343,9 @@ const binary MATROSKA_DVD_LEVEL_CN = 0x08;
class
chapter_codec_cmds_c
class
chapter_codec_cmds_c
{
{
public:
public:
chapter_codec_cmds_c
(
int
codec_id
=
-
1
)
chapter_codec_cmds_c
(
demux_sys_t
&
demuxer
,
int
codec_id
=
-
1
)
:
i_codec_id
(
codec_id
)
:
i_codec_id
(
codec_id
)
,
sys
(
demuxer
)
{}
{}
virtual
~
chapter_codec_cmds_c
()
{}
virtual
~
chapter_codec_cmds_c
()
{}
...
@@ -369,6 +370,7 @@ protected:
...
@@ -369,6 +370,7 @@ protected:
std
::
vector
<
KaxChapterProcessData
>
leave_cmds
;
std
::
vector
<
KaxChapterProcessData
>
leave_cmds
;
int
i_codec_id
;
int
i_codec_id
;
demux_sys_t
&
sys
;
};
};
class
dvd_command_interpretor_c
class
dvd_command_interpretor_c
...
@@ -377,41 +379,57 @@ public:
...
@@ -377,41 +379,57 @@ public:
dvd_command_interpretor_c
(
demux_sys_t
&
demuxer
)
dvd_command_interpretor_c
(
demux_sys_t
&
demuxer
)
:
sys
(
demuxer
)
:
sys
(
demuxer
)
{
{
memset
(
p_GPRM
,
0
,
sizeof
(
p_GPRM
)
);
memset
(
p_PRMs
,
0
,
sizeof
(
p_PRMs
)
);
memset
(
p_SPRM
,
0
,
sizeof
(
p_SPRM
)
);
p_PRMs
[
0x80
+
1
]
=
15
;
p_SPRM
[
1
]
=
15
;
p_PRMs
[
0x80
+
2
]
=
62
;
p_SPRM
[
2
]
=
62
;
p_PRMs
[
0x80
+
3
]
=
1
;
p_SPRM
[
3
]
=
1
;
p_PRMs
[
0x80
+
4
]
=
1
;
p_SPRM
[
4
]
=
1
;
p_PRMs
[
0x80
+
7
]
=
1
;
p_SPRM
[
7
]
=
1
;
p_PRMs
[
0x80
+
8
]
=
1
;
p_SPRM
[
8
]
=
1
;
p_PRMs
[
0x80
+
16
]
=
0xFFFFu
;
p_SPRM
[
16
]
=
0xFFFFu
;
p_PRMs
[
0x80
+
18
]
=
0xFFFFu
;
p_SPRM
[
18
]
=
0xFFFFu
;
}
}
bool
Interpret
(
const
binary
*
p_command
,
size_t
i_size
=
8
);
bool
Interpret
(
const
binary
*
p_command
,
size_t
i_size
=
8
);
protected:
protected:
uint16
GetPRM
(
size_t
index
)
const
{
if
(
index
<
256
)
return
p_PRMs
[
index
];
else
return
0
;
}
uint16
GetGPRM
(
size_t
index
)
const
uint16
GetGPRM
(
size_t
index
)
const
{
{
if
(
index
>=
0
&&
index
<
16
)
if
(
index
>=
0
&&
index
<
16
)
return
p_
GPRM
[
index
];
return
p_
PRMs
[
index
];
else
return
0
;
else
return
0
;
}
}
uint16
GetSPRM
(
size_t
index
)
const
uint16
GetSPRM
(
size_t
index
)
const
{
{
// 21,22,23 reserved for future use
// 21,22,23 reserved for future use
if
(
index
>=
0
&&
index
<
21
)
if
(
index
>=
0
x80
&&
index
<
0x95
)
return
p_
SPRM
[
index
];
return
p_
PRMs
[
index
];
else
return
0
;
else
return
0
;
}
}
bool
SetPRM
(
size_t
index
,
uint16
value
)
{
if
(
index
>=
0
&&
index
<
16
)
{
p_PRMs
[
index
]
=
value
;
return
true
;
}
return
false
;
}
bool
SetGPRM
(
size_t
index
,
uint16
value
)
bool
SetGPRM
(
size_t
index
,
uint16
value
)
{
{
if
(
index
>=
0
&&
index
<
16
)
if
(
index
>=
0
&&
index
<
16
)
{
{
p_
GPRM
[
index
]
=
value
;
p_
PRMs
[
index
]
=
value
;
return
true
;
return
true
;
}
}
return
false
;
return
false
;
...
@@ -419,21 +437,89 @@ protected:
...
@@ -419,21 +437,89 @@ protected:
bool
SetSPRM
(
size_t
index
,
uint16
value
)
bool
SetSPRM
(
size_t
index
,
uint16
value
)
{
{
if
(
index
>
0
&&
index
<=
13
&&
index
!=
12
)
if
(
index
>
0
x80
&&
index
<=
0x8D
&&
index
!=
0x8C
)
{
{
p_
SPRM
[
index
]
=
value
;
p_
PRMs
[
index
]
=
value
;
return
true
;
return
true
;
}
}
return
false
;
return
false
;
}
}
uint16
p_GPRM
[
16
];
std
::
string
GetRegTypeName
(
bool
b_value
,
uint16
value
)
const
uint16
p_SPRM
[
24
];
{
std
::
string
result
;
char
s_value
[
6
],
s_reg_value
[
6
];
itoa
(
value
,
s_value
,
10
);
if
(
b_value
)
{
result
=
"value ("
;
result
+=
s_value
;
result
+=
")"
;
}
else
if
(
value
<
0x80
)
{
itoa
(
GetPRM
(
value
)
,
s_reg_value
,
10
);
result
=
"GPreg["
;
result
+=
s_value
;
result
+=
"] ("
;
result
+=
s_reg_value
;
result
+=
")"
;
}
else
{
itoa
(
GetPRM
(
value
)
,
s_reg_value
,
10
);
result
=
"SPreg["
;
result
+=
s_value
;
result
+=
"] ("
;
result
+=
s_reg_value
;
result
+=
")"
;
}
return
result
;
}
uint16
p_PRMs
[
256
];
demux_sys_t
&
sys
;
demux_sys_t
&
sys
;
// DVD command IDs
// DVD command IDs
static
const
uint16
CMD_JUMP_TT
=
0x3002
;
static
const
uint16
CMD_CALLSS_VTSM
=
0x3008
;
// Tests
// wether the test has to be positive or not
static
const
uint16
CMD_DVD_IF_NOT
=
0x10
;
// wether it's a comparison on the value or register
static
const
uint16
CMD_DVD_TEST_VALUE
=
0x80
;
static
const
uint16
CMD_DVD_IF_GPREG_AND
=
(
0
<<
5
);
static
const
uint16
CMD_DVD_IF_GPREG_EQUAL
=
(
1
<<
5
);
static
const
uint16
CMD_DVD_IF_GPREG_SUP_EQUAL
=
(
2
<<
5
);
static
const
uint16
CMD_DVD_IF_GPREG_INF
=
(
3
<<
5
);
static
const
uint16
CMD_DVD_NOP
=
0x0000
;
static
const
uint16
CMD_DVD_GOTO_LINE
=
0x0001
;
static
const
uint16
CMD_DVD_BREAK
=
0x0002
;
// Links
static
const
uint16
CMD_DVD_NOP2
=
0x2001
;
static
const
uint16
CMD_DVD_LINKPGCN
=
0x2004
;
static
const
uint16
CMD_DVD_LINKPGN
=
0x2006
;
static
const
uint16
CMD_DVD_LINKCN
=
0x2007
;
static
const
uint16
CMD_DVD_JUMP_TT
=
0x3002
;
static
const
uint16
CMD_DVD_JUMPVTS_TT
=
0x3003
;
static
const
uint16
CMD_DVD_JUMP_SS
=
0x3006
;
static
const
uint16
CMD_DVD_CALLSS_VTSM1
=
0x3008
;
//
static
const
uint16
CMD_DVD_SET_HL_BTNN2
=
0x4600
;
static
const
uint16
CMD_DVD_SET_HL_BTNN_LINKPGCN1
=
0x4604
;
static
const
uint16
CMD_DVD_SET_AUDIO
=
0x5100
;
static
const
uint16
CMD_DVD_SET_GPRMMD
=
0x5300
;
static
const
uint16
CMD_DVD_SET_HL_BTNN1
=
0x5600
;
static
const
uint16
CMD_DVD_SET_HL_BTNN_LINKPGCN2
=
0x5604
;
static
const
uint16
CMD_DVD_SET_HL_BTNN_LINKCN
=
0x5607
;
// Operations
static
const
uint16
CMD_DVD_MOV_SPREG_PREG
=
0x6100
;
static
const
uint16
CMD_DVD_GPREG_MOV_VALUE
=
0x7100
;
static
const
uint16
CMD_DVD_SUB_GPREG
=
0x7400
;
static
const
uint16
CMD_DVD_MULT_GPREG
=
0x7500
;
static
const
uint16
CMD_DVD_GPREG_DIV_VALUE
=
0x7600
;
static
const
uint16
CMD_DVD_GPREG_AND_VALUE
=
0x7900
;
// callbacks when browsing inside CodecPrivate
// callbacks when browsing inside CodecPrivate
static
bool
MatchTitleNumber
(
const
chapter_codec_cmds_c
&
data
,
const
void
*
p_cookie
,
size_t
i_cookie_size
);
static
bool
MatchTitleNumber
(
const
chapter_codec_cmds_c
&
data
,
const
void
*
p_cookie
,
size_t
i_cookie_size
);
...
@@ -444,7 +530,7 @@ class dvd_chapter_codec_c : public chapter_codec_cmds_c
...
@@ -444,7 +530,7 @@ class dvd_chapter_codec_c : public chapter_codec_cmds_c
{
{
public:
public:
dvd_chapter_codec_c
(
demux_sys_t
&
sys
)
dvd_chapter_codec_c
(
demux_sys_t
&
sys
)
:
chapter_codec_cmds_c
(
1
)
:
chapter_codec_cmds_c
(
sys
,
1
)
,
interpretor
(
sys
)
,
interpretor
(
sys
)
{}
{}
...
@@ -479,7 +565,7 @@ class matroska_script_codec_c : public chapter_codec_cmds_c
...
@@ -479,7 +565,7 @@ class matroska_script_codec_c : public chapter_codec_cmds_c
{
{
public:
public:
matroska_script_codec_c
(
demux_sys_t
&
sys
)
matroska_script_codec_c
(
demux_sys_t
&
sys
)
:
chapter_codec_cmds_c
(
0
)
:
chapter_codec_cmds_c
(
sys
,
0
)
,
interpretor
(
sys
)
,
interpretor
(
sys
)
{}
{}
...
@@ -4504,6 +4590,7 @@ bool dvd_chapter_codec_c::Enter()
...
@@ -4504,6 +4590,7 @@ bool dvd_chapter_codec_c::Enter()
i_size
=
min
(
i_size
,
((
*
index
).
GetSize
()
-
1
)
>>
3
);
i_size
=
min
(
i_size
,
((
*
index
).
GetSize
()
-
1
)
>>
3
);
for
(
;
i_size
>
0
;
i_size
--
,
p_data
+=
8
)
for
(
;
i_size
>
0
;
i_size
--
,
p_data
+=
8
)
{
{
msg_Dbg
(
&
sys
.
demuxer
,
"Matroska DVD enter command"
);
f_result
|=
interpretor
.
Interpret
(
p_data
);
f_result
|=
interpretor
.
Interpret
(
p_data
);
}
}
}
}
...
@@ -4526,6 +4613,7 @@ bool dvd_chapter_codec_c::Leave()
...
@@ -4526,6 +4613,7 @@ bool dvd_chapter_codec_c::Leave()
i_size
=
min
(
i_size
,
((
*
index
).
GetSize
()
-
1
)
>>
3
);
i_size
=
min
(
i_size
,
((
*
index
).
GetSize
()
-
1
)
>>
3
);
for
(
;
i_size
>
0
;
i_size
--
,
p_data
+=
8
)
for
(
;
i_size
>
0
;
i_size
--
,
p_data
+=
8
)
{
{
msg_Dbg
(
&
sys
.
demuxer
,
"Matroska DVD leave command"
);
f_result
|=
interpretor
.
Interpret
(
p_data
);
f_result
|=
interpretor
.
Interpret
(
p_data
);
}
}
}
}
...
@@ -4545,12 +4633,80 @@ bool dvd_command_interpretor_c::Interpret( const binary * p_command, size_t i_si
...
@@ -4545,12 +4633,80 @@ bool dvd_command_interpretor_c::Interpret( const binary * p_command, size_t i_si
bool
f_result
=
false
;
bool
f_result
=
false
;
uint16
i_command
=
(
p_command
[
0
]
<<
8
)
+
p_command
[
1
];
uint16
i_command
=
(
p_command
[
0
]
<<
8
)
+
p_command
[
1
];
// handle register tests if there are some
if
(
(
i_command
&
0xF0
)
!=
0
)
{
bool
b_test_positive
=
(
i_command
&
CMD_DVD_IF_NOT
)
==
0
;
bool
b_test_value
=
(
i_command
&
CMD_DVD_TEST_VALUE
)
!=
0
;
uint8
i_test
=
i_command
&
0x70
;
uint16
i_value
;
if
(
b_test_value
)
i_value
=
(
p_command
[
4
]
<<
8
)
+
p_command
[
5
];
else
i_value
=
GetPRM
(
p_command
[
7
]
);
switch
(
i_test
)
{
case
CMD_DVD_IF_GPREG_EQUAL
:
// if equals
msg_Dbg
(
&
sys
.
demuxer
,
"IF %s EQUALS %s"
,
GetRegTypeName
(
false
,
p_command
[
3
]
).
c_str
(),
GetRegTypeName
(
b_test_value
,
i_value
).
c_str
()
);
if
(
!
(
GetPRM
(
p_command
[
3
]
)
==
i_value
))
{
b_test_positive
=
!
b_test_positive
;
}
break
;
case
CMD_DVD_IF_GPREG_INF
:
// if inferior
msg_Dbg
(
&
sys
.
demuxer
,
"IF %s < %s"
,
GetRegTypeName
(
false
,
p_command
[
3
]
).
c_str
(),
GetRegTypeName
(
b_test_value
,
i_value
).
c_str
()
);
if
(
!
(
GetPRM
(
p_command
[
3
]
)
<
i_value
))
{
b_test_positive
=
!
b_test_positive
;
}
break
;
case
CMD_DVD_IF_GPREG_AND
:
// if logical and
msg_Dbg
(
&
sys
.
demuxer
,
"IF %s & %s"
,
GetRegTypeName
(
false
,
p_command
[
3
]
).
c_str
(),
GetRegTypeName
(
b_test_value
,
i_value
).
c_str
()
);
if
(
!
(
GetPRM
(
p_command
[
3
]
)
&
i_value
))
{
b_test_positive
=
!
b_test_positive
;
}
break
;
case
CMD_DVD_IF_GPREG_SUP_EQUAL
:
// if superior or equal
msg_Dbg
(
&
sys
.
demuxer
,
"IF %s >= %s"
,
GetRegTypeName
(
false
,
p_command
[
3
]
).
c_str
(),
GetRegTypeName
(
b_test_value
,
i_value
).
c_str
()
);
if
(
!
(
GetPRM
(
p_command
[
3
]
)
>=
i_value
))
{
b_test_positive
=
!
b_test_positive
;
}
break
;
}
if
(
!
b_test_positive
)
return
false
;
}
// strip the test command
i_command
&=
0xFF0F
;
switch
(
i_command
)
switch
(
i_command
)
{
{
case
CMD_JUMP_TT
:
case
CMD_DVD_NOP
:
case
CMD_DVD_NOP2
:
{
msg_Dbg
(
&
sys
.
demuxer
,
"NOP"
);
break
;
}
case
CMD_DVD_BREAK
:
{
msg_Dbg
(
&
sys
.
demuxer
,
"Break"
);
// TODO
break
;
}
case
CMD_DVD_JUMP_TT
:
{
{
uint8
i_title
=
p_command
[
5
];
uint8
i_title
=
p_command
[
5
];
msg_Dbg
(
&
sys
.
demuxer
,
"
DVD command:
JumpTT %d"
,
i_title
);
msg_Dbg
(
&
sys
.
demuxer
,
"JumpTT %d"
,
i_title
);
// find in the ChapProcessPrivate matching this Title level
// find in the ChapProcessPrivate matching this Title level
p_chapter
=
sys
.
BrowseCodecPrivate
(
1
,
MatchTitleNumber
,
&
i_title
,
sizeof
(
i_title
),
p_segment
);
p_chapter
=
sys
.
BrowseCodecPrivate
(
1
,
MatchTitleNumber
,
&
i_title
,
sizeof
(
i_title
),
p_segment
);
...
@@ -4571,9 +4727,9 @@ bool dvd_command_interpretor_c::Interpret( const binary * p_command, size_t i_si
...
@@ -4571,9 +4727,9 @@ bool dvd_command_interpretor_c::Interpret( const binary * p_command, size_t i_si
break
;
break
;
}
}
case
CMD_
CALLSS_VTSM
:
case
CMD_
DVD_CALLSS_VTSM1
:
{
{
msg_Dbg
(
&
sys
.
demuxer
,
"
DVD command:
CallSS VTSM"
);
msg_Dbg
(
&
sys
.
demuxer
,
"CallSS VTSM"
);
switch
(
(
p_command
[
6
]
&
0xC0
)
>>
6
)
{
switch
(
(
p_command
[
6
]
&
0xC0
)
>>
6
)
{
case
0
:
case
0
:
switch
(
p_command
[
5
]
)
switch
(
p_command
[
5
]
)
...
@@ -4631,9 +4787,38 @@ bool dvd_command_interpretor_c::Interpret( const binary * p_command, size_t i_si
...
@@ -4631,9 +4787,38 @@ bool dvd_command_interpretor_c::Interpret( const binary * p_command, size_t i_si
}
}
break
;
break
;
}
}
case
CMD_DVD_SET_GPRMMD
:
{
msg_Dbg
(
&
sys
.
demuxer
,
"Set GPRMMD [%d]=%d"
,
(
p_command
[
4
]
<<
8
)
+
p_command
[
5
],
(
p_command
[
2
]
<<
8
)
+
p_command
[
3
]);
if
(
!
SetGPRM
(
(
p_command
[
4
]
<<
8
)
+
p_command
[
5
],
(
p_command
[
2
]
<<
8
)
+
p_command
[
3
]
)
)
msg_Dbg
(
&
sys
.
demuxer
,
"Set GPRMMD failed"
);
break
;
}
case
CMD_DVD_LINKPGCN
:
{
uint16
i_pgcn
=
(
p_command
[
6
]
<<
8
)
+
p_command
[
7
];
msg_Dbg
(
&
sys
.
demuxer
,
"Link PGCN(%d)"
,
i_pgcn
);
// TODO
break
;
}
case
CMD_DVD_LINKCN
:
{
msg_Dbg
(
&
sys
.
demuxer
,
"LinkCN (cell %d)"
,
(
p_command
[
6
]
<<
8
)
+
p_command
[
7
]
);
// TODO
f_result
=
true
;
break
;
}
case
CMD_DVD_GOTO_LINE
:
{
msg_Dbg
(
&
sys
.
demuxer
,
"GotoLine (%d)"
,
(
p_command
[
6
]
<<
8
)
+
p_command
[
7
]
);
// TODO
break
;
}
default:
default:
{
{
msg_Dbg
(
&
sys
.
demuxer
,
"
DVD command: unsupported
%02X %02X %02X %02X %02X %02X %02X %02X"
msg_Dbg
(
&
sys
.
demuxer
,
"
unsupported command :
%02X %02X %02X %02X %02X %02X %02X %02X"
,
p_command
[
0
]
,
p_command
[
0
]
,
p_command
[
1
]
,
p_command
[
1
]
,
p_command
[
2
]
,
p_command
[
2
]
...
@@ -4685,6 +4870,7 @@ bool matroska_script_codec_c::Enter()
...
@@ -4685,6 +4870,7 @@ bool matroska_script_codec_c::Enter()
{
{
if
(
(
*
index
).
GetSize
()
)
if
(
(
*
index
).
GetSize
()
)
{
{
msg_Dbg
(
&
sys
.
demuxer
,
"Matroska Script enter command"
);
f_result
|=
interpretor
.
Interpret
(
(
*
index
).
GetBuffer
(),
(
*
index
).
GetSize
()
);
f_result
|=
interpretor
.
Interpret
(
(
*
index
).
GetBuffer
(),
(
*
index
).
GetSize
()
);
}
}
index
++
;
index
++
;
...
@@ -4700,6 +4886,7 @@ bool matroska_script_codec_c::Leave()
...
@@ -4700,6 +4886,7 @@ bool matroska_script_codec_c::Leave()
{
{
if
(
(
*
index
).
GetSize
()
)
if
(
(
*
index
).
GetSize
()
)
{
{
msg_Dbg
(
&
sys
.
demuxer
,
"Matroska Script leave command"
);
f_result
|=
interpretor
.
Interpret
(
(
*
index
).
GetBuffer
(),
(
*
index
).
GetSize
()
);
f_result
|=
interpretor
.
Interpret
(
(
*
index
).
GetBuffer
(),
(
*
index
).
GetSize
()
);
}
}
index
++
;
index
++
;
...
@@ -4718,8 +4905,9 @@ bool matroska_script_interpretor_c::Interpret( const binary * p_command, size_t
...
@@ -4718,8 +4905,9 @@ bool matroska_script_interpretor_c::Interpret( const binary * p_command, size_t
psz_str
[
i_size
]
=
'\0'
;
psz_str
[
i_size
]
=
'\0'
;
std
::
string
sz_command
=
psz_str
;
std
::
string
sz_command
=
psz_str
;
free
(
psz_str
);
msg_Dbg
(
&
sys
.
demuxer
,
"
Matroska Script
command : %s"
,
sz_command
.
c_str
()
);
msg_Dbg
(
&
sys
.
demuxer
,
"command : %s"
,
sz_command
.
c_str
()
);
if
(
sz_command
.
compare
(
0
,
CMD_MS_GOTO_AND_PLAY
.
size
(),
CMD_MS_GOTO_AND_PLAY
)
==
0
)
if
(
sz_command
.
compare
(
0
,
CMD_MS_GOTO_AND_PLAY
.
size
(),
CMD_MS_GOTO_AND_PLAY
)
==
0
)
{
{
...
...
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