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
1b753413
Commit
1b753413
authored
Jan 08, 2024
by
Rémi Bernon
Committed by
Alexandre Julliard
Jan 09, 2024
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dmusic: Clone streams instead of allocating wave data.
Wine-Bug:
https://bugs.winehq.org/show_bug.cgi?id=56117
parent
67f2da2a
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
33 additions
and
17 deletions
+33
-17
wave.c
dlls/dmusic/wave.c
+33
-17
No files found.
dlls/dmusic/wave.c
View file @
1b753413
...
@@ -38,7 +38,7 @@ struct wave
...
@@ -38,7 +38,7 @@ struct wave
struct
sample
*
sample
;
struct
sample
*
sample
;
WAVEFORMATEX
*
format
;
WAVEFORMATEX
*
format
;
UINT
data_size
;
UINT
data_size
;
void
*
data
;
IStream
*
data
;
};
};
static
inline
struct
wave
*
impl_from_IUnknown
(
IUnknown
*
iface
)
static
inline
struct
wave
*
impl_from_IUnknown
(
IUnknown
*
iface
)
...
@@ -96,7 +96,7 @@ static ULONG WINAPI wave_Release(IUnknown *iface)
...
@@ -96,7 +96,7 @@ static ULONG WINAPI wave_Release(IUnknown *iface)
if
(
!
ref
)
if
(
!
ref
)
{
{
free
(
This
->
format
);
free
(
This
->
format
);
fre
e
(
This
->
data
);
if
(
This
->
data
)
IStream_Releas
e
(
This
->
data
);
free
(
This
->
sample
);
free
(
This
->
sample
);
free
(
This
);
free
(
This
);
}
}
...
@@ -150,8 +150,8 @@ static HRESULT parse_wave_chunk(struct wave *This, IStream *stream, struct chunk
...
@@ -150,8 +150,8 @@ static HRESULT parse_wave_chunk(struct wave *This, IStream *stream, struct chunk
break
;
break
;
case
mmioFOURCC
(
'd'
,
'a'
,
't'
,
'a'
):
case
mmioFOURCC
(
'd'
,
'a'
,
't'
,
'a'
):
if
(
!
(
This
->
data
=
malloc
(
chunk
.
size
)))
return
E_OUTOFMEMORY
;
if
(
This
->
data
)
IStream_Release
(
This
->
data
)
;
hr
=
stream_chunk_get_data
(
stream
,
&
chunk
,
This
->
data
,
chunk
.
size
);
hr
=
IStream_Clone
(
stream
,
&
This
->
data
);
if
(
SUCCEEDED
(
hr
))
This
->
data_size
=
chunk
.
size
;
if
(
SUCCEEDED
(
hr
))
This
->
data_size
=
chunk
.
size
;
break
;
break
;
...
@@ -341,9 +341,9 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
...
@@ -341,9 +341,9 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
struct
sample
*
sample
=
NULL
;
struct
sample
*
sample
=
NULL
;
WAVEFORMATEX
*
format
=
NULL
;
WAVEFORMATEX
*
format
=
NULL
;
HRESULT
hr
=
E_OUTOFMEMORY
;
HRESULT
hr
=
E_OUTOFMEMORY
;
UINT
data_size
,
offset
;
DWORD
data_size
,
offset
;
struct
wave
*
This
;
struct
wave
*
This
;
void
*
data
=
NULL
;
IStream
*
stream
=
NULL
;
IDirectMusicObject
*
iface
;
IDirectMusicObject
*
iface
;
TRACE
(
"(%p, %u, %p)
\n
"
,
soundfont
,
index
,
ret_iface
);
TRACE
(
"(%p, %u, %p)
\n
"
,
soundfont
,
index
,
ret_iface
);
...
@@ -365,9 +365,9 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
...
@@ -365,9 +365,9 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
sample
->
loops
[
0
].
ulLength
=
sf_sample
->
end_loop
-
sf_sample
->
start_loop
;
sample
->
loops
[
0
].
ulLength
=
sf_sample
->
end_loop
-
sf_sample
->
start_loop
;
data_size
=
sf_sample
->
end
-
sf_sample
->
start
;
data_size
=
sf_sample
->
end
-
sf_sample
->
start
;
if
(
!
(
data
=
malloc
(
data_size
*
format
->
nBlockAlign
)))
goto
failed
;
if
(
FAILED
(
hr
=
CreateStreamOnHGlobal
(
NULL
,
TRUE
,
&
stream
)))
goto
failed
;
offset
=
sf_sample
->
start
*
format
->
nBlockAlign
/
format
->
nChannels
;
offset
=
sf_sample
->
start
*
format
->
nBlockAlign
/
format
->
nChannels
;
memcpy
(
data
,
soundfont
->
sdta
+
offset
,
data_size
)
;
if
(
FAILED
(
hr
=
IStream_Write
(
stream
,
soundfont
->
sdta
+
offset
,
data_size
,
&
data_size
)))
goto
failed
;
if
(
FAILED
(
hr
=
wave_create
(
&
iface
)))
goto
failed
;
if
(
FAILED
(
hr
=
wave_create
(
&
iface
)))
goto
failed
;
...
@@ -375,7 +375,7 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
...
@@ -375,7 +375,7 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
This
->
format
=
format
;
This
->
format
=
format
;
This
->
sample
=
sample
;
This
->
sample
=
sample
;
This
->
data_size
=
data_size
;
This
->
data_size
=
data_size
;
This
->
data
=
data
;
This
->
data
=
stream
;
if
(
TRACE_ON
(
dmusic
))
if
(
TRACE_ON
(
dmusic
))
{
{
...
@@ -408,12 +408,26 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
...
@@ -408,12 +408,26 @@ HRESULT wave_create_from_soundfont(struct soundfont *soundfont, UINT index, IDir
return
S_OK
;
return
S_OK
;
failed:
failed:
free
(
data
);
if
(
stream
)
IStream_Release
(
stream
);
free
(
sample
);
free
(
sample
);
free
(
format
);
free
(
format
);
return
hr
;
return
hr
;
}
}
static
HRESULT
wave_read_data
(
struct
wave
*
This
,
void
*
data
,
DWORD
*
data_size
)
{
IStream
*
stream
;
HRESULT
hr
;
if
(
SUCCEEDED
(
hr
=
IStream_Clone
(
This
->
data
,
&
stream
)))
{
hr
=
IStream_Read
(
stream
,
data
,
This
->
data_size
,
data_size
);
IStream_Release
(
stream
);
}
return
hr
;
}
HRESULT
wave_download_to_port
(
IDirectMusicObject
*
iface
,
IDirectMusicPortDownload
*
port
,
DWORD
*
id
)
HRESULT
wave_download_to_port
(
IDirectMusicObject
*
iface
,
IDirectMusicPortDownload
*
port
,
DWORD
*
id
)
{
{
struct
download_buffer
struct
download_buffer
...
@@ -446,11 +460,12 @@ HRESULT wave_download_to_port(IDirectMusicObject *iface, IDirectMusicPortDownloa
...
@@ -446,11 +460,12 @@ HRESULT wave_download_to_port(IDirectMusicObject *iface, IDirectMusicPortDownloa
buffer
->
wave
.
ulCopyrightIdx
=
0
;
buffer
->
wave
.
ulCopyrightIdx
=
0
;
buffer
->
wave
.
ulFirstExtCkIdx
=
0
;
buffer
->
wave
.
ulFirstExtCkIdx
=
0
;
buffer
->
data
.
cbSize
=
This
->
data_size
;
if
(
FAILED
(
hr
=
wave_read_data
(
This
,
buffer
->
data
.
byData
,
&
buffer
->
data
.
cbSize
)))
memcpy
(
buffer
->
data
.
byData
,
This
->
data
,
This
->
data_size
);
WARN
(
"Failed to read wave data from stream, hr %#lx
\n
"
,
hr
);
else
if
(
FAILED
(
hr
=
IDirectMusicPortDownload_Download
(
port
,
download
)))
if
(
SUCCEEDED
(
hr
=
IDirectMusicPortDownload_Download
(
port
,
download
)))
*
id
=
buffer
->
info
.
dwDLId
;
WARN
(
"Failed to download wave to port, hr %#lx
\n
"
,
hr
);
else
WARN
(
"Failed to download wave to port, hr %#lx
\n
"
,
hr
);
else
*
id
=
buffer
->
info
.
dwDLId
;
}
}
IDirectMusicDownload_Release
(
download
);
IDirectMusicDownload_Release
(
download
);
...
@@ -481,8 +496,9 @@ HRESULT wave_download_to_dsound(IDirectMusicObject *iface, IDirectSound *dsound,
...
@@ -481,8 +496,9 @@ HRESULT wave_download_to_dsound(IDirectMusicObject *iface, IDirectSound *dsound,
if
(
SUCCEEDED
(
hr
=
IDirectSoundBuffer_Lock
(
buffer
,
0
,
This
->
data_size
,
&
data
,
&
size
,
NULL
,
0
,
0
)))
if
(
SUCCEEDED
(
hr
=
IDirectSoundBuffer_Lock
(
buffer
,
0
,
This
->
data_size
,
&
data
,
&
size
,
NULL
,
0
,
0
)))
{
{
memcpy
(
data
,
This
->
data
,
This
->
data_size
);
if
(
FAILED
(
hr
=
wave_read_data
(
This
,
data
,
&
size
)))
hr
=
IDirectSoundBuffer_Unlock
(
buffer
,
data
,
This
->
data_size
,
NULL
,
0
);
WARN
(
"Failed to read wave data from stream, hr %#lx
\n
"
,
hr
);
hr
=
IDirectSoundBuffer_Unlock
(
buffer
,
data
,
size
,
NULL
,
0
);
}
}
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
...
...
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