Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
72d18a48
Commit
72d18a48
authored
Sep 26, 2022
by
Rémi Bernon
Committed by
Alexandre Julliard
Sep 29, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winegstreamer: Keep input / output stream info in struct wma_decoder.
And calculate the sizes when media type is successfully changed.
parent
78789038
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
29 deletions
+25
-29
wma_decoder.c
dlls/winegstreamer/wma_decoder.c
+25
-29
No files found.
dlls/winegstreamer/wma_decoder.c
View file @
72d18a48
...
@@ -52,8 +52,11 @@ struct wma_decoder
...
@@ -52,8 +52,11 @@ struct wma_decoder
IPropertyBag
IPropertyBag_iface
;
IPropertyBag
IPropertyBag_iface
;
IUnknown
*
outer
;
IUnknown
*
outer
;
LONG
refcount
;
LONG
refcount
;
IMFMediaType
*
input_type
;
IMFMediaType
*
input_type
;
MFT_INPUT_STREAM_INFO
input_info
;
IMFMediaType
*
output_type
;
IMFMediaType
*
output_type
;
MFT_OUTPUT_STREAM_INFO
output_info
;
struct
wg_transform
*
wg_transform
;
struct
wg_transform
*
wg_transform
;
struct
wg_sample_queue
*
wg_sample_queue
;
struct
wg_sample_queue
*
wg_sample_queue
;
...
@@ -201,46 +204,32 @@ static HRESULT WINAPI transform_GetStreamIDs(IMFTransform *iface, DWORD input_si
...
@@ -201,46 +204,32 @@ static HRESULT WINAPI transform_GetStreamIDs(IMFTransform *iface, DWORD input_si
static
HRESULT
WINAPI
transform_GetInputStreamInfo
(
IMFTransform
*
iface
,
DWORD
id
,
MFT_INPUT_STREAM_INFO
*
info
)
static
HRESULT
WINAPI
transform_GetInputStreamInfo
(
IMFTransform
*
iface
,
DWORD
id
,
MFT_INPUT_STREAM_INFO
*
info
)
{
{
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
UINT32
block_alignment
;
HRESULT
hr
;
TRACE
(
"iface %p, id %lu, info %p.
\n
"
,
iface
,
id
,
info
);
TRACE
(
"iface %p, id %lu, info %p.
\n
"
,
iface
,
id
,
info
);
if
(
!
decoder
->
input_type
||
!
decoder
->
output_type
)
if
(
!
decoder
->
input_type
||
!
decoder
->
output_type
)
{
memset
(
info
,
0
,
sizeof
(
*
info
));
return
MF_E_TRANSFORM_TYPE_NOT_SET
;
return
MF_E_TRANSFORM_TYPE_NOT_SET
;
}
if
(
FAILED
(
hr
=
IMFMediaType_GetUINT32
(
decoder
->
input_type
,
&
MF_MT_AUDIO_BLOCK_ALIGNMENT
,
&
block_alignment
)))
*
info
=
decoder
->
input_info
;
return
hr
;
info
->
hnsMaxLatency
=
0
;
info
->
dwFlags
=
0
;
info
->
cbSize
=
block_alignment
;
info
->
cbMaxLookahead
=
0
;
info
->
cbAlignment
=
1
;
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
WINAPI
transform_GetOutputStreamInfo
(
IMFTransform
*
iface
,
DWORD
id
,
MFT_OUTPUT_STREAM_INFO
*
info
)
static
HRESULT
WINAPI
transform_GetOutputStreamInfo
(
IMFTransform
*
iface
,
DWORD
id
,
MFT_OUTPUT_STREAM_INFO
*
info
)
{
{
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
UINT32
channel_count
,
block_alignment
;
HRESULT
hr
;
TRACE
(
"iface %p, id %lu, info %p.
\n
"
,
iface
,
id
,
info
);
TRACE
(
"iface %p, id %lu, info %p.
\n
"
,
iface
,
id
,
info
);
if
(
!
decoder
->
input_type
||
!
decoder
->
output_type
)
if
(
!
decoder
->
input_type
||
!
decoder
->
output_type
)
{
memset
(
info
,
0
,
sizeof
(
*
info
));
return
MF_E_TRANSFORM_TYPE_NOT_SET
;
return
MF_E_TRANSFORM_TYPE_NOT_SET
;
}
if
(
FAILED
(
hr
=
IMFMediaType_GetUINT32
(
decoder
->
output_type
,
&
MF_MT_AUDIO_NUM_CHANNELS
,
&
channel_count
)))
*
info
=
decoder
->
output_info
;
return
hr
;
if
(
FAILED
(
hr
=
IMFMediaType_GetUINT32
(
decoder
->
output_type
,
&
MF_MT_AUDIO_BLOCK_ALIGNMENT
,
&
block_alignment
)))
return
hr
;
info
->
dwFlags
=
0
;
info
->
cbSize
=
1024
*
block_alignment
*
channel_count
;
info
->
cbAlignment
=
1
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -358,6 +347,7 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
...
@@ -358,6 +347,7 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
{
{
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
MF_ATTRIBUTE_TYPE
item_type
;
MF_ATTRIBUTE_TYPE
item_type
;
UINT32
block_alignment
;
GUID
major
,
subtype
;
GUID
major
,
subtype
;
HRESULT
hr
;
HRESULT
hr
;
ULONG
i
;
ULONG
i
;
...
@@ -380,8 +370,7 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
...
@@ -380,8 +370,7 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_USER_DATA
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_USER_DATA
,
&
item_type
))
||
item_type
!=
MF_ATTRIBUTE_BLOB
)
item_type
!=
MF_ATTRIBUTE_BLOB
)
return
MF_E_INVALIDMEDIATYPE
;
return
MF_E_INVALIDMEDIATYPE
;
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_BLOCK_ALIGNMENT
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetUINT32
(
type
,
&
MF_MT_AUDIO_BLOCK_ALIGNMENT
,
&
block_alignment
)))
item_type
!=
MF_ATTRIBUTE_UINT32
)
return
MF_E_INVALIDMEDIATYPE
;
return
MF_E_INVALIDMEDIATYPE
;
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_SAMPLES_PER_SECOND
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_SAMPLES_PER_SECOND
,
&
item_type
))
||
item_type
!=
MF_ATTRIBUTE_UINT32
)
item_type
!=
MF_ATTRIBUTE_UINT32
)
...
@@ -401,9 +390,12 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
...
@@ -401,9 +390,12 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
decoder
->
output_type
=
NULL
;
decoder
->
output_type
=
NULL
;
}
}
if
(
FAILED
(
hr
=
IMFMediaType_CopyAllItems
(
type
,
(
IMFAttributes
*
)
decoder
->
input_type
)))
if
(
SUCCEEDED
(
hr
=
IMFMediaType_CopyAllItems
(
type
,
(
IMFAttributes
*
)
decoder
->
input_type
)))
decoder
->
input_info
.
cbSize
=
block_alignment
;
else
{
{
IMFMediaType_Release
(
decoder
->
input_type
);
IMFMediaType_Release
(
decoder
->
input_type
);
decoder
->
input_info
.
cbSize
=
0
;
decoder
->
input_type
=
NULL
;
decoder
->
input_type
=
NULL
;
}
}
...
@@ -413,6 +405,7 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
...
@@ -413,6 +405,7 @@ static HRESULT WINAPI transform_SetInputType(IMFTransform *iface, DWORD id, IMFM
static
HRESULT
WINAPI
transform_SetOutputType
(
IMFTransform
*
iface
,
DWORD
id
,
IMFMediaType
*
type
,
DWORD
flags
)
static
HRESULT
WINAPI
transform_SetOutputType
(
IMFTransform
*
iface
,
DWORD
id
,
IMFMediaType
*
type
,
DWORD
flags
)
{
{
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
struct
wma_decoder
*
decoder
=
impl_from_IMFTransform
(
iface
);
UINT32
channel_count
,
block_alignment
;
MF_ATTRIBUTE_TYPE
item_type
;
MF_ATTRIBUTE_TYPE
item_type
;
ULONG
i
,
sample_size
;
ULONG
i
,
sample_size
;
GUID
major
,
subtype
;
GUID
major
,
subtype
;
...
@@ -453,14 +446,12 @@ static HRESULT WINAPI transform_SetOutputType(IMFTransform *iface, DWORD id, IMF
...
@@ -453,14 +446,12 @@ static HRESULT WINAPI transform_SetOutputType(IMFTransform *iface, DWORD id, IMF
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_BITS_PER_SAMPLE
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_BITS_PER_SAMPLE
,
&
item_type
))
||
item_type
!=
MF_ATTRIBUTE_UINT32
)
item_type
!=
MF_ATTRIBUTE_UINT32
)
return
MF_E_INVALIDMEDIATYPE
;
return
MF_E_INVALIDMEDIATYPE
;
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_NUM_CHANNELS
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetUINT32
(
type
,
&
MF_MT_AUDIO_NUM_CHANNELS
,
&
channel_count
)))
item_type
!=
MF_ATTRIBUTE_UINT32
)
return
MF_E_INVALIDMEDIATYPE
;
return
MF_E_INVALIDMEDIATYPE
;
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_SAMPLES_PER_SECOND
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_SAMPLES_PER_SECOND
,
&
item_type
))
||
item_type
!=
MF_ATTRIBUTE_UINT32
)
item_type
!=
MF_ATTRIBUTE_UINT32
)
return
MF_E_INVALIDMEDIATYPE
;
return
MF_E_INVALIDMEDIATYPE
;
if
(
FAILED
(
IMFMediaType_GetItemType
(
type
,
&
MF_MT_AUDIO_BLOCK_ALIGNMENT
,
&
item_type
))
||
if
(
FAILED
(
IMFMediaType_GetUINT32
(
type
,
&
MF_MT_AUDIO_BLOCK_ALIGNMENT
,
&
block_alignment
)))
item_type
!=
MF_ATTRIBUTE_UINT32
)
return
MF_E_INVALIDMEDIATYPE
;
return
MF_E_INVALIDMEDIATYPE
;
if
(
flags
&
MFT_SET_TYPE_TEST_ONLY
)
if
(
flags
&
MFT_SET_TYPE_TEST_ONLY
)
return
S_OK
;
return
S_OK
;
...
@@ -477,10 +468,12 @@ static HRESULT WINAPI transform_SetOutputType(IMFTransform *iface, DWORD id, IMF
...
@@ -477,10 +468,12 @@ static HRESULT WINAPI transform_SetOutputType(IMFTransform *iface, DWORD id, IMF
if
(
FAILED
(
hr
=
try_create_wg_transform
(
decoder
)))
if
(
FAILED
(
hr
=
try_create_wg_transform
(
decoder
)))
goto
failed
;
goto
failed
;
decoder
->
output_info
.
cbSize
=
1024
*
block_alignment
*
channel_count
;
return
S_OK
;
return
S_OK
;
failed:
failed:
IMFMediaType_Release
(
decoder
->
output_type
);
IMFMediaType_Release
(
decoder
->
output_type
);
decoder
->
output_info
.
cbSize
=
0
;
decoder
->
output_type
=
NULL
;
decoder
->
output_type
=
NULL
;
return
hr
;
return
hr
;
}
}
...
@@ -901,6 +894,9 @@ HRESULT wma_decoder_create(IUnknown *outer, IUnknown **out)
...
@@ -901,6 +894,9 @@ HRESULT wma_decoder_create(IUnknown *outer, IUnknown **out)
decoder
->
refcount
=
1
;
decoder
->
refcount
=
1
;
decoder
->
outer
=
outer
?
outer
:
&
decoder
->
IUnknown_inner
;
decoder
->
outer
=
outer
?
outer
:
&
decoder
->
IUnknown_inner
;
decoder
->
input_info
.
cbAlignment
=
1
;
decoder
->
output_info
.
cbAlignment
=
1
;
*
out
=
&
decoder
->
IUnknown_inner
;
*
out
=
&
decoder
->
IUnknown_inner
;
TRACE
(
"Created decoder %p
\n
"
,
*
out
);
TRACE
(
"Created decoder %p
\n
"
,
*
out
);
return
S_OK
;
return
S_OK
;
...
...
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