Commit 2a185126 authored by Rémi Bernon's avatar Rémi Bernon Committed by Alexandre Julliard

mf/topology_loader: Ignore SetOutputType errors when doing indirect connect.

It only succeeds with converters, or if a decoder can directly output the downstream media type. If it fails we may have to add a converter after the decoder, and we will call topology_branch_connect on the downstream branch for that.
parent 0dab1ffd
...@@ -3293,7 +3293,6 @@ static void test_topology_loader(void) ...@@ -3293,7 +3293,6 @@ static void test_topology_loader(void)
.input_type = &video_h264_1280, .output_type = &video_video_processor_1280_rgb32, .sink_method = -1, .source_method = -1, .input_type = &video_h264_1280, .output_type = &video_video_processor_1280_rgb32, .sink_method = -1, .source_method = -1,
.decoded_type = &video_nv12_1280, .decoded_type = &video_nv12_1280,
.expected_result = S_OK, .decoder_class = CLSID_CMSH264DecoderMFT, .converter_class = CLSID_CColorConvertDMO, .expected_result = S_OK, .decoder_class = CLSID_CMSH264DecoderMFT, .converter_class = CLSID_CColorConvertDMO,
.flags = LOADER_TODO,
}, },
{ {
/* RGB32 -> Any Video, no current output type */ /* RGB32 -> Any Video, no current output type */
...@@ -3577,7 +3576,7 @@ todo_wine { ...@@ -3577,7 +3576,7 @@ todo_wine {
hr = IMFTopology_GetNodeCount(full_topology, &node_count); hr = IMFTopology_GetNodeCount(full_topology, &node_count);
ok(hr == S_OK, "Failed to get node count, hr %#lx.\n", hr); ok(hr == S_OK, "Failed to get node count, hr %#lx.\n", hr);
todo_wine_if(!IsEqualGUID(&test->decoder_class, &GUID_NULL)) todo_wine_if(IsEqualGUID(&test->decoder_class, &CLSID_CMP3DecMediaObject))
ok(node_count == count, "Unexpected node count %u.\n", node_count); ok(node_count == count, "Unexpected node count %u.\n", node_count);
hr = IMFTopologyNode_GetTopoNodeID(src_node, &node_id); hr = IMFTopologyNode_GetTopoNodeID(src_node, &node_id);
...@@ -3623,14 +3622,21 @@ todo_wine { ...@@ -3623,14 +3622,21 @@ todo_wine {
IUnknown_Release(node_object); IUnknown_Release(node_object);
hr = IMFTransform_GetInputCurrentType(transform, 0, &media_type); hr = IMFTransform_GetInputCurrentType(transform, 0, &media_type);
todo_wine
ok(hr == S_OK, "Failed to get transform input type, hr %#lx.\n", hr); ok(hr == S_OK, "Failed to get transform input type, hr %#lx.\n", hr);
if (hr == S_OK)
{
hr = IMFMediaType_Compare(input_type, (IMFAttributes *)media_type, MF_ATTRIBUTES_MATCH_OUR_ITEMS, &ret); hr = IMFMediaType_Compare(input_type, (IMFAttributes *)media_type, MF_ATTRIBUTES_MATCH_OUR_ITEMS, &ret);
ok(hr == S_OK, "Failed to compare media types, hr %#lx.\n", hr); ok(hr == S_OK, "Failed to compare media types, hr %#lx.\n", hr);
ok(ret, "Input type of first transform doesn't match source node type.\n"); ok(ret, "Input type of first transform doesn't match source node type.\n");
IMFMediaType_Release(media_type); IMFMediaType_Release(media_type);
}
hr = IMFTransform_GetOutputCurrentType(transform, 0, &media_type); hr = IMFTransform_GetOutputCurrentType(transform, 0, &media_type);
todo_wine
ok(hr == S_OK, "Failed to get transform input type, hr %#lx.\n", hr); ok(hr == S_OK, "Failed to get transform input type, hr %#lx.\n", hr);
if (hr == S_OK)
{
if (IsEqualGUID(&test->converter_class, &GUID_NULL)) if (IsEqualGUID(&test->converter_class, &GUID_NULL))
{ {
hr = IMFMediaType_Compare(output_type, (IMFAttributes *)media_type, MF_ATTRIBUTES_MATCH_OUR_ITEMS, &ret); hr = IMFMediaType_Compare(output_type, (IMFAttributes *)media_type, MF_ATTRIBUTES_MATCH_OUR_ITEMS, &ret);
...@@ -3642,6 +3648,7 @@ todo_wine { ...@@ -3642,6 +3648,7 @@ todo_wine {
check_media_type(media_type, *test->decoded_type, -1); check_media_type(media_type, *test->decoded_type, -1);
} }
IMFMediaType_Release(media_type); IMFMediaType_Release(media_type);
}
IMFTransform_Release(transform); IMFTransform_Release(transform);
} }
...@@ -3702,13 +3709,17 @@ todo_wine { ...@@ -3702,13 +3709,17 @@ todo_wine {
hr = IMFTopology_SetUINT32(full_topology, &IID_IMFTopology, 123); hr = IMFTopology_SetUINT32(full_topology, &IID_IMFTopology, 123);
ok(hr == S_OK, "Unexpected hr %#lx.\n", hr); ok(hr == S_OK, "Unexpected hr %#lx.\n", hr);
hr = IMFTopoLoader_Load(loader, full_topology, &topology2, NULL); hr = IMFTopoLoader_Load(loader, full_topology, &topology2, NULL);
todo_wine_if(IsEqualGUID(&test->decoder_class, &CLSID_MSH264DecoderMFT))
ok(hr == S_OK, "Failed to resolve topology, hr %#lx.\n", hr); ok(hr == S_OK, "Failed to resolve topology, hr %#lx.\n", hr);
if (hr == S_OK)
{
ok(full_topology != topology2, "Unexpected instance.\n"); ok(full_topology != topology2, "Unexpected instance.\n");
hr = IMFTopology_GetUINT32(topology2, &IID_IMFTopology, &value); hr = IMFTopology_GetUINT32(topology2, &IID_IMFTopology, &value);
ok(hr == S_OK, "Unexpected hr %#lx.\n", hr); ok(hr == S_OK, "Unexpected hr %#lx.\n", hr);
ref = IMFTopology_Release(topology2); ref = IMFTopology_Release(topology2);
ok(ref == 0, "Release returned %ld\n", ref); ok(ref == 0, "Release returned %ld\n", ref);
}
ref = IMFTopology_Release(full_topology); ref = IMFTopology_Release(full_topology);
ok(ref == 0, "Release returned %ld\n", ref); ok(ref == 0, "Release returned %ld\n", ref);
} }
......
...@@ -309,11 +309,8 @@ static HRESULT topology_branch_connect_indirect(IMFTopology *topology, MF_CONNEC ...@@ -309,11 +309,8 @@ static HRESULT topology_branch_connect_indirect(IMFTopology *topology, MF_CONNEC
hr = topology_branch_connect_down(topology, MF_CONNECT_DIRECT, &up_branch, up_type); hr = topology_branch_connect_down(topology, MF_CONNECT_DIRECT, &up_branch, up_type);
if (down_type) if (down_type)
{ {
if (SUCCEEDED(hr)) if (SUCCEEDED(topology_branch_fill_media_type(up_type, down_type))
hr = topology_branch_fill_media_type(up_type, down_type); && SUCCEEDED(IMFTransform_SetOutputType(transform, 0, down_type, 0)))
if (SUCCEEDED(hr))
hr = IMFTransform_SetOutputType(transform, 0, down_type, 0);
if (SUCCEEDED(hr))
method = MF_CONNECT_DIRECT; method = MF_CONNECT_DIRECT;
} }
IMFTransform_Release(transform); IMFTransform_Release(transform);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment