Blame libfreerdp/primitives/prim_add.c

Packit Service fa4841
/* FreeRDP: A Remote Desktop Protocol Client
Packit Service fa4841
 * Add operations.
Packit Service fa4841
 * vi:ts=4 sw=4:
Packit Service fa4841
 *
Packit Service fa4841
 * (c) Copyright 2012 Hewlett-Packard Development Company, L.P.
Packit Service fa4841
 * Licensed under the Apache License, Version 2.0 (the "License"); you may
Packit Service fa4841
 * not use this file except in compliance with the License. You may obtain
Packit Service fa4841
 * a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
Packit Service fa4841
 * Unless required by applicable law or agreed to in writing, software
Packit Service fa4841
 * distributed under the License is distributed on an "AS IS" BASIS,
Packit Service fa4841
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
Packit Service fa4841
 * or implied. See the License for the specific language governing
Packit Service fa4841
 * permissions and limitations under the License.
Packit Service fa4841
 *
Packit Service fa4841
 */
Packit Service fa4841
Packit Service fa4841
#ifdef HAVE_CONFIG_H
Packit Service fa4841
#include "config.h"
Packit Service fa4841
#endif
Packit Service fa4841
Packit Service fa4841
#include <freerdp/types.h>
Packit Service fa4841
#include <freerdp/primitives.h>
Packit Service fa4841
Packit Service fa4841
#include "prim_internal.h"
Packit Service fa4841
Packit Service fa4841
/* ----------------------------------------------------------------------------
Packit Service fa4841
 * 16-bit signed add with saturation (under and over).
Packit Service fa4841
 */
Packit Service b1ea74
static pstatus_t general_add_16s(const INT16* pSrc1, const INT16* pSrc2, INT16* pDst, UINT32 len)
Packit Service fa4841
{
Packit Service fa4841
	while (len--)
Packit Service fa4841
	{
Packit Service fa4841
		INT32 k = (INT32)(*pSrc1++) + (INT32)(*pSrc2++);
Packit Service fa4841
Packit Service b1ea74
		if (k > 32767)
Packit Service b1ea74
			*pDst++ = ((INT16)32767);
Packit Service b1ea74
		else if (k < -32768)
Packit Service b1ea74
			*pDst++ = ((INT16)-32768);
Packit Service b1ea74
		else
Packit Service b1ea74
			*pDst++ = (INT16)k;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	return PRIMITIVES_SUCCESS;
Packit Service fa4841
}
Packit Service fa4841
Packit Service fa4841
/* ------------------------------------------------------------------------- */
Packit Service b1ea74
void primitives_init_add(primitives_t* prims)
Packit Service fa4841
{
Packit Service fa4841
	prims->add_16s = general_add_16s;
Packit Service fa4841
}