genericopenlibs/liboil/tsrc/testsuite/function/src/function.c
author hgs
Tue, 02 Nov 2010 19:23:22 +0530
changeset 79 564bc7b7ad27
parent 71 28ccaba883f4
permissions -rw-r--r--
201043
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
71
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: 
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include <liboil/liboil.h>
hgs
parents:
diff changeset
    20
#include <liboil/liboilfunction.h>
hgs
parents:
diff changeset
    21
#include <stdio.h>
hgs
parents:
diff changeset
    22
#include <stdlib.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include <liboil/globals.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#define LOG_FILE "c:\\logs\\testsuite_function_log.txt"
hgs
parents:
diff changeset
    27
#include "std_log_result.h"
hgs
parents:
diff changeset
    28
#define LOG_FILENAME_LINE __FILE__, __LINE__
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
#define SIZE    20
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
void create_xml(int result)
hgs
parents:
diff changeset
    33
{
hgs
parents:
diff changeset
    34
    if(result)
hgs
parents:
diff changeset
    35
        assert_failed = 1;
hgs
parents:
diff changeset
    36
    
hgs
parents:
diff changeset
    37
    testResultXml("testsuite_function");
hgs
parents:
diff changeset
    38
    close_log_file();
hgs
parents:
diff changeset
    39
}
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
void abs_f32_f32_test(float * dest, int dstr, const float * src, int sstr, int n)
hgs
parents:
diff changeset
    42
    {
hgs
parents:
diff changeset
    43
    int i = 0;
hgs
parents:
diff changeset
    44
    std_log(LOG_FILENAME_LINE,"abs_f32_f32_test is called");
hgs
parents:
diff changeset
    45
    assert_failed = 0;
hgs
parents:
diff changeset
    46
    
hgs
parents:
diff changeset
    47
    for(i=0; i<SIZE; i++)
hgs
parents:
diff changeset
    48
        dest[i] = 10;
hgs
parents:
diff changeset
    49
    }
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
void test_oil_class_register_impl_by_name()
hgs
parents:
diff changeset
    52
    {
hgs
parents:
diff changeset
    53
    float output[SIZE];
hgs
parents:
diff changeset
    54
    float input[SIZE];
hgs
parents:
diff changeset
    55
    
hgs
parents:
diff changeset
    56
    OilFunctionImpl *impl;
hgs
parents:
diff changeset
    57
    
hgs
parents:
diff changeset
    58
    impl = (OilFunctionImpl*)calloc(sizeof(OilFunctionImpl), 0);
hgs
parents:
diff changeset
    59
	if(impl != NULL)
hgs
parents:
diff changeset
    60
		{
hgs
parents:
diff changeset
    61
		impl->func = (void*)abs_f32_f32_test;
hgs
parents:
diff changeset
    62
		impl->name = "abs_f32_f32_test";
hgs
parents:
diff changeset
    63
	    
hgs
parents:
diff changeset
    64
		oil_class_register_impl_by_name("abs_f32_f32", impl);
hgs
parents:
diff changeset
    65
	    
hgs
parents:
diff changeset
    66
		assert_failed = 1; //will be set to 0, if abs_f32_f32_test is called
hgs
parents:
diff changeset
    67
		oil_abs_f32_f32(output, 1, input, 2, SIZE);
hgs
parents:
diff changeset
    68
		}
hgs
parents:
diff changeset
    69
	else
hgs
parents:
diff changeset
    70
		{
hgs
parents:
diff changeset
    71
		std_log(LOG_FILENAME_LINE,"memory allocation failed. errno = %d", errno);
hgs
parents:
diff changeset
    72
		assert_failed = 1;
hgs
parents:
diff changeset
    73
		}
hgs
parents:
diff changeset
    74
    }
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
void test_oil_class_register_impl()
hgs
parents:
diff changeset
    77
    {
hgs
parents:
diff changeset
    78
    float output[SIZE];
hgs
parents:
diff changeset
    79
    float input[SIZE];
hgs
parents:
diff changeset
    80
    
hgs
parents:
diff changeset
    81
    OilFunctionClass *klass;
hgs
parents:
diff changeset
    82
    OilFunctionImpl *impl;
hgs
parents:
diff changeset
    83
    
hgs
parents:
diff changeset
    84
	if(impl != NULL)
hgs
parents:
diff changeset
    85
		{
hgs
parents:
diff changeset
    86
		impl = (OilFunctionImpl*)calloc(sizeof(OilFunctionImpl), 0);
hgs
parents:
diff changeset
    87
		impl->func = (void *)abs_f32_f32_test;
hgs
parents:
diff changeset
    88
		impl->name = "abs_f32_f32_test";
hgs
parents:
diff changeset
    89
	    
hgs
parents:
diff changeset
    90
		klass = (OilFunctionClass *)oil_class_get ("abs_f32_f32");
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
		if(klass != NULL)
hgs
parents:
diff changeset
    93
			{
hgs
parents:
diff changeset
    94
			oil_class_register_impl(klass, impl);
hgs
parents:
diff changeset
    95
		    
hgs
parents:
diff changeset
    96
			assert_failed = 1; //will be set to 0, if abs_f32_f32_test is called
hgs
parents:
diff changeset
    97
			oil_abs_f32_f32(output, 1, input, 2, SIZE);
hgs
parents:
diff changeset
    98
			}
hgs
parents:
diff changeset
    99
		else
hgs
parents:
diff changeset
   100
			{
hgs
parents:
diff changeset
   101
			std_log(LOG_FILENAME_LINE,"oil_class_get returned NULL. errno = %d", errno);
hgs
parents:
diff changeset
   102
			assert_failed = 1;
hgs
parents:
diff changeset
   103
			}
hgs
parents:
diff changeset
   104
		}
hgs
parents:
diff changeset
   105
	else
hgs
parents:
diff changeset
   106
		{
hgs
parents:
diff changeset
   107
		std_log(LOG_FILENAME_LINE,"memory allocation failed. errno = %d", errno);
hgs
parents:
diff changeset
   108
		assert_failed = 1;
hgs
parents:
diff changeset
   109
		}
hgs
parents:
diff changeset
   110
    }
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
void test_oil_class_register_impl_full()
hgs
parents:
diff changeset
   113
    {
hgs
parents:
diff changeset
   114
    float output[SIZE];
hgs
parents:
diff changeset
   115
    float input[SIZE];
hgs
parents:
diff changeset
   116
    OilFunctionClass *klass;
hgs
parents:
diff changeset
   117
    
hgs
parents:
diff changeset
   118
    klass = (OilFunctionClass *)oil_class_get ("abs_f32_f32");
hgs
parents:
diff changeset
   119
    
hgs
parents:
diff changeset
   120
	if(klass != NULL)
hgs
parents:
diff changeset
   121
		{
hgs
parents:
diff changeset
   122
		oil_class_register_impl_full(klass, (void*)abs_f32_f32_test, "abs_f32_f32_test", OIL_IMPL_FLAG_OPT);
hgs
parents:
diff changeset
   123
	    
hgs
parents:
diff changeset
   124
		assert_failed = 1; //will be set to 0, if abs_f32_f32_test is called
hgs
parents:
diff changeset
   125
		oil_abs_f32_f32(output, 1, input, 2, SIZE);
hgs
parents:
diff changeset
   126
		}
hgs
parents:
diff changeset
   127
	else
hgs
parents:
diff changeset
   128
		{
hgs
parents:
diff changeset
   129
		std_log(LOG_FILENAME_LINE,"oil_class_get returned NULL. errno = %d", errno);
hgs
parents:
diff changeset
   130
		assert_failed = 1;
hgs
parents:
diff changeset
   131
		}
hgs
parents:
diff changeset
   132
    }
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
int main (int argc, char *argv[])
hgs
parents:
diff changeset
   135
{
hgs
parents:
diff changeset
   136
  oil_init();
hgs
parents:
diff changeset
   137
  oil_init_no_optimize();
hgs
parents:
diff changeset
   138
  oil_optimize("abs_f32_f32");
hgs
parents:
diff changeset
   139
  
hgs
parents:
diff changeset
   140
 
hgs
parents:
diff changeset
   141
  test_oil_class_register_impl_by_name();
hgs
parents:
diff changeset
   142
  test_oil_class_register_impl();
hgs
parents:
diff changeset
   143
  test_oil_class_register_impl_full();
hgs
parents:
diff changeset
   144
    
hgs
parents:
diff changeset
   145
  if(assert_failed)
hgs
parents:
diff changeset
   146
      std_log(LOG_FILENAME_LINE,"Test Failed");
hgs
parents:
diff changeset
   147
  else
hgs
parents:
diff changeset
   148
      std_log(LOG_FILENAME_LINE,"Test Successful");
hgs
parents:
diff changeset
   149
  create_xml(0);
hgs
parents:
diff changeset
   150
  return 0;
hgs
parents:
diff changeset
   151
}
hgs
parents:
diff changeset
   152