2020-04-15 12:41:43 +02:00
|
|
|
/*
|
|
|
|
* Copyright 2020 Ziqing Hui
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
|
|
|
#define COBJMACROS
|
|
|
|
|
|
|
|
#include "windef.h"
|
|
|
|
#include "wincodec.h"
|
|
|
|
#include "wine/test.h"
|
|
|
|
|
2020-08-17 04:24:13 +02:00
|
|
|
#define GET_RGB565_R(color) ((BYTE)(((color) >> 11) & 0x1F))
|
|
|
|
#define GET_RGB565_G(color) ((BYTE)(((color) >> 5) & 0x3F))
|
|
|
|
#define GET_RGB565_B(color) ((BYTE)(((color) >> 0) & 0x1F))
|
|
|
|
#define MAKE_RGB565(r, g, b) ((WORD)(((BYTE)(r) << 11) | ((BYTE)(g) << 5) | (BYTE)(b)))
|
|
|
|
#define MAKE_ARGB(a, r, g, b) (((DWORD)(a) << 24) | ((DWORD)(r) << 16) | ((DWORD)(g) << 8) | (DWORD)(b))
|
|
|
|
|
2020-08-19 04:04:05 +02:00
|
|
|
#define BLOCK_WIDTH 4
|
|
|
|
#define BLOCK_HEIGHT 4
|
|
|
|
|
2020-07-23 08:01:40 +02:00
|
|
|
/* 1x1 uncompressed(Alpha) DDS image */
|
|
|
|
static BYTE test_dds_alpha[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xFF
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 1x1 uncompressed(Luminance) DDS image */
|
|
|
|
static BYTE test_dds_luminance[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x82
|
|
|
|
};
|
|
|
|
|
2020-07-21 07:49:53 +02:00
|
|
|
/* 4x4 uncompressed(16bpp RGB565) DDS image */
|
|
|
|
static BYTE test_dds_rgb565[] = {
|
2020-04-22 10:37:32 +02:00
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0xF8, 0x00, 0x00,
|
|
|
|
0xE0, 0x07, 0x00, 0x00, 0x1F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xF5, 0xA7, 0x08, 0x69, 0x4C, 0x7B, 0x08, 0x69, 0xF5, 0xA7, 0xF5, 0xA7, 0xF5, 0xA7, 0x4C, 0x7B,
|
|
|
|
0x4C, 0x7B, 0x4C, 0x7B, 0x4C, 0x7B, 0xB1, 0x95, 0x4C, 0x7B, 0x08, 0x69, 0x08, 0x69, 0x4C, 0x7B
|
|
|
|
};
|
|
|
|
|
2020-07-18 05:14:22 +02:00
|
|
|
/* 1x1 uncompressed(24bpp RGB) DDS image */
|
|
|
|
static BYTE test_dds_24bpp[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x18, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00,
|
|
|
|
0x00, 0xFF, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x70, 0x81, 0x83
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 1x1 uncompressed(32bpp XRGB) DDS image */
|
|
|
|
static BYTE test_dds_32bpp_xrgb[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x40, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00,
|
|
|
|
0x00, 0xFF, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x70, 0x81, 0x83, 0x00
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 1x1 uncompressed(32bpp ARGB) DDS image */
|
|
|
|
static BYTE test_dds_32bpp_argb[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x41, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00,
|
|
|
|
0x00, 0xFF, 0x00, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFF, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x70, 0x81, 0x83, 0xFF
|
|
|
|
};
|
|
|
|
|
2020-07-18 05:15:13 +02:00
|
|
|
/* 1x1 uncompressed(64bpp ABGR) DDS image */
|
|
|
|
static BYTE test_dds_64bpp[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x0F, 0x10, 0x02, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x24, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x83, 0x83, 0x81, 0x81, 0x70, 0x70, 0xFF, 0xFF
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 1x1 uncompressed(96bpp ABGR float) DDS image */
|
|
|
|
static BYTE test_dds_96bpp[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x0F, 0x10, 0x02, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', '1', '0', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x06, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x84, 0x83, 0x03, 0x3F, 0x82, 0x81, 0x01, 0x3F, 0xE2, 0xE0, 0xE0, 0x3E
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 1x1 uncompressed(128bpp ABGR float) DDS image */
|
|
|
|
static BYTE test_dds_128bpp[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x0F, 0x10, 0x02, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x74, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x84, 0x83, 0x03, 0x3F, 0x82, 0x81, 0x01, 0x3F, 0xE2, 0xE0, 0xE0, 0x3E, 0x00, 0x00, 0x80, 0x3F
|
|
|
|
};
|
|
|
|
|
2020-07-18 05:17:54 +02:00
|
|
|
/* 4x4 compressed(DXT1) cube map, mipMapCount = 3 */
|
2020-04-22 10:37:32 +02:00
|
|
|
static BYTE test_dds_cube[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '1', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55,
|
|
|
|
0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7,
|
|
|
|
0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55,
|
|
|
|
0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7,
|
|
|
|
0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55,
|
|
|
|
0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7,
|
|
|
|
0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00
|
|
|
|
};
|
|
|
|
|
2020-07-18 05:17:54 +02:00
|
|
|
/* 4x4 compressed(DXT1) cube map with extended header, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_cube_dx10[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', '1', '0', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0xFE, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x47, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
|
|
|
|
0x03, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B,
|
|
|
|
0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69,
|
|
|
|
0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B,
|
|
|
|
0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69,
|
|
|
|
0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B,
|
|
|
|
0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69,
|
|
|
|
0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84,
|
|
|
|
0x00, 0x00, 0x00, 0x00
|
|
|
|
};
|
|
|
|
|
2020-07-18 05:14:22 +02:00
|
|
|
/* 4x4 compressed(DXT1) DDS image with mip maps, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_mipmaps[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '1', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0xB1, 0x95, 0x6D, 0x7B, 0xFC, 0x55, 0x5D, 0x5D,
|
|
|
|
0x2E, 0x8C, 0x4E, 0x7C, 0xAA, 0xAB, 0xAB, 0xAB
|
|
|
|
};
|
|
|
|
|
2020-04-22 10:37:32 +02:00
|
|
|
/* 4x4 compressed(DXT1) volume texture, depth=4, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_volume[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x8A, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '1', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xD5, 0xA7, 0x2C, 0x7B, 0xE0, 0x00, 0x55, 0x55, 0xD5, 0xA7, 0x49, 0x69, 0x57, 0x00, 0xFF, 0x55,
|
|
|
|
0xD5, 0xA7, 0x48, 0x69, 0xFD, 0x80, 0xFF, 0x55, 0x30, 0x8D, 0x89, 0x71, 0x55, 0xA8, 0x00, 0xFF,
|
|
|
|
0x32, 0x96, 0x6D, 0x83, 0xA8, 0x55, 0x5D, 0x5D, 0x0E, 0x84, 0x6D, 0x7B, 0xA8, 0xA9, 0xAD, 0xAD,
|
|
|
|
0x2E, 0x8C, 0x2E, 0x7C, 0xAA, 0xAB, 0xAB, 0xAB
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 4x4 compressed(DXT1) texture array, arraySize=3, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_array[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', '1', '0', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x47, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B,
|
|
|
|
0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69,
|
|
|
|
0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B, 0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0xF5, 0xA7, 0x08, 0x69, 0x74, 0xC0, 0xBF, 0xD7, 0x32, 0x96, 0x0B, 0x7B,
|
|
|
|
0xCC, 0x55, 0xCC, 0x55, 0x0E, 0x84, 0x0E, 0x84, 0x00, 0x00, 0x00, 0x00
|
|
|
|
};
|
|
|
|
|
2020-07-23 08:02:36 +02:00
|
|
|
/* 4x4 compressed(DXT1c) DDS image */
|
|
|
|
static BYTE test_dds_dxt1c[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '1', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x9A, 0xE6, 0x2B, 0x39, 0x37, 0xB7, 0x7F, 0x7F
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 4x4 compressed(DXT1a) DDS image */
|
|
|
|
static BYTE test_dds_dxt1a[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x08, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '1', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x2A, 0x31, 0xF5, 0xBC, 0xE3, 0x6E, 0x2A, 0x3A
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 4x4 compressed(DXT2) DDS image, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_dxt2[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x02, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '2', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFD, 0xDE, 0xC4, 0x10, 0x2F, 0xBF, 0xFF, 0x7B,
|
|
|
|
0xFF, 0x00, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x57, 0x53, 0x00, 0x00, 0x52, 0x52, 0x55, 0x55,
|
|
|
|
0x0F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xCE, 0x59, 0x00, 0x00, 0x54, 0x55, 0x55, 0x55
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 1x3 compressed(DXT3) DDS image, mipMapCount=2 */
|
2020-06-09 06:28:09 +02:00
|
|
|
static BYTE test_dds_dxt3[] = {
|
2020-07-23 08:02:36 +02:00
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x01, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '3', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0C, 0x92, 0x38, 0x84, 0x00, 0xFF, 0x55, 0xFF,
|
|
|
|
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x53, 0x8B, 0x53, 0x8B, 0x00, 0x00, 0x00, 0x00
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 4x4 compressed(DXT4) DDS image, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_dxt4[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x02, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', 'T', '4', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFD, 0xDE, 0xC4, 0x10, 0x2F, 0xBF, 0xFF, 0x7B,
|
|
|
|
0xFF, 0x00, 0x40, 0x02, 0x24, 0x49, 0x92, 0x24, 0x57, 0x53, 0x00, 0x00, 0x52, 0x52, 0x55, 0x55,
|
|
|
|
0xFF, 0x00, 0x48, 0x92, 0x24, 0x49, 0x92, 0x24, 0xCE, 0x59, 0x00, 0x00, 0x54, 0x55, 0x55, 0x55
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 6x6 compressed(DXT5) image, mipMapCount=3 */
|
|
|
|
static BYTE test_dds_dxt5[] = {
|
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x06, 0x00, 0x00, 0x00,
|
|
|
|
0x06, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 0x44, 0x58, 0x54, 0x35, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x73, 0x73, 0x8E, 0x51, 0x97, 0x97, 0xBF, 0xAF,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x9D, 0xC6, 0xCF, 0x52, 0x22, 0x22, 0xBB, 0x55,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x44, 0xA2, 0xB8, 0x5B, 0xF8, 0xF8, 0xF8, 0xF8,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0C, 0x3A, 0x05, 0x19, 0xCC, 0x66, 0xCC, 0x66,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x38, 0x9D, 0x0A, 0x39, 0xCF, 0xEF, 0x9B, 0xEF,
|
|
|
|
0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF0, 0x6A, 0xF0, 0x6A, 0x00, 0x00, 0x00, 0x00
|
|
|
|
};
|
|
|
|
|
|
|
|
/* 12x12 compressed(DXT3) texture array, arraySize=2, mipMapCount=4 */
|
|
|
|
static BYTE test_dds_12x12[] = {
|
2020-06-09 06:28:09 +02:00
|
|
|
'D', 'D', 'S', ' ', 0x7C, 0x00, 0x00, 0x00, 0x07, 0x10, 0x0A, 0x00, 0x0C, 0x00, 0x00, 0x00,
|
|
|
|
0x0C, 0x00, 0x00, 0x00, 0x90, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
|
|
|
|
0x04, 0x00, 0x00, 0x00, 'D', 'X', '1', '0', 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x10, 0x40, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
0x4A, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xB5, 0xA7, 0xAD, 0x83,
|
|
|
|
0x60, 0x60, 0xE0, 0x80, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x12, 0x96, 0x6B, 0x72,
|
|
|
|
0xD5, 0xD5, 0xAF, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x30, 0x8D, 0x89, 0x69,
|
|
|
|
0x57, 0x5F, 0x5E, 0xF8, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xB4, 0xA7, 0xAD, 0x83,
|
|
|
|
0x00, 0xAA, 0xFF, 0x55, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xF3, 0x9E, 0x6D, 0x83,
|
|
|
|
0x00, 0x00, 0xAA, 0x55, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x12, 0x96, 0xCD, 0x83,
|
|
|
|
0x5C, 0xF8, 0xAA, 0xAF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xEC, 0x7A, 0xC9, 0x71,
|
|
|
|
0x80, 0x60, 0x60, 0x60, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x4A, 0x72, 0xA8, 0x68,
|
|
|
|
0x28, 0xBE, 0xD7, 0xD7, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xAF, 0x8C, 0xEA, 0x71,
|
|
|
|
0x0B, 0xAB, 0xAD, 0xBD, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x54, 0x9F, 0xCC, 0x7A,
|
|
|
|
0x5C, 0xA8, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x50, 0x8D, 0x49, 0x69,
|
|
|
|
0x77, 0xEE, 0x88, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0C, 0x7B, 0x08, 0x69,
|
|
|
|
0xF8, 0x58, 0xF8, 0x58, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x4E, 0x84, 0x6B, 0x72,
|
|
|
|
0x33, 0x99, 0x33, 0x99, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x14, 0x9F, 0x0A, 0x72,
|
|
|
|
0xDC, 0xAA, 0x75, 0xAA, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0E, 0x84, 0x0E, 0x84,
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xB5, 0xA7, 0xAD, 0x83,
|
|
|
|
0x60, 0x60, 0xE0, 0x80, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x12, 0x96, 0x6B, 0x72,
|
|
|
|
0xD5, 0xD5, 0xAF, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x30, 0x8D, 0x89, 0x69,
|
|
|
|
0x57, 0x5F, 0x5E, 0xF8, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xB4, 0xA7, 0xAD, 0x83,
|
|
|
|
0x00, 0xAA, 0xFF, 0x55, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xF3, 0x9E, 0x6D, 0x83,
|
|
|
|
0x00, 0x00, 0xAA, 0x55, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x12, 0x96, 0xCD, 0x83,
|
|
|
|
0x5C, 0xF8, 0xAA, 0xAF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xEC, 0x7A, 0xC9, 0x71,
|
|
|
|
0x80, 0x60, 0x60, 0x60, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x4A, 0x72, 0xA8, 0x68,
|
|
|
|
0x28, 0xBE, 0xD7, 0xD7, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xAF, 0x8C, 0xEA, 0x71,
|
|
|
|
0x0B, 0xAB, 0xAD, 0xBD, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x54, 0x9F, 0xCC, 0x7A,
|
|
|
|
0x5C, 0xA8, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x50, 0x8D, 0x49, 0x69,
|
|
|
|
0x77, 0xEE, 0x88, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0C, 0x7B, 0x08, 0x69,
|
|
|
|
0xF8, 0x58, 0xF8, 0x58, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x4E, 0x84, 0x6B, 0x72,
|
|
|
|
0x33, 0x99, 0x33, 0x99, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x14, 0x9F, 0x0A, 0x72,
|
|
|
|
0xDC, 0xAA, 0x75, 0xAA, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x0E, 0x84, 0x0E, 0x84,
|
|
|
|
0x00, 0x00, 0x00, 0x00
|
|
|
|
};
|
|
|
|
|
2020-07-23 08:02:36 +02:00
|
|
|
static BYTE test_dds_bad_magic[sizeof(test_dds_dxt1c)];
|
|
|
|
static BYTE test_dds_bad_header[sizeof(test_dds_dxt1c)];
|
2020-07-21 07:48:52 +02:00
|
|
|
static BYTE test_byte[1] = { 0 };
|
|
|
|
static BYTE test_word[2] = { 0 };
|
|
|
|
static BYTE test_dword[4] = { 0 };
|
|
|
|
static BYTE test_qword_a[8] = { 0 };
|
|
|
|
static BYTE test_qword_b[8] = "DDS ";
|
|
|
|
|
2020-05-22 05:17:31 +02:00
|
|
|
static struct test_data {
|
2020-06-03 12:45:57 +02:00
|
|
|
BYTE *data;
|
2020-05-22 05:17:31 +02:00
|
|
|
UINT size;
|
2020-07-21 07:48:52 +02:00
|
|
|
HRESULT init_hr;
|
2020-05-22 05:17:31 +02:00
|
|
|
UINT expected_frame_count;
|
2020-07-15 16:01:25 +02:00
|
|
|
UINT expected_bytes_per_block;
|
2020-08-25 16:01:22 +02:00
|
|
|
UINT pixel_format_bpp;
|
2020-06-16 07:52:01 +02:00
|
|
|
const GUID *expected_pixel_format;
|
2020-05-22 05:17:31 +02:00
|
|
|
WICDdsParameters expected_parameters;
|
2020-07-10 11:09:20 +02:00
|
|
|
BOOL wine_init;
|
2020-05-22 05:17:31 +02:00
|
|
|
} test_data[] = {
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_alpha, sizeof(test_dds_alpha), WINCODEC_ERR_BADHEADER, 1, 1, 8, &GUID_WICPixelFormat8bppAlpha,
|
2020-07-23 08:01:40 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_A8_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_luminance, sizeof(test_dds_luminance), WINCODEC_ERR_BADHEADER, 1, 1, 8, &GUID_WICPixelFormat8bppGray,
|
2020-07-23 08:01:40 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_R8_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_rgb565, sizeof(test_dds_rgb565), WINCODEC_ERR_BADHEADER, 1, 2, 16, &GUID_WICPixelFormat16bppBGR565,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 4, 4, 1, 1, 1, DXGI_FORMAT_B5G6R5_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_24bpp, sizeof(test_dds_24bpp), WINCODEC_ERR_BADHEADER, 1, 3, 24, &GUID_WICPixelFormat24bppBGR,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_UNKNOWN, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_32bpp_xrgb, sizeof(test_dds_32bpp_xrgb), WINCODEC_ERR_BADHEADER, 1, 4, 32, &GUID_WICPixelFormat32bppBGR,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_B8G8R8X8_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_32bpp_argb, sizeof(test_dds_32bpp_argb), WINCODEC_ERR_BADHEADER, 1, 4, 32, &GUID_WICPixelFormat32bppBGRA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_B8G8R8A8_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-27 07:37:19 +02:00
|
|
|
{ test_dds_64bpp, sizeof(test_dds_64bpp), WINCODEC_ERR_BADHEADER, 1, 8, 64, &GUID_WICPixelFormat64bppRGBA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_R16G16B16A16_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_96bpp, sizeof(test_dds_96bpp), WINCODEC_ERR_BADHEADER, 1, 12, 96, &GUID_WICPixelFormat96bppRGBFloat,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_R32G32B32_FLOAT, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_128bpp, sizeof(test_dds_128bpp), WINCODEC_ERR_BADHEADER, 1, 16, 128, &GUID_WICPixelFormat128bppRGBAFloat,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 1, 1, 1, 1, 1, DXGI_FORMAT_R32G32B32A32_FLOAT, WICDdsTexture2D, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_cube, sizeof(test_dds_cube), WINCODEC_ERR_BADHEADER, 18, 8, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 4, 4, 1, 3, 1, DXGI_FORMAT_BC1_UNORM, WICDdsTextureCube, WICDdsAlphaModePremultiplied }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_cube_dx10, sizeof(test_dds_cube_dx10), WINCODEC_ERR_BADHEADER, 18, 8, 32, &GUID_WICPixelFormat32bppBGRA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 4, 4, 1, 3, 1, DXGI_FORMAT_BC1_UNORM, WICDdsTextureCube, WICDdsAlphaModeUnknown }, TRUE },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_mipmaps, sizeof(test_dds_mipmaps), S_OK, 3, 8, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 4, 4, 1, 3, 1, DXGI_FORMAT_BC1_UNORM, WICDdsTexture2D, WICDdsAlphaModePremultiplied } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_volume, sizeof(test_dds_volume), S_OK, 7, 8, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 4, 4, 4, 3, 1, DXGI_FORMAT_BC1_UNORM, WICDdsTexture3D, WICDdsAlphaModePremultiplied } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_array, sizeof(test_dds_array), S_OK, 9, 8, 32, &GUID_WICPixelFormat32bppBGRA,
|
2020-07-18 05:17:54 +02:00
|
|
|
{ 4, 4, 1, 3, 3, DXGI_FORMAT_BC1_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_dxt1c, sizeof(test_dds_dxt1c), S_OK, 1, 8, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-23 08:02:36 +02:00
|
|
|
{ 4, 4, 1, 1, 1, DXGI_FORMAT_BC1_UNORM, WICDdsTexture2D, WICDdsAlphaModePremultiplied } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_dxt1a, sizeof(test_dds_dxt1a), S_OK, 1, 8, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-23 08:02:36 +02:00
|
|
|
{ 4, 4, 1, 1, 1, DXGI_FORMAT_BC1_UNORM, WICDdsTexture2D, WICDdsAlphaModePremultiplied } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_dxt2, sizeof(test_dds_dxt2), S_OK, 3, 16, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-23 08:02:36 +02:00
|
|
|
{ 4, 4, 1, 3, 1, DXGI_FORMAT_BC2_UNORM, WICDdsTexture2D, WICDdsAlphaModePremultiplied } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_dxt3, sizeof(test_dds_dxt3), S_OK, 2, 16, 32, &GUID_WICPixelFormat32bppBGRA,
|
2020-07-23 08:02:36 +02:00
|
|
|
{ 1, 3, 1, 2, 1, DXGI_FORMAT_BC2_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_dxt4, sizeof(test_dds_dxt4), S_OK, 3, 16, 32, &GUID_WICPixelFormat32bppPBGRA,
|
2020-07-23 08:02:36 +02:00
|
|
|
{ 4, 4, 1, 3, 1, DXGI_FORMAT_BC3_UNORM, WICDdsTexture2D, WICDdsAlphaModePremultiplied } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_dxt5, sizeof(test_dds_dxt5), S_OK, 3, 16, 32, &GUID_WICPixelFormat32bppBGRA,
|
2020-07-23 08:02:36 +02:00
|
|
|
{ 6, 6, 1, 3, 1, DXGI_FORMAT_BC3_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown } },
|
2020-08-25 16:01:22 +02:00
|
|
|
{ test_dds_12x12, sizeof(test_dds_12x12), S_OK, 8, 16, 32, &GUID_WICPixelFormat32bppBGRA,
|
2020-07-21 07:48:52 +02:00
|
|
|
{ 12, 12, 1, 4, 2, DXGI_FORMAT_BC2_UNORM, WICDdsTexture2D, WICDdsAlphaModeUnknown } },
|
|
|
|
{ test_dds_bad_magic, sizeof(test_dds_bad_magic), WINCODEC_ERR_UNKNOWNIMAGEFORMAT },
|
|
|
|
{ test_dds_bad_header, sizeof(test_dds_bad_header), WINCODEC_ERR_BADHEADER },
|
|
|
|
{ test_byte, sizeof(test_byte), WINCODEC_ERR_STREAMREAD },
|
|
|
|
{ test_word, sizeof(test_word), WINCODEC_ERR_STREAMREAD },
|
|
|
|
{ test_dword, sizeof(test_dword), WINCODEC_ERR_UNKNOWNIMAGEFORMAT },
|
|
|
|
{ test_qword_a, sizeof(test_qword_a), WINCODEC_ERR_UNKNOWNIMAGEFORMAT },
|
|
|
|
{ test_qword_b, sizeof(test_qword_b), WINCODEC_ERR_STREAMREAD },
|
2020-05-22 05:17:31 +02:00
|
|
|
};
|
2020-04-22 10:37:32 +02:00
|
|
|
|
2020-08-25 16:01:08 +02:00
|
|
|
static DXGI_FORMAT compressed_formats[] = {
|
|
|
|
DXGI_FORMAT_BC1_TYPELESS, DXGI_FORMAT_BC1_UNORM, DXGI_FORMAT_BC1_UNORM_SRGB,
|
|
|
|
DXGI_FORMAT_BC2_TYPELESS, DXGI_FORMAT_BC2_UNORM, DXGI_FORMAT_BC2_UNORM_SRGB,
|
|
|
|
DXGI_FORMAT_BC3_TYPELESS, DXGI_FORMAT_BC3_UNORM, DXGI_FORMAT_BC3_UNORM_SRGB,
|
|
|
|
DXGI_FORMAT_BC4_TYPELESS, DXGI_FORMAT_BC4_UNORM, DXGI_FORMAT_BC4_SNORM,
|
|
|
|
DXGI_FORMAT_BC5_TYPELESS, DXGI_FORMAT_BC5_UNORM, DXGI_FORMAT_BC5_SNORM,
|
|
|
|
DXGI_FORMAT_BC6H_TYPELESS, DXGI_FORMAT_BC6H_UF16, DXGI_FORMAT_BC6H_SF16,
|
|
|
|
DXGI_FORMAT_BC7_TYPELESS, DXGI_FORMAT_BC7_UNORM, DXGI_FORMAT_BC7_UNORM_SRGB
|
|
|
|
};
|
|
|
|
|
2020-04-15 12:41:43 +02:00
|
|
|
static IWICImagingFactory *factory = NULL;
|
|
|
|
|
|
|
|
static IWICStream *create_stream(const void *image_data, UINT image_size)
|
|
|
|
{
|
|
|
|
HRESULT hr;
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
|
|
|
|
hr = IWICImagingFactory_CreateStream(factory, &stream);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CreateStream failed, hr %#lx\n", hr);
|
2020-04-20 06:00:18 +02:00
|
|
|
if (hr != S_OK) goto fail;
|
2020-04-15 12:41:43 +02:00
|
|
|
|
|
|
|
hr = IWICStream_InitializeFromMemory(stream, (BYTE *)image_data, image_size);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "InitializeFromMemory failed, hr %#lx\n", hr);
|
2020-04-20 06:00:18 +02:00
|
|
|
if (hr != S_OK) goto fail;
|
2020-04-15 12:41:43 +02:00
|
|
|
|
|
|
|
return stream;
|
|
|
|
|
|
|
|
fail:
|
|
|
|
if (stream) IWICStream_Release(stream);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2020-04-16 11:43:00 +02:00
|
|
|
static IWICBitmapDecoder *create_decoder(void)
|
2020-04-15 12:41:43 +02:00
|
|
|
{
|
|
|
|
HRESULT hr;
|
|
|
|
IWICBitmapDecoder *decoder = NULL;
|
|
|
|
GUID guidresult;
|
|
|
|
|
|
|
|
hr = CoCreateInstance(&CLSID_WICDdsDecoder, NULL, CLSCTX_INPROC_SERVER,
|
|
|
|
&IID_IWICBitmapDecoder, (void **)&decoder);
|
2020-04-20 06:00:18 +02:00
|
|
|
if (hr != S_OK) {
|
2020-04-15 12:41:43 +02:00
|
|
|
win_skip("Dds decoder is not supported\n");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
memset(&guidresult, 0, sizeof(guidresult));
|
|
|
|
hr = IWICBitmapDecoder_GetContainerFormat(decoder, &guidresult);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetContainerFormat failed, hr %#lx\n", hr);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(IsEqualGUID(&guidresult, &GUID_ContainerFormatDds),
|
2021-01-29 06:02:40 +01:00
|
|
|
"Got unexpected container format %s\n", debugstr_guid(&guidresult));
|
2020-04-15 12:41:43 +02:00
|
|
|
|
2020-04-16 11:43:00 +02:00
|
|
|
return decoder;
|
|
|
|
}
|
|
|
|
|
2021-05-01 05:14:34 +02:00
|
|
|
static IWICBitmapEncoder *create_encoder(void)
|
|
|
|
{
|
|
|
|
IWICBitmapEncoder *encoder = NULL;
|
|
|
|
GUID guidresult;
|
|
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
hr = CoCreateInstance(&CLSID_WICDdsEncoder, NULL, CLSCTX_INPROC_SERVER,
|
|
|
|
&IID_IWICBitmapEncoder, (void **)&encoder);
|
|
|
|
if (hr != S_OK)
|
|
|
|
{
|
|
|
|
win_skip("DDS encoder is not supported\n");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
memset(&guidresult, 0, sizeof(guidresult));
|
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_GetContainerFormat(encoder, &guidresult);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetContainerFormat failed, hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
ok(IsEqualGUID(&guidresult, &GUID_ContainerFormatDds),
|
|
|
|
"Got unexpected container format %s\n", debugstr_guid(&guidresult));
|
|
|
|
|
|
|
|
return encoder;
|
|
|
|
}
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
static HRESULT init_decoder(IWICBitmapDecoder *decoder, IWICStream *stream, HRESULT expected, BOOL wine_init)
|
2020-04-16 11:43:00 +02:00
|
|
|
{
|
|
|
|
HRESULT hr;
|
2020-07-10 11:09:20 +02:00
|
|
|
IWICWineDecoder *wine_decoder;
|
2020-04-16 11:43:00 +02:00
|
|
|
|
2020-04-15 12:41:43 +02:00
|
|
|
hr = IWICBitmapDecoder_Initialize(decoder, (IStream*)stream, WICDecodeMetadataCacheOnDemand);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == expected, "Expected hr %#lx, got %#lx\n", expected, hr);
|
2020-07-10 11:09:20 +02:00
|
|
|
|
|
|
|
if (hr != S_OK && wine_init) {
|
|
|
|
hr = IWICBitmapDecoder_QueryInterface(decoder, &IID_IWICWineDecoder, (void **)&wine_decoder);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK || broken(hr != S_OK), "QueryInterface failed, hr %#lx\n", hr);
|
2020-07-21 07:49:18 +02:00
|
|
|
|
2020-07-10 11:09:20 +02:00
|
|
|
if (hr == S_OK) {
|
|
|
|
hr = IWICWineDecoder_Initialize(wine_decoder, (IStream*)stream, WICDecodeMetadataCacheOnDemand);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "Initialize failed, hr %#lx\n", hr);
|
2020-07-10 11:09:20 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-16 11:43:00 +02:00
|
|
|
return hr;
|
|
|
|
}
|
2020-04-15 12:41:43 +02:00
|
|
|
|
2021-05-24 04:58:18 +02:00
|
|
|
static void release_encoder(IWICBitmapEncoder *encoder, IWICDdsEncoder *dds_encoder, IWICStream *stream)
|
|
|
|
{
|
|
|
|
if (dds_encoder) IWICDdsEncoder_Release(dds_encoder);
|
|
|
|
if (stream) IWICStream_Release(stream);
|
|
|
|
if (encoder) IWICBitmapEncoder_Release(encoder);
|
|
|
|
}
|
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
static HRESULT create_and_init_encoder(BYTE *image_buffer, UINT buffer_size, WICDdsParameters *params,
|
2021-05-24 04:58:18 +02:00
|
|
|
IWICBitmapEncoder **encoder, IWICDdsEncoder **dds_encoder, IWICStream **stream)
|
|
|
|
{
|
2021-05-29 02:26:43 +02:00
|
|
|
IWICDdsEncoder *dds = NULL;
|
2021-05-24 04:58:18 +02:00
|
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
*encoder = create_encoder();
|
|
|
|
if (!*encoder) goto fail;
|
|
|
|
|
|
|
|
*stream = create_stream(image_buffer, buffer_size);
|
|
|
|
if (!*stream) goto fail;
|
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(*encoder, (IStream *)*stream, WICBitmapEncoderNoCache);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "Initialize failed, hr %#lx\n", hr);
|
2021-05-24 04:58:18 +02:00
|
|
|
if (hr != S_OK) goto fail;
|
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
hr = IWICBitmapEncoder_QueryInterface(*encoder, &IID_IWICDdsEncoder, (void **)&dds);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "QueryInterface failed, hr %#lx\n", hr);
|
2021-05-24 04:58:18 +02:00
|
|
|
if (hr != S_OK) goto fail;
|
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
if (params)
|
|
|
|
{
|
|
|
|
hr = IWICDdsEncoder_SetParameters(dds, params);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "SetParameters failed, hr %#lx\n", hr);
|
2021-05-29 02:26:43 +02:00
|
|
|
if (hr != S_OK) goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (dds_encoder)
|
|
|
|
{
|
|
|
|
*dds_encoder = dds;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
IWICDdsEncoder_Release(dds);
|
|
|
|
dds = NULL;
|
|
|
|
}
|
|
|
|
|
2021-05-24 04:58:18 +02:00
|
|
|
return S_OK;
|
|
|
|
|
|
|
|
fail:
|
2021-05-29 02:26:43 +02:00
|
|
|
release_encoder(*encoder, dds, *stream);
|
2021-05-24 04:58:18 +02:00
|
|
|
return E_FAIL;
|
|
|
|
}
|
|
|
|
|
2020-08-25 16:01:08 +02:00
|
|
|
static BOOL is_compressed(DXGI_FORMAT format)
|
|
|
|
{
|
|
|
|
UINT i;
|
|
|
|
for (i = 0; i < ARRAY_SIZE(compressed_formats); i++)
|
|
|
|
{
|
|
|
|
if (format == compressed_formats[i]) return TRUE;
|
|
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2020-06-03 12:45:57 +02:00
|
|
|
static BOOL has_extended_header(const BYTE *data)
|
|
|
|
{
|
|
|
|
return data[84] == 'D' && data[85] == 'X' && data[86] == '1' && data[87] == '0';
|
|
|
|
}
|
|
|
|
|
2020-08-19 04:02:35 +02:00
|
|
|
static DWORD rgb565_to_argb(WORD color, BYTE alpha)
|
2020-08-17 04:24:13 +02:00
|
|
|
{
|
2020-08-19 04:02:35 +02:00
|
|
|
return MAKE_ARGB(alpha, (GET_RGB565_R(color) * 0xFF + 0x0F) / 0x1F,
|
|
|
|
(GET_RGB565_G(color) * 0xFF + 0x1F) / 0x3F,
|
|
|
|
(GET_RGB565_B(color) * 0xFF + 0x0F) / 0x1F);
|
2020-08-17 04:24:13 +02:00
|
|
|
}
|
|
|
|
|
2020-08-19 04:03:37 +02:00
|
|
|
static void decode_block(const BYTE *block_data, UINT block_count, DXGI_FORMAT format,
|
|
|
|
UINT width, UINT height, DWORD *buffer)
|
2020-08-17 04:24:13 +02:00
|
|
|
{
|
2020-08-19 04:03:37 +02:00
|
|
|
const BYTE *block, *color_indices, *alpha_indices, *alpha_table;
|
|
|
|
int i, j, x, y, block_x, block_y, color_index, alpha_index;
|
|
|
|
int block_size, color_offset, color_indices_offset;
|
|
|
|
WORD color[4], color_value = 0;
|
|
|
|
BYTE alpha[8], alpha_value = 0;
|
|
|
|
|
|
|
|
if (format == DXGI_FORMAT_BC1_UNORM) {
|
|
|
|
block_size = 8;
|
|
|
|
color_offset = 0;
|
|
|
|
color_indices_offset = 4;
|
|
|
|
} else {
|
|
|
|
block_size = 16;
|
|
|
|
color_offset = 8;
|
|
|
|
color_indices_offset = 12;
|
2020-08-17 04:24:13 +02:00
|
|
|
}
|
2020-08-19 04:02:35 +02:00
|
|
|
block_x = 0;
|
|
|
|
block_y = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < block_count; i++)
|
|
|
|
{
|
2020-08-19 04:03:37 +02:00
|
|
|
block = block_data + i * block_size;
|
2020-08-19 04:02:35 +02:00
|
|
|
|
2020-08-19 04:03:37 +02:00
|
|
|
color[0] = *((WORD *)(block + color_offset));
|
|
|
|
color[1] = *((WORD *)(block + color_offset + 2));
|
2020-08-19 04:02:35 +02:00
|
|
|
color[2] = MAKE_RGB565(((GET_RGB565_R(color[0]) * 2 + GET_RGB565_R(color[1]) + 1) / 3),
|
|
|
|
((GET_RGB565_G(color[0]) * 2 + GET_RGB565_G(color[1]) + 1) / 3),
|
|
|
|
((GET_RGB565_B(color[0]) * 2 + GET_RGB565_B(color[1]) + 1) / 3));
|
|
|
|
color[3] = MAKE_RGB565(((GET_RGB565_R(color[0]) + GET_RGB565_R(color[1]) * 2 + 1) / 3),
|
|
|
|
((GET_RGB565_G(color[0]) + GET_RGB565_G(color[1]) * 2 + 1) / 3),
|
|
|
|
((GET_RGB565_B(color[0]) + GET_RGB565_B(color[1]) * 2 + 1) / 3));
|
|
|
|
|
2020-08-19 04:03:37 +02:00
|
|
|
switch (format)
|
2020-08-19 04:02:35 +02:00
|
|
|
{
|
2020-08-19 04:03:37 +02:00
|
|
|
case DXGI_FORMAT_BC1_UNORM:
|
|
|
|
if (color[0] <= color[1]) {
|
|
|
|
color[2] = MAKE_RGB565(((GET_RGB565_R(color[0]) + GET_RGB565_R(color[1]) + 1) / 2),
|
|
|
|
((GET_RGB565_G(color[0]) + GET_RGB565_G(color[1]) + 1) / 2),
|
|
|
|
((GET_RGB565_B(color[0]) + GET_RGB565_B(color[1]) + 1) / 2));
|
|
|
|
color[3] = 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case DXGI_FORMAT_BC2_UNORM:
|
|
|
|
alpha_table = block;
|
|
|
|
break;
|
|
|
|
case DXGI_FORMAT_BC3_UNORM:
|
|
|
|
alpha[0] = *block;
|
|
|
|
alpha[1] = *(block + 1);
|
|
|
|
if (alpha[0] > alpha[1]) {
|
|
|
|
for (j = 2; j < 8; j++)
|
|
|
|
{
|
|
|
|
alpha[j] = (BYTE)((alpha[0] * (8 - j) + alpha[1] * (j - 1) + 3) / 7);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
for (j = 2; j < 6; j++)
|
|
|
|
{
|
|
|
|
alpha[j] = (BYTE)((alpha[0] * (6 - j) + alpha[1] * (j - 1) + 2) / 5);
|
|
|
|
}
|
|
|
|
alpha[6] = 0;
|
|
|
|
alpha[7] = 0xFF;
|
|
|
|
}
|
|
|
|
alpha_indices = block + 2;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
2020-08-19 04:03:04 +02:00
|
|
|
}
|
|
|
|
|
2020-08-19 04:03:37 +02:00
|
|
|
color_indices = block + color_indices_offset;
|
2020-08-19 04:03:04 +02:00
|
|
|
for (j = 0; j < 16; j++)
|
|
|
|
{
|
|
|
|
x = block_x + j % 4;
|
|
|
|
y = block_y + j / 4;
|
|
|
|
if (x >= width || y >= height) continue;
|
2020-08-19 04:03:37 +02:00
|
|
|
|
2020-08-19 04:03:04 +02:00
|
|
|
color_index = (color_indices[j / 4] >> ((j % 4) * 2)) & 0x3;
|
2020-08-19 04:03:37 +02:00
|
|
|
color_value = color[color_index];
|
|
|
|
|
|
|
|
switch (format)
|
|
|
|
{
|
|
|
|
case DXGI_FORMAT_BC1_UNORM:
|
|
|
|
if ((color[0] <= color[1]) && !color_value) {
|
|
|
|
color_value = 0;
|
|
|
|
alpha_value = 0;
|
|
|
|
} else {
|
|
|
|
alpha_value = 0xFF;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case DXGI_FORMAT_BC2_UNORM:
|
|
|
|
alpha_value = (alpha_table[j / 2] >> (j % 2) * 4) & 0xF;
|
|
|
|
alpha_value = (BYTE)((alpha_value * 0xFF + 0x7)/ 0xF);
|
|
|
|
break;
|
|
|
|
case DXGI_FORMAT_BC3_UNORM:
|
|
|
|
alpha_index = (*((DWORD *)(alpha_indices + (j / 8) * 3)) >> ((j % 8) * 3)) & 0x7;
|
|
|
|
alpha_value = alpha[alpha_index];
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
buffer[x + y * width] = rgb565_to_argb(color_value, alpha_value);
|
2020-08-19 04:03:04 +02:00
|
|
|
}
|
|
|
|
|
2020-08-19 04:04:05 +02:00
|
|
|
block_x += BLOCK_WIDTH;
|
2020-08-19 04:03:04 +02:00
|
|
|
if (block_x >= width) {
|
|
|
|
block_x = 0;
|
2020-08-19 04:04:05 +02:00
|
|
|
block_y += BLOCK_HEIGHT;
|
2020-08-19 04:03:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-17 04:24:13 +02:00
|
|
|
static BOOL color_match(DWORD color_a, DWORD color_b)
|
|
|
|
{
|
|
|
|
static const int tolerance = 8;
|
|
|
|
|
|
|
|
const int da = abs((int)((color_a & 0xFF000000) >> 24) - (int)((color_b & 0xFF000000) >> 24));
|
|
|
|
const int dr = abs((int)((color_a & 0x00FF0000) >> 16) - (int)((color_b & 0x00FF0000) >> 16));
|
|
|
|
const int dg = abs((int)((color_a & 0x0000FF00) >> 8) - (int)((color_b & 0x0000FF00) >> 8));
|
|
|
|
const int db = abs((int)((color_a & 0x000000FF) >> 0) - (int)((color_b & 0x000000FF) >> 0));
|
|
|
|
|
|
|
|
return (da <= tolerance && dr <= tolerance && dg <= tolerance && db <= tolerance);
|
|
|
|
}
|
|
|
|
|
|
|
|
static BOOL color_buffer_match(DWORD *color_buffer_a, DWORD *color_buffer_b, UINT color_count)
|
|
|
|
{
|
|
|
|
UINT i;
|
|
|
|
|
|
|
|
for (i = 0; i < color_count; i++)
|
|
|
|
{
|
|
|
|
if (!color_match(color_buffer_a[i], color_buffer_b[i])) return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
static void copy_pixels(void *src_buffer, UINT src_stride, void *dst_buffer, UINT dst_stride, UINT size)
|
|
|
|
{
|
|
|
|
char *src = src_buffer, *dst = dst_buffer;
|
|
|
|
UINT i;
|
|
|
|
|
|
|
|
for (i = 0; i < size; i++)
|
|
|
|
{
|
|
|
|
*dst = src[i];
|
|
|
|
if (i % src_stride == src_stride - 1) dst += dst_stride - src_stride;
|
|
|
|
dst ++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-16 11:43:00 +02:00
|
|
|
static void test_dds_decoder_initialize(void)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2020-07-23 08:02:36 +02:00
|
|
|
memcpy(test_dds_bad_magic, test_dds_dxt1c, sizeof(test_dds_dxt1c));
|
|
|
|
memcpy(test_dds_bad_header, test_dds_dxt1c, sizeof(test_dds_dxt1c));
|
2020-04-16 11:43:00 +02:00
|
|
|
test_dds_bad_magic[0] = 0;
|
|
|
|
test_dds_bad_header[4] = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(test_data); i++)
|
|
|
|
{
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
IWICBitmapDecoder *decoder = NULL;
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_push_context("Test %u", i);
|
|
|
|
|
2020-04-16 11:43:00 +02:00
|
|
|
stream = create_stream(test_data[i].data, test_data[i].size);
|
|
|
|
if (!stream) goto next;
|
|
|
|
|
|
|
|
decoder = create_decoder();
|
|
|
|
if (!decoder) goto next;
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
init_decoder(decoder, stream, test_data[i].init_hr, test_data[i].wine_init);
|
2020-04-16 11:43:00 +02:00
|
|
|
|
|
|
|
next:
|
|
|
|
if (decoder) IWICBitmapDecoder_Release(decoder);
|
|
|
|
if (stream) IWICStream_Release(stream);
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_pop_context();
|
2020-04-16 11:43:00 +02:00
|
|
|
}
|
2020-04-15 12:41:43 +02:00
|
|
|
}
|
|
|
|
|
2020-04-20 05:59:37 +02:00
|
|
|
static void test_dds_decoder_global_properties(IWICBitmapDecoder *decoder)
|
|
|
|
{
|
|
|
|
HRESULT hr;
|
2020-05-16 12:18:08 +02:00
|
|
|
IWICPalette *palette = NULL;
|
2020-04-20 05:59:37 +02:00
|
|
|
IWICMetadataQueryReader *metadata_reader = NULL;
|
|
|
|
IWICBitmapSource *preview = NULL, *thumnail = NULL;
|
|
|
|
IWICColorContext *color_context = NULL;
|
|
|
|
UINT count;
|
|
|
|
|
2020-05-16 12:18:08 +02:00
|
|
|
hr = IWICImagingFactory_CreatePalette(factory, &palette);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CreatePalette failed, hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
if (hr == S_OK) {
|
2020-05-16 12:18:08 +02:00
|
|
|
hr = IWICBitmapDecoder_CopyPalette(decoder, palette);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_PALETTEUNAVAILABLE, "CopyPalette got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
hr = IWICBitmapDecoder_CopyPalette(decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_PALETTEUNAVAILABLE, "CopyPalette got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
hr = IWICBitmapDecoder_GetMetadataQueryReader(decoder, &metadata_reader);
|
2022-03-09 08:21:55 +01:00
|
|
|
todo_wine ok (hr == S_OK, "GetMetadataQueryReader got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
hr = IWICBitmapDecoder_GetMetadataQueryReader(decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetMetadataQueryReader got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapDecoder_GetPreview(decoder, &preview);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_UNSUPPORTEDOPERATION, "GetPreview got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
hr = IWICBitmapDecoder_GetPreview(decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_UNSUPPORTEDOPERATION, "GetPreview got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapDecoder_GetColorContexts(decoder, 1, &color_context, &count);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_UNSUPPORTEDOPERATION, "GetColorContexts got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
hr = IWICBitmapDecoder_GetColorContexts(decoder, 1, NULL, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_UNSUPPORTEDOPERATION, "GetColorContexts got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapDecoder_GetThumbnail(decoder, &thumnail);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_CODECNOTHUMBNAIL, "GetThumbnail got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
hr = IWICBitmapDecoder_GetThumbnail(decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_CODECNOTHUMBNAIL, "GetThumbnail got unexpected hr %#lx\n", hr);
|
2020-04-20 05:59:37 +02:00
|
|
|
|
2020-05-16 12:18:08 +02:00
|
|
|
if (palette) IWICPalette_Release(palette);
|
2020-04-20 05:59:37 +02:00
|
|
|
if (metadata_reader) IWICMetadataQueryReader_Release(metadata_reader);
|
|
|
|
if (preview) IWICBitmapSource_Release(preview);
|
|
|
|
if (color_context) IWICColorContext_Release(color_context);
|
|
|
|
if (thumnail) IWICBitmapSource_Release(thumnail);
|
|
|
|
}
|
|
|
|
|
2020-05-12 04:25:06 +02:00
|
|
|
static void test_dds_decoder_image_parameters(void)
|
2020-04-22 10:37:51 +02:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
HRESULT hr;
|
2020-05-12 04:25:06 +02:00
|
|
|
WICDdsParameters parameters;
|
2020-04-22 10:37:51 +02:00
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(test_data); i++)
|
|
|
|
{
|
|
|
|
UINT frame_count;
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
IWICBitmapDecoder *decoder = NULL;
|
2020-05-12 04:25:06 +02:00
|
|
|
IWICDdsDecoder *dds_decoder = NULL;
|
2020-04-22 10:37:51 +02:00
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_push_context("Test %u", i);
|
|
|
|
|
2020-04-22 10:37:51 +02:00
|
|
|
stream = create_stream(test_data[i].data, test_data[i].size);
|
|
|
|
if (!stream) goto next;
|
|
|
|
|
|
|
|
decoder = create_decoder();
|
|
|
|
if (!decoder) goto next;
|
|
|
|
|
2020-05-12 04:25:06 +02:00
|
|
|
hr = IWICBitmapDecoder_QueryInterface(decoder, &IID_IWICDdsDecoder, (void **)&dds_decoder);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "QueryInterface failed, hr %#lx\n", hr);
|
2020-05-12 04:25:06 +02:00
|
|
|
if (hr != S_OK) goto next;
|
|
|
|
|
2020-04-23 11:29:49 +02:00
|
|
|
hr = IWICBitmapDecoder_GetFrameCount(decoder, &frame_count);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_WRONGSTATE, "GetFrameCount got unexpected hr %#lx\n", hr);
|
2020-04-23 11:29:49 +02:00
|
|
|
hr = IWICBitmapDecoder_GetFrameCount(decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetFrameCount got unexpected hr %#lx\n", hr);
|
2020-04-23 11:29:49 +02:00
|
|
|
|
2020-05-12 04:25:06 +02:00
|
|
|
hr = IWICDdsDecoder_GetParameters(dds_decoder, ¶meters);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_WRONGSTATE, "GetParameters got unexpected hr %#lx\n", hr);
|
2020-05-12 04:25:06 +02:00
|
|
|
hr = IWICDdsDecoder_GetParameters(dds_decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetParameters got unexpected hr %#lx\n", hr);
|
2020-05-12 04:25:06 +02:00
|
|
|
|
2020-07-21 07:48:52 +02:00
|
|
|
if (test_data[i].init_hr != S_OK && !test_data[i].wine_init) continue;
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
hr = init_decoder(decoder, stream, test_data[i].init_hr, test_data[i].wine_init);
|
2020-07-15 16:01:25 +02:00
|
|
|
if (hr != S_OK) {
|
2020-07-18 05:17:54 +02:00
|
|
|
if (test_data[i].expected_parameters.Dimension == WICDdsTextureCube) {
|
2021-06-15 03:59:50 +02:00
|
|
|
win_skip("Cube map is not supported\n");
|
2020-07-18 05:17:54 +02:00
|
|
|
} else {
|
2021-06-15 03:59:50 +02:00
|
|
|
win_skip("Uncompressed DDS image is not supported\n");
|
2020-07-18 05:17:54 +02:00
|
|
|
}
|
2020-07-15 16:01:25 +02:00
|
|
|
goto next;
|
|
|
|
}
|
2020-04-22 10:37:51 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapDecoder_GetFrameCount(decoder, &frame_count);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetFrameCount failed, hr %#lx\n", hr);
|
2020-04-22 10:37:51 +02:00
|
|
|
if (hr == S_OK) {
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(frame_count == test_data[i].expected_frame_count, "Expected frame count %u, got %u\n",
|
|
|
|
test_data[i].expected_frame_count, frame_count);
|
2020-04-22 10:37:51 +02:00
|
|
|
}
|
2020-04-23 11:29:49 +02:00
|
|
|
hr = IWICBitmapDecoder_GetFrameCount(decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetParameters got unexpected hr %#lx\n", hr);
|
2020-04-22 10:37:51 +02:00
|
|
|
|
2020-05-12 04:25:06 +02:00
|
|
|
hr = IWICDdsDecoder_GetParameters(dds_decoder, ¶meters);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetParameters failed, hr %#lx\n", hr);
|
2020-05-12 04:25:06 +02:00
|
|
|
if (hr == S_OK) {
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.Width == test_data[i].expected_parameters.Width,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected Width %u, got %u\n", test_data[i].expected_parameters.Width, parameters.Width);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.Height == test_data[i].expected_parameters.Height,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected Height %u, got %u\n", test_data[i].expected_parameters.Height, parameters.Height);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.Depth == test_data[i].expected_parameters.Depth,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected Depth %u, got %u\n", test_data[i].expected_parameters.Depth, parameters.Depth);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.MipLevels == test_data[i].expected_parameters.MipLevels,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected MipLevels %u, got %u\n", test_data[i].expected_parameters.MipLevels, parameters.MipLevels);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.ArraySize == test_data[i].expected_parameters.ArraySize,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected ArraySize %u, got %u\n", test_data[i].expected_parameters.ArraySize, parameters.ArraySize);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.DxgiFormat == test_data[i].expected_parameters.DxgiFormat,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected DxgiFormat %#x, got %#x\n", test_data[i].expected_parameters.DxgiFormat, parameters.DxgiFormat);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.Dimension == test_data[i].expected_parameters.Dimension,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected Dimension %#x, got %#x\n", test_data[i].expected_parameters.Dimension, parameters.Dimension);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(parameters.AlphaMode == test_data[i].expected_parameters.AlphaMode,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected AlphaMode %#x, got %#x\n", test_data[i].expected_parameters.AlphaMode, parameters.AlphaMode);
|
2020-05-12 04:25:06 +02:00
|
|
|
}
|
|
|
|
hr = IWICDdsDecoder_GetParameters(dds_decoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetParameters got unexpected hr %#lx\n", hr);
|
2020-05-12 04:25:06 +02:00
|
|
|
|
2020-04-22 10:37:51 +02:00
|
|
|
next:
|
|
|
|
if (decoder) IWICBitmapDecoder_Release(decoder);
|
|
|
|
if (stream) IWICStream_Release(stream);
|
2020-05-12 04:25:06 +02:00
|
|
|
if (dds_decoder) IWICDdsDecoder_Release(dds_decoder);
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_pop_context();
|
2020-04-22 10:37:51 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-03 12:45:57 +02:00
|
|
|
static void test_dds_decoder_frame_properties(IWICBitmapFrameDecode *frame_decode, IWICDdsFrameDecode *dds_frame,
|
2021-06-15 03:59:50 +02:00
|
|
|
UINT frame_count, WICDdsParameters *params, struct test_data *test, UINT frame_index)
|
2020-04-15 12:41:43 +02:00
|
|
|
{
|
2020-04-16 11:43:00 +02:00
|
|
|
HRESULT hr;
|
2020-05-22 05:17:31 +02:00
|
|
|
UINT width, height ,expected_width, expected_height, slice_index, depth;
|
2020-06-01 06:59:32 +02:00
|
|
|
UINT width_in_blocks, height_in_blocks, expected_width_in_blocks, expected_height_in_blocks;
|
2020-07-15 16:01:25 +02:00
|
|
|
UINT expected_block_width, expected_block_height;
|
2020-06-01 06:59:07 +02:00
|
|
|
WICDdsFormatInfo format_info;
|
2020-06-16 07:52:01 +02:00
|
|
|
GUID pixel_format;
|
2020-04-15 12:41:43 +02:00
|
|
|
|
2020-06-01 06:59:07 +02:00
|
|
|
/* frame size tests */
|
|
|
|
|
2020-06-01 06:58:52 +02:00
|
|
|
hr = IWICBitmapFrameDecode_GetSize(frame_decode, NULL, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetSize got unexpected hr %#lx\n", hr);
|
2020-06-01 06:58:52 +02:00
|
|
|
hr = IWICBitmapFrameDecode_GetSize(frame_decode, NULL, &height);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetSize got unexpected hr %#lx\n", hr);
|
2020-06-01 06:58:52 +02:00
|
|
|
hr = IWICBitmapFrameDecode_GetSize(frame_decode, &width, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetSize got unexpected hr %#lx\n", hr);
|
2020-05-22 05:17:31 +02:00
|
|
|
hr = IWICBitmapFrameDecode_GetSize(frame_decode, &width, &height);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetSize failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-04-16 11:43:00 +02:00
|
|
|
|
2020-06-03 12:45:57 +02:00
|
|
|
depth = params->Depth;
|
|
|
|
expected_width = params->Width;
|
|
|
|
expected_height = params->Height;
|
|
|
|
slice_index = frame_index % (frame_count / params->ArraySize);
|
2020-05-22 05:17:31 +02:00
|
|
|
while (slice_index >= depth)
|
|
|
|
{
|
|
|
|
if (expected_width > 1) expected_width /= 2;
|
|
|
|
if (expected_height > 1) expected_height /= 2;
|
|
|
|
slice_index -= depth;
|
|
|
|
if (depth > 1) depth /= 2;
|
|
|
|
}
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(width == expected_width, "Expected width %u, got %u\n", expected_width, width);
|
|
|
|
ok(height == expected_height, "Expected height %u, got %u\n", expected_height, height);
|
2020-05-22 05:17:31 +02:00
|
|
|
|
2020-06-01 06:59:07 +02:00
|
|
|
/* frame format information tests */
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
if (is_compressed(test->expected_parameters.DxgiFormat)) {
|
2020-08-19 04:04:05 +02:00
|
|
|
expected_block_width = BLOCK_WIDTH;
|
|
|
|
expected_block_height = BLOCK_HEIGHT;
|
2020-08-25 16:01:08 +02:00
|
|
|
} else {
|
|
|
|
expected_block_width = 1;
|
|
|
|
expected_block_height = 1;
|
2020-07-15 16:01:25 +02:00
|
|
|
}
|
|
|
|
|
2020-06-01 06:59:07 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetFormatInfo(dds_frame, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetFormatInfo got unexpected hr %#lx\n", hr);
|
2020-06-01 06:59:07 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetFormatInfo(dds_frame, &format_info);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetFormatInfo failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-06-01 06:59:07 +02:00
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(format_info.DxgiFormat == test->expected_parameters.DxgiFormat,
|
|
|
|
"Expected DXGI format %#x, got %#x\n",
|
|
|
|
test->expected_parameters.DxgiFormat, format_info.DxgiFormat);
|
|
|
|
ok(format_info.BytesPerBlock == test->expected_bytes_per_block,
|
|
|
|
"Expected bytes per block %u, got %u\n",
|
|
|
|
test->expected_bytes_per_block, format_info.BytesPerBlock);
|
2020-07-15 16:01:25 +02:00
|
|
|
ok(format_info.BlockWidth == expected_block_width,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected block width %u, got %u\n",
|
|
|
|
expected_block_width, format_info.BlockWidth);
|
2020-07-15 16:01:25 +02:00
|
|
|
ok(format_info.BlockHeight == expected_block_height,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected block height %u, got %u\n",
|
|
|
|
expected_block_height, format_info.BlockHeight);
|
2020-07-18 05:15:38 +02:00
|
|
|
|
2020-06-01 06:59:07 +02:00
|
|
|
|
2020-06-01 06:59:32 +02:00
|
|
|
/* size in blocks tests */
|
|
|
|
|
|
|
|
hr = IWICDdsFrameDecode_GetSizeInBlocks(dds_frame, NULL, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetSizeInBlocks got unexpected hr %#lx\n", hr);
|
2020-06-01 06:59:32 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetSizeInBlocks(dds_frame, NULL, &height_in_blocks);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetSizeInBlocks got unexpected hr %#lx\n", hr);
|
2020-06-01 06:59:32 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetSizeInBlocks(dds_frame, &width_in_blocks, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetSizeInBlocks got unexpected hr %#lx\n", hr);
|
2020-06-01 06:59:32 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetSizeInBlocks(dds_frame, &width_in_blocks, &height_in_blocks);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetSizeInBlocks failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-06-01 06:59:32 +02:00
|
|
|
|
2020-07-15 16:01:25 +02:00
|
|
|
expected_width_in_blocks = (expected_width + expected_block_width - 1) / expected_block_width;
|
|
|
|
expected_height_in_blocks = (expected_height + expected_block_height - 1) / expected_block_height;
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(width_in_blocks == expected_width_in_blocks,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected width in blocks %u, got %u\n", expected_width_in_blocks, width_in_blocks);
|
2020-06-19 04:37:16 +02:00
|
|
|
ok(height_in_blocks == expected_height_in_blocks,
|
2021-06-15 03:59:50 +02:00
|
|
|
"Expected height in blocks %u, got %u\n", expected_height_in_blocks, height_in_blocks);
|
2020-06-01 06:59:32 +02:00
|
|
|
|
2020-06-16 07:52:01 +02:00
|
|
|
/* pixel format tests */
|
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_GetPixelFormat(frame_decode, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetPixelFormat got unexpected hr %#lx\n", hr);
|
2020-06-16 07:52:01 +02:00
|
|
|
hr = IWICBitmapFrameDecode_GetPixelFormat(frame_decode, &pixel_format);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetPixelFormat failed, hr %#lx\n", hr);
|
2020-06-16 07:52:01 +02:00
|
|
|
if (hr != S_OK) return;
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(IsEqualGUID(&pixel_format, test->expected_pixel_format),
|
|
|
|
"Expected pixel format %s, got %s\n",
|
|
|
|
debugstr_guid(test->expected_pixel_format), debugstr_guid(&pixel_format));
|
2020-06-03 12:45:57 +02:00
|
|
|
}
|
|
|
|
|
2020-08-17 04:23:47 +02:00
|
|
|
static void test_dds_decoder_frame_data(IWICBitmapFrameDecode* frame, IWICDdsFrameDecode *dds_frame, UINT frame_count,
|
2021-06-15 03:59:50 +02:00
|
|
|
WICDdsParameters *params, struct test_data *test, UINT frame_index)
|
2020-06-03 12:45:57 +02:00
|
|
|
{
|
|
|
|
HRESULT hr;
|
2020-08-17 04:23:47 +02:00
|
|
|
GUID pixel_format;
|
2020-06-03 12:45:57 +02:00
|
|
|
WICDdsFormatInfo format_info;
|
2020-06-05 05:53:29 +02:00
|
|
|
WICRect rect = { 0, 0, 1, 1 }, rect_test_a = { 0, 0, 0, 0 }, rect_test_b = { 0, 0, 0xdeadbeaf, 0xdeadbeaf };
|
2020-06-09 06:28:09 +02:00
|
|
|
WICRect rect_test_c = { -0xdeadbeaf, -0xdeadbeaf, 1, 1 }, rect_test_d = { 0xdeadbeaf, 0xdeadbeaf, 1, 1 };
|
2020-08-25 16:01:56 +02:00
|
|
|
BYTE buffer[2048], pixels[2048];
|
2020-08-17 04:23:47 +02:00
|
|
|
UINT stride, frame_stride, frame_size, frame_width, frame_height, width_in_blocks, height_in_blocks, bpp;
|
2020-06-03 12:45:57 +02:00
|
|
|
UINT width, height, depth, array_index;
|
|
|
|
UINT block_offset;
|
|
|
|
int slice_index;
|
|
|
|
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &pixel_format);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetPixelFormat failed, hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
if (hr != S_OK) return;
|
|
|
|
hr = IWICBitmapFrameDecode_GetSize(frame, &frame_width, &frame_height);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetSize failed, hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-06-03 12:45:57 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetFormatInfo(dds_frame, &format_info);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetFormatInfo failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-06-09 06:28:09 +02:00
|
|
|
hr = IWICDdsFrameDecode_GetSizeInBlocks(dds_frame, &width_in_blocks, &height_in_blocks);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetSizeInBlocks failed, hr %#lx\n", hr);
|
2020-06-09 06:28:09 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-06-05 05:53:29 +02:00
|
|
|
stride = rect.Width * format_info.BytesPerBlock;
|
2020-06-09 06:28:09 +02:00
|
|
|
frame_stride = width_in_blocks * format_info.BytesPerBlock;
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
frame_size = frame_stride * height_in_blocks;
|
|
|
|
|
2020-08-17 04:23:47 +02:00
|
|
|
/* CopyBlocks tests */
|
|
|
|
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, 0, 0, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect_test_a, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect_test_b, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect_test_c, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect_test_d, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
|
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride - 1, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride * 2, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-09 06:28:09 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks got unexpected hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride, frame_stride * height_in_blocks - 1, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride, frame_stride * height_in_blocks, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
|
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, 0, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride - 1, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride * 2, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
|
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride, 0, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride, 1, buffer);
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(hr == E_INVALIDARG || (hr == S_OK && test->expected_bytes_per_block == 1),
|
2022-03-09 08:21:55 +01:00
|
|
|
"CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride, stride * rect.Height - 1, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride, stride * rect.Height, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
|
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride, sizeof(buffer), NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-06-05 05:53:29 +02:00
|
|
|
|
2020-06-03 12:45:57 +02:00
|
|
|
block_offset = 128; /* DDS magic and header */
|
2021-06-15 03:59:50 +02:00
|
|
|
if (has_extended_header(test->data)) block_offset += 20; /* DDS extended header */
|
2020-06-03 12:45:57 +02:00
|
|
|
width = params->Width;
|
|
|
|
height = params->Height;
|
|
|
|
depth = params->Depth;
|
|
|
|
slice_index = frame_index % (frame_count / params->ArraySize);
|
|
|
|
array_index = frame_index / (frame_count / params->ArraySize);
|
2021-06-15 03:59:50 +02:00
|
|
|
block_offset += (test->size - block_offset) / params->ArraySize * array_index;
|
2020-06-03 12:45:57 +02:00
|
|
|
while (slice_index >= 0)
|
|
|
|
{
|
|
|
|
width_in_blocks = (width + format_info.BlockWidth - 1) / format_info.BlockWidth;
|
|
|
|
height_in_blocks = (width + format_info.BlockWidth - 1) / format_info.BlockWidth;
|
|
|
|
block_offset += (slice_index >= depth) ?
|
|
|
|
(width_in_blocks * height_in_blocks * format_info.BytesPerBlock * depth) :
|
|
|
|
(width_in_blocks * height_in_blocks * format_info.BytesPerBlock * slice_index);
|
|
|
|
if (width > 1) width /= 2;
|
|
|
|
if (height > 1) height /= 2;
|
|
|
|
slice_index -= depth;
|
|
|
|
if (depth > 1) depth /= 2;
|
|
|
|
}
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
memset(buffer, 0, sizeof(buffer));
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, &rect, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks failed, hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
if (hr != S_OK) return;
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(!memcmp(test->data + block_offset, buffer, format_info.BytesPerBlock),
|
|
|
|
"Block data mismatch\n");
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
memset(buffer, 0, sizeof(buffer));
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks failed, hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
if (hr != S_OK) return;
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(!memcmp(test->data + block_offset, buffer, frame_size),
|
|
|
|
"Block data mismatch\n");
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
memset(buffer, 0, sizeof(buffer));
|
|
|
|
memset(pixels, 0, sizeof(pixels));
|
2021-06-15 03:59:50 +02:00
|
|
|
copy_pixels(test->data + block_offset, frame_stride, pixels, frame_stride * 2, frame_size);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
hr = IWICDdsFrameDecode_CopyBlocks(dds_frame, NULL, frame_stride * 2, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyBlocks failed, hr %#lx\n", hr);
|
windowscodecs/tests: Add more tests for DdsFrameDecode_Dds_CopyBlocks() when "boundsInBlocks" is NULL.
The added tests shows that when boundsInBlocks parameter is NULL,
stride parameter will be checked to ensure it is bigger or equal to
frame stride, but it will be ignored in the call. This can be proved
by:
* CopyBlocks(NULL, frame_stride - 1, sizeof(buffer), buffer) return
error.
* CopyBlocks(NULL, frame_stride, sizeof(buffer), buffer) and
CopyBlocks(NULL, frame_stride * 2, sizeof(buffer), buffer) works fine
and result in same buffer content.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com>
Signed-off-by: Esme Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
2020-06-09 06:28:41 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-08-27 07:35:01 +02:00
|
|
|
ok(!memcmp(pixels, buffer, frame_size),
|
2021-06-15 03:59:50 +02:00
|
|
|
"Block data mismatch\n");
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
/* CopyPixels tests */
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
bpp = test->pixel_format_bpp;
|
2020-08-17 04:23:47 +02:00
|
|
|
stride = rect.Width * bpp / 8;
|
|
|
|
frame_stride = frame_width * bpp / 8;
|
2020-08-17 04:24:13 +02:00
|
|
|
frame_size = frame_stride * frame_height;
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, 0, 0, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect_test_a, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect_test_b, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect_test_c, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect_test_d, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, frame_stride - 1, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, frame_stride * 2, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, frame_stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, frame_stride, frame_stride * frame_height - 1, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_INSUFFICIENTBUFFER, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, frame_stride, frame_stride * frame_height, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, 0, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride - 1, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride * 2, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride, 0, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_INSUFFICIENTBUFFER, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride, 1, buffer);
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(hr == WINCODEC_ERR_INSUFFICIENTBUFFER || (hr == S_OK && test->expected_bytes_per_block == 1),
|
2022-03-09 08:21:55 +01:00
|
|
|
"CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride, stride * rect.Height - 1, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_INSUFFICIENTBUFFER, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride, stride * rect.Height, buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels got unexpected hr %#lx\n", hr);
|
2020-08-17 04:23:47 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride, sizeof(buffer), NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "CopyBlocks got unexpected hr %#lx\n", hr);
|
2020-08-17 04:24:13 +02:00
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
memset(buffer, 0, sizeof(pixels));
|
2020-08-25 16:01:08 +02:00
|
|
|
if (is_compressed(format_info.DxgiFormat)) {
|
2021-06-15 03:59:50 +02:00
|
|
|
decode_block(test->data + block_offset, width_in_blocks * height_in_blocks,
|
2020-08-25 16:01:56 +02:00
|
|
|
format_info.DxgiFormat, frame_width, frame_height, (DWORD *)pixels);
|
|
|
|
} else {
|
2021-06-15 03:59:50 +02:00
|
|
|
memcpy(pixels, test->data + block_offset, frame_size);
|
2020-08-25 16:01:56 +02:00
|
|
|
}
|
2020-08-17 04:24:13 +02:00
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
memset(buffer, 0, sizeof(buffer));
|
2020-08-25 16:01:56 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, &rect, stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels failed, hr %#lx\n", hr);
|
2020-08-25 16:01:56 +02:00
|
|
|
if (hr == S_OK) {
|
|
|
|
if (is_compressed(format_info.DxgiFormat)) {
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(color_buffer_match((DWORD *)pixels, (DWORD *)buffer, 1), "Pixels mismatch\n");
|
2020-08-25 16:01:56 +02:00
|
|
|
} else {
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(!memcmp(pixels, buffer, bpp / 8), "Pixels mismatch\n");
|
2020-08-17 04:24:13 +02:00
|
|
|
}
|
2020-08-25 16:01:56 +02:00
|
|
|
}
|
2020-08-17 04:24:13 +02:00
|
|
|
|
2020-08-27 07:35:01 +02:00
|
|
|
memset(buffer, 0, sizeof(buffer));
|
2020-08-25 16:01:56 +02:00
|
|
|
hr = IWICBitmapFrameDecode_CopyPixels(frame, NULL, frame_stride, sizeof(buffer), buffer);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CopyPixels failed, hr %#lx\n", hr);
|
2020-08-25 16:01:56 +02:00
|
|
|
if (hr == S_OK) {
|
|
|
|
if (is_compressed(format_info.DxgiFormat)) {
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(color_buffer_match((DWORD *)pixels, (DWORD *)buffer, frame_size / (bpp / 8)), "Pixels mismatch\n");
|
2020-08-25 16:01:56 +02:00
|
|
|
} else {
|
2021-06-15 03:59:50 +02:00
|
|
|
ok(!memcmp(pixels, buffer, frame_size), "Pixels mismatch\n");
|
2020-08-25 16:01:56 +02:00
|
|
|
};
|
2020-08-17 04:24:13 +02:00
|
|
|
}
|
2020-05-22 05:17:31 +02:00
|
|
|
}
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
static void test_dds_decoder_frame(IWICBitmapDecoder *decoder, struct test_data *test)
|
2020-05-22 05:17:31 +02:00
|
|
|
{
|
|
|
|
HRESULT hr;
|
2020-06-03 12:45:57 +02:00
|
|
|
IWICDdsDecoder *dds_decoder = NULL;
|
2020-05-22 05:17:31 +02:00
|
|
|
UINT frame_count, j;
|
2020-06-03 12:45:57 +02:00
|
|
|
WICDdsParameters params;
|
2020-05-22 05:17:31 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapDecoder_GetFrameCount(decoder, &frame_count);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetFrameCount failed, hr %#lx\n", hr);
|
2020-05-22 05:17:31 +02:00
|
|
|
if (hr != S_OK) return;
|
2020-06-03 12:45:57 +02:00
|
|
|
hr = IWICBitmapDecoder_QueryInterface(decoder, &IID_IWICDdsDecoder, (void **)&dds_decoder);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "QueryInterface failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) goto end;
|
|
|
|
hr = IWICDdsDecoder_GetParameters(dds_decoder, ¶ms);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetParameters failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) goto end;
|
2020-05-22 05:17:31 +02:00
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
if (test->expected_parameters.Dimension == WICDdsTextureCube) params.ArraySize *= 6;
|
2020-07-18 05:17:54 +02:00
|
|
|
|
2020-05-22 05:17:31 +02:00
|
|
|
for (j = 0; j < frame_count; j++)
|
|
|
|
{
|
|
|
|
IWICBitmapFrameDecode *frame_decode = NULL;
|
2020-06-03 12:45:57 +02:00
|
|
|
IWICDdsFrameDecode *dds_frame = NULL;
|
2020-05-22 05:17:31 +02:00
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_push_context("Frame %u", j);
|
|
|
|
|
2020-05-22 05:17:31 +02:00
|
|
|
hr = IWICBitmapDecoder_GetFrame(decoder, j, &frame_decode);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetFrame failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) goto next;
|
|
|
|
hr = IWICBitmapFrameDecode_QueryInterface(frame_decode, &IID_IWICDdsFrameDecode, (void **)&dds_frame);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "QueryInterface failed, hr %#lx\n", hr);
|
2020-06-03 12:45:57 +02:00
|
|
|
if (hr != S_OK) goto next;
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
test_dds_decoder_frame_properties(frame_decode, dds_frame, frame_count, ¶ms, test, j);
|
|
|
|
test_dds_decoder_frame_data(frame_decode, dds_frame, frame_count, ¶ms, test, j);
|
2020-05-22 05:17:31 +02:00
|
|
|
|
2020-06-03 12:45:57 +02:00
|
|
|
next:
|
|
|
|
if (frame_decode) IWICBitmapFrameDecode_Release(frame_decode);
|
|
|
|
if (dds_frame) IWICDdsFrameDecode_Release(dds_frame);
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_pop_context();
|
2020-05-22 05:17:31 +02:00
|
|
|
}
|
2020-06-03 12:45:57 +02:00
|
|
|
|
|
|
|
end:
|
|
|
|
if (dds_decoder) IWICDdsDecoder_Release(dds_decoder);
|
2020-05-22 05:17:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_dds_decoder(void)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
HRESULT hr;
|
|
|
|
|
2020-04-16 11:43:00 +02:00
|
|
|
test_dds_decoder_initialize();
|
2020-05-12 04:25:06 +02:00
|
|
|
test_dds_decoder_image_parameters();
|
2020-04-16 11:43:00 +02:00
|
|
|
|
2020-05-22 05:17:31 +02:00
|
|
|
for (i = 0; i < ARRAY_SIZE(test_data); i++)
|
|
|
|
{
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
IWICBitmapDecoder *decoder = NULL;
|
|
|
|
|
2020-07-21 07:48:52 +02:00
|
|
|
if (test_data[i].init_hr != S_OK && !test_data[i].wine_init) continue;
|
|
|
|
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_push_context("Test %u", i);
|
|
|
|
|
2020-05-22 05:17:31 +02:00
|
|
|
stream = create_stream(test_data[i].data, test_data[i].size);
|
|
|
|
if (!stream) goto next;
|
|
|
|
decoder = create_decoder();
|
|
|
|
if (!decoder) goto next;
|
2021-06-15 03:59:50 +02:00
|
|
|
hr = init_decoder(decoder, stream, test_data[i].init_hr, test_data[i].wine_init);
|
2020-07-15 16:01:25 +02:00
|
|
|
if (hr != S_OK) {
|
2020-07-18 05:17:54 +02:00
|
|
|
if (test_data[i].expected_parameters.Dimension == WICDdsTextureCube) {
|
2021-06-15 03:59:50 +02:00
|
|
|
win_skip("Cube map is not supported\n");
|
2020-07-18 05:17:54 +02:00
|
|
|
} else {
|
2021-06-15 03:59:50 +02:00
|
|
|
win_skip("Uncompressed DDS image is not supported\n");
|
2020-07-18 05:17:54 +02:00
|
|
|
}
|
2020-07-15 16:01:25 +02:00
|
|
|
goto next;
|
|
|
|
}
|
2020-05-22 05:17:31 +02:00
|
|
|
|
|
|
|
test_dds_decoder_global_properties(decoder);
|
2021-06-15 03:59:50 +02:00
|
|
|
test_dds_decoder_frame(decoder, test_data + i);
|
2020-05-22 05:17:31 +02:00
|
|
|
|
|
|
|
next:
|
|
|
|
if (decoder) IWICBitmapDecoder_Release(decoder);
|
|
|
|
if (stream) IWICStream_Release(stream);
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_pop_context();
|
2020-05-22 05:17:31 +02:00
|
|
|
}
|
2020-04-15 12:41:43 +02:00
|
|
|
}
|
|
|
|
|
2021-05-01 05:14:34 +02:00
|
|
|
static void test_dds_encoder_initialize(void)
|
|
|
|
{
|
|
|
|
IWICBitmapEncoder *encoder = NULL;
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
BYTE buffer[1];
|
|
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
encoder = create_encoder();
|
|
|
|
if (!encoder) goto end;
|
|
|
|
|
|
|
|
stream = create_stream(buffer, sizeof(buffer));
|
|
|
|
if (!stream) goto end;
|
|
|
|
|
|
|
|
/* initialize with invalid cache option */
|
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(encoder, (IStream *)stream, 0xdeadbeef);
|
|
|
|
todo_wine
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_UNSUPPORTEDOPERATION, "Initialize got unexpected hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(encoder, (IStream *)stream, WICBitmapEncoderNoCache);
|
|
|
|
todo_wine
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "Initialize got unexpected hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
IWICBitmapEncoder_Release(encoder);
|
|
|
|
|
|
|
|
/* initialize with null stream */
|
|
|
|
|
|
|
|
encoder = create_encoder();
|
|
|
|
if (!encoder) goto end;
|
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(encoder, NULL, WICBitmapEncoderNoCache);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "Initialize got unexpected hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(encoder, (IStream *)stream, WICBitmapEncoderNoCache);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "Initialize failed, hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
IWICBitmapEncoder_Release(encoder);
|
|
|
|
|
|
|
|
/* regularly initialize */
|
|
|
|
|
|
|
|
encoder = create_encoder();
|
|
|
|
if (!encoder) goto end;
|
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(encoder, (IStream *)stream, WICBitmapEncoderNoCache);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "Initialize failed, hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_Initialize(encoder, (IStream *)stream, WICBitmapEncoderNoCache);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_WRONGSTATE, "Initialize got unexpected hr %#lx\n", hr);
|
2021-05-01 05:14:34 +02:00
|
|
|
|
|
|
|
end:
|
|
|
|
if (stream) IWICStream_Release(stream);
|
|
|
|
if (encoder) IWICBitmapEncoder_Release(encoder);
|
|
|
|
}
|
|
|
|
|
2021-05-24 04:58:18 +02:00
|
|
|
static void test_dds_encoder_params(void)
|
2021-05-12 07:07:39 +02:00
|
|
|
{
|
|
|
|
WICDdsParameters params, params_set = { 4, 4, 4, 3, 1, DXGI_FORMAT_BC1_UNORM,
|
|
|
|
WICDdsTexture3D, WICDdsAlphaModePremultiplied };
|
2021-05-24 04:58:18 +02:00
|
|
|
IWICDdsEncoder *dds_encoder = NULL;
|
|
|
|
IWICBitmapEncoder *encoder = NULL;
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
BYTE buffer[1024];
|
2021-05-12 07:07:39 +02:00
|
|
|
HRESULT hr;
|
2021-05-24 04:58:32 +02:00
|
|
|
UINT i;
|
2021-05-12 07:07:39 +02:00
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
hr = create_and_init_encoder(buffer, sizeof(buffer), NULL, &encoder, &dds_encoder, &stream);
|
2021-05-24 04:58:18 +02:00
|
|
|
if (hr != S_OK) goto end;
|
|
|
|
|
2021-05-12 07:07:39 +02:00
|
|
|
hr = IWICDdsEncoder_GetParameters(dds_encoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "GetParameters got unexpected hr %#lx\n", hr);
|
2021-05-12 07:07:39 +02:00
|
|
|
|
|
|
|
hr = IWICDdsEncoder_GetParameters(dds_encoder, ¶ms);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "GetParameters failed, hr %#lx\n", hr);
|
2021-05-24 04:58:18 +02:00
|
|
|
if (hr != S_OK) goto end;
|
2021-05-12 07:07:39 +02:00
|
|
|
|
|
|
|
/* default DDS parameters for encoder */
|
|
|
|
ok(params.Width == 1, "Got unexpected Width %u\n", params.Width);
|
|
|
|
ok(params.Height == 1, "Got unexpected Height %u\n", params.Height);
|
|
|
|
ok(params.Depth == 1, "Got unexpected Depth %u\n", params.Depth);
|
|
|
|
ok(params.MipLevels == 1, "Got unexpected MipLevels %u\n", params.MipLevels);
|
|
|
|
ok(params.ArraySize == 1, "Got unexpected ArraySize %u\n", params.ArraySize);
|
|
|
|
ok(params.DxgiFormat == DXGI_FORMAT_BC3_UNORM, "Got unexpected DxgiFormat %#x\n", params.DxgiFormat);
|
|
|
|
ok(params.Dimension == WICDdsTexture2D, "Got unexpected Dimension %#x\n", params.Dimension);
|
|
|
|
ok(params.AlphaMode == WICDdsAlphaModeUnknown, "Got unexpected AlphaMode %#x\n", params.AlphaMode);
|
|
|
|
|
|
|
|
hr = IWICDdsEncoder_SetParameters(dds_encoder, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == E_INVALIDARG, "SetParameters got unexpected hr %#lx\n", hr);
|
2021-05-12 07:07:39 +02:00
|
|
|
|
|
|
|
hr = IWICDdsEncoder_SetParameters(dds_encoder, ¶ms_set);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "SetParameters failed, hr %#lx\n", hr);
|
2021-05-24 04:58:18 +02:00
|
|
|
if (hr != S_OK) goto end;
|
2021-05-12 07:07:39 +02:00
|
|
|
|
|
|
|
IWICDdsEncoder_GetParameters(dds_encoder, ¶ms);
|
|
|
|
|
|
|
|
ok(params.Width == params_set.Width,
|
|
|
|
"Expected Width %u, got %u\n", params_set.Width, params.Width);
|
|
|
|
ok(params.Height == params_set.Height,
|
|
|
|
"Expected Height %u, got %u\n", params_set.Height, params.Height);
|
|
|
|
ok(params.Depth == params_set.Depth,
|
|
|
|
"Expected Depth %u, got %u\n", params_set.Depth, params.Depth);
|
|
|
|
ok(params.MipLevels == params_set.MipLevels,
|
|
|
|
"Expected MipLevels %u, got %u\n", params_set.MipLevels, params.MipLevels);
|
|
|
|
ok(params.ArraySize == params_set.ArraySize,
|
|
|
|
"Expected ArraySize %u, got %u\n", params_set.ArraySize, params.ArraySize);
|
|
|
|
ok(params.DxgiFormat == params_set.DxgiFormat,
|
|
|
|
"Expected DxgiFormat %u, got %#x\n", params_set.DxgiFormat, params.DxgiFormat);
|
|
|
|
ok(params.Dimension == params_set.Dimension,
|
|
|
|
"Expected Dimension %u, got %#x\n", params_set.Dimension, params.Dimension);
|
|
|
|
ok(params.AlphaMode == params_set.AlphaMode,
|
|
|
|
"Expected AlphaMode %u, got %#x\n", params_set.AlphaMode, params.AlphaMode);
|
2021-05-24 04:58:18 +02:00
|
|
|
|
2021-05-24 04:58:32 +02:00
|
|
|
for (i = 0; i < ARRAY_SIZE(test_data); ++i)
|
|
|
|
{
|
|
|
|
hr = IWICDdsEncoder_SetParameters(dds_encoder, &test_data[i].expected_parameters);
|
|
|
|
todo_wine_if(test_data[i].init_hr != S_OK)
|
|
|
|
ok((hr == S_OK && test_data[i].init_hr == S_OK) || hr == WINCODEC_ERR_BADHEADER,
|
2022-03-09 08:21:55 +01:00
|
|
|
"Test %u: SetParameters got unexpected hr %#lx\n", i, hr);
|
2021-05-24 04:58:32 +02:00
|
|
|
}
|
|
|
|
|
2021-05-24 04:58:18 +02:00
|
|
|
end:
|
|
|
|
release_encoder(encoder, dds_encoder, stream);
|
2021-05-12 07:07:39 +02:00
|
|
|
}
|
|
|
|
|
2021-05-26 03:53:54 +02:00
|
|
|
static void test_dds_encoder_create_frame(void)
|
|
|
|
{
|
|
|
|
WICDdsParameters params = { 4, 4, 1, 3, 1, DXGI_FORMAT_BC1_UNORM,
|
|
|
|
WICDdsTexture2D, WICDdsAlphaModePremultiplied };
|
|
|
|
IWICBitmapFrameEncode *frame0 = NULL, *frame1 = NULL;
|
|
|
|
UINT array_index, mip_level, slice_index;
|
|
|
|
IWICDdsEncoder *dds_encoder = NULL;
|
|
|
|
IWICBitmapEncoder *encoder = NULL;
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
BYTE buffer[1024];
|
|
|
|
HRESULT hr;
|
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
hr = create_and_init_encoder(buffer, sizeof(buffer), ¶ms, &encoder, &dds_encoder, &stream);
|
2021-05-26 03:53:54 +02:00
|
|
|
if (hr != S_OK) goto end;
|
|
|
|
|
|
|
|
hr = IWICBitmapEncoder_CreateNewFrame(encoder, &frame0, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CreateNewFrame failed, hr %#lx\n", hr);
|
2021-05-26 03:53:54 +02:00
|
|
|
hr = IWICBitmapEncoder_CreateNewFrame(encoder, &frame1, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_WRONGSTATE, "CreateNewFrame got unexpected hr %#lx\n", hr);
|
2021-05-26 03:53:54 +02:00
|
|
|
|
|
|
|
IWICBitmapFrameEncode_Release(frame0);
|
|
|
|
hr = IWICBitmapEncoder_CreateNewFrame(encoder, &frame1, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_WRONGSTATE, "CreateNewFrame got unexpected hr %#lx\n", hr);
|
2021-05-26 03:53:54 +02:00
|
|
|
|
|
|
|
release_encoder(encoder, dds_encoder, stream);
|
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
create_and_init_encoder(buffer, sizeof(buffer), ¶ms, &encoder, &dds_encoder, &stream);
|
2021-05-26 03:53:54 +02:00
|
|
|
hr = IWICDdsEncoder_CreateNewFrame(dds_encoder, &frame0, &array_index, &mip_level, &slice_index);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CreateNewFrame failed, hr %#lx\n", hr);
|
2021-05-26 03:54:04 +02:00
|
|
|
IWICBitmapFrameEncode_Release(frame0);
|
2021-05-26 03:53:54 +02:00
|
|
|
release_encoder(encoder, dds_encoder, stream);
|
|
|
|
|
2021-05-29 02:26:43 +02:00
|
|
|
create_and_init_encoder(buffer, sizeof(buffer), ¶ms, &encoder, &dds_encoder, &stream);
|
2021-05-26 03:53:54 +02:00
|
|
|
hr = IWICDdsEncoder_CreateNewFrame(dds_encoder, &frame0, NULL, NULL, NULL);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CreateNewFrame failed, hr %#lx\n", hr);
|
2021-05-26 03:54:04 +02:00
|
|
|
IWICBitmapFrameEncode_Release(frame0);
|
2021-05-26 03:53:54 +02:00
|
|
|
|
|
|
|
end:
|
|
|
|
release_encoder(encoder, dds_encoder, stream);
|
|
|
|
}
|
|
|
|
|
2021-05-29 02:27:03 +02:00
|
|
|
static void test_dds_encoder_pixel_format(void)
|
|
|
|
{
|
|
|
|
DXGI_FORMAT image_formats[] = { DXGI_FORMAT_BC1_UNORM, DXGI_FORMAT_BC2_UNORM, DXGI_FORMAT_BC3_UNORM };
|
|
|
|
const WICPixelFormatGUID *test_formats[] =
|
|
|
|
{
|
|
|
|
&GUID_WICPixelFormat8bppIndexed,
|
|
|
|
&GUID_WICPixelFormatBlackWhite,
|
|
|
|
&GUID_WICPixelFormat16bppGray,
|
|
|
|
&GUID_WICPixelFormat8bppAlpha,
|
|
|
|
&GUID_WICPixelFormat16bppBGR555,
|
|
|
|
&GUID_WICPixelFormat16bppBGR565,
|
|
|
|
&GUID_WICPixelFormat24bppBGR,
|
|
|
|
&GUID_WICPixelFormat32bppBGR,
|
|
|
|
&GUID_WICPixelFormat32bppBGRA,
|
|
|
|
&GUID_WICPixelFormat32bppPBGRA,
|
|
|
|
&GUID_WICPixelFormat32bppRGB,
|
|
|
|
&GUID_WICPixelFormat32bppRGBA,
|
|
|
|
&GUID_WICPixelFormat32bppPRGBA,
|
|
|
|
&GUID_WICPixelFormat48bppRGB,
|
|
|
|
&GUID_WICPixelFormat64bppRGB,
|
|
|
|
&GUID_WICPixelFormat64bppRGBA
|
|
|
|
};
|
|
|
|
IWICBitmapFrameEncode *frame = NULL;
|
|
|
|
IWICDdsEncoder *dds_encoder = NULL;
|
|
|
|
IWICBitmapEncoder *encoder = NULL;
|
|
|
|
IWICStream *stream = NULL;
|
|
|
|
WICPixelFormatGUID format;
|
|
|
|
WICDdsParameters params;
|
|
|
|
BYTE buffer[1];
|
|
|
|
HRESULT hr;
|
|
|
|
UINT i, j;
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_SIZE(image_formats); ++i)
|
|
|
|
{
|
|
|
|
hr = create_and_init_encoder(buffer, sizeof(buffer), NULL, &encoder, &dds_encoder, &stream);
|
|
|
|
if (hr != S_OK)
|
|
|
|
{
|
|
|
|
release_encoder(encoder, dds_encoder, stream);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
IWICDdsEncoder_GetParameters(dds_encoder, ¶ms);
|
|
|
|
params.DxgiFormat = image_formats[i];
|
|
|
|
IWICDdsEncoder_SetParameters(dds_encoder, ¶ms);
|
|
|
|
|
|
|
|
IWICBitmapEncoder_CreateNewFrame(encoder, &frame, NULL);
|
|
|
|
|
|
|
|
hr = IWICBitmapFrameEncode_SetPixelFormat(frame, &format);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == WINCODEC_ERR_NOTINITIALIZED, "SetPixelFormat got unexpected hr %#lx\n", hr);
|
2021-05-29 02:27:03 +02:00
|
|
|
|
|
|
|
IWICBitmapFrameEncode_Initialize(frame, NULL);
|
|
|
|
|
|
|
|
for (j = 0; j < ARRAY_SIZE(test_formats); ++j)
|
|
|
|
{
|
2021-06-15 03:59:50 +02:00
|
|
|
winetest_push_context("Test %u", j);
|
|
|
|
|
2021-05-29 02:27:03 +02:00
|
|
|
format = *(test_formats[j]);
|
|
|
|
hr = IWICBitmapFrameEncode_SetPixelFormat(frame, &format);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "SetPixelFormat failed, hr %#lx\n", hr);
|
2021-05-29 02:27:13 +02:00
|
|
|
ok(IsEqualGUID(&format, &GUID_WICPixelFormat32bppBGRA),
|
2021-06-15 03:59:50 +02:00
|
|
|
"Got unexpected GUID %s\n", debugstr_guid(&format));
|
|
|
|
|
|
|
|
winetest_pop_context();
|
2021-05-29 02:27:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
IWICBitmapFrameEncode_Release(frame);
|
|
|
|
release_encoder(encoder, dds_encoder, stream);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-01 05:14:34 +02:00
|
|
|
static void test_dds_encoder(void)
|
|
|
|
{
|
|
|
|
test_dds_encoder_initialize();
|
2021-05-24 04:58:18 +02:00
|
|
|
test_dds_encoder_params();
|
2021-05-26 03:53:54 +02:00
|
|
|
test_dds_encoder_create_frame();
|
2021-05-29 02:27:03 +02:00
|
|
|
test_dds_encoder_pixel_format();
|
2021-05-01 05:14:34 +02:00
|
|
|
}
|
|
|
|
|
2020-04-15 12:41:43 +02:00
|
|
|
START_TEST(ddsformat)
|
|
|
|
{
|
|
|
|
HRESULT hr;
|
|
|
|
CoInitializeEx(NULL, COINIT_APARTMENTTHREADED);
|
|
|
|
|
|
|
|
hr = CoCreateInstance(&CLSID_WICImagingFactory, NULL, CLSCTX_INPROC_SERVER,
|
|
|
|
&IID_IWICImagingFactory, (void **)&factory);
|
2022-03-09 08:21:55 +01:00
|
|
|
ok(hr == S_OK, "CoCreateInstance failed, hr %#lx\n", hr);
|
2020-04-20 06:00:18 +02:00
|
|
|
if (hr != S_OK) goto end;
|
2020-04-15 12:41:43 +02:00
|
|
|
|
|
|
|
test_dds_decoder();
|
2021-05-01 05:14:34 +02:00
|
|
|
test_dds_encoder();
|
2020-04-15 12:41:43 +02:00
|
|
|
|
|
|
|
end:
|
2020-06-19 04:37:16 +02:00
|
|
|
if (factory) IWICImagingFactory_Release(factory);
|
2020-04-15 12:41:43 +02:00
|
|
|
CoUninitialize();
|
|
|
|
}
|