Blame libfreerdp/primitives/prim_internal.h

Packit 1fb8d4
/* prim_internal.h
Packit 1fb8d4
 * vi:ts=4 sw=4
Packit 1fb8d4
 *
Packit 1fb8d4
 * (c) Copyright 2012 Hewlett-Packard Development Company, L.P.
Packit 1fb8d4
 * Licensed under the Apache License, Version 2.0 (the "License"); you may
Packit 1fb8d4
 * not use this file except in compliance with the License. You may obtain
Packit 1fb8d4
 * a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
Packit 1fb8d4
 * Unless required by applicable law or agreed to in writing, software
Packit 1fb8d4
 * distributed under the License is distributed on an "AS IS" BASIS,
Packit 1fb8d4
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
Packit 1fb8d4
 * or implied. See the License for the specific language governing
Packit 1fb8d4
 * permissions and limitations under the License.  Algorithms used by
Packit 1fb8d4
 * this code may be covered by patents by HP, Microsoft, or other parties.
Packit 1fb8d4
 *
Packit 1fb8d4
 */
Packit 1fb8d4
Packit 1fb8d4
#ifndef FREERDP_LIB_PRIM_INTERNAL_H
Packit 1fb8d4
#define FREERDP_LIB_PRIM_INTERNAL_H
Packit 1fb8d4
Packit 1fb8d4
#ifdef HAVE_CONFIG_H
Packit 1fb8d4
#include "config.h"
Packit 1fb8d4
#endif
Packit 1fb8d4
Packit 1fb8d4
#include <freerdp/primitives.h>
Packit 1fb8d4
#include <freerdp/api.h>
Packit 1fb8d4
Packit 1fb8d4
#ifdef __GNUC__
Packit 1fb8d4
#define PRIM_ALIGN_128 __attribute__((aligned(16)))
Packit 1fb8d4
#else
Packit 1fb8d4
#ifdef _WIN32
Packit 1fb8d4
#define PRIM_ALIGN_128 __declspec(align(16))
Packit 1fb8d4
#endif
Packit 1fb8d4
#endif
Packit 1fb8d4
Packit Service 5a9772
#if defined(WITH_SSE2) || defined(WITH_NEON) || defined(WITH_OPENCL)
Packit 1fb8d4
#define HAVE_OPTIMIZED_PRIMITIVES 1
Packit 1fb8d4
#endif
Packit 1fb8d4
Packit Service 5a9772
#if defined(WITH_SSE2) || defined(WITH_NEON)
Packit Service 5a9772
#define HAVE_CPU_OPTIMIZED_PRIMITIVES 1
Packit Service 5a9772
#endif
Packit Service 5a9772
Packit 1fb8d4
#if defined(WITH_SSE2)
Packit 1fb8d4
/* Use lddqu for unaligned; load for 16-byte aligned. */
Packit Service 5a9772
#define LOAD_SI128(_ptr_)                                           \
Packit Service 5a9772
	(((ULONG_PTR)(_ptr_)&0x0f) ? _mm_lddqu_si128((__m128i*)(_ptr_)) \
Packit Service 5a9772
	                           : _mm_load_si128((__m128i*)(_ptr_)))
Packit 1fb8d4
#endif
Packit 1fb8d4
Packit Service 5a9772
static INLINE BYTE* writePixelBGRX(BYTE* dst, DWORD formatSize, UINT32 format, BYTE R, BYTE G,
Packit Service 5a9772
                                   BYTE B, BYTE A)
Packit 1fb8d4
{
Packit Service 5a9772
	WINPR_UNUSED(formatSize);
Packit Service 5a9772
	WINPR_UNUSED(format);
Packit 1fb8d4
	*dst++ = B;
Packit 1fb8d4
	*dst++ = G;
Packit 1fb8d4
	*dst++ = R;
Packit 1fb8d4
	*dst++ = A;
Packit 1fb8d4
	return dst;
Packit 1fb8d4
}
Packit 1fb8d4
Packit Service 5a9772
static INLINE BYTE* writePixelRGBX(BYTE* dst, DWORD formatSize, UINT32 format, BYTE R, BYTE G,
Packit Service 5a9772
                                   BYTE B, BYTE A)
Packit 1fb8d4
{
Packit Service 5a9772
	WINPR_UNUSED(formatSize);
Packit Service 5a9772
	WINPR_UNUSED(format);
Packit 1fb8d4
	*dst++ = R;
Packit 1fb8d4
	*dst++ = G;
Packit 1fb8d4
	*dst++ = B;
Packit 1fb8d4
	*dst++ = A;
Packit 1fb8d4
	return dst;
Packit 1fb8d4
}
Packit 1fb8d4
Packit Service 5a9772
static INLINE BYTE* writePixelXBGR(BYTE* dst, DWORD formatSize, UINT32 format, BYTE R, BYTE G,
Packit Service 5a9772
                                   BYTE B, BYTE A)
Packit 1fb8d4
{
Packit Service 5a9772
	WINPR_UNUSED(formatSize);
Packit Service 5a9772
	WINPR_UNUSED(format);
Packit 1fb8d4
	*dst++ = A;
Packit 1fb8d4
	*dst++ = B;
Packit 1fb8d4
	*dst++ = G;
Packit 1fb8d4
	*dst++ = R;
Packit 1fb8d4
	return dst;
Packit 1fb8d4
}
Packit 1fb8d4
Packit Service 5a9772
static INLINE BYTE* writePixelXRGB(BYTE* dst, DWORD formatSize, UINT32 format, BYTE R, BYTE G,
Packit Service 5a9772
                                   BYTE B, BYTE A)
Packit 1fb8d4
{
Packit Service 5a9772
	WINPR_UNUSED(formatSize);
Packit Service 5a9772
	WINPR_UNUSED(format);
Packit 1fb8d4
	*dst++ = A;
Packit 1fb8d4
	*dst++ = R;
Packit 1fb8d4
	*dst++ = G;
Packit 1fb8d4
	*dst++ = B;
Packit 1fb8d4
	return dst;
Packit 1fb8d4
}
Packit 1fb8d4
Packit Service 5a9772
static INLINE BYTE* writePixelGeneric(BYTE* dst, DWORD formatSize, UINT32 format, BYTE R, BYTE G,
Packit Service 5a9772
                                      BYTE B, BYTE A)
Packit 1fb8d4
{
Packit 1fb8d4
	UINT32 color = FreeRDPGetColor(format, R, G, B, A);
Packit 1fb8d4
	WriteColor(dst, format, color);
Packit 1fb8d4
	return dst + formatSize;
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
typedef BYTE* (*fkt_writePixel)(BYTE*, DWORD, UINT32, BYTE, BYTE, BYTE, BYTE);
Packit 1fb8d4
Packit 1fb8d4
static INLINE fkt_writePixel getPixelWriteFunction(DWORD format)
Packit 1fb8d4
{
Packit 1fb8d4
	switch (format)
Packit 1fb8d4
	{
Packit 1fb8d4
		case PIXEL_FORMAT_ARGB32:
Packit 1fb8d4
		case PIXEL_FORMAT_XRGB32:
Packit 1fb8d4
			return writePixelXRGB;
Packit 1fb8d4
Packit 1fb8d4
		case PIXEL_FORMAT_ABGR32:
Packit 1fb8d4
		case PIXEL_FORMAT_XBGR32:
Packit 1fb8d4
			return writePixelXBGR;
Packit 1fb8d4
Packit 1fb8d4
		case PIXEL_FORMAT_RGBA32:
Packit 1fb8d4
		case PIXEL_FORMAT_RGBX32:
Packit 1fb8d4
			return writePixelRGBX;
Packit 1fb8d4
Packit 1fb8d4
		case PIXEL_FORMAT_BGRA32:
Packit 1fb8d4
		case PIXEL_FORMAT_BGRX32:
Packit 1fb8d4
			return writePixelBGRX;
Packit 1fb8d4
Packit 1fb8d4
		default:
Packit 1fb8d4
			return writePixelGeneric;
Packit 1fb8d4
	}
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
static INLINE BYTE CLIP(INT32 X)
Packit 1fb8d4
{
Packit 1fb8d4
	if (X > 255L)
Packit 1fb8d4
		return 255L;
Packit 1fb8d4
Packit 1fb8d4
	if (X < 0L)
Packit 1fb8d4
		return 0L;
Packit 1fb8d4
Packit 1fb8d4
	return X;
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
/**
Packit 1fb8d4
 * | R |   ( | 256     0    403 | |    Y    | )
Packit 1fb8d4
 * | G | = ( | 256   -48   -120 | | U - 128 | ) >> 8
Packit 1fb8d4
 * | B |   ( | 256   475      0 | | V - 128 | )
Packit 1fb8d4
 */
Packit 1fb8d4
static INLINE INT32 C(INT32 Y)
Packit 1fb8d4
{
Packit Service 5a9772
	return (Y)-0L;
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
static INLINE INT32 D(INT32 U)
Packit 1fb8d4
{
Packit Service 5a9772
	return (U)-128L;
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
static INLINE INT32 E(INT32 V)
Packit 1fb8d4
{
Packit Service 5a9772
	return (V)-128L;
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
static INLINE BYTE YUV2R(INT32 Y, INT32 U, INT32 V)
Packit 1fb8d4
{
Packit Service 5a9772
	const INT32 r = (256L * C(Y) + 0L * D(U) + 403L * E(V));
Packit 1fb8d4
	const INT32 r8 = r >> 8L;
Packit 1fb8d4
	return CLIP(r8);
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
static INLINE BYTE YUV2G(INT32 Y, INT32 U, INT32 V)
Packit 1fb8d4
{
Packit Service 5a9772
	const INT32 g = (256L * C(Y) - 48L * D(U) - 120L * E(V));
Packit 1fb8d4
	const INT32 g8 = g >> 8L;
Packit 1fb8d4
	return CLIP(g8);
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
static INLINE BYTE YUV2B(INT32 Y, INT32 U, INT32 V)
Packit 1fb8d4
{
Packit Service 5a9772
	const INT32 b = (256L * C(Y) + 475L * D(U) + 0L * E(V));
Packit 1fb8d4
	const INT32 b8 = b >> 8L;
Packit 1fb8d4
	return CLIP(b8);
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
/* Function prototypes for all the init/deinit routines. */
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_copy(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_set(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_add(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_andor(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_shift(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_sign(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_alphaComp(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_colors(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_YCoCg(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_YUV(primitives_t* prims);
Packit 1fb8d4
Packit 1fb8d4
#if defined(WITH_SSE2) || defined(WITH_NEON)
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_copy_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_set_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_add_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_andor_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_shift_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_sign_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_alphaComp_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_colors_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_YCoCg_opt(primitives_t* prims);
Packit 1fb8d4
FREERDP_LOCAL void primitives_init_YUV_opt(primitives_t* prims);
Packit 1fb8d4
#endif
Packit 1fb8d4
Packit Service 5a9772
#if defined(WITH_OPENCL)
Packit Service 5a9772
FREERDP_LOCAL BOOL primitives_init_opencl(primitives_t* prims);
Packit Service 5a9772
#endif
Packit Service 5a9772
Packit Service 5a9772
FREERDP_LOCAL primitives_t* primitives_get_by_type(DWORD type);
Packit Service 5a9772
Packit 1fb8d4
#endif /* FREERDP_LIB_PRIM_INTERNAL_H */