Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
e7225aaa
Commit
e7225aaa
authored
Apr 11, 2024
by
Ziqing Hui
Committed by
Alexandre Julliard
Apr 29, 2024
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winegstreamer/video_decoder: Use video_decoder to implement wmv decoder.
parent
181b609f
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
57 additions
and
15 deletions
+57
-15
transform.c
dlls/mf/tests/transform.c
+56
-13
Makefile.in
dlls/winegstreamer/Makefile.in
+1
-2
video_decoder.c
dlls/winegstreamer/video_decoder.c
+0
-0
wmv_decoder.c
dlls/winegstreamer/wmv_decoder.c
+0
-0
No files found.
dlls/mf/tests/transform.c
View file @
e7225aaa
...
@@ -681,6 +681,7 @@ static void check_mft_set_input_type_required_(int line, IMFTransform *transform
...
@@ -681,6 +681,7 @@ static void check_mft_set_input_type_required_(int line, IMFTransform *transform
hr
=
IMFMediaType_DeleteItem
(
media_type
,
attr
->
key
);
hr
=
IMFMediaType_DeleteItem
(
media_type
,
attr
->
key
);
ok_
(
__FILE__
,
line
)(
hr
==
S_OK
,
"DeleteItem returned %#lx
\n
"
,
hr
);
ok_
(
__FILE__
,
line
)(
hr
==
S_OK
,
"DeleteItem returned %#lx
\n
"
,
hr
);
hr
=
IMFTransform_SetInputType
(
transform
,
0
,
media_type
,
MFT_SET_TYPE_TEST_ONLY
);
hr
=
IMFTransform_SetInputType
(
transform
,
0
,
media_type
,
MFT_SET_TYPE_TEST_ONLY
);
todo_wine_if
(
attr
->
todo
)
ok_
(
__FILE__
,
line
)(
FAILED
(
hr
)
==
attr
->
required
,
"SetInputType returned %#lx.
\n
"
,
hr
);
ok_
(
__FILE__
,
line
)(
FAILED
(
hr
)
==
attr
->
required
,
"SetInputType returned %#lx.
\n
"
,
hr
);
hr
=
IMFMediaType_SetItem
(
media_type
,
attr
->
key
,
&
attr
->
value
);
hr
=
IMFMediaType_SetItem
(
media_type
,
attr
->
key
,
&
attr
->
value
);
ok_
(
__FILE__
,
line
)(
hr
==
S_OK
,
"SetItem returned %#lx
\n
"
,
hr
);
ok_
(
__FILE__
,
line
)(
hr
==
S_OK
,
"SetItem returned %#lx
\n
"
,
hr
);
...
@@ -1285,7 +1286,7 @@ static DWORD check_mf_sample_(const char *file, int line, IMFSample *sample, con
...
@@ -1285,7 +1286,7 @@ static DWORD check_mf_sample_(const char *file, int line, IMFSample *sample, con
timestamp
=
0xdeadbeef
;
timestamp
=
0xdeadbeef
;
hr
=
IMFSample_GetSampleDuration
(
sample
,
&
timestamp
);
hr
=
IMFSample_GetSampleDuration
(
sample
,
&
timestamp
);
ok_
(
file
,
line
)(
hr
==
S_OK
,
"GetSampleDuration returned %#lx
\n
"
,
hr
);
ok_
(
file
,
line
)(
hr
==
S_OK
,
"GetSampleDuration returned %#lx
\n
"
,
hr
);
todo_wine_if
(
expect
->
todo_duration
&&
expect
->
todo_duration
==
timestamp
)
todo_wine_if
(
expect
->
todo_duration
)
ok_
(
file
,
line
)(
llabs
(
timestamp
-
expect
->
sample_duration
)
<=
1
,
ok_
(
file
,
line
)(
llabs
(
timestamp
-
expect
->
sample_duration
)
<=
1
,
"got sample duration %I64d
\n
"
,
timestamp
);
"got sample duration %I64d
\n
"
,
timestamp
);
...
@@ -5602,7 +5603,7 @@ static void test_wmv_decoder(void)
...
@@ -5602,7 +5603,7 @@ static void test_wmv_decoder(void)
ATTR_RATIO
(
MF_MT_PIXEL_ASPECT_RATIO
,
1
,
1
),
ATTR_RATIO
(
MF_MT_PIXEL_ASPECT_RATIO
,
1
,
1
),
ATTR_UINT32
(
MF_MT_ALL_SAMPLES_INDEPENDENT
,
1
),
ATTR_UINT32
(
MF_MT_ALL_SAMPLES_INDEPENDENT
,
1
),
ATTR_UINT32
(
MF_MT_FIXED_SIZE_SAMPLES
,
1
),
ATTR_UINT32
(
MF_MT_FIXED_SIZE_SAMPLES
,
1
),
ATTR_UINT32
(
MF_MT_INTERLACE_MODE
,
2
),
ATTR_UINT32
(
MF_MT_INTERLACE_MODE
,
2
,
.
todo_value
=
TRUE
),
{
0
},
{
0
},
};
};
const
media_type_desc
expect_available_outputs
[]
=
const
media_type_desc
expect_available_outputs
[]
=
...
@@ -5714,7 +5715,7 @@ static void test_wmv_decoder(void)
...
@@ -5714,7 +5715,7 @@ static void test_wmv_decoder(void)
{
{
ATTR_GUID
(
MF_MT_MAJOR_TYPE
,
MFMediaType_Video
,
.
required
=
TRUE
),
ATTR_GUID
(
MF_MT_MAJOR_TYPE
,
MFMediaType_Video
,
.
required
=
TRUE
),
ATTR_GUID
(
MF_MT_SUBTYPE
,
MFVideoFormat_WMV1
,
.
required
=
TRUE
),
ATTR_GUID
(
MF_MT_SUBTYPE
,
MFVideoFormat_WMV1
,
.
required
=
TRUE
),
ATTR_RATIO
(
MF_MT_FRAME_SIZE
,
actual_width
,
actual_height
,
.
required
=
TRUE
),
ATTR_RATIO
(
MF_MT_FRAME_SIZE
,
actual_width
,
actual_height
,
.
required
=
TRUE
,
.
todo
=
TRUE
),
{
0
},
{
0
},
};
};
const
struct
attribute_desc
output_type_desc
[]
=
const
struct
attribute_desc
output_type_desc
[]
=
...
@@ -5760,7 +5761,7 @@ static void test_wmv_decoder(void)
...
@@ -5760,7 +5761,7 @@ static void test_wmv_decoder(void)
ATTR_GUID
(
MF_MT_MAJOR_TYPE
,
MFMediaType_Video
),
ATTR_GUID
(
MF_MT_MAJOR_TYPE
,
MFMediaType_Video
),
ATTR_GUID
(
MF_MT_SUBTYPE
,
MFVideoFormat_WMV1
),
ATTR_GUID
(
MF_MT_SUBTYPE
,
MFVideoFormat_WMV1
),
ATTR_RATIO
(
MF_MT_FRAME_SIZE
,
actual_width
,
actual_height
),
ATTR_RATIO
(
MF_MT_FRAME_SIZE
,
actual_width
,
actual_height
),
ATTR_RATIO
(
MF_MT_PIXEL_ASPECT_RATIO
,
1
,
1
),
ATTR_RATIO
(
MF_MT_PIXEL_ASPECT_RATIO
,
1
,
1
,
.
todo
=
TRUE
),
{
0
},
{
0
},
};
};
const
struct
attribute_desc
expect_output_type_desc
[]
=
const
struct
attribute_desc
expect_output_type_desc
[]
=
...
@@ -5828,6 +5829,7 @@ static void test_wmv_decoder(void)
...
@@ -5828,6 +5829,7 @@ static void test_wmv_decoder(void)
.
cbSize
=
0x9000
,
.
cbSize
=
0x9000
,
.
cbAlignment
=
1
,
.
cbAlignment
=
1
,
};
};
const
MFT_INPUT_STREAM_INFO
empty_input_info
=
{
0
};
const
struct
attribute_desc
output_sample_attributes
[]
=
const
struct
attribute_desc
output_sample_attributes
[]
=
{
{
...
@@ -5849,12 +5851,21 @@ static void test_wmv_decoder(void)
...
@@ -5849,12 +5851,21 @@ static void test_wmv_decoder(void)
.
attributes
=
output_sample_attributes
,
.
attributes
=
output_sample_attributes
,
.
sample_time
=
0
,
.
sample_duration
=
333333
,
.
sample_time
=
0
,
.
sample_duration
=
333333
,
.
buffer_count
=
1
,
.
buffers
=
&
output_buffer_desc_nv12
,
.
buffer_count
=
1
,
.
buffers
=
&
output_buffer_desc_nv12
,
.
todo_duration
=
TRUE
,
};
const
struct
sample_desc
output_sample_desc_nv12_todo_time
=
{
.
attributes
=
output_sample_attributes
,
.
sample_time
=
0
,
.
sample_duration
=
333333
,
.
buffer_count
=
1
,
.
buffers
=
&
output_buffer_desc_nv12
,
.
todo_time
=
TRUE
,
.
todo_duration
=
TRUE
,
};
};
const
struct
sample_desc
output_sample_desc_rgb
=
const
struct
sample_desc
output_sample_desc_rgb
=
{
{
.
attributes
=
output_sample_attributes
,
.
attributes
=
output_sample_attributes
,
.
sample_time
=
0
,
.
sample_duration
=
333333
,
.
sample_time
=
0
,
.
sample_duration
=
333333
,
.
buffer_count
=
1
,
.
buffers
=
&
output_buffer_desc_rgb
,
.
buffer_count
=
1
,
.
buffers
=
&
output_buffer_desc_rgb
,
.
todo_time
=
TRUE
,
.
todo_duration
=
TRUE
,
};
};
const
struct
transform_desc
const
struct
transform_desc
...
@@ -5886,7 +5897,7 @@ static void test_wmv_decoder(void)
...
@@ -5886,7 +5897,7 @@ static void test_wmv_decoder(void)
.
expect_output_type_desc
=
expect_output_type_desc
,
.
expect_output_type_desc
=
expect_output_type_desc
,
.
expect_input_info
=
&
expect_input_info
,
.
expect_input_info
=
&
expect_input_info
,
.
expect_output_info
=
&
expect_output_info
,
.
expect_output_info
=
&
expect_output_info
,
.
output_sample_desc
=
&
output_sample_desc_nv12
,
.
output_sample_desc
=
&
output_sample_desc_nv12
_todo_time
,
.
result_bitmap
=
L"nv12frame.bmp"
,
.
result_bitmap
=
L"nv12frame.bmp"
,
.
delta
=
0
,
.
delta
=
0
,
},
},
...
@@ -5929,6 +5940,8 @@ static void test_wmv_decoder(void)
...
@@ -5929,6 +5940,8 @@ static void test_wmv_decoder(void)
MFT_REGISTER_TYPE_INFO
output_type
=
{
MFMediaType_Video
,
MFVideoFormat_NV12
};
MFT_REGISTER_TYPE_INFO
output_type
=
{
MFMediaType_Video
,
MFVideoFormat_NV12
};
MFT_REGISTER_TYPE_INFO
input_type
=
{
MFMediaType_Video
,
MFVideoFormat_WMV1
};
MFT_REGISTER_TYPE_INFO
input_type
=
{
MFMediaType_Video
,
MFVideoFormat_WMV1
};
IMFSample
*
input_sample
,
*
output_sample
;
IMFSample
*
input_sample
,
*
output_sample
;
MFT_OUTPUT_STREAM_INFO
output_info
;
MFT_INPUT_STREAM_INFO
input_info
;
IMFCollection
*
output_samples
;
IMFCollection
*
output_samples
;
IMFMediaType
*
media_type
;
IMFMediaType
*
media_type
;
IMFTransform
*
transform
;
IMFTransform
*
transform
;
...
@@ -5965,13 +5978,27 @@ static void test_wmv_decoder(void)
...
@@ -5965,13 +5978,27 @@ static void test_wmv_decoder(void)
check_mft_optional_methods
(
transform
,
1
);
check_mft_optional_methods
(
transform
,
1
);
check_mft_get_attributes
(
transform
,
expect_attributes
,
TRUE
);
check_mft_get_attributes
(
transform
,
expect_attributes
,
TRUE
);
memset
(
&
input_info
,
0xcd
,
sizeof
(
input_info
));
hr
=
IMFTransform_GetInputStreamInfo
(
transform
,
0
,
&
input_info
);
todo_wine
todo_wine
check_mft_get_input_stream_info
(
transform
,
MF_E_TRANSFORM_TYPE_NOT_SET
,
NULL
);
ok
(
hr
==
MF_E_TRANSFORM_TYPE_NOT_SET
,
"GetInputStreamInfo returned %#lx
\n
"
,
hr
);
check_member
(
input_info
,
empty_input_info
,
"%I64d"
,
hnsMaxLatency
);
check_member
(
input_info
,
empty_input_info
,
"%#lx"
,
dwFlags
);
check_member
(
input_info
,
empty_input_info
,
"%#lx"
,
cbSize
);
check_member
(
input_info
,
empty_input_info
,
"%#lx"
,
cbMaxLookahead
);
check_member
(
input_info
,
empty_input_info
,
"%#lx"
,
cbAlignment
);
memset
(
&
output_info
,
0xcd
,
sizeof
(
output_info
));
hr
=
IMFTransform_GetOutputStreamInfo
(
transform
,
0
,
&
output_info
);
todo_wine
todo_wine
check_mft_get_output_stream_info
(
transform
,
MF_E_TRANSFORM_TYPE_NOT_SET
,
&
empty_output_info
);
ok
(
hr
==
MF_E_TRANSFORM_TYPE_NOT_SET
,
"GetOutputStreamInfo returned %#lx
\n
"
,
hr
);
todo_wine
check_member
(
output_info
,
empty_output_info
,
"%#lx"
,
dwFlags
);
check_member
(
output_info
,
empty_output_info
,
"%#lx"
,
cbSize
);
check_member
(
output_info
,
empty_output_info
,
"%#lx"
,
cbAlignment
);
hr
=
IMFTransform_GetOutputAvailableType
(
transform
,
0
,
0
,
&
media_type
);
hr
=
IMFTransform_GetOutputAvailableType
(
transform
,
0
,
0
,
&
media_type
);
todo_wine
ok
(
hr
==
MF_E_TRANSFORM_TYPE_NOT_SET
,
"GetOutputAvailableType returned %#lx
\n
"
,
hr
);
ok
(
hr
==
MF_E_TRANSFORM_TYPE_NOT_SET
,
"GetOutputAvailableType returned %#lx
\n
"
,
hr
);
i
=
-
1
;
i
=
-
1
;
...
@@ -5985,9 +6012,7 @@ static void test_wmv_decoder(void)
...
@@ -5985,9 +6012,7 @@ static void test_wmv_decoder(void)
ok
(
!
ret
,
"Release returned %lu
\n
"
,
ret
);
ok
(
!
ret
,
"Release returned %lu
\n
"
,
ret
);
winetest_pop_context
();
winetest_pop_context
();
}
}
todo_wine
ok
(
hr
==
MF_E_NO_MORE_TYPES
,
"GetInputAvailableType returned %#lx
\n
"
,
hr
);
ok
(
hr
==
MF_E_NO_MORE_TYPES
,
"GetInputAvailableType returned %#lx
\n
"
,
hr
);
todo_wine
ok
(
i
==
ARRAY_SIZE
(
expect_available_inputs
),
"%lu input media types
\n
"
,
i
);
ok
(
i
==
ARRAY_SIZE
(
expect_available_inputs
),
"%lu input media types
\n
"
,
i
);
if
(
hr
==
E_NOTIMPL
)
if
(
hr
==
E_NOTIMPL
)
...
@@ -6021,10 +6046,28 @@ static void test_wmv_decoder(void)
...
@@ -6021,10 +6046,28 @@ static void test_wmv_decoder(void)
check_mft_set_output_type_required
(
transform
,
transform_tests
[
j
].
output_type_desc
);
check_mft_set_output_type_required
(
transform
,
transform_tests
[
j
].
output_type_desc
);
check_mft_set_output_type
(
transform
,
transform_tests
[
j
].
output_type_desc
,
S_OK
);
check_mft_set_output_type
(
transform
,
transform_tests
[
j
].
output_type_desc
,
S_OK
);
check_mft_get_output_current_type_
(
__LINE__
,
transform
,
transform_tests
[
j
].
expect_output_type_desc
,
FALSE
,
FALS
E
);
check_mft_get_output_current_type_
(
__LINE__
,
transform
,
transform_tests
[
j
].
expect_output_type_desc
,
FALSE
,
TRU
E
);
check_mft_get_input_stream_info
(
transform
,
S_OK
,
transform_tests
[
j
].
expect_input_info
);
memset
(
&
input_info
,
0xcd
,
sizeof
(
input_info
));
check_mft_get_output_stream_info
(
transform
,
S_OK
,
transform_tests
[
j
].
expect_output_info
);
hr
=
IMFTransform_GetInputStreamInfo
(
transform
,
0
,
&
input_info
);
ok
(
hr
==
S_OK
,
"GetInputStreamInfo returned %#lx
\n
"
,
hr
);
check_member
(
input_info
,
*
transform_tests
[
j
].
expect_input_info
,
"%I64d"
,
hnsMaxLatency
);
check_member
(
input_info
,
*
transform_tests
[
j
].
expect_input_info
,
"%#lx"
,
dwFlags
);
todo_wine
check_member
(
input_info
,
*
transform_tests
[
j
].
expect_input_info
,
"%#lx"
,
cbSize
);
check_member
(
input_info
,
*
transform_tests
[
j
].
expect_input_info
,
"%#lx"
,
cbMaxLookahead
);
todo_wine
check_member
(
input_info
,
*
transform_tests
[
j
].
expect_input_info
,
"%#lx"
,
cbAlignment
);
memset
(
&
output_info
,
0xcd
,
sizeof
(
output_info
));
hr
=
IMFTransform_GetOutputStreamInfo
(
transform
,
0
,
&
output_info
);
ok
(
hr
==
S_OK
,
"GetOutputStreamInfo returned %#lx
\n
"
,
hr
);
todo_wine
check_member
(
output_info
,
*
transform_tests
[
j
].
expect_output_info
,
"%#lx"
,
dwFlags
);
todo_wine_if
(
transform_tests
[
j
].
expect_output_info
==
&
expect_output_info
)
check_member
(
output_info
,
*
transform_tests
[
j
].
expect_output_info
,
"%#lx"
,
cbSize
);
todo_wine
check_member
(
output_info
,
*
transform_tests
[
j
].
expect_output_info
,
"%#lx"
,
cbAlignment
);
load_resource
(
L"wmvencdata.bin"
,
&
wmvenc_data
,
&
wmvenc_data_len
);
load_resource
(
L"wmvencdata.bin"
,
&
wmvenc_data
,
&
wmvenc_data_len
);
...
...
dlls/winegstreamer/Makefile.in
View file @
e7225aaa
...
@@ -28,5 +28,4 @@ SOURCES = \
...
@@ -28,5 +28,4 @@ SOURCES = \
wg_transform.c
\
wg_transform.c
\
winegstreamer_classes.idl
\
winegstreamer_classes.idl
\
wm_reader.c
\
wm_reader.c
\
wma_decoder.c
\
wma_decoder.c
wmv_decoder.c
dlls/winegstreamer/video_decoder.c
View file @
e7225aaa
This diff is collapsed.
Click to expand it.
dlls/winegstreamer/wmv_decoder.c
deleted
100644 → 0
View file @
181b609f
This diff is collapsed.
Click to expand it.
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