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
eed30019
Commit
eed30019
authored
Jan 04, 2004
by
Rocky Bernstein
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Was putting 1 byte of garbage for each packet.
parent
a9bd5d7e
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
163 additions
and
158 deletions
+163
-158
modules/codec/ogt/cvd.c
modules/codec/ogt/cvd.c
+4
-153
modules/codec/ogt/cvd.h
modules/codec/ogt/cvd.h
+2
-2
modules/codec/ogt/cvd_parse.c
modules/codec/ogt/cvd_parse.c
+155
-1
modules/codec/ogt/subtitle.h
modules/codec/ogt/subtitle.h
+2
-2
No files found.
modules/codec/ogt/cvd.c
View file @
eed30019
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* cvd.c : CVD Subtitle decoder thread
* cvd.c : CVD Subtitle decoder thread
*****************************************************************************
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* Copyright (C) 2003 VideoLAN
* $Id: cvd.c,v 1.
6 2004/01/03 12:54:56
rocky Exp $
* $Id: cvd.c,v 1.
7 2004/01/04 04:56:21
rocky Exp $
*
*
* Authors: Rocky Bernstein
* Authors: Rocky Bernstein
* based on code from:
* based on code from:
...
@@ -243,164 +243,15 @@ Reassemble( decoder_t *p_dec, block_t **pp_block )
...
@@ -243,164 +243,15 @@ Reassemble( decoder_t *p_dec, block_t **pp_block )
}
}
/* FIXME - remove append_data and use chainappend */
/* FIXME - remove append_data and use chainappend */
VCDSubAppendData
(
p_dec
,
p_buffer
,
p_block
->
i_buffer
-
SPU_HEADER_LEN
);
VCDSubAppendData
(
p_dec
,
p_buffer
+
SPU_HEADER_LEN
,
p_block
->
i_buffer
-
SPU_HEADER_LEN
);
block_ChainAppend
(
&
p_sys
->
p_block
,
p_block
);
block_ChainAppend
(
&
p_sys
->
p_block
,
p_block
);
p_sys
->
i_spu
+=
p_block
->
i_buffer
-
SPU_HEADER_LEN
;
p_sys
->
i_spu
+=
p_block
->
i_buffer
-
SPU_HEADER_LEN
;
if
(
p_sys
->
subtitle_data_pos
==
p_sys
->
i_spu_size
)
{
if
(
p_sys
->
subtitle_data_pos
==
p_sys
->
i_spu_size
)
{
/* last packet in subtitle block. */
E_
(
ParseMetaInfo
)(
p_dec
);
uint8_t
*
p
=
p_sys
->
subtitle_data
+
p_sys
->
metadata_offset
+
1
;
uint8_t
*
p_end
=
p
+
p_sys
->
metadata_length
;
dbg_print
(
(
DECODE_DBG_PACKET
),
"subtitle packet complete, size=%d"
,
p_sys
->
i_spu
);
p_sys
->
state
=
SUBTITLE_BLOCK_COMPLETE
;
p_sys
->
i_image
++
;
for
(
;
p
<
p_end
;
p
+=
4
)
{
switch
(
p
[
0
]
)
{
case
0x04
:
/* Display duration in 1/90000ths of a second */
p_sys
->
i_duration
=
(
p
[
1
]
<<
16
)
+
(
p
[
2
]
<<
8
)
+
p
[
3
];
dbg_print
(
DECODE_DBG_PACKET
,
"subtitle display duration %u"
,
p_sys
->
i_duration
);
break
;
case
0x0c
:
/* Unknown */
dbg_print
(
DECODE_DBG_PACKET
,
"subtitle command unknown 0x%0x 0x%0x 0x%0x 0x%0x
\n
"
,
p
[
0
],
p
[
1
],
p
[
2
],
p
[
3
]);
break
;
case
0x17
:
/* Position */
p_sys
->
i_x_start
=
((
p
[
1
]
&
0x0f
)
<<
6
)
+
(
p
[
2
]
>>
2
);
p_sys
->
i_y_start
=
((
p
[
2
]
&
0x03
)
<<
8
)
+
p
[
3
];
dbg_print
(
DECODE_DBG_PACKET
,
"start position (%d,%d): %.2x %.2x %.2x"
,
p_sys
->
i_x_start
,
p_sys
->
i_y_start
,
p
[
1
],
p
[
2
],
p
[
3
]
);
break
;
case
0x1f
:
/* Coordinates of the image bottom right */
{
int
lastx
=
((
p
[
1
]
&
0x0f
)
<<
6
)
+
(
p
[
2
]
>>
2
);
int
lasty
=
((
p
[
2
]
&
0x03
)
<<
8
)
+
p
[
3
];
p_sys
->
i_width
=
lastx
-
p_sys
->
i_x_start
+
1
;
p_sys
->
i_height
=
lasty
-
p_sys
->
i_y_start
+
1
;
dbg_print
(
DECODE_DBG_PACKET
,
"end position: (%d,%d): %.2x %.2x %.2x, w x h: %dx%d"
,
lastx
,
lasty
,
p
[
1
],
p
[
2
],
p
[
3
],
p_sys
->
i_width
,
p_sys
->
i_height
);
break
;
}
case
0x24
:
case
0x25
:
case
0x26
:
case
0x27
:
{
uint8_t
v
=
p
[
0
]
-
0x24
;
/* Primary Palette */
dbg_print
(
DECODE_DBG_PACKET
,
"primary palette %d (y,u,v): (0x%0x,0x%0x,0x%0x)"
,
v
,
p
[
1
],
p
[
2
],
p
[
3
]);
p_sys
->
p_palette
[
v
].
s
.
y
=
p
[
1
];
p_sys
->
p_palette
[
v
].
s
.
u
=
p
[
2
];
p_sys
->
p_palette
[
v
].
s
.
v
=
p
[
3
];
break
;
}
case
0x2c
:
case
0x2d
:
case
0x2e
:
case
0x2f
:
{
uint8_t
v
=
p
[
0
]
-
0x2c
;
dbg_print
(
DECODE_DBG_PACKET
,
"highlight palette %d (y,u,v): (0x%0x,0x%0x,0x%0x)"
,
v
,
p
[
1
],
p
[
2
],
p
[
3
]);
/* Highlight Palette */
p_sys
->
p_palette_highlight
[
v
].
s
.
y
=
p
[
1
];
p_sys
->
p_palette_highlight
[
v
].
s
.
u
=
p
[
2
];
p_sys
->
p_palette_highlight
[
v
].
s
.
v
=
p
[
3
];
break
;
}
case
0x37
:
/* transparency for primary palette */
p_sys
->
p_palette
[
0
].
s
.
t
=
p
[
3
]
&
0x0f
;
p_sys
->
p_palette
[
1
].
s
.
t
=
p
[
3
]
>>
4
;
p_sys
->
p_palette
[
2
].
s
.
t
=
p
[
2
]
&
0x0f
;
p_sys
->
p_palette
[
3
].
s
.
t
=
p
[
2
]
>>
4
;
dbg_print
(
DECODE_DBG_PACKET
,
"transparancy for primary palette 0..3: "
"0x%0x 0x%0x 0x%0x 0x%0x"
,
p_sys
->
p_palette
[
0
].
s
.
t
,
p_sys
->
p_palette
[
1
].
s
.
t
,
p_sys
->
p_palette
[
2
].
s
.
t
,
p_sys
->
p_palette
[
3
].
s
.
t
);
break
;
case
0x3f
:
/* transparency for highlight palette */
p_sys
->
p_palette_highlight
[
0
].
s
.
t
=
p
[
2
]
&
0x0f
;
p_sys
->
p_palette_highlight
[
1
].
s
.
t
=
p
[
2
]
>>
4
;
p_sys
->
p_palette_highlight
[
2
].
s
.
t
=
p
[
1
]
&
0x0f
;
p_sys
->
p_palette_highlight
[
3
].
s
.
t
=
p
[
1
]
>>
4
;
dbg_print
(
DECODE_DBG_PACKET
,
"transparancy for primary palette 0..3: "
"0x%0x 0x%0x 0x%0x 0x%0x"
,
p_sys
->
p_palette_highlight
[
0
].
s
.
t
,
p_sys
->
p_palette_highlight
[
1
].
s
.
t
,
p_sys
->
p_palette_highlight
[
2
].
s
.
t
,
p_sys
->
p_palette_highlight
[
3
].
s
.
t
);
break
;
case
0x47
:
/* offset to first field data, we correct to make it relative
to comp_image_offset (usually 4) */
p_sys
->
first_field_offset
=
(
p
[
2
]
<<
8
)
+
p
[
3
]
-
p_sys
->
comp_image_offset
;
dbg_print
(
DECODE_DBG_PACKET
,
"first_field_offset %d"
,
p_sys
->
first_field_offset
);
break
;
case
0x4f
:
/* offset to second field data, we correct to make it relative to
comp_image_offset (usually 4) */
p_sys
->
second_field_offset
=
(
p
[
2
]
<<
8
)
+
p
[
3
]
-
p_sys
->
comp_image_offset
;
dbg_print
(
DECODE_DBG_PACKET
,
"second_field_offset %d"
,
p_sys
->
second_field_offset
);
break
;
default:
msg_Warn
(
p_dec
,
"unknown sequence in control header "
"0x%0x 0x%0x 0x%0x 0x%0x"
,
p
[
0
],
p
[
1
],
p
[
2
],
p
[
3
]);
p_sys
->
subtitle_data_pos
=
0
;
}
}
return
p_sys
->
p_block
;
return
p_sys
->
p_block
;
}
else
{
}
else
{
/* Not last block in subtitle, so wait for another. */
/* Not last block in subtitle, so wait for another. */
...
...
modules/codec/ogt/cvd.h
View file @
eed30019
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* cvd.h : CVD subtitles decoder thread interface
* cvd.h : CVD subtitles decoder thread interface
*****************************************************************************
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* Copyright (C) 2003 VideoLAN
* $Id: cvd.h,v 1.
1 2003/12/28 04:51:52
rocky Exp $
* $Id: cvd.h,v 1.
2 2004/01/04 04:56:21
rocky Exp $
*
*
* Author: Rocky Bernstein
* Author: Rocky Bernstein
*
*
...
@@ -27,4 +27,4 @@
...
@@ -27,4 +27,4 @@
*****************************************************************************/
*****************************************************************************/
void
E_
(
ParseHeader
)(
decoder_t
*
,
uint8_t
*
,
block_t
*
);
void
E_
(
ParseHeader
)(
decoder_t
*
,
uint8_t
*
,
block_t
*
);
void
E_
(
ParsePacket
)(
decoder_t
*
);
void
E_
(
ParsePacket
)(
decoder_t
*
);
void
E_
(
ParseMetaInfo
)(
decoder_t
*
p_dec
);
modules/codec/ogt/cvd_parse.c
View file @
eed30019
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* parse.c: Philips OGT (SVCD subtitle) packet parser
* parse.c: Philips OGT (SVCD subtitle) packet parser
*****************************************************************************
*****************************************************************************
* Copyright (C) 2003, 2004 VideoLAN
* Copyright (C) 2003, 2004 VideoLAN
* $Id: cvd_parse.c,v 1.
5 2004/01/03 12:54:56
rocky Exp $
* $Id: cvd_parse.c,v 1.
6 2004/01/04 04:56:21
rocky Exp $
*
*
* Authors: Rocky Bernstein
* Authors: Rocky Bernstein
* based on code from:
* based on code from:
...
@@ -108,6 +108,160 @@ void E_(ParseHeader)( decoder_t *p_dec, uint8_t *p_buffer, block_t *p_block )
...
@@ -108,6 +108,160 @@ void E_(ParseHeader)( decoder_t *p_dec, uint8_t *p_buffer, block_t *p_block )
}
}
void
E_
(
ParseMetaInfo
)(
decoder_t
*
p_dec
)
{
/* last packet in subtitle block. */
decoder_sys_t
*
p_sys
=
p_dec
->
p_sys
;
uint8_t
*
p
=
p_sys
->
subtitle_data
+
p_sys
->
metadata_offset
;
uint8_t
*
p_end
=
p
+
p_sys
->
metadata_length
;
dbg_print
(
(
DECODE_DBG_PACKET
),
"subtitle packet complete, size=%d"
,
p_sys
->
i_spu
);
p_sys
->
state
=
SUBTITLE_BLOCK_COMPLETE
;
p_sys
->
i_image
++
;
for
(
;
p
<
p_end
;
p
+=
4
)
{
switch
(
p
[
0
]
)
{
case
0x04
:
/* Display duration in 1/90000ths of a second */
p_sys
->
i_duration
=
(
p
[
1
]
<<
16
)
+
(
p
[
2
]
<<
8
)
+
p
[
3
];
dbg_print
(
DECODE_DBG_PACKET
,
"subtitle display duration %u"
,
p_sys
->
i_duration
);
break
;
case
0x0c
:
/* Unknown */
dbg_print
(
DECODE_DBG_PACKET
,
"subtitle command unknown 0x%0x 0x%0x 0x%0x 0x%0x
\n
"
,
p
[
0
],
p
[
1
],
p
[
2
],
p
[
3
]);
break
;
case
0x17
:
/* Position */
p_sys
->
i_x_start
=
((
p
[
1
]
&
0x0f
)
<<
6
)
+
(
p
[
2
]
>>
2
);
p_sys
->
i_y_start
=
((
p
[
2
]
&
0x03
)
<<
8
)
+
p
[
3
];
dbg_print
(
DECODE_DBG_PACKET
,
"start position (%d,%d): %.2x %.2x %.2x"
,
p_sys
->
i_x_start
,
p_sys
->
i_y_start
,
p
[
1
],
p
[
2
],
p
[
3
]
);
break
;
case
0x1f
:
/* Coordinates of the image bottom right */
{
int
lastx
=
((
p
[
1
]
&
0x0f
)
<<
6
)
+
(
p
[
2
]
>>
2
);
int
lasty
=
((
p
[
2
]
&
0x03
)
<<
8
)
+
p
[
3
];
p_sys
->
i_width
=
lastx
-
p_sys
->
i_x_start
+
1
;
p_sys
->
i_height
=
lasty
-
p_sys
->
i_y_start
+
1
;
dbg_print
(
DECODE_DBG_PACKET
,
"end position: (%d,%d): %.2x %.2x %.2x, w x h: %dx%d"
,
lastx
,
lasty
,
p
[
1
],
p
[
2
],
p
[
3
],
p_sys
->
i_width
,
p_sys
->
i_height
);
break
;
}
case
0x24
:
case
0x25
:
case
0x26
:
case
0x27
:
{
uint8_t
v
=
p
[
0
]
-
0x24
;
/* Primary Palette */
dbg_print
(
DECODE_DBG_PACKET
,
"primary palette %d (y,u,v): (0x%0x,0x%0x,0x%0x)"
,
v
,
p
[
1
],
p
[
2
],
p
[
3
]);
p_sys
->
p_palette
[
v
].
s
.
y
=
p
[
1
];
p_sys
->
p_palette
[
v
].
s
.
u
=
p
[
2
];
p_sys
->
p_palette
[
v
].
s
.
v
=
p
[
3
];
break
;
}
case
0x2c
:
case
0x2d
:
case
0x2e
:
case
0x2f
:
{
uint8_t
v
=
p
[
0
]
-
0x2c
;
dbg_print
(
DECODE_DBG_PACKET
,
"highlight palette %d (y,u,v): (0x%0x,0x%0x,0x%0x)"
,
v
,
p
[
1
],
p
[
2
],
p
[
3
]);
/* Highlight Palette */
p_sys
->
p_palette_highlight
[
v
].
s
.
y
=
p
[
1
];
p_sys
->
p_palette_highlight
[
v
].
s
.
u
=
p
[
2
];
p_sys
->
p_palette_highlight
[
v
].
s
.
v
=
p
[
3
];
break
;
}
case
0x37
:
/* transparency for primary palette */
p_sys
->
p_palette
[
0
].
s
.
t
=
p
[
3
]
&
0x0f
;
p_sys
->
p_palette
[
1
].
s
.
t
=
p
[
3
]
>>
4
;
p_sys
->
p_palette
[
2
].
s
.
t
=
p
[
2
]
&
0x0f
;
p_sys
->
p_palette
[
3
].
s
.
t
=
p
[
2
]
>>
4
;
dbg_print
(
DECODE_DBG_PACKET
,
"transparancy for primary palette 0..3: "
"0x%0x 0x%0x 0x%0x 0x%0x"
,
p_sys
->
p_palette
[
0
].
s
.
t
,
p_sys
->
p_palette
[
1
].
s
.
t
,
p_sys
->
p_palette
[
2
].
s
.
t
,
p_sys
->
p_palette
[
3
].
s
.
t
);
break
;
case
0x3f
:
/* transparency for highlight palette */
p_sys
->
p_palette_highlight
[
0
].
s
.
t
=
p
[
2
]
&
0x0f
;
p_sys
->
p_palette_highlight
[
1
].
s
.
t
=
p
[
2
]
>>
4
;
p_sys
->
p_palette_highlight
[
2
].
s
.
t
=
p
[
1
]
&
0x0f
;
p_sys
->
p_palette_highlight
[
3
].
s
.
t
=
p
[
1
]
>>
4
;
dbg_print
(
DECODE_DBG_PACKET
,
"transparancy for primary palette 0..3: "
"0x%0x 0x%0x 0x%0x 0x%0x"
,
p_sys
->
p_palette_highlight
[
0
].
s
.
t
,
p_sys
->
p_palette_highlight
[
1
].
s
.
t
,
p_sys
->
p_palette_highlight
[
2
].
s
.
t
,
p_sys
->
p_palette_highlight
[
3
].
s
.
t
);
break
;
case
0x47
:
/* offset to first field data, we correct to make it relative
to comp_image_offset (usually 4) */
p_sys
->
first_field_offset
=
(
p
[
2
]
<<
8
)
+
p
[
3
]
-
p_sys
->
comp_image_offset
;
dbg_print
(
DECODE_DBG_PACKET
,
"first_field_offset %d"
,
p_sys
->
first_field_offset
);
break
;
case
0x4f
:
/* offset to second field data, we correct to make it relative to
comp_image_offset (usually 4) */
p_sys
->
second_field_offset
=
(
p
[
2
]
<<
8
)
+
p
[
3
]
-
p_sys
->
comp_image_offset
;
dbg_print
(
DECODE_DBG_PACKET
,
"second_field_offset %d"
,
p_sys
->
second_field_offset
);
break
;
default:
msg_Warn
(
p_dec
,
"unknown sequence in control header "
"0x%0x 0x%0x 0x%0x 0x%0x"
,
p
[
0
],
p
[
1
],
p
[
2
],
p
[
3
]);
p_sys
->
subtitle_data_pos
=
0
;
}
}
}
/*****************************************************************************
/*****************************************************************************
* ParsePacket: parse an SPU packet and send it to the video output
* ParsePacket: parse an SPU packet and send it to the video output
...
...
modules/codec/ogt/subtitle.h
View file @
eed30019
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* subtitle.h : Common SVCD and CVD subtitles header
* subtitle.h : Common SVCD and CVD subtitles header
*****************************************************************************
*****************************************************************************
* Copyright (C) 2003,2004 VideoLAN
* Copyright (C) 2003,2004 VideoLAN
* $Id: subtitle.h,v 1.
3 2004/01/03 12:54:56
rocky Exp $
* $Id: subtitle.h,v 1.
4 2004/01/04 04:56:21
rocky Exp $
*
*
* Author: Rocky Bernstein
* Author: Rocky Bernstein
* based on code from:
* based on code from:
...
@@ -76,8 +76,8 @@ typedef union {
...
@@ -76,8 +76,8 @@ typedef union {
uint8_t
plane
[
4
];
uint8_t
plane
[
4
];
struct
{
struct
{
uint8_t
y
;
uint8_t
y
;
uint8_t
u
;
uint8_t
v
;
uint8_t
v
;
uint8_t
u
;
uint8_t
t
;
uint8_t
t
;
}
s
;
}
s
;
}
ogt_yuvt_t
;
}
ogt_yuvt_t
;
...
...
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