Blame pixman/pixman-bits-image.c

Packit 030a23
/*
Packit 030a23
 * Copyright © 2000 Keith Packard, member of The XFree86 Project, Inc.
Packit 030a23
 *             2005 Lars Knoll & Zack Rusin, Trolltech
Packit 030a23
 *             2008 Aaron Plattner, NVIDIA Corporation
Packit 030a23
 * Copyright © 2000 SuSE, Inc.
Packit 030a23
 * Copyright © 2007, 2009 Red Hat, Inc.
Packit 030a23
 * Copyright © 2008 André Tupinambá <andrelrt@gmail.com>
Packit 030a23
 *
Packit 030a23
 * Permission to use, copy, modify, distribute, and sell this software and its
Packit 030a23
 * documentation for any purpose is hereby granted without fee, provided that
Packit 030a23
 * the above copyright notice appear in all copies and that both that
Packit 030a23
 * copyright notice and this permission notice appear in supporting
Packit 030a23
 * documentation, and that the name of Keith Packard not be used in
Packit 030a23
 * advertising or publicity pertaining to distribution of the software without
Packit 030a23
 * specific, written prior permission.  Keith Packard makes no
Packit 030a23
 * representations about the suitability of this software for any purpose.  It
Packit 030a23
 * is provided "as is" without express or implied warranty.
Packit 030a23
 *
Packit 030a23
 * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
Packit 030a23
 * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
Packit 030a23
 * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
Packit 030a23
 * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
Packit 030a23
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
Packit 030a23
 * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
Packit 030a23
 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
Packit 030a23
 * SOFTWARE.
Packit 030a23
 */
Packit 030a23
Packit 030a23
#ifdef HAVE_CONFIG_H
Packit 030a23
#include <config.h>
Packit 030a23
#endif
Packit 030a23
#include <stdio.h>
Packit 030a23
#include <stdlib.h>
Packit 030a23
#include <string.h>
Packit 030a23
#include "pixman-private.h"
Packit 030a23
#include "pixman-combine32.h"
Packit 030a23
#include "pixman-inlines.h"
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
_pixman_image_get_scanline_generic_float (pixman_iter_t * iter,
Packit 030a23
					  const uint32_t *mask)
Packit 030a23
{
Packit 030a23
    pixman_iter_get_scanline_t fetch_32 = iter->data;
Packit 030a23
    uint32_t *buffer = iter->buffer;
Packit 030a23
Packit 030a23
    fetch_32 (iter, NULL);
Packit 030a23
Packit 030a23
    pixman_expand_to_float ((argb_t *)buffer, buffer, PIXMAN_a8r8g8b8, iter->width);
Packit 030a23
Packit 030a23
    return iter->buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
/* Fetch functions */
Packit 030a23
Packit 030a23
static force_inline uint32_t
Packit 030a23
fetch_pixel_no_alpha (bits_image_t *image,
Packit 030a23
		      int x, int y, pixman_bool_t check_bounds)
Packit 030a23
{
Packit 030a23
    if (check_bounds &&
Packit 030a23
	(x < 0 || x >= image->width || y < 0 || y >= image->height))
Packit 030a23
    {
Packit 030a23
	return 0;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return image->fetch_pixel_32 (image, x, y);
Packit 030a23
}
Packit 030a23
Packit 030a23
typedef uint32_t (* get_pixel_t) (bits_image_t *image,
Packit 030a23
				  int x, int y, pixman_bool_t check_bounds);
Packit 030a23
Packit 030a23
static force_inline uint32_t
Packit 030a23
bits_image_fetch_pixel_nearest (bits_image_t   *image,
Packit 030a23
				pixman_fixed_t  x,
Packit 030a23
				pixman_fixed_t  y,
Packit 030a23
				get_pixel_t	get_pixel)
Packit 030a23
{
Packit 030a23
    int x0 = pixman_fixed_to_int (x - pixman_fixed_e);
Packit 030a23
    int y0 = pixman_fixed_to_int (y - pixman_fixed_e);
Packit 030a23
Packit 030a23
    if (image->common.repeat != PIXMAN_REPEAT_NONE)
Packit 030a23
    {
Packit 030a23
	repeat (image->common.repeat, &x0, image->width);
Packit 030a23
	repeat (image->common.repeat, &y0, image->height);
Packit 030a23
Packit 030a23
	return get_pixel (image, x0, y0, FALSE);
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	return get_pixel (image, x0, y0, TRUE);
Packit 030a23
    }
Packit 030a23
}
Packit 030a23
Packit 030a23
static force_inline uint32_t
Packit 030a23
bits_image_fetch_pixel_bilinear (bits_image_t   *image,
Packit 030a23
				 pixman_fixed_t  x,
Packit 030a23
				 pixman_fixed_t  y,
Packit 030a23
				 get_pixel_t	 get_pixel)
Packit 030a23
{
Packit 030a23
    pixman_repeat_t repeat_mode = image->common.repeat;
Packit 030a23
    int width = image->width;
Packit 030a23
    int height = image->height;
Packit 030a23
    int x1, y1, x2, y2;
Packit 030a23
    uint32_t tl, tr, bl, br;
Packit 030a23
    int32_t distx, disty;
Packit 030a23
Packit 030a23
    x1 = x - pixman_fixed_1 / 2;
Packit 030a23
    y1 = y - pixman_fixed_1 / 2;
Packit 030a23
Packit 030a23
    distx = pixman_fixed_to_bilinear_weight (x1);
Packit 030a23
    disty = pixman_fixed_to_bilinear_weight (y1);
Packit 030a23
Packit 030a23
    x1 = pixman_fixed_to_int (x1);
Packit 030a23
    y1 = pixman_fixed_to_int (y1);
Packit 030a23
    x2 = x1 + 1;
Packit 030a23
    y2 = y1 + 1;
Packit 030a23
Packit 030a23
    if (repeat_mode != PIXMAN_REPEAT_NONE)
Packit 030a23
    {
Packit 030a23
	repeat (repeat_mode, &x1, width);
Packit 030a23
	repeat (repeat_mode, &y1, height);
Packit 030a23
	repeat (repeat_mode, &x2, width);
Packit 030a23
	repeat (repeat_mode, &y2, height);
Packit 030a23
Packit 030a23
	tl = get_pixel (image, x1, y1, FALSE);
Packit 030a23
	bl = get_pixel (image, x1, y2, FALSE);
Packit 030a23
	tr = get_pixel (image, x2, y1, FALSE);
Packit 030a23
	br = get_pixel (image, x2, y2, FALSE);
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	tl = get_pixel (image, x1, y1, TRUE);
Packit 030a23
	tr = get_pixel (image, x2, y1, TRUE);
Packit 030a23
	bl = get_pixel (image, x1, y2, TRUE);
Packit 030a23
	br = get_pixel (image, x2, y2, TRUE);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return bilinear_interpolation (tl, tr, bl, br, distx, disty);
Packit 030a23
}
Packit 030a23
Packit 030a23
static force_inline uint32_t
Packit 030a23
bits_image_fetch_pixel_convolution (bits_image_t   *image,
Packit 030a23
				    pixman_fixed_t  x,
Packit 030a23
				    pixman_fixed_t  y,
Packit 030a23
				    get_pixel_t     get_pixel)
Packit 030a23
{
Packit 030a23
    pixman_fixed_t *params = image->common.filter_params;
Packit 030a23
    int x_off = (params[0] - pixman_fixed_1) >> 1;
Packit 030a23
    int y_off = (params[1] - pixman_fixed_1) >> 1;
Packit 030a23
    int32_t cwidth = pixman_fixed_to_int (params[0]);
Packit 030a23
    int32_t cheight = pixman_fixed_to_int (params[1]);
Packit 030a23
    int32_t i, j, x1, x2, y1, y2;
Packit 030a23
    pixman_repeat_t repeat_mode = image->common.repeat;
Packit 030a23
    int width = image->width;
Packit 030a23
    int height = image->height;
Packit 030a23
    int srtot, sgtot, sbtot, satot;
Packit 030a23
Packit 030a23
    params += 2;
Packit 030a23
Packit 030a23
    x1 = pixman_fixed_to_int (x - pixman_fixed_e - x_off);
Packit 030a23
    y1 = pixman_fixed_to_int (y - pixman_fixed_e - y_off);
Packit 030a23
    x2 = x1 + cwidth;
Packit 030a23
    y2 = y1 + cheight;
Packit 030a23
Packit 030a23
    srtot = sgtot = sbtot = satot = 0;
Packit 030a23
Packit 030a23
    for (i = y1; i < y2; ++i)
Packit 030a23
    {
Packit 030a23
	for (j = x1; j < x2; ++j)
Packit 030a23
	{
Packit 030a23
	    int rx = j;
Packit 030a23
	    int ry = i;
Packit 030a23
Packit 030a23
	    pixman_fixed_t f = *params;
Packit 030a23
Packit 030a23
	    if (f)
Packit 030a23
	    {
Packit 030a23
		uint32_t pixel;
Packit 030a23
Packit 030a23
		if (repeat_mode != PIXMAN_REPEAT_NONE)
Packit 030a23
		{
Packit 030a23
		    repeat (repeat_mode, &rx, width);
Packit 030a23
		    repeat (repeat_mode, &ry, height);
Packit 030a23
Packit 030a23
		    pixel = get_pixel (image, rx, ry, FALSE);
Packit 030a23
		}
Packit 030a23
		else
Packit 030a23
		{
Packit 030a23
		    pixel = get_pixel (image, rx, ry, TRUE);
Packit 030a23
		}
Packit 030a23
Packit 030a23
		srtot += (int)RED_8 (pixel) * f;
Packit 030a23
		sgtot += (int)GREEN_8 (pixel) * f;
Packit 030a23
		sbtot += (int)BLUE_8 (pixel) * f;
Packit 030a23
		satot += (int)ALPHA_8 (pixel) * f;
Packit 030a23
	    }
Packit 030a23
Packit 030a23
	    params++;
Packit 030a23
	}
Packit 030a23
    }
Packit 030a23
Packit 030a23
    satot = (satot + 0x8000) >> 16;
Packit 030a23
    srtot = (srtot + 0x8000) >> 16;
Packit 030a23
    sgtot = (sgtot + 0x8000) >> 16;
Packit 030a23
    sbtot = (sbtot + 0x8000) >> 16;
Packit 030a23
Packit 030a23
    satot = CLIP (satot, 0, 0xff);
Packit 030a23
    srtot = CLIP (srtot, 0, 0xff);
Packit 030a23
    sgtot = CLIP (sgtot, 0, 0xff);
Packit 030a23
    sbtot = CLIP (sbtot, 0, 0xff);
Packit 030a23
Packit 030a23
    return ((satot << 24) | (srtot << 16) | (sgtot <<  8) | (sbtot));
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t
Packit 030a23
bits_image_fetch_pixel_separable_convolution (bits_image_t *image,
Packit 030a23
                                              pixman_fixed_t x,
Packit 030a23
                                              pixman_fixed_t y,
Packit 030a23
                                              get_pixel_t    get_pixel)
Packit 030a23
{
Packit 030a23
    pixman_fixed_t *params = image->common.filter_params;
Packit 030a23
    pixman_repeat_t repeat_mode = image->common.repeat;
Packit 030a23
    int width = image->width;
Packit 030a23
    int height = image->height;
Packit 030a23
    int cwidth = pixman_fixed_to_int (params[0]);
Packit 030a23
    int cheight = pixman_fixed_to_int (params[1]);
Packit 030a23
    int x_phase_bits = pixman_fixed_to_int (params[2]);
Packit 030a23
    int y_phase_bits = pixman_fixed_to_int (params[3]);
Packit 030a23
    int x_phase_shift = 16 - x_phase_bits;
Packit 030a23
    int y_phase_shift = 16 - y_phase_bits;
Packit 030a23
    int x_off = ((cwidth << 16) - pixman_fixed_1) >> 1;
Packit 030a23
    int y_off = ((cheight << 16) - pixman_fixed_1) >> 1;
Packit 030a23
    pixman_fixed_t *y_params;
Packit 030a23
    int srtot, sgtot, sbtot, satot;
Packit 030a23
    int32_t x1, x2, y1, y2;
Packit 030a23
    int32_t px, py;
Packit 030a23
    int i, j;
Packit 030a23
Packit 030a23
    /* Round x and y to the middle of the closest phase before continuing. This
Packit 030a23
     * ensures that the convolution matrix is aligned right, since it was
Packit 030a23
     * positioned relative to a particular phase (and not relative to whatever
Packit 030a23
     * exact fraction we happen to get here).
Packit 030a23
     */
Packit 030a23
    x = ((x >> x_phase_shift) << x_phase_shift) + ((1 << x_phase_shift) >> 1);
Packit 030a23
    y = ((y >> y_phase_shift) << y_phase_shift) + ((1 << y_phase_shift) >> 1);
Packit 030a23
Packit 030a23
    px = (x & 0xffff) >> x_phase_shift;
Packit 030a23
    py = (y & 0xffff) >> y_phase_shift;
Packit 030a23
Packit 030a23
    y_params = params + 4 + (1 << x_phase_bits) * cwidth + py * cheight;
Packit 030a23
Packit 030a23
    x1 = pixman_fixed_to_int (x - pixman_fixed_e - x_off);
Packit 030a23
    y1 = pixman_fixed_to_int (y - pixman_fixed_e - y_off);
Packit 030a23
    x2 = x1 + cwidth;
Packit 030a23
    y2 = y1 + cheight;
Packit 030a23
Packit 030a23
    srtot = sgtot = sbtot = satot = 0;
Packit 030a23
Packit 030a23
    for (i = y1; i < y2; ++i)
Packit 030a23
    {
Packit 030a23
        pixman_fixed_48_16_t fy = *y_params++;
Packit 030a23
        pixman_fixed_t *x_params = params + 4 + px * cwidth;
Packit 030a23
Packit 030a23
        if (fy)
Packit 030a23
        {
Packit 030a23
            for (j = x1; j < x2; ++j)
Packit 030a23
            {
Packit 030a23
                pixman_fixed_t fx = *x_params++;
Packit 030a23
		int rx = j;
Packit 030a23
		int ry = i;
Packit 030a23
Packit 030a23
                if (fx)
Packit 030a23
                {
Packit 030a23
                    pixman_fixed_t f;
Packit 030a23
                    uint32_t pixel;
Packit 030a23
Packit 030a23
                    if (repeat_mode != PIXMAN_REPEAT_NONE)
Packit 030a23
                    {
Packit 030a23
                        repeat (repeat_mode, &rx, width);
Packit 030a23
                        repeat (repeat_mode, &ry, height);
Packit 030a23
Packit 030a23
                        pixel = get_pixel (image, rx, ry, FALSE);
Packit 030a23
                    }
Packit 030a23
                    else
Packit 030a23
                    {
Packit 030a23
                        pixel = get_pixel (image, rx, ry, TRUE);
Packit 030a23
		    }
Packit 030a23
Packit 030a23
                    f = (fy * fx + 0x8000) >> 16;
Packit 030a23
Packit 030a23
                    srtot += (int)RED_8 (pixel) * f;
Packit 030a23
                    sgtot += (int)GREEN_8 (pixel) * f;
Packit 030a23
                    sbtot += (int)BLUE_8 (pixel) * f;
Packit 030a23
                    satot += (int)ALPHA_8 (pixel) * f;
Packit 030a23
                }
Packit 030a23
            }
Packit 030a23
	}
Packit 030a23
    }
Packit 030a23
Packit 030a23
    satot = (satot + 0x8000) >> 16;
Packit 030a23
    srtot = (srtot + 0x8000) >> 16;
Packit 030a23
    sgtot = (sgtot + 0x8000) >> 16;
Packit 030a23
    sbtot = (sbtot + 0x8000) >> 16;
Packit 030a23
Packit 030a23
    satot = CLIP (satot, 0, 0xff);
Packit 030a23
    srtot = CLIP (srtot, 0, 0xff);
Packit 030a23
    sgtot = CLIP (sgtot, 0, 0xff);
Packit 030a23
    sbtot = CLIP (sbtot, 0, 0xff);
Packit 030a23
Packit 030a23
    return ((satot << 24) | (srtot << 16) | (sgtot <<  8) | (sbtot));
Packit 030a23
}
Packit 030a23
Packit 030a23
static force_inline uint32_t
Packit 030a23
bits_image_fetch_pixel_filtered (bits_image_t *image,
Packit 030a23
				 pixman_fixed_t x,
Packit 030a23
				 pixman_fixed_t y,
Packit 030a23
				 get_pixel_t    get_pixel)
Packit 030a23
{
Packit 030a23
    switch (image->common.filter)
Packit 030a23
    {
Packit 030a23
    case PIXMAN_FILTER_NEAREST:
Packit 030a23
    case PIXMAN_FILTER_FAST:
Packit 030a23
	return bits_image_fetch_pixel_nearest (image, x, y, get_pixel);
Packit 030a23
	break;
Packit 030a23
Packit 030a23
    case PIXMAN_FILTER_BILINEAR:
Packit 030a23
    case PIXMAN_FILTER_GOOD:
Packit 030a23
    case PIXMAN_FILTER_BEST:
Packit 030a23
	return bits_image_fetch_pixel_bilinear (image, x, y, get_pixel);
Packit 030a23
	break;
Packit 030a23
Packit 030a23
    case PIXMAN_FILTER_CONVOLUTION:
Packit 030a23
	return bits_image_fetch_pixel_convolution (image, x, y, get_pixel);
Packit 030a23
	break;
Packit 030a23
Packit 030a23
    case PIXMAN_FILTER_SEPARABLE_CONVOLUTION:
Packit 030a23
        return bits_image_fetch_pixel_separable_convolution (image, x, y, get_pixel);
Packit 030a23
        break;
Packit 030a23
Packit 030a23
    default:
Packit 030a23
        break;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return 0;
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
bits_image_fetch_affine_no_alpha (pixman_iter_t *  iter,
Packit 030a23
				  const uint32_t * mask)
Packit 030a23
{
Packit 030a23
    pixman_image_t *image  = iter->image;
Packit 030a23
    int             offset = iter->x;
Packit 030a23
    int             line   = iter->y++;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    uint32_t *      buffer = iter->buffer;
Packit 030a23
Packit 030a23
    pixman_fixed_t x, y;
Packit 030a23
    pixman_fixed_t ux, uy;
Packit 030a23
    pixman_vector_t v;
Packit 030a23
    int i;
Packit 030a23
Packit 030a23
    /* reference point is the center of the pixel */
Packit 030a23
    v.vector[0] = pixman_int_to_fixed (offset) + pixman_fixed_1 / 2;
Packit 030a23
    v.vector[1] = pixman_int_to_fixed (line) + pixman_fixed_1 / 2;
Packit 030a23
    v.vector[2] = pixman_fixed_1;
Packit 030a23
Packit 030a23
    if (image->common.transform)
Packit 030a23
    {
Packit 030a23
	if (!pixman_transform_point_3d (image->common.transform, &v))
Packit 030a23
	    return iter->buffer;
Packit 030a23
Packit 030a23
	ux = image->common.transform->matrix[0][0];
Packit 030a23
	uy = image->common.transform->matrix[1][0];
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	ux = pixman_fixed_1;
Packit 030a23
	uy = 0;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    x = v.vector[0];
Packit 030a23
    y = v.vector[1];
Packit 030a23
Packit 030a23
    for (i = 0; i < width; ++i)
Packit 030a23
    {
Packit 030a23
	if (!mask || mask[i])
Packit 030a23
	{
Packit 030a23
	    buffer[i] = bits_image_fetch_pixel_filtered (
Packit 030a23
		&image->bits, x, y, fetch_pixel_no_alpha);
Packit 030a23
	}
Packit 030a23
Packit 030a23
	x += ux;
Packit 030a23
	y += uy;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
/* General fetcher */
Packit 030a23
static force_inline uint32_t
Packit 030a23
fetch_pixel_general (bits_image_t *image, int x, int y, pixman_bool_t check_bounds)
Packit 030a23
{
Packit 030a23
    uint32_t pixel;
Packit 030a23
Packit 030a23
    if (check_bounds &&
Packit 030a23
	(x < 0 || x >= image->width || y < 0 || y >= image->height))
Packit 030a23
    {
Packit 030a23
	return 0;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    pixel = image->fetch_pixel_32 (image, x, y);
Packit 030a23
Packit 030a23
    if (image->common.alpha_map)
Packit 030a23
    {
Packit 030a23
	uint32_t pixel_a;
Packit 030a23
Packit 030a23
	x -= image->common.alpha_origin_x;
Packit 030a23
	y -= image->common.alpha_origin_y;
Packit 030a23
Packit 030a23
	if (x < 0 || x >= image->common.alpha_map->width ||
Packit 030a23
	    y < 0 || y >= image->common.alpha_map->height)
Packit 030a23
	{
Packit 030a23
	    pixel_a = 0;
Packit 030a23
	}
Packit 030a23
	else
Packit 030a23
	{
Packit 030a23
	    pixel_a = image->common.alpha_map->fetch_pixel_32 (
Packit 030a23
		image->common.alpha_map, x, y);
Packit 030a23
Packit 030a23
	    pixel_a = ALPHA_8 (pixel_a);
Packit 030a23
	}
Packit 030a23
Packit 030a23
	pixel &= 0x00ffffff;
Packit 030a23
	pixel |= (pixel_a << 24);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return pixel;
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
bits_image_fetch_general (pixman_iter_t  *iter,
Packit 030a23
			  const uint32_t *mask)
Packit 030a23
{
Packit 030a23
    pixman_image_t *image  = iter->image;
Packit 030a23
    int             offset = iter->x;
Packit 030a23
    int             line   = iter->y++;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    uint32_t *      buffer = iter->buffer;
Packit 030a23
Packit 030a23
    pixman_fixed_t x, y, w;
Packit 030a23
    pixman_fixed_t ux, uy, uw;
Packit 030a23
    pixman_vector_t v;
Packit 030a23
    int i;
Packit 030a23
Packit 030a23
    /* reference point is the center of the pixel */
Packit 030a23
    v.vector[0] = pixman_int_to_fixed (offset) + pixman_fixed_1 / 2;
Packit 030a23
    v.vector[1] = pixman_int_to_fixed (line) + pixman_fixed_1 / 2;
Packit 030a23
    v.vector[2] = pixman_fixed_1;
Packit 030a23
Packit 030a23
    if (image->common.transform)
Packit 030a23
    {
Packit 030a23
	if (!pixman_transform_point_3d (image->common.transform, &v))
Packit 030a23
	    return buffer;
Packit 030a23
Packit 030a23
	ux = image->common.transform->matrix[0][0];
Packit 030a23
	uy = image->common.transform->matrix[1][0];
Packit 030a23
	uw = image->common.transform->matrix[2][0];
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	ux = pixman_fixed_1;
Packit 030a23
	uy = 0;
Packit 030a23
	uw = 0;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    x = v.vector[0];
Packit 030a23
    y = v.vector[1];
Packit 030a23
    w = v.vector[2];
Packit 030a23
Packit 030a23
    for (i = 0; i < width; ++i)
Packit 030a23
    {
Packit 030a23
	pixman_fixed_t x0, y0;
Packit 030a23
Packit 030a23
	if (!mask || mask[i])
Packit 030a23
	{
Packit 030a23
	    if (w != 0)
Packit 030a23
	    {
Packit 030a23
		x0 = ((pixman_fixed_48_16_t)x << 16) / w;
Packit 030a23
		y0 = ((pixman_fixed_48_16_t)y << 16) / w;
Packit 030a23
	    }
Packit 030a23
	    else
Packit 030a23
	    {
Packit 030a23
		x0 = 0;
Packit 030a23
		y0 = 0;
Packit 030a23
	    }
Packit 030a23
Packit 030a23
	    buffer[i] = bits_image_fetch_pixel_filtered (
Packit 030a23
		&image->bits, x0, y0, fetch_pixel_general);
Packit 030a23
	}
Packit 030a23
Packit 030a23
	x += ux;
Packit 030a23
	y += uy;
Packit 030a23
	w += uw;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
static void
Packit 030a23
replicate_pixel_32 (bits_image_t *   bits,
Packit 030a23
		    int              x,
Packit 030a23
		    int              y,
Packit 030a23
		    int              width,
Packit 030a23
		    uint32_t *       buffer)
Packit 030a23
{
Packit 030a23
    uint32_t color;
Packit 030a23
    uint32_t *end;
Packit 030a23
Packit 030a23
    color = bits->fetch_pixel_32 (bits, x, y);
Packit 030a23
Packit 030a23
    end = buffer + width;
Packit 030a23
    while (buffer < end)
Packit 030a23
	*(buffer++) = color;
Packit 030a23
}
Packit 030a23
Packit 030a23
static void
Packit 030a23
replicate_pixel_float (bits_image_t *   bits,
Packit 030a23
		       int              x,
Packit 030a23
		       int              y,
Packit 030a23
		       int              width,
Packit 030a23
		       uint32_t *       b)
Packit 030a23
{
Packit 030a23
    argb_t color;
Packit 030a23
    argb_t *buffer = (argb_t *)b;
Packit 030a23
    argb_t *end;
Packit 030a23
Packit 030a23
    color = bits->fetch_pixel_float (bits, x, y);
Packit 030a23
Packit 030a23
    end = buffer + width;
Packit 030a23
    while (buffer < end)
Packit 030a23
	*(buffer++) = color;
Packit 030a23
}
Packit 030a23
Packit 030a23
static void
Packit 030a23
bits_image_fetch_untransformed_repeat_none (bits_image_t *image,
Packit 030a23
                                            pixman_bool_t wide,
Packit 030a23
                                            int           x,
Packit 030a23
                                            int           y,
Packit 030a23
                                            int           width,
Packit 030a23
                                            uint32_t *    buffer)
Packit 030a23
{
Packit 030a23
    uint32_t w;
Packit 030a23
Packit 030a23
    if (y < 0 || y >= image->height)
Packit 030a23
    {
Packit 030a23
	memset (buffer, 0, width * (wide? sizeof (argb_t) : 4));
Packit 030a23
	return;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    if (x < 0)
Packit 030a23
    {
Packit 030a23
	w = MIN (width, -x);
Packit 030a23
Packit 030a23
	memset (buffer, 0, w * (wide ? sizeof (argb_t) : 4));
Packit 030a23
Packit 030a23
	width -= w;
Packit 030a23
	buffer += w * (wide? 4 : 1);
Packit 030a23
	x += w;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    if (x < image->width)
Packit 030a23
    {
Packit 030a23
	w = MIN (width, image->width - x);
Packit 030a23
Packit 030a23
	if (wide)
Packit 030a23
	    image->fetch_scanline_float (image, x, y, w, buffer, NULL);
Packit 030a23
	else
Packit 030a23
	    image->fetch_scanline_32 (image, x, y, w, buffer, NULL);
Packit 030a23
Packit 030a23
	width -= w;
Packit 030a23
	buffer += w * (wide? 4 : 1);
Packit 030a23
	x += w;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    memset (buffer, 0, width * (wide ? sizeof (argb_t) : 4));
Packit 030a23
}
Packit 030a23
Packit 030a23
static void
Packit 030a23
bits_image_fetch_untransformed_repeat_normal (bits_image_t *image,
Packit 030a23
                                              pixman_bool_t wide,
Packit 030a23
                                              int           x,
Packit 030a23
                                              int           y,
Packit 030a23
                                              int           width,
Packit 030a23
                                              uint32_t *    buffer)
Packit 030a23
{
Packit 030a23
    uint32_t w;
Packit 030a23
Packit 030a23
    while (y < 0)
Packit 030a23
	y += image->height;
Packit 030a23
Packit 030a23
    while (y >= image->height)
Packit 030a23
	y -= image->height;
Packit 030a23
Packit 030a23
    if (image->width == 1)
Packit 030a23
    {
Packit 030a23
	if (wide)
Packit 030a23
	    replicate_pixel_float (image, 0, y, width, buffer);
Packit 030a23
	else
Packit 030a23
	    replicate_pixel_32 (image, 0, y, width, buffer);
Packit 030a23
Packit 030a23
	return;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    while (width)
Packit 030a23
    {
Packit 030a23
	while (x < 0)
Packit 030a23
	    x += image->width;
Packit 030a23
	while (x >= image->width)
Packit 030a23
	    x -= image->width;
Packit 030a23
Packit 030a23
	w = MIN (width, image->width - x);
Packit 030a23
Packit 030a23
	if (wide)
Packit 030a23
	    image->fetch_scanline_float (image, x, y, w, buffer, NULL);
Packit 030a23
	else
Packit 030a23
	    image->fetch_scanline_32 (image, x, y, w, buffer, NULL);
Packit 030a23
Packit 030a23
	buffer += w * (wide? 4 : 1);
Packit 030a23
	x += w;
Packit 030a23
	width -= w;
Packit 030a23
    }
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
bits_image_fetch_untransformed_32 (pixman_iter_t * iter,
Packit 030a23
				   const uint32_t *mask)
Packit 030a23
{
Packit 030a23
    pixman_image_t *image  = iter->image;
Packit 030a23
    int             x      = iter->x;
Packit 030a23
    int             y      = iter->y;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    uint32_t *      buffer = iter->buffer;
Packit 030a23
Packit 030a23
    if (image->common.repeat == PIXMAN_REPEAT_NONE)
Packit 030a23
    {
Packit 030a23
	bits_image_fetch_untransformed_repeat_none (
Packit 030a23
	    &image->bits, FALSE, x, y, width, buffer);
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	bits_image_fetch_untransformed_repeat_normal (
Packit 030a23
	    &image->bits, FALSE, x, y, width, buffer);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    iter->y++;
Packit 030a23
    return buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
bits_image_fetch_untransformed_float (pixman_iter_t * iter,
Packit 030a23
				      const uint32_t *mask)
Packit 030a23
{
Packit 030a23
    pixman_image_t *image  = iter->image;
Packit 030a23
    int             x      = iter->x;
Packit 030a23
    int             y      = iter->y;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    uint32_t *      buffer = iter->buffer;
Packit 030a23
Packit 030a23
    if (image->common.repeat == PIXMAN_REPEAT_NONE)
Packit 030a23
    {
Packit 030a23
	bits_image_fetch_untransformed_repeat_none (
Packit 030a23
	    &image->bits, TRUE, x, y, width, buffer);
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	bits_image_fetch_untransformed_repeat_normal (
Packit 030a23
	    &image->bits, TRUE, x, y, width, buffer);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    iter->y++;
Packit 030a23
    return buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
typedef struct
Packit 030a23
{
Packit 030a23
    pixman_format_code_t	format;
Packit 030a23
    uint32_t			flags;
Packit 030a23
    pixman_iter_get_scanline_t	get_scanline_32;
Packit 030a23
    pixman_iter_get_scanline_t  get_scanline_float;
Packit 030a23
} fetcher_info_t;
Packit 030a23
Packit 030a23
static const fetcher_info_t fetcher_info[] =
Packit 030a23
{
Packit 030a23
    { PIXMAN_any,
Packit 030a23
      (FAST_PATH_NO_ALPHA_MAP			|
Packit 030a23
       FAST_PATH_ID_TRANSFORM			|
Packit 030a23
       FAST_PATH_NO_CONVOLUTION_FILTER		|
Packit 030a23
       FAST_PATH_NO_PAD_REPEAT			|
Packit 030a23
       FAST_PATH_NO_REFLECT_REPEAT),
Packit 030a23
      bits_image_fetch_untransformed_32,
Packit 030a23
      bits_image_fetch_untransformed_float
Packit 030a23
    },
Packit 030a23
Packit 030a23
    /* Affine, no alpha */
Packit 030a23
    { PIXMAN_any,
Packit 030a23
      (FAST_PATH_NO_ALPHA_MAP | FAST_PATH_HAS_TRANSFORM | FAST_PATH_AFFINE_TRANSFORM),
Packit 030a23
      bits_image_fetch_affine_no_alpha,
Packit 030a23
      _pixman_image_get_scanline_generic_float
Packit 030a23
    },
Packit 030a23
Packit 030a23
    /* General */
Packit 030a23
    { PIXMAN_any,
Packit 030a23
      0,
Packit 030a23
      bits_image_fetch_general,
Packit 030a23
      _pixman_image_get_scanline_generic_float
Packit 030a23
    },
Packit 030a23
Packit 030a23
    { PIXMAN_null },
Packit 030a23
};
Packit 030a23
Packit 030a23
static void
Packit 030a23
bits_image_property_changed (pixman_image_t *image)
Packit 030a23
{
Packit 030a23
    _pixman_bits_image_setup_accessors (&image->bits);
Packit 030a23
}
Packit 030a23
Packit 030a23
void
Packit 030a23
_pixman_bits_image_src_iter_init (pixman_image_t *image, pixman_iter_t *iter)
Packit 030a23
{
Packit 030a23
    pixman_format_code_t format = image->common.extended_format_code;
Packit 030a23
    uint32_t flags = image->common.flags;
Packit 030a23
    const fetcher_info_t *info;
Packit 030a23
Packit 030a23
    for (info = fetcher_info; info->format != PIXMAN_null; ++info)
Packit 030a23
    {
Packit 030a23
	if ((info->format == format || info->format == PIXMAN_any)	&&
Packit 030a23
	    (info->flags & flags) == info->flags)
Packit 030a23
	{
Packit 030a23
	    if (iter->iter_flags & ITER_NARROW)
Packit 030a23
	    {
Packit 030a23
		iter->get_scanline = info->get_scanline_32;
Packit 030a23
	    }
Packit 030a23
	    else
Packit 030a23
	    {
Packit 030a23
		iter->data = info->get_scanline_32;
Packit 030a23
		iter->get_scanline = info->get_scanline_float;
Packit 030a23
	    }
Packit 030a23
	    return;
Packit 030a23
	}
Packit 030a23
    }
Packit 030a23
Packit 030a23
    /* Just in case we somehow didn't find a scanline function */
Packit 030a23
    iter->get_scanline = _pixman_iter_get_scanline_noop;
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
dest_get_scanline_narrow (pixman_iter_t *iter, const uint32_t *mask)
Packit 030a23
{
Packit 030a23
    pixman_image_t *image  = iter->image;
Packit 030a23
    int             x      = iter->x;
Packit 030a23
    int             y      = iter->y;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    uint32_t *	    buffer = iter->buffer;
Packit 030a23
Packit 030a23
    image->bits.fetch_scanline_32 (&image->bits, x, y, width, buffer, mask);
Packit 030a23
    if (image->common.alpha_map)
Packit 030a23
    {
Packit 030a23
	uint32_t *alpha;
Packit 030a23
Packit 030a23
	if ((alpha = malloc (width * sizeof (uint32_t))))
Packit 030a23
	{
Packit 030a23
	    int i;
Packit 030a23
Packit 030a23
	    x -= image->common.alpha_origin_x;
Packit 030a23
	    y -= image->common.alpha_origin_y;
Packit 030a23
Packit 030a23
	    image->common.alpha_map->fetch_scanline_32 (
Packit 030a23
		image->common.alpha_map, x, y, width, alpha, mask);
Packit 030a23
Packit 030a23
	    for (i = 0; i < width; ++i)
Packit 030a23
	    {
Packit 030a23
		buffer[i] &= ~0xff000000;
Packit 030a23
		buffer[i] |= (alpha[i] & 0xff000000);
Packit 030a23
	    }
Packit 030a23
Packit 030a23
	    free (alpha);
Packit 030a23
	}
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return iter->buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
dest_get_scanline_wide (pixman_iter_t *iter, const uint32_t *mask)
Packit 030a23
{
Packit 030a23
    bits_image_t *  image  = &iter->image->bits;
Packit 030a23
    int             x      = iter->x;
Packit 030a23
    int             y      = iter->y;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    argb_t *	    buffer = (argb_t *)iter->buffer;
Packit 030a23
Packit 030a23
    image->fetch_scanline_float (
Packit 030a23
	image, x, y, width, (uint32_t *)buffer, mask);
Packit 030a23
    if (image->common.alpha_map)
Packit 030a23
    {
Packit 030a23
	argb_t *alpha;
Packit 030a23
Packit 030a23
	if ((alpha = malloc (width * sizeof (argb_t))))
Packit 030a23
	{
Packit 030a23
	    int i;
Packit 030a23
Packit 030a23
	    x -= image->common.alpha_origin_x;
Packit 030a23
	    y -= image->common.alpha_origin_y;
Packit 030a23
Packit 030a23
	    image->common.alpha_map->fetch_scanline_float (
Packit 030a23
		image->common.alpha_map, x, y, width, (uint32_t *)alpha, mask);
Packit 030a23
Packit 030a23
	    for (i = 0; i < width; ++i)
Packit 030a23
		buffer[i].a = alpha[i].a;
Packit 030a23
Packit 030a23
	    free (alpha);
Packit 030a23
	}
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return iter->buffer;
Packit 030a23
}
Packit 030a23
Packit 030a23
static void
Packit 030a23
dest_write_back_narrow (pixman_iter_t *iter)
Packit 030a23
{
Packit 030a23
    bits_image_t *  image  = &iter->image->bits;
Packit 030a23
    int             x      = iter->x;
Packit 030a23
    int             y      = iter->y;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    const uint32_t *buffer = iter->buffer;
Packit 030a23
Packit 030a23
    image->store_scanline_32 (image, x, y, width, buffer);
Packit 030a23
Packit 030a23
    if (image->common.alpha_map)
Packit 030a23
    {
Packit 030a23
	x -= image->common.alpha_origin_x;
Packit 030a23
	y -= image->common.alpha_origin_y;
Packit 030a23
Packit 030a23
	image->common.alpha_map->store_scanline_32 (
Packit 030a23
	    image->common.alpha_map, x, y, width, buffer);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    iter->y++;
Packit 030a23
}
Packit 030a23
Packit 030a23
static void
Packit 030a23
dest_write_back_wide (pixman_iter_t *iter)
Packit 030a23
{
Packit 030a23
    bits_image_t *  image  = &iter->image->bits;
Packit 030a23
    int             x      = iter->x;
Packit 030a23
    int             y      = iter->y;
Packit 030a23
    int             width  = iter->width;
Packit 030a23
    const uint32_t *buffer = iter->buffer;
Packit 030a23
Packit 030a23
    image->store_scanline_float (image, x, y, width, buffer);
Packit 030a23
Packit 030a23
    if (image->common.alpha_map)
Packit 030a23
    {
Packit 030a23
	x -= image->common.alpha_origin_x;
Packit 030a23
	y -= image->common.alpha_origin_y;
Packit 030a23
Packit 030a23
	image->common.alpha_map->store_scanline_float (
Packit 030a23
	    image->common.alpha_map, x, y, width, buffer);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    iter->y++;
Packit 030a23
}
Packit 030a23
Packit 030a23
void
Packit 030a23
_pixman_bits_image_dest_iter_init (pixman_image_t *image, pixman_iter_t *iter)
Packit 030a23
{
Packit 030a23
    if (iter->iter_flags & ITER_NARROW)
Packit 030a23
    {
Packit 030a23
	if ((iter->iter_flags & (ITER_IGNORE_RGB | ITER_IGNORE_ALPHA)) ==
Packit 030a23
	    (ITER_IGNORE_RGB | ITER_IGNORE_ALPHA))
Packit 030a23
	{
Packit 030a23
	    iter->get_scanline = _pixman_iter_get_scanline_noop;
Packit 030a23
	}
Packit 030a23
	else
Packit 030a23
	{
Packit 030a23
	    iter->get_scanline = dest_get_scanline_narrow;
Packit 030a23
	}
Packit 030a23
	
Packit 030a23
	iter->write_back = dest_write_back_narrow;
Packit 030a23
    }
Packit 030a23
    else
Packit 030a23
    {
Packit 030a23
	iter->get_scanline = dest_get_scanline_wide;
Packit 030a23
	iter->write_back = dest_write_back_wide;
Packit 030a23
    }
Packit 030a23
}
Packit 030a23
Packit 030a23
static uint32_t *
Packit 030a23
create_bits (pixman_format_code_t format,
Packit 030a23
             int                  width,
Packit 030a23
             int                  height,
Packit 030a23
             int *		  rowstride_bytes,
Packit 030a23
	     pixman_bool_t	  clear)
Packit 030a23
{
Packit 030a23
    int stride;
Packit 030a23
    size_t buf_size;
Packit 030a23
    int bpp;
Packit 030a23
Packit 030a23
    /* what follows is a long-winded way, avoiding any possibility of integer
Packit 030a23
     * overflows, of saying:
Packit 030a23
     * stride = ((width * bpp + 0x1f) >> 5) * sizeof (uint32_t);
Packit 030a23
     */
Packit 030a23
Packit 030a23
    bpp = PIXMAN_FORMAT_BPP (format);
Packit 030a23
    if (_pixman_multiply_overflows_int (width, bpp))
Packit 030a23
	return NULL;
Packit 030a23
Packit 030a23
    stride = width * bpp;
Packit 030a23
    if (_pixman_addition_overflows_int (stride, 0x1f))
Packit 030a23
	return NULL;
Packit 030a23
Packit 030a23
    stride += 0x1f;
Packit 030a23
    stride >>= 5;
Packit 030a23
Packit 030a23
    stride *= sizeof (uint32_t);
Packit 030a23
Packit 030a23
    if (_pixman_multiply_overflows_size (height, stride))
Packit 030a23
	return NULL;
Packit 030a23
Packit 030a23
    buf_size = (size_t)height * stride;
Packit 030a23
Packit 030a23
    if (rowstride_bytes)
Packit 030a23
	*rowstride_bytes = stride;
Packit 030a23
Packit 030a23
    if (clear)
Packit 030a23
	return calloc (buf_size, 1);
Packit 030a23
    else
Packit 030a23
	return malloc (buf_size);
Packit 030a23
}
Packit 030a23
Packit 030a23
pixman_bool_t
Packit 030a23
_pixman_bits_image_init (pixman_image_t *     image,
Packit 030a23
                         pixman_format_code_t format,
Packit 030a23
                         int                  width,
Packit 030a23
                         int                  height,
Packit 030a23
                         uint32_t *           bits,
Packit 030a23
                         int                  rowstride,
Packit 030a23
			 pixman_bool_t	      clear)
Packit 030a23
{
Packit 030a23
    uint32_t *free_me = NULL;
Packit 030a23
Packit 030a23
    if (!bits && width && height)
Packit 030a23
    {
Packit 030a23
	int rowstride_bytes;
Packit 030a23
Packit 030a23
	free_me = bits = create_bits (format, width, height, &rowstride_bytes, clear);
Packit 030a23
Packit 030a23
	if (!bits)
Packit 030a23
	    return FALSE;
Packit 030a23
Packit 030a23
	rowstride = rowstride_bytes / (int) sizeof (uint32_t);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    _pixman_image_init (image);
Packit 030a23
Packit 030a23
    image->type = BITS;
Packit 030a23
    image->bits.format = format;
Packit 030a23
    image->bits.width = width;
Packit 030a23
    image->bits.height = height;
Packit 030a23
    image->bits.bits = bits;
Packit 030a23
    image->bits.free_me = free_me;
Packit 030a23
    image->bits.read_func = NULL;
Packit 030a23
    image->bits.write_func = NULL;
Packit 030a23
    image->bits.rowstride = rowstride;
Packit 030a23
    image->bits.indexed = NULL;
Packit 030a23
Packit 030a23
    image->common.property_changed = bits_image_property_changed;
Packit 030a23
Packit 030a23
    _pixman_image_reset_clip_region (image);
Packit 030a23
Packit 030a23
    return TRUE;
Packit 030a23
}
Packit 030a23
Packit 030a23
static pixman_image_t *
Packit 030a23
create_bits_image_internal (pixman_format_code_t format,
Packit 030a23
			    int                  width,
Packit 030a23
			    int                  height,
Packit 030a23
			    uint32_t *           bits,
Packit 030a23
			    int                  rowstride_bytes,
Packit 030a23
			    pixman_bool_t	 clear)
Packit 030a23
{
Packit 030a23
    pixman_image_t *image;
Packit 030a23
Packit 030a23
    /* must be a whole number of uint32_t's
Packit 030a23
     */
Packit 030a23
    return_val_if_fail (
Packit 030a23
	bits == NULL || (rowstride_bytes % sizeof (uint32_t)) == 0, NULL);
Packit 030a23
Packit 030a23
    return_val_if_fail (PIXMAN_FORMAT_BPP (format) >= PIXMAN_FORMAT_DEPTH (format), NULL);
Packit 030a23
Packit 030a23
    image = _pixman_image_allocate ();
Packit 030a23
Packit 030a23
    if (!image)
Packit 030a23
	return NULL;
Packit 030a23
Packit 030a23
    if (!_pixman_bits_image_init (image, format, width, height, bits,
Packit 030a23
				  rowstride_bytes / (int) sizeof (uint32_t),
Packit 030a23
				  clear))
Packit 030a23
    {
Packit 030a23
	free (image);
Packit 030a23
	return NULL;
Packit 030a23
    }
Packit 030a23
Packit 030a23
    return image;
Packit 030a23
}
Packit 030a23
Packit 030a23
/* If bits is NULL, a buffer will be allocated and initialized to 0 */
Packit 030a23
PIXMAN_EXPORT pixman_image_t *
Packit 030a23
pixman_image_create_bits (pixman_format_code_t format,
Packit 030a23
                          int                  width,
Packit 030a23
                          int                  height,
Packit 030a23
                          uint32_t *           bits,
Packit 030a23
                          int                  rowstride_bytes)
Packit 030a23
{
Packit 030a23
    return create_bits_image_internal (
Packit 030a23
	format, width, height, bits, rowstride_bytes, TRUE);
Packit 030a23
}
Packit 030a23
Packit 030a23
Packit 030a23
/* If bits is NULL, a buffer will be allocated and _not_ initialized */
Packit 030a23
PIXMAN_EXPORT pixman_image_t *
Packit 030a23
pixman_image_create_bits_no_clear (pixman_format_code_t format,
Packit 030a23
				   int                  width,
Packit 030a23
				   int                  height,
Packit 030a23
				   uint32_t *           bits,
Packit 030a23
				   int                  rowstride_bytes)
Packit 030a23
{
Packit 030a23
    return create_bits_image_internal (
Packit 030a23
	format, width, height, bits, rowstride_bytes, FALSE);
Packit 030a23
}