2013-01-19 02:32:58 +04:00
|
|
|
/* test_set.c
|
|
|
|
* vi:ts=4 sw=4
|
|
|
|
*
|
|
|
|
* (c) Copyright 2012 Hewlett-Packard Development Company, L.P.
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
* not use this file except in compliance with the License. You may obtain
|
|
|
|
* a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
|
|
|
|
* or implied. See the License for the specific language governing
|
|
|
|
* permissions and limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2013-01-19 23:27:34 +04:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2013-02-27 18:58:06 +04:00
|
|
|
#include <winpr/sysinfo.h>
|
2013-01-19 02:32:58 +04:00
|
|
|
#include "prim_test.h"
|
|
|
|
|
|
|
|
static const int MEMSET8_PRETEST_ITERATIONS = 100000000;
|
|
|
|
static const int MEMSET32_PRETEST_ITERATIONS = 40000000;
|
|
|
|
static const float TEST_TIME = 1.0;
|
|
|
|
|
|
|
|
static const int set_sizes[] = { 1, 4, 16, 32, 64, 256, 1024, 4096 };
|
|
|
|
#define NUM_SET_SIZES (sizeof(set_sizes)/sizeof(int))
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
2016-04-05 18:07:45 +03:00
|
|
|
static BOOL check8(const BYTE* src, UINT32 length, UINT32 offset, BYTE value)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
UINT32 i;
|
|
|
|
for (i = 0; i < length; ++i)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
if (src[offset + i] != value)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("SET8U FAILED: off=%"PRIu32" len=%"PRIu32" dest[%"PRIu32"]=0x%02"PRIx8"\n",
|
2016-04-05 18:07:45 +03:00
|
|
|
offset, length, i + offset, src[i + offset]);
|
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static BOOL test_set8u_func(void)
|
|
|
|
{
|
|
|
|
pstatus_t status;
|
|
|
|
UINT32 off;
|
|
|
|
BYTE dest[1024];
|
|
|
|
|
|
|
|
for (off = 0; off < 16; ++off)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
UINT32 len;
|
|
|
|
|
2016-07-13 15:04:48 +03:00
|
|
|
memset(dest, 3, sizeof(dest));
|
2016-04-05 18:07:45 +03:00
|
|
|
for (len = 1; len < 48 - off; ++len)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
status = generic->set_8u(0xa5, dest + off, len);
|
|
|
|
if (status != PRIMITIVES_SUCCESS)
|
|
|
|
return FALSE;
|
|
|
|
|
2016-07-13 15:04:48 +03:00
|
|
|
if (!check8(dest, len, off, 0xa5))
|
2016-04-05 18:07:45 +03:00
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
for (off = 0; off < 16; ++off)
|
|
|
|
{
|
|
|
|
UINT32 len;
|
2013-01-19 02:32:58 +04:00
|
|
|
|
2016-07-13 15:04:48 +03:00
|
|
|
memset(dest, 3, sizeof(dest));
|
2016-04-05 18:07:45 +03:00
|
|
|
for (len = 1; len < 48 - off; ++len)
|
|
|
|
{
|
|
|
|
status = optimized->set_8u(0xa5, dest + off, len);
|
|
|
|
if (status != PRIMITIVES_SUCCESS)
|
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
|
2016-07-13 15:04:48 +03:00
|
|
|
if (!check8(dest, len, off, 0xa5))
|
2016-04-05 18:07:45 +03:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
2016-04-05 18:07:45 +03:00
|
|
|
static BOOL test_set8u_speed(void)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
BYTE dest[1024];
|
|
|
|
BYTE value;
|
|
|
|
UINT32 x;
|
2013-01-19 02:32:58 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
for (x=0; x<16; x++)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
winpr_RAND(&value, sizeof(value));
|
|
|
|
if (!speed_test("set_8u", "", g_Iterations,
|
2016-07-13 15:04:48 +03:00
|
|
|
(speed_test_fkt)generic->set_8u,
|
|
|
|
(speed_test_fkt)optimized->set_8u,
|
|
|
|
value, dest + x, x))
|
2016-04-05 18:07:45 +03:00
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static BOOL check32s(const INT32* src, UINT32 length, UINT32 offset, INT32 value)
|
|
|
|
{
|
|
|
|
UINT32 i;
|
|
|
|
for (i = 0; i < length; ++i)
|
|
|
|
{
|
|
|
|
if (src[offset + i] != value)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("SET8U FAILED: off=%"PRIu32" len=%"PRIu32" dest[%"PRIu32"]=0x%08"PRIx32"\n",
|
2016-04-05 18:07:45 +03:00
|
|
|
offset, length, i + offset, src[i + offset]);
|
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
return TRUE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
2016-04-05 18:07:45 +03:00
|
|
|
static BOOL test_set32s_func(void)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
pstatus_t status;
|
|
|
|
UINT32 off;
|
|
|
|
INT32 dest[1024];
|
|
|
|
const INT32 value = -0x12345678;
|
2013-01-19 02:32:58 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
for (off = 0; off < 16; ++off)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
UINT32 len;
|
|
|
|
|
|
|
|
memset(dest, 0, sizeof(dest));
|
|
|
|
for (len = 1; len < 48 - off; ++len)
|
|
|
|
{
|
|
|
|
status = generic->set_32s(value, dest + off, len);
|
|
|
|
if (status != PRIMITIVES_SUCCESS)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (!check32s(dest, len, off, value))
|
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
for (off = 0; off < 16; ++off)
|
|
|
|
{
|
|
|
|
UINT32 len;
|
|
|
|
|
|
|
|
memset(dest, 0, sizeof(dest));
|
|
|
|
for (len = 1; len < 48 - off; ++len)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
status = optimized->set_32s(value, dest + off, len);
|
|
|
|
if (status != PRIMITIVES_SUCCESS)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (!check32s(dest, len, off, value))
|
|
|
|
return FALSE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
return TRUE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
static BOOL check32u(const UINT32* src, UINT32 length, UINT32 offset, UINT32 value)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
UINT32 i;
|
|
|
|
for (i = 0; i < length; ++i)
|
|
|
|
{
|
|
|
|
if (src[offset + i] != value)
|
|
|
|
{
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("SET8U FAILED: off=%"PRIu32" len=%"PRIu32" dest[%"PRIu32"]=0x%08"PRIx32"\n",
|
2016-04-05 18:07:45 +03:00
|
|
|
offset, length, i + offset, src[i + offset]);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
2016-04-05 18:07:45 +03:00
|
|
|
static BOOL test_set32u_func(void)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
pstatus_t status;
|
|
|
|
UINT32 off;
|
|
|
|
UINT32 dest[1024];
|
|
|
|
const UINT32 value = 0xABCDEF12;
|
|
|
|
|
|
|
|
for (off = 0; off < 16; ++off)
|
|
|
|
{
|
|
|
|
UINT32 len;
|
|
|
|
|
|
|
|
memset(dest, 0, sizeof(dest));
|
|
|
|
for (len = 1; len < 48 - off; ++len)
|
|
|
|
{
|
|
|
|
status = generic->set_32u(value, dest + off, len);
|
|
|
|
if (status != PRIMITIVES_SUCCESS)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (!check32u(dest, len, off, value))
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (off = 0; off < 16; ++off)
|
|
|
|
{
|
|
|
|
UINT32 len;
|
|
|
|
|
|
|
|
memset(dest, 0, sizeof(dest));
|
|
|
|
for (len = 1; len < 48 - off; ++len)
|
|
|
|
{
|
|
|
|
status = optimized->set_32u(value, dest + off, len);
|
|
|
|
if (status != PRIMITIVES_SUCCESS)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (!check32u(dest, len, off, value))
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
2016-04-05 18:07:45 +03:00
|
|
|
static BOOL test_set32u_speed(void)
|
2013-01-19 02:32:58 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
UINT32 dest[1024];
|
|
|
|
BYTE value;
|
|
|
|
UINT32 x;
|
2013-01-19 02:32:58 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
for (x=0; x<16; x++)
|
|
|
|
{
|
|
|
|
winpr_RAND(&value, sizeof(value));
|
|
|
|
if (!speed_test("set_32u", "", g_Iterations,
|
2016-07-13 15:04:48 +03:00
|
|
|
(speed_test_fkt)generic->set_32u,
|
|
|
|
(speed_test_fkt)optimized->set_32u,
|
|
|
|
value, dest + x, x))
|
2016-04-05 18:07:45 +03:00
|
|
|
return FALSE;
|
|
|
|
}
|
2013-01-19 02:32:58 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
return TRUE;
|
2013-01-19 02:32:58 +04:00
|
|
|
}
|
2014-09-04 23:46:20 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
static BOOL test_set32s_speed(void)
|
2014-09-04 23:46:20 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
INT32 dest[1024];
|
|
|
|
BYTE value;
|
|
|
|
UINT32 x;
|
2014-09-04 23:46:20 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
for (x=0; x<16; x++)
|
2014-09-04 23:46:20 +04:00
|
|
|
{
|
2016-04-05 18:07:45 +03:00
|
|
|
winpr_RAND(&value, sizeof(value));
|
|
|
|
if (!speed_test("set_32s", "", g_Iterations,
|
2016-07-13 15:04:48 +03:00
|
|
|
(speed_test_fkt)generic->set_32s,
|
|
|
|
(speed_test_fkt)optimized->set_32s,
|
|
|
|
value, dest + x, x))
|
2016-04-05 18:07:45 +03:00
|
|
|
return FALSE;
|
2014-09-04 23:46:20 +04:00
|
|
|
}
|
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
return TRUE;
|
|
|
|
}
|
2014-09-04 23:46:20 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
int TestPrimitivesSet(int argc, char* argv[])
|
|
|
|
{
|
|
|
|
prim_test_setup(FALSE);
|
2014-09-04 23:46:20 +04:00
|
|
|
|
2016-04-05 18:07:45 +03:00
|
|
|
if (!test_set8u_func())
|
|
|
|
return -1;
|
|
|
|
if (!test_set32s_func())
|
|
|
|
return -1;
|
|
|
|
if (!test_set32u_func())
|
|
|
|
return -1;
|
2014-09-04 23:46:20 +04:00
|
|
|
|
2016-07-13 15:04:48 +03:00
|
|
|
if (g_TestPrimitivesPerformance)
|
|
|
|
{
|
|
|
|
if (!test_set8u_speed())
|
|
|
|
return -1;
|
|
|
|
if (!test_set32s_speed())
|
|
|
|
return -1;
|
|
|
|
if (!test_set32u_speed())
|
|
|
|
return -1;
|
|
|
|
}
|
2014-09-04 23:46:20 +04:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|