Blame tests/exynos/exynos_fimg2d_test.c

Packit Service 103f6b
/*
Packit Service 103f6b
 * Copyright (C) 2013 Samsung Electronics Co.Ltd
Packit Service 103f6b
 * Authors:
Packit Service 103f6b
 *	Inki Dae <inki.dae@samsung.com>
Packit Service 103f6b
 *
Packit Service 103f6b
 * Permission is hereby granted, free of charge, to any person obtaining a
Packit Service 103f6b
 * copy of this software and associated documentation files (the "Software"),
Packit Service 103f6b
 * to deal in the Software without restriction, including without limitation
Packit Service 103f6b
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
Packit Service 103f6b
 * and/or sell copies of the Software, and to permit persons to whom the
Packit Service 103f6b
 * Software is furnished to do so, subject to the following conditions:
Packit Service 103f6b
 *
Packit Service 103f6b
 * The above copyright notice and this permission notice (including the next
Packit Service 103f6b
 * paragraph) shall be included in all copies or substantial portions of the
Packit Service 103f6b
 * Software.
Packit Service 103f6b
 *
Packit Service 103f6b
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Packit Service 103f6b
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Packit Service 103f6b
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
Packit Service 103f6b
 * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
Packit Service 103f6b
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
Packit Service 103f6b
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
Packit Service 103f6b
 * OTHER DEALINGS IN THE SOFTWARE.
Packit Service 103f6b
 */
Packit Service 103f6b
Packit Service 103f6b
#include <stdlib.h>
Packit Service 103f6b
#include <stdio.h>
Packit Service 103f6b
#include <string.h>
Packit Service 103f6b
#include <errno.h>
Packit Service 103f6b
#include <time.h>
Packit Service 103f6b
#include <unistd.h>
Packit Service 103f6b
Packit Service 103f6b
#include <sys/mman.h>
Packit Service 103f6b
#include <linux/stddef.h>
Packit Service 103f6b
Packit Service 103f6b
#include <xf86drm.h>
Packit Service 103f6b
#include <xf86drmMode.h>
Packit Service 103f6b
#include <libkms.h>
Packit Service 103f6b
#include <drm_fourcc.h>
Packit Service 103f6b
Packit Service 103f6b
#include "exynos_drm.h"
Packit Service 103f6b
#include "exynos_drmif.h"
Packit Service 103f6b
#include "exynos_fimg2d.h"
Packit Service 103f6b
Packit Service 103f6b
#define DRM_MODULE_NAME		"exynos"
Packit Service 103f6b
Packit Service 103f6b
static unsigned int screen_width, screen_height;
Packit Service 103f6b
Packit Service 103f6b
struct connector {
Packit Service 103f6b
	uint32_t id;
Packit Service 103f6b
	char mode_str[64];
Packit Service 103f6b
	drmModeModeInfo *mode;
Packit Service 103f6b
	drmModeEncoder *encoder;
Packit Service 103f6b
	int crtc;
Packit Service 103f6b
};
Packit Service 103f6b
Packit Service 103f6b
static void connector_find_mode(int fd, struct connector *c,
Packit Service 103f6b
				drmModeRes *resources)
Packit Service 103f6b
{
Packit Service 103f6b
	drmModeConnector *connector;
Packit Service 103f6b
	int i, j;
Packit Service 103f6b
Packit Service 103f6b
	/* First, find the connector & mode */
Packit Service 103f6b
	c->mode = NULL;
Packit Service 103f6b
	for (i = 0; i < resources->count_connectors; i++) {
Packit Service 103f6b
		connector = drmModeGetConnector(fd, resources->connectors[i]);
Packit Service 103f6b
Packit Service 103f6b
		if (!connector) {
Packit Service 103f6b
			fprintf(stderr, "could not get connector %i: %s\n",
Packit Service 103f6b
				resources->connectors[i], strerror(errno));
Packit Service 103f6b
			continue;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		if (!connector->count_modes) {
Packit Service 103f6b
			drmModeFreeConnector(connector);
Packit Service 103f6b
			continue;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		if (connector->connector_id != c->id) {
Packit Service 103f6b
			drmModeFreeConnector(connector);
Packit Service 103f6b
			continue;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		for (j = 0; j < connector->count_modes; j++) {
Packit Service 103f6b
			c->mode = &connector->modes[j];
Packit Service 103f6b
			if (!strcmp(c->mode->name, c->mode_str))
Packit Service 103f6b
				break;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		/* Found it, break out */
Packit Service 103f6b
		if (c->mode)
Packit Service 103f6b
			break;
Packit Service 103f6b
Packit Service 103f6b
		drmModeFreeConnector(connector);
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	if (!c->mode) {
Packit Service 103f6b
		fprintf(stderr, "failed to find mode \"%s\"\n", c->mode_str);
Packit Service 103f6b
		return;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	/* Now get the encoder */
Packit Service 103f6b
	for (i = 0; i < resources->count_encoders; i++) {
Packit Service 103f6b
		c->encoder = drmModeGetEncoder(fd, resources->encoders[i]);
Packit Service 103f6b
Packit Service 103f6b
		if (!c->encoder) {
Packit Service 103f6b
			fprintf(stderr, "could not get encoder %i: %s\n",
Packit Service 103f6b
				resources->encoders[i], strerror(errno));
Packit Service 103f6b
			continue;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		if (c->encoder->encoder_id  == connector->encoder_id)
Packit Service 103f6b
			break;
Packit Service 103f6b
Packit Service 103f6b
		drmModeFreeEncoder(c->encoder);
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	if (c->crtc == -1)
Packit Service 103f6b
		c->crtc = c->encoder->crtc_id;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static int drm_set_crtc(struct exynos_device *dev, struct connector *c,
Packit Service 103f6b
			unsigned int fb_id)
Packit Service 103f6b
{
Packit Service 103f6b
	int ret;
Packit Service 103f6b
Packit Service 103f6b
	ret = drmModeSetCrtc(dev->fd, c->crtc,
Packit Service 103f6b
			fb_id, 0, 0, &c->id, 1, c->mode);
Packit Service 103f6b
	if (ret)
Packit Service 103f6b
		drmMsg("failed to set mode: %s\n", strerror(errno));
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static struct exynos_bo *exynos_create_buffer(struct exynos_device *dev,
Packit Service 103f6b
						unsigned long size,
Packit Service 103f6b
						unsigned int flags)
Packit Service 103f6b
{
Packit Service 103f6b
	struct exynos_bo *bo;
Packit Service 103f6b
Packit Service 103f6b
	bo = exynos_bo_create(dev, size, flags);
Packit Service 103f6b
	if (!bo)
Packit Service 103f6b
		return bo;
Packit Service 103f6b
Packit Service 103f6b
	if (!exynos_bo_map(bo)) {
Packit Service 103f6b
		exynos_bo_destroy(bo);
Packit Service 103f6b
		return NULL;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	return bo;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
/* Allocate buffer and fill it with checkerboard pattern, where the tiles *
Packit Service 103f6b
 * have a random color. The caller has to free the buffer.                */
Packit Service 103f6b
static void *create_checkerboard_pattern(unsigned int num_tiles_x,
Packit Service 103f6b
						unsigned int num_tiles_y, unsigned int tile_size)
Packit Service 103f6b
{
Packit Service 103f6b
	unsigned int *buf;
Packit Service 103f6b
	unsigned int x, y, i, j;
Packit Service 103f6b
	const unsigned int stride = num_tiles_x * tile_size;
Packit Service 103f6b
Packit Service 103f6b
	if (posix_memalign((void*)&buf, 64, num_tiles_y * tile_size * stride * 4) != 0)
Packit Service 103f6b
		return NULL;
Packit Service 103f6b
Packit Service 103f6b
	for (x = 0; x < num_tiles_x; ++x) {
Packit Service 103f6b
		for (y = 0; y < num_tiles_y; ++y) {
Packit Service 103f6b
			const unsigned int color = 0xff000000 + (random() & 0xffffff);
Packit Service 103f6b
Packit Service 103f6b
			for (i = 0; i < tile_size; ++i) {
Packit Service 103f6b
				for (j = 0; j < tile_size; ++j) {
Packit Service 103f6b
					buf[x * tile_size + y * stride * tile_size + i + j * stride] = color;
Packit Service 103f6b
				}
Packit Service 103f6b
			}
Packit Service 103f6b
		}
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	return buf;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static void exynos_destroy_buffer(struct exynos_bo *bo)
Packit Service 103f6b
{
Packit Service 103f6b
	exynos_bo_destroy(bo);
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static void wait_for_user_input(int last)
Packit Service 103f6b
{
Packit Service 103f6b
	printf("press <ENTER> to %s\n", last ? "exit test application" :
Packit Service 103f6b
			"skip to next test");
Packit Service 103f6b
Packit Service 103f6b
	getchar();
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static int g2d_solid_fill_test(struct exynos_device *dev, struct exynos_bo *dst)
Packit Service 103f6b
{
Packit Service 103f6b
	struct g2d_context *ctx;
Packit Service 103f6b
	struct g2d_image img = {0};
Packit Service 103f6b
	unsigned int count, img_w, img_h;
Packit Service 103f6b
	int ret = 0;
Packit Service 103f6b
Packit Service 103f6b
	ctx = g2d_init(dev->fd);
Packit Service 103f6b
	if (!ctx)
Packit Service 103f6b
		return -EFAULT;
Packit Service 103f6b
Packit Service 103f6b
	img.bo[0] = dst->handle;
Packit Service 103f6b
Packit Service 103f6b
	printf("solid fill test.\n");
Packit Service 103f6b
Packit Service 103f6b
	srand(time(NULL));
Packit Service 103f6b
	img_w = screen_width;
Packit Service 103f6b
	img_h = screen_height;
Packit Service 103f6b
Packit Service 103f6b
	for (count = 0; count < 2; count++) {
Packit Service 103f6b
		unsigned int x, y, w, h;
Packit Service 103f6b
Packit Service 103f6b
		x = rand() % (img_w / 2);
Packit Service 103f6b
		y = rand() % (img_h / 2);
Packit Service 103f6b
		w = rand() % (img_w - x);
Packit Service 103f6b
		h = rand() % (img_h - y);
Packit Service 103f6b
Packit Service 103f6b
		img.width = img_w;
Packit Service 103f6b
		img.height = img_h;
Packit Service 103f6b
		img.stride = img.width * 4;
Packit Service 103f6b
		img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
		img.color = 0xff000000 + (random() & 0xffffff);
Packit Service 103f6b
Packit Service 103f6b
		ret = g2d_solid_fill(ctx, &img, x, y, w, h);
Packit Service 103f6b
		if (ret < 0)
Packit Service 103f6b
			goto err_fini;
Packit Service 103f6b
Packit Service 103f6b
		ret = g2d_exec(ctx);
Packit Service 103f6b
		if (ret < 0)
Packit Service 103f6b
			break;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
err_fini:
Packit Service 103f6b
	g2d_fini(ctx);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static int g2d_copy_test(struct exynos_device *dev, struct exynos_bo *src,
Packit Service 103f6b
				struct exynos_bo *dst,
Packit Service 103f6b
				enum e_g2d_buf_type type)
Packit Service 103f6b
{
Packit Service 103f6b
	struct g2d_context *ctx;
Packit Service 103f6b
	struct g2d_image src_img = {0}, dst_img = {0};
Packit Service 103f6b
	unsigned int src_x, src_y, dst_x, dst_y, img_w, img_h;
Packit Service 103f6b
	unsigned long userptr, size;
Packit Service 103f6b
	int ret;
Packit Service 103f6b
Packit Service 103f6b
	ctx = g2d_init(dev->fd);
Packit Service 103f6b
	if (!ctx)
Packit Service 103f6b
		return -EFAULT;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.bo[0] = dst->handle;
Packit Service 103f6b
Packit Service 103f6b
	src_x = 0;
Packit Service 103f6b
	src_y = 0;
Packit Service 103f6b
	dst_x = 0;
Packit Service 103f6b
	dst_y = 0;
Packit Service 103f6b
	img_w = screen_width;
Packit Service 103f6b
	img_h = screen_height;
Packit Service 103f6b
Packit Service 103f6b
	switch (type) {
Packit Service 103f6b
	case G2D_IMGBUF_GEM:
Packit Service 103f6b
		src_img.bo[0] = src->handle;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_USERPTR:
Packit Service 103f6b
		size = img_w * img_h * 4;
Packit Service 103f6b
Packit Service 103f6b
		userptr = (unsigned long)malloc(size);
Packit Service 103f6b
		if (!userptr) {
Packit Service 103f6b
			fprintf(stderr, "failed to allocate userptr.\n");
Packit Service 103f6b
			ret = -EFAULT;
Packit Service 103f6b
			goto fail;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		src_img.user_ptr[0].userptr = userptr;
Packit Service 103f6b
		src_img.user_ptr[0].size = size;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_COLOR:
Packit Service 103f6b
	default:
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	printf("copy test with %s.\n",
Packit Service 103f6b
			type == G2D_IMGBUF_GEM ? "gem" : "userptr");
Packit Service 103f6b
Packit Service 103f6b
	src_img.width = img_w;
Packit Service 103f6b
	src_img.height = img_h;
Packit Service 103f6b
	src_img.stride = src_img.width * 4;
Packit Service 103f6b
	src_img.buf_type = type;
Packit Service 103f6b
	src_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
	src_img.color = 0xffff0000;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &src_img, src_x, src_y, img_w, img_h);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.width = img_w;
Packit Service 103f6b
	dst_img.height = img_h;
Packit Service 103f6b
	dst_img.stride = dst_img.width * 4;
Packit Service 103f6b
	dst_img.buf_type = G2D_IMGBUF_GEM;
Packit Service 103f6b
	dst_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_copy(ctx, &src_img, &dst_img, src_x, src_y, dst_x, dst_y,
Packit Service 103f6b
			img_w - 4, img_h - 4);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	g2d_exec(ctx);
Packit Service 103f6b
Packit Service 103f6b
err_free_userptr:
Packit Service 103f6b
	if (type == G2D_IMGBUF_USERPTR)
Packit Service 103f6b
		if (userptr)
Packit Service 103f6b
			free((void *)userptr);
Packit Service 103f6b
Packit Service 103f6b
fail:
Packit Service 103f6b
	g2d_fini(ctx);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static int g2d_move_test(struct exynos_device *dev,
Packit Service 103f6b
				struct exynos_bo *tmp,
Packit Service 103f6b
				struct exynos_bo *buf,
Packit Service 103f6b
				enum e_g2d_buf_type type)
Packit Service 103f6b
{
Packit Service 103f6b
	struct g2d_context *ctx;
Packit Service 103f6b
	struct g2d_image img = {0}, tmp_img = {0};
Packit Service 103f6b
	unsigned int img_w, img_h, count;
Packit Service 103f6b
	int cur_x, cur_y;
Packit Service 103f6b
	void *checkerboard;
Packit Service 103f6b
	int ret;
Packit Service 103f6b
Packit Service 103f6b
	static const struct g2d_step {
Packit Service 103f6b
		int x, y;
Packit Service 103f6b
	} steps[] = {
Packit Service 103f6b
		{ 1,  0}, { 0,  1},
Packit Service 103f6b
		{-1,  0}, { 0, -1},
Packit Service 103f6b
		{ 1,  1}, {-1, -1},
Packit Service 103f6b
		{ 1, -1}, {-1,  1},
Packit Service 103f6b
		{ 2,  1}, { 1,  2},
Packit Service 103f6b
		{-2, -1}, {-1, -2},
Packit Service 103f6b
		{ 2, -1}, { 1, -2},
Packit Service 103f6b
		{-2,  1}, {-1,  2}
Packit Service 103f6b
	};
Packit Service 103f6b
	static const unsigned int num_steps =
Packit Service 103f6b
		sizeof(steps) / sizeof(struct g2d_step);
Packit Service 103f6b
Packit Service 103f6b
	ctx = g2d_init(dev->fd);
Packit Service 103f6b
	if (!ctx)
Packit Service 103f6b
		return -EFAULT;
Packit Service 103f6b
Packit Service 103f6b
	img.bo[0] = buf->handle;
Packit Service 103f6b
Packit Service 103f6b
	/* create pattern of half the screen size */
Packit Service 103f6b
	checkerboard = create_checkerboard_pattern(screen_width / 64, screen_height / 64, 32);
Packit Service 103f6b
	if (!checkerboard) {
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	img_w = (screen_width / 64) * 32;
Packit Service 103f6b
	img_h = (screen_height / 64) * 32;
Packit Service 103f6b
Packit Service 103f6b
	switch (type) {
Packit Service 103f6b
	case G2D_IMGBUF_GEM:
Packit Service 103f6b
		memcpy(tmp->vaddr, checkerboard, img_w * img_h * 4);
Packit Service 103f6b
		tmp_img.bo[0] = tmp->handle;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_USERPTR:
Packit Service 103f6b
		tmp_img.user_ptr[0].userptr = (unsigned long)checkerboard;
Packit Service 103f6b
		tmp_img.user_ptr[0].size = img_w * img_h * 4;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_COLOR:
Packit Service 103f6b
	default:
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	/* solid fill framebuffer with white color */
Packit Service 103f6b
	img.width = screen_width;
Packit Service 103f6b
	img.height = screen_height;
Packit Service 103f6b
	img.stride = screen_width * 4;
Packit Service 103f6b
	img.buf_type = G2D_IMGBUF_GEM;
Packit Service 103f6b
	img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
	img.color = 0xffffffff;
Packit Service 103f6b
Packit Service 103f6b
	/* put checkerboard pattern in the center of the framebuffer */
Packit Service 103f6b
	cur_x = (screen_width - img_w) / 2;
Packit Service 103f6b
	cur_y = (screen_height - img_h) / 2;
Packit Service 103f6b
	tmp_img.width = img_w;
Packit Service 103f6b
	tmp_img.height = img_h;
Packit Service 103f6b
	tmp_img.stride = img_w * 4;
Packit Service 103f6b
	tmp_img.buf_type = type;
Packit Service 103f6b
	tmp_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &img, 0, 0, screen_width, screen_height) ||
Packit Service 103f6b
		g2d_copy(ctx, &tmp_img, &img, 0, 0, cur_x, cur_y, img_w, img_h);
Packit Service 103f6b
Packit Service 103f6b
	if (!ret)
Packit Service 103f6b
		ret = g2d_exec(ctx);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
			goto fail;
Packit Service 103f6b
Packit Service 103f6b
	printf("move test with %s.\n",
Packit Service 103f6b
			type == G2D_IMGBUF_GEM ? "gem" : "userptr");
Packit Service 103f6b
Packit Service 103f6b
	srand(time(NULL));
Packit Service 103f6b
	for (count = 0; count < 256; ++count) {
Packit Service 103f6b
		const struct g2d_step *s;
Packit Service 103f6b
Packit Service 103f6b
		/* select step and validate it */
Packit Service 103f6b
		while (1) {
Packit Service 103f6b
			s = &steps[random() % num_steps];
Packit Service 103f6b
Packit Service 103f6b
			if (cur_x + s->x < 0 || cur_y + s->y < 0 ||
Packit Service 103f6b
				cur_x + img_w + s->x >= screen_width ||
Packit Service 103f6b
				cur_y + img_h + s->y >= screen_height)
Packit Service 103f6b
				continue;
Packit Service 103f6b
			else
Packit Service 103f6b
				break;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		ret = g2d_move(ctx, &img, cur_x, cur_y, cur_x + s->x, cur_y + s->y,
Packit Service 103f6b
			img_w, img_h);
Packit Service 103f6b
		if (!ret)
Packit Service 103f6b
			ret = g2d_exec(ctx);
Packit Service 103f6b
Packit Service 103f6b
		if (ret < 0)
Packit Service 103f6b
			goto fail;
Packit Service 103f6b
Packit Service 103f6b
		cur_x += s->x;
Packit Service 103f6b
		cur_y += s->y;
Packit Service 103f6b
Packit Service 103f6b
		usleep(100000);
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
fail:
Packit Service 103f6b
	g2d_fini(ctx);
Packit Service 103f6b
Packit Service 103f6b
	free(checkerboard);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static int g2d_copy_with_scale_test(struct exynos_device *dev,
Packit Service 103f6b
					struct exynos_bo *src,
Packit Service 103f6b
					struct exynos_bo *dst,
Packit Service 103f6b
					enum e_g2d_buf_type type)
Packit Service 103f6b
{
Packit Service 103f6b
	struct g2d_context *ctx;
Packit Service 103f6b
	struct g2d_image src_img = {0}, dst_img = {0};
Packit Service 103f6b
	unsigned int src_x, src_y, img_w, img_h;
Packit Service 103f6b
	unsigned long userptr, size;
Packit Service 103f6b
	int ret;
Packit Service 103f6b
Packit Service 103f6b
	ctx = g2d_init(dev->fd);
Packit Service 103f6b
	if (!ctx)
Packit Service 103f6b
		return -EFAULT;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.bo[0] = dst->handle;
Packit Service 103f6b
Packit Service 103f6b
	src_x = 0;
Packit Service 103f6b
	src_y = 0;
Packit Service 103f6b
	img_w = screen_width;
Packit Service 103f6b
	img_h = screen_height;
Packit Service 103f6b
Packit Service 103f6b
	switch (type) {
Packit Service 103f6b
	case G2D_IMGBUF_GEM:
Packit Service 103f6b
		src_img.bo[0] = src->handle;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_USERPTR:
Packit Service 103f6b
		size = img_w * img_h * 4;
Packit Service 103f6b
Packit Service 103f6b
		userptr = (unsigned long)malloc(size);
Packit Service 103f6b
		if (!userptr) {
Packit Service 103f6b
			fprintf(stderr, "failed to allocate userptr.\n");
Packit Service 103f6b
			ret = -EFAULT;
Packit Service 103f6b
			goto fail;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		src_img.user_ptr[0].userptr = userptr;
Packit Service 103f6b
		src_img.user_ptr[0].size = size;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_COLOR:
Packit Service 103f6b
	default:
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	printf("copy and scale test with %s.\n",
Packit Service 103f6b
			type == G2D_IMGBUF_GEM ? "gem" : "userptr");
Packit Service 103f6b
Packit Service 103f6b
	src_img.width = img_w;
Packit Service 103f6b
	src_img.height = img_h;
Packit Service 103f6b
	src_img.stride = src_img.width * 4;
Packit Service 103f6b
	src_img.buf_type = type;
Packit Service 103f6b
	src_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
	src_img.color = 0xffffffff;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &src_img, src_x, src_y, img_w ,  img_h);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	src_img.color = 0xff00ff00;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &src_img, 5, 5, 100, 100);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.width = img_w;
Packit Service 103f6b
	dst_img.height = img_h;
Packit Service 103f6b
	dst_img.buf_type = G2D_IMGBUF_GEM;
Packit Service 103f6b
	dst_img.stride = dst_img.width * 4;
Packit Service 103f6b
	dst_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_copy_with_scale(ctx, &src_img, &dst_img, 5, 5, 100, 100,
Packit Service 103f6b
					100, 100, 200, 200, 0);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	g2d_exec(ctx);
Packit Service 103f6b
Packit Service 103f6b
err_free_userptr:
Packit Service 103f6b
	if (type == G2D_IMGBUF_USERPTR)
Packit Service 103f6b
		if (userptr)
Packit Service 103f6b
			free((void *)userptr);
Packit Service 103f6b
Packit Service 103f6b
fail:
Packit Service 103f6b
	g2d_fini(ctx);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
#ifdef EXYNOS_G2D_USERPTR_TEST
Packit Service 103f6b
static int g2d_blend_test(struct exynos_device *dev,
Packit Service 103f6b
					struct exynos_bo *src,
Packit Service 103f6b
					struct exynos_bo *dst,
Packit Service 103f6b
					enum e_g2d_buf_type type)
Packit Service 103f6b
{
Packit Service 103f6b
	struct g2d_context *ctx;
Packit Service 103f6b
	struct g2d_image src_img = {0}, dst_img = {0};
Packit Service 103f6b
	unsigned int src_x, src_y, dst_x, dst_y, img_w, img_h;
Packit Service 103f6b
	unsigned long userptr, size;
Packit Service 103f6b
	int ret;
Packit Service 103f6b
Packit Service 103f6b
	ctx = g2d_init(dev->fd);
Packit Service 103f6b
	if (!ctx)
Packit Service 103f6b
		return -EFAULT;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.bo[0] = dst->handle;
Packit Service 103f6b
Packit Service 103f6b
	src_x = 0;
Packit Service 103f6b
	src_y = 0;
Packit Service 103f6b
	dst_x = 0;
Packit Service 103f6b
	dst_y = 0;
Packit Service 103f6b
	img_w = screen_width;
Packit Service 103f6b
	img_h = screen_height;
Packit Service 103f6b
Packit Service 103f6b
	switch (type) {
Packit Service 103f6b
	case G2D_IMGBUF_GEM:
Packit Service 103f6b
		src_img.bo[0] = src->handle;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_USERPTR:
Packit Service 103f6b
		size = img_w * img_h * 4;
Packit Service 103f6b
Packit Service 103f6b
		userptr = (unsigned long)malloc(size);
Packit Service 103f6b
		if (!userptr) {
Packit Service 103f6b
			fprintf(stderr, "failed to allocate userptr.\n");
Packit Service 103f6b
			ret = -EFAULT;
Packit Service 103f6b
			goto fail;
Packit Service 103f6b
		}
Packit Service 103f6b
Packit Service 103f6b
		src_img.user_ptr[0].userptr = userptr;
Packit Service 103f6b
		src_img.user_ptr[0].size = size;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_COLOR:
Packit Service 103f6b
	default:
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	printf("blend test with %s.\n",
Packit Service 103f6b
			type == G2D_IMGBUF_GEM ? "gem" : "userptr");
Packit Service 103f6b
Packit Service 103f6b
	src_img.width = img_w;
Packit Service 103f6b
	src_img.height = img_h;
Packit Service 103f6b
	src_img.stride = src_img.width * 4;
Packit Service 103f6b
	src_img.buf_type = type;
Packit Service 103f6b
	src_img.select_mode = G2D_SELECT_MODE_NORMAL;
Packit Service 103f6b
	src_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
	src_img.color = 0xffffffff;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &src_img, src_x, src_y, img_w, img_h);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	src_img.color = 0x770000ff;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &src_img, 5, 5, 200, 200);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.width = img_w;
Packit Service 103f6b
	dst_img.height = img_h;
Packit Service 103f6b
	dst_img.stride = dst_img.width * 4;
Packit Service 103f6b
	dst_img.buf_type = G2D_IMGBUF_GEM;
Packit Service 103f6b
	dst_img.select_mode = G2D_SELECT_MODE_NORMAL;
Packit Service 103f6b
	dst_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
	dst_img.color = 0xffffffff;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &dst_img, dst_x, dst_y, img_w, img_h);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.color = 0x77ff0000;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &dst_img, 105, 105, 200, 200);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_blend(ctx, &src_img, &dst_img, 5, 5, 105, 105, 200, 200,
Packit Service 103f6b
			G2D_OP_OVER);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_free_userptr;
Packit Service 103f6b
Packit Service 103f6b
	g2d_exec(ctx);
Packit Service 103f6b
Packit Service 103f6b
err_free_userptr:
Packit Service 103f6b
	if (type == G2D_IMGBUF_USERPTR)
Packit Service 103f6b
		if (userptr)
Packit Service 103f6b
			free((void *)userptr);
Packit Service 103f6b
Packit Service 103f6b
fail:
Packit Service 103f6b
	g2d_fini(ctx);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
#endif
Packit Service 103f6b
Packit Service 103f6b
static int g2d_checkerboard_test(struct exynos_device *dev,
Packit Service 103f6b
					struct exynos_bo *src,
Packit Service 103f6b
					struct exynos_bo *dst,
Packit Service 103f6b
					enum e_g2d_buf_type type)
Packit Service 103f6b
{
Packit Service 103f6b
	struct g2d_context *ctx;
Packit Service 103f6b
	struct g2d_image src_img = {0}, dst_img = {0};
Packit Service 103f6b
	unsigned int src_x, src_y, dst_x, dst_y, img_w, img_h;
Packit Service 103f6b
	void *checkerboard = NULL;
Packit Service 103f6b
	int ret;
Packit Service 103f6b
Packit Service 103f6b
	ctx = g2d_init(dev->fd);
Packit Service 103f6b
	if (!ctx)
Packit Service 103f6b
		return -EFAULT;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.bo[0] = dst->handle;
Packit Service 103f6b
Packit Service 103f6b
	src_x = 0;
Packit Service 103f6b
	src_y = 0;
Packit Service 103f6b
	dst_x = 0;
Packit Service 103f6b
	dst_y = 0;
Packit Service 103f6b
Packit Service 103f6b
	checkerboard = create_checkerboard_pattern(screen_width / 32, screen_height / 32, 32);
Packit Service 103f6b
	if (!checkerboard) {
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	img_w = screen_width - (screen_width % 32);
Packit Service 103f6b
	img_h = screen_height - (screen_height % 32);
Packit Service 103f6b
Packit Service 103f6b
	switch (type) {
Packit Service 103f6b
	case G2D_IMGBUF_GEM:
Packit Service 103f6b
		memcpy(src->vaddr, checkerboard, img_w * img_h * 4);
Packit Service 103f6b
		src_img.bo[0] = src->handle;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_USERPTR:
Packit Service 103f6b
		src_img.user_ptr[0].userptr = (unsigned long)checkerboard;
Packit Service 103f6b
		src_img.user_ptr[0].size = img_w * img_h * 4;
Packit Service 103f6b
		break;
Packit Service 103f6b
	case G2D_IMGBUF_COLOR:
Packit Service 103f6b
	default:
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	printf("checkerboard test with %s.\n",
Packit Service 103f6b
			type == G2D_IMGBUF_GEM ? "gem" : "userptr");
Packit Service 103f6b
Packit Service 103f6b
	src_img.width = img_w;
Packit Service 103f6b
	src_img.height = img_h;
Packit Service 103f6b
	src_img.stride = src_img.width * 4;
Packit Service 103f6b
	src_img.buf_type = type;
Packit Service 103f6b
	src_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
Packit Service 103f6b
	dst_img.width = screen_width;
Packit Service 103f6b
	dst_img.height = screen_height;
Packit Service 103f6b
	dst_img.stride = dst_img.width * 4;
Packit Service 103f6b
	dst_img.buf_type = G2D_IMGBUF_GEM;
Packit Service 103f6b
	dst_img.color_mode = G2D_COLOR_FMT_ARGB8888 | G2D_ORDER_AXRGB;
Packit Service 103f6b
	src_img.color = 0xff000000;
Packit Service 103f6b
	ret = g2d_solid_fill(ctx, &dst_img, src_x, src_y, screen_width, screen_height);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_copy(ctx, &src_img, &dst_img, src_x, src_y, dst_x, dst_y,
Packit Service 103f6b
			img_w, img_h);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto fail;
Packit Service 103f6b
Packit Service 103f6b
	g2d_exec(ctx);
Packit Service 103f6b
Packit Service 103f6b
fail:
Packit Service 103f6b
	free(checkerboard);
Packit Service 103f6b
	g2d_fini(ctx);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
static void usage(char *name)
Packit Service 103f6b
{
Packit Service 103f6b
	fprintf(stderr, "usage: %s [-s]\n", name);
Packit Service 103f6b
	fprintf(stderr, "-s <connector_id>@<crtc_id>:<mode>\n");
Packit Service 103f6b
	exit(0);
Packit Service 103f6b
}
Packit Service 103f6b
Packit Service 103f6b
extern char *optarg;
Packit Service 103f6b
static const char optstr[] = "s:";
Packit Service 103f6b
Packit Service 103f6b
int main(int argc, char **argv)
Packit Service 103f6b
{
Packit Service 103f6b
	struct exynos_device *dev;
Packit Service 103f6b
	struct exynos_bo *bo, *src;
Packit Service 103f6b
	struct connector con;
Packit Service 103f6b
	unsigned int fb_id;
Packit Service 103f6b
	uint32_t handles[4] = {0}, pitches[4] = {0}, offsets[4] = {0};
Packit Service 103f6b
	drmModeRes *resources;
Packit Service 103f6b
	int ret, fd, c;
Packit Service 103f6b
Packit Service 103f6b
	memset(&con, 0, sizeof(struct connector));
Packit Service 103f6b
Packit Service 103f6b
	if (argc != 3) {
Packit Service 103f6b
		usage(argv[0]);
Packit Service 103f6b
		return -EINVAL;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	while ((c = getopt(argc, argv, optstr)) != -1) {
Packit Service 103f6b
		switch (c) {
Packit Service 103f6b
		case 's':
Packit Service 103f6b
			con.crtc = -1;
Packit Service 103f6b
			if (sscanf(optarg, "%d:0x%64s",
Packit Service 103f6b
						&con.id,
Packit Service 103f6b
						con.mode_str) != 2 &&
Packit Service 103f6b
					sscanf(optarg, "%d@%d:%64s",
Packit Service 103f6b
						&con.id,
Packit Service 103f6b
						&con.crtc,
Packit Service 103f6b
						con.mode_str) != 3)
Packit Service 103f6b
				usage(argv[0]);
Packit Service 103f6b
			break;
Packit Service 103f6b
		default:
Packit Service 103f6b
			usage(argv[0]);
Packit Service 103f6b
			break;
Packit Service 103f6b
		}
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	fd = drmOpen(DRM_MODULE_NAME, NULL);
Packit Service 103f6b
	if (fd < 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to open.\n");
Packit Service 103f6b
		return fd;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	dev = exynos_device_create(fd);
Packit Service 103f6b
	if (!dev) {
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto err_drm_close;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	resources = drmModeGetResources(dev->fd);
Packit Service 103f6b
	if (!resources) {
Packit Service 103f6b
		fprintf(stderr, "drmModeGetResources failed: %s\n",
Packit Service 103f6b
				strerror(errno));
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto err_dev_destory;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	connector_find_mode(dev->fd, &con, resources);
Packit Service 103f6b
	drmModeFreeResources(resources);
Packit Service 103f6b
Packit Service 103f6b
	if (!con.mode) {
Packit Service 103f6b
		fprintf(stderr, "failed to find usable connector\n");
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto err_dev_destory;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	screen_width = con.mode->hdisplay;
Packit Service 103f6b
	screen_height = con.mode->vdisplay;
Packit Service 103f6b
Packit Service 103f6b
	if (screen_width == 0 || screen_height == 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to find sane resolution on connector\n");
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto err_dev_destory;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	printf("screen width = %d, screen height = %d\n", screen_width,
Packit Service 103f6b
			screen_height);
Packit Service 103f6b
Packit Service 103f6b
	bo = exynos_create_buffer(dev, screen_width * screen_height * 4, 0);
Packit Service 103f6b
	if (!bo) {
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto err_dev_destory;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	handles[0] = bo->handle;
Packit Service 103f6b
	pitches[0] = screen_width * 4;
Packit Service 103f6b
	offsets[0] = 0;
Packit Service 103f6b
Packit Service 103f6b
	ret = drmModeAddFB2(dev->fd, screen_width, screen_height,
Packit Service 103f6b
				DRM_FORMAT_XRGB8888, handles,
Packit Service 103f6b
				pitches, offsets, &fb_id, 0);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_destroy_buffer;
Packit Service 103f6b
Packit Service 103f6b
	memset(bo->vaddr, 0xff, screen_width * screen_height * 4);
Packit Service 103f6b
Packit Service 103f6b
	ret = drm_set_crtc(dev, &con, fb_id);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		goto err_rm_fb;
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_solid_fill_test(dev, bo);
Packit Service 103f6b
	if (ret < 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to solid fill operation.\n");
Packit Service 103f6b
		goto err_rm_fb;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	wait_for_user_input(0);
Packit Service 103f6b
Packit Service 103f6b
	src = exynos_create_buffer(dev, screen_width * screen_height * 4, 0);
Packit Service 103f6b
	if (!src) {
Packit Service 103f6b
		ret = -EFAULT;
Packit Service 103f6b
		goto err_rm_fb;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_copy_test(dev, src, bo, G2D_IMGBUF_GEM);
Packit Service 103f6b
	if (ret < 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to test copy operation.\n");
Packit Service 103f6b
		goto err_free_src;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	wait_for_user_input(0);
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_move_test(dev, src, bo, G2D_IMGBUF_GEM);
Packit Service 103f6b
	if (ret < 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to test move operation.\n");
Packit Service 103f6b
		goto err_free_src;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	wait_for_user_input(0);
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_copy_with_scale_test(dev, src, bo, G2D_IMGBUF_GEM);
Packit Service 103f6b
	if (ret < 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to test copy and scale operation.\n");
Packit Service 103f6b
		goto err_free_src;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	wait_for_user_input(0);
Packit Service 103f6b
Packit Service 103f6b
	ret = g2d_checkerboard_test(dev, src, bo, G2D_IMGBUF_GEM);
Packit Service 103f6b
	if (ret < 0) {
Packit Service 103f6b
		fprintf(stderr, "failed to issue checkerboard test.\n");
Packit Service 103f6b
		goto err_free_src;
Packit Service 103f6b
	}
Packit Service 103f6b
Packit Service 103f6b
	wait_for_user_input(1);
Packit Service 103f6b
Packit Service 103f6b
	/*
Packit Service 103f6b
	 * The blend test uses the userptr functionality of exynos-drm, which
Packit Service 103f6b
	 * is currently not safe to use. If the kernel hasn't been build with
Packit Service 103f6b
	 * exynos-iommu support, then the blend test is going to produce (kernel)
Packit Service 103f6b
	 * memory corruption, eventually leading to a system crash.
Packit Service 103f6b
	 *
Packit Service 103f6b
	 * Disable the test for now, until the kernel code has been sanitized.
Packit Service 103f6b
	 */
Packit Service 103f6b
#ifdef EXYNOS_G2D_USERPTR_TEST
Packit Service 103f6b
	ret  = g2d_blend_test(dev, src, bo, G2D_IMGBUF_USERPTR);
Packit Service 103f6b
	if (ret < 0)
Packit Service 103f6b
		fprintf(stderr, "failed to test blend operation.\n");
Packit Service 103f6b
Packit Service 103f6b
	getchar();
Packit Service 103f6b
#endif
Packit Service 103f6b
Packit Service 103f6b
err_free_src:
Packit Service 103f6b
	if (src)
Packit Service 103f6b
		exynos_destroy_buffer(src);
Packit Service 103f6b
Packit Service 103f6b
err_rm_fb:
Packit Service 103f6b
	drmModeRmFB(dev->fd, fb_id);
Packit Service 103f6b
Packit Service 103f6b
err_destroy_buffer:
Packit Service 103f6b
	exynos_destroy_buffer(bo);
Packit Service 103f6b
Packit Service 103f6b
err_dev_destory:
Packit Service 103f6b
	exynos_device_destroy(dev);
Packit Service 103f6b
Packit Service 103f6b
err_drm_close:
Packit Service 103f6b
	drmClose(fd);
Packit Service 103f6b
Packit Service 103f6b
	return ret;
Packit Service 103f6b
}