quartz/vmr9: Fix copying from the d3d9 surface if the pitch doesn't match the width.

Spotted by Henri Verbeet.

Signed-off-by: Zebediah Figura <z.figura12@gmail.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Zebediah Figura 2020-02-12 09:34:15 -06:00 committed by Alexandre Julliard
parent 56d529694b
commit 6c8f52c4fb
1 changed files with 16 additions and 4 deletions

View File

@ -627,7 +627,10 @@ static HRESULT WINAPI VMR9_GetStaticImage(BaseControlVideo *iface, LONG *size, L
IDirect3DSurface9 *rt = NULL, *surface = NULL; IDirect3DSurface9 *rt = NULL, *surface = NULL;
D3DLOCKED_RECT locked_rect; D3DLOCKED_RECT locked_rect;
IDirect3DDevice9 *device; IDirect3DDevice9 *device;
unsigned int row_size;
BITMAPINFOHEADER bih; BITMAPINFOHEADER bih;
LONG i, size_left;
char *dst;
HRESULT hr; HRESULT hr;
TRACE("filter %p, size %d, image %p.\n", filter, *size, image); TRACE("filter %p, size %d, image %p.\n", filter, *size, image);
@ -661,10 +664,19 @@ static HRESULT WINAPI VMR9_GetStaticImage(BaseControlVideo *iface, LONG *size, L
if (FAILED(hr = IDirect3DSurface9_LockRect(surface, &locked_rect, NULL, D3DLOCK_READONLY))) if (FAILED(hr = IDirect3DSurface9_LockRect(surface, &locked_rect, NULL, D3DLOCK_READONLY)))
goto out; goto out;
memcpy(image, &bih, min(*size, sizeof(BITMAPINFOHEADER))); size_left = *size;
if (*size > sizeof(BITMAPINFOHEADER)) memcpy(image, &bih, min(size_left, sizeof(BITMAPINFOHEADER)));
memcpy((char *)image + sizeof(BITMAPINFOHEADER), locked_rect.pBits, size_left -= sizeof(BITMAPINFOHEADER);
min(*size - sizeof(BITMAPINFOHEADER), bih.biSizeImage));
dst = (char *)image + sizeof(BITMAPINFOHEADER);
row_size = bih.biWidth * bih.biBitCount / 8;
for (i = 0; i < bih.biHeight && size_left > 0; ++i)
{
memcpy(dst, (char *)locked_rect.pBits + (i * locked_rect.Pitch), min(row_size, size_left));
dst += row_size;
size_left -= row_size;
}
IDirect3DSurface9_UnlockRect(surface); IDirect3DSurface9_UnlockRect(surface);