|
Packit |
030a23 |
#include <stdlib.h>
|
|
Packit |
030a23 |
#include "utils.h"
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
#define WIDTH 32
|
|
Packit |
030a23 |
#define HEIGHT 32
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
static const pixman_format_code_t formats[] =
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
PIXMAN_a8r8g8b8,
|
|
Packit |
030a23 |
PIXMAN_a8b8g8r8,
|
|
Packit |
030a23 |
PIXMAN_x8r8g8b8,
|
|
Packit |
030a23 |
PIXMAN_x8b8g8r8,
|
|
Packit |
030a23 |
PIXMAN_r5g6b5,
|
|
Packit |
030a23 |
PIXMAN_b5g6r5,
|
|
Packit |
030a23 |
PIXMAN_a8,
|
|
Packit |
030a23 |
PIXMAN_a1,
|
|
Packit |
030a23 |
};
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
static const pixman_op_t ops[] =
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
PIXMAN_OP_OVER,
|
|
Packit |
030a23 |
PIXMAN_OP_SRC,
|
|
Packit |
030a23 |
PIXMAN_OP_ADD,
|
|
Packit |
030a23 |
};
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
#define TRANSFORM(v00, v01, v10, v11) \
|
|
Packit |
030a23 |
{ { { v00, v01, WIDTH * pixman_fixed_1 / 2 }, \
|
|
Packit |
030a23 |
{ v10, v11, HEIGHT * pixman_fixed_1 / 2 }, \
|
|
Packit |
030a23 |
{ 0, 0, pixman_fixed_1 } } }
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
#define F1 pixman_fixed_1
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
static const pixman_transform_t transforms[] =
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
TRANSFORM (0, -1, 1, 0), /* wrong 90 degree rotation */
|
|
Packit |
030a23 |
TRANSFORM (0, 1, -1, 0), /* wrong 270 degree rotation */
|
|
Packit |
030a23 |
TRANSFORM (1, 0, 0, 1), /* wrong identity */
|
|
Packit |
030a23 |
TRANSFORM (-1, 0, 0, -1), /* wrong 180 degree rotation */
|
|
Packit |
030a23 |
TRANSFORM (0, -F1, F1, 0), /* correct 90 degree rotation */
|
|
Packit |
030a23 |
TRANSFORM (0, F1, -F1, 0), /* correct 270 degree rotation */
|
|
Packit |
030a23 |
TRANSFORM (F1, 0, 0, F1), /* correct identity */
|
|
Packit |
030a23 |
TRANSFORM (-F1, 0, 0, -F1), /* correct 180 degree rotation */
|
|
Packit |
030a23 |
};
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
#define RANDOM_FORMAT() \
|
|
Packit |
030a23 |
(formats[prng_rand_n (ARRAY_LENGTH (formats))])
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
#define RANDOM_OP() \
|
|
Packit |
030a23 |
(ops[prng_rand_n (ARRAY_LENGTH (ops))])
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
#define RANDOM_TRANSFORM() \
|
|
Packit |
030a23 |
(&(transforms[prng_rand_n (ARRAY_LENGTH (transforms))]))
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
static void
|
|
Packit |
030a23 |
on_destroy (pixman_image_t *image, void *data)
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
free (data);
|
|
Packit |
030a23 |
}
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
static pixman_image_t *
|
|
Packit |
030a23 |
make_image (void)
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
pixman_format_code_t format = RANDOM_FORMAT();
|
|
Packit |
030a23 |
uint32_t *bytes, *orig;
|
|
Packit |
030a23 |
pixman_image_t *image;
|
|
Packit |
030a23 |
int stride;
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
orig = bytes = malloc (WIDTH * HEIGHT * 4);
|
|
Packit |
030a23 |
prng_randmemset (bytes, WIDTH * HEIGHT * 4, 0);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
stride = WIDTH * 4;
|
|
Packit |
030a23 |
if (prng_rand_n (2) == 0)
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
bytes += (stride / 4) * (HEIGHT - 1);
|
|
Packit |
030a23 |
stride = - stride;
|
|
Packit |
030a23 |
}
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
image = pixman_image_create_bits (
|
|
Packit |
030a23 |
format, WIDTH, HEIGHT, bytes, stride);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
pixman_image_set_transform (image, RANDOM_TRANSFORM());
|
|
Packit |
030a23 |
pixman_image_set_destroy_function (image, on_destroy, orig);
|
|
Packit |
030a23 |
pixman_image_set_repeat (image, PIXMAN_REPEAT_NORMAL);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
image_endian_swap (image);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
return image;
|
|
Packit |
030a23 |
}
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
static uint32_t
|
|
Packit |
030a23 |
test_transform (int testnum, int verbose)
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
pixman_image_t *src, *dest;
|
|
Packit |
030a23 |
uint32_t crc;
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
prng_srand (testnum);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
src = make_image ();
|
|
Packit |
030a23 |
dest = make_image ();
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
pixman_image_composite (RANDOM_OP(),
|
|
Packit |
030a23 |
src, NULL, dest,
|
|
Packit |
030a23 |
0, 0, 0, 0, WIDTH / 2, HEIGHT / 2,
|
|
Packit |
030a23 |
WIDTH, HEIGHT);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
crc = compute_crc32_for_image (0, dest);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
pixman_image_unref (src);
|
|
Packit |
030a23 |
pixman_image_unref (dest);
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
return crc;
|
|
Packit |
030a23 |
}
|
|
Packit |
030a23 |
|
|
Packit |
030a23 |
int
|
|
Packit |
030a23 |
main (int argc, const char *argv[])
|
|
Packit |
030a23 |
{
|
|
Packit |
030a23 |
return fuzzer_test_main ("rotate", 15000,
|
|
Packit |
030a23 |
0x81E9EC2F,
|
|
Packit |
030a23 |
test_transform, argc, argv);
|
|
Packit |
030a23 |
}
|