os/ossrv/genericopenlibs/liboil/src/mmx/splat_mmx.c
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
/*
sl@0
     2
 * Copyright (c) 2005
sl@0
     3
 *	Eric Anholt.  All rights reserved.
sl@0
     4
 *
sl@0
     5
 * Redistribution and use in source and binary forms, with or without
sl@0
     6
 * modification, are permitted provided that the following conditions
sl@0
     7
 * are met:
sl@0
     8
 * 1. Redistributions of source code must retain the above copyright
sl@0
     9
 *    notice, this list of conditions and the following disclaimer.
sl@0
    10
 * 2. Redistributions in binary form must reproduce the above copyright
sl@0
    11
 *    notice, this list of conditions and the following disclaimer in the
sl@0
    12
 *    documentation and/or other materials provided with the distribution.
sl@0
    13
 *
sl@0
    14
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND
sl@0
    15
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
sl@0
    16
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
sl@0
    17
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE
sl@0
    18
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
sl@0
    19
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
sl@0
    20
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
sl@0
    21
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
sl@0
    22
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
sl@0
    23
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
sl@0
    24
 * SUCH DAMAGE.
sl@0
    25
 */
sl@0
    26
//Portions Copyright (c)  2008-2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. 
sl@0
    27
sl@0
    28
#ifdef HAVE_CONFIG_H
sl@0
    29
#include "config.h"
sl@0
    30
#endif
sl@0
    31
#include <liboil/liboilclasses.h>
sl@0
    32
#include <liboil/liboilfunction.h>
sl@0
    33
sl@0
    34
#ifdef HAVE_GCC_ASM      
sl@0
    35
#include <mmintrin.h>
sl@0
    36
#endif
sl@0
    37
sl@0
    38
static void
sl@0
    39
splat_u32_ns_mmx (uint32_t *dest, const uint32_t *param, int n)
sl@0
    40
{
sl@0
    41
#ifdef HAVE_GCC_ASM      
sl@0
    42
  __m64 v;
sl@0
    43
sl@0
    44
  v = _mm_set1_pi32(*param);
sl@0
    45
sl@0
    46
  for (; n >= 2; n -= 2) {
sl@0
    47
    *(__m64 *)dest = v;
sl@0
    48
    dest += 2;
sl@0
    49
  }
sl@0
    50
  for (; n > 0; n--) {
sl@0
    51
    *dest++ = *param;
sl@0
    52
  }
sl@0
    53
  _mm_empty();
sl@0
    54
#endif  
sl@0
    55
}
sl@0
    56
OIL_DEFINE_IMPL_FULL (splat_u32_ns_mmx, splat_u32_ns, OIL_IMPL_FLAG_MMX);
sl@0
    57
sl@0
    58
static void
sl@0
    59
splat_u32_ns_mmx_unroll4 (uint32_t *dest, const uint32_t *param, int n)
sl@0
    60
{
sl@0
    61
#ifdef HAVE_GCC_ASM      
sl@0
    62
  __m64 v;
sl@0
    63
sl@0
    64
  v = _mm_set1_pi32(*param);
sl@0
    65
sl@0
    66
  for (; n >= 8; n -= 8) {
sl@0
    67
    ((__m64 *)dest)[0] = v;
sl@0
    68
    ((__m64 *)dest)[1] = v;
sl@0
    69
    ((__m64 *)dest)[2] = v;
sl@0
    70
    ((__m64 *)dest)[3] = v;
sl@0
    71
    dest += 8;
sl@0
    72
  }
sl@0
    73
  for (; n >= 2; n -= 2) {
sl@0
    74
    *(__m64 *)dest = v;
sl@0
    75
    dest += 2;
sl@0
    76
  }
sl@0
    77
  for (; n > 0; n--) {
sl@0
    78
    *dest++ = *param;
sl@0
    79
  }
sl@0
    80
  _mm_empty();
sl@0
    81
#endif  
sl@0
    82
}
sl@0
    83
OIL_DEFINE_IMPL_FULL (splat_u32_ns_mmx_unroll4, splat_u32_ns, OIL_IMPL_FLAG_MMX);
sl@0
    84
sl@0
    85
static void
sl@0
    86
splat_u8_ns_mmx (uint8_t *dest, const uint8_t *param, int n)
sl@0
    87
{
sl@0
    88
#ifdef HAVE_GCC_ASM      
sl@0
    89
  __m64 v;
sl@0
    90
sl@0
    91
  v = _mm_set1_pi8(*param);
sl@0
    92
sl@0
    93
  for (; n >= 8; n -= 8) {
sl@0
    94
    *(__m64 *)dest = v;
sl@0
    95
    dest += 8;
sl@0
    96
  }
sl@0
    97
  for (; n > 0; n--) {
sl@0
    98
    *dest++ = *param;
sl@0
    99
  }
sl@0
   100
  _mm_empty();
sl@0
   101
#endif
sl@0
   102
}
sl@0
   103
OIL_DEFINE_IMPL_FULL (splat_u8_ns_mmx, splat_u8_ns, OIL_IMPL_FLAG_MMX);
sl@0
   104
sl@0
   105
static void
sl@0
   106
splat_u8_ns_mmx_unroll4 (uint8_t *dest, const uint8_t *param, int n)
sl@0
   107
{
sl@0
   108
#ifdef HAVE_GCC_ASM          
sl@0
   109
  __m64 v;
sl@0
   110
sl@0
   111
  v = _mm_set1_pi8(*param);
sl@0
   112
sl@0
   113
  for (; n >= 32; n -= 32) {
sl@0
   114
    ((__m64 *)dest)[0] = v;
sl@0
   115
    ((__m64 *)dest)[1] = v;
sl@0
   116
    ((__m64 *)dest)[2] = v;
sl@0
   117
    ((__m64 *)dest)[3] = v;
sl@0
   118
    dest += 32;
sl@0
   119
  }
sl@0
   120
  for (; n >= 8; n -= 8) {
sl@0
   121
    *(__m64 *)dest = v;
sl@0
   122
    dest += 8;
sl@0
   123
  }
sl@0
   124
  for (; n > 0; n--) {
sl@0
   125
    *dest++ = *param;
sl@0
   126
  }
sl@0
   127
  _mm_empty();
sl@0
   128
#endif
sl@0
   129
}
sl@0
   130
OIL_DEFINE_IMPL_FULL (splat_u8_ns_mmx_unroll4, splat_u8_ns, OIL_IMPL_FLAG_MMX);
sl@0
   131
sl@0
   132
sl@0
   133
#ifdef	__SYMBIAN32__
sl@0
   134
 
sl@0
   135
OilFunctionImpl* __oil_function_impl_splat_u32_ns_mmx() {
sl@0
   136
		return &_oil_function_impl_splat_u32_ns_mmx;
sl@0
   137
}
sl@0
   138
#endif
sl@0
   139
sl@0
   140
#ifdef	__SYMBIAN32__
sl@0
   141
 
sl@0
   142
OilFunctionImpl* __oil_function_impl_splat_u32_ns_mmx_unroll4() {
sl@0
   143
		return &_oil_function_impl_splat_u32_ns_mmx_unroll4;
sl@0
   144
}
sl@0
   145
#endif
sl@0
   146
sl@0
   147
#ifdef	__SYMBIAN32__
sl@0
   148
 
sl@0
   149
OilFunctionImpl* __oil_function_impl_splat_u8_ns_mmx() {
sl@0
   150
		return &_oil_function_impl_splat_u8_ns_mmx;
sl@0
   151
}
sl@0
   152
#endif
sl@0
   153
sl@0
   154
#ifdef	__SYMBIAN32__
sl@0
   155
 
sl@0
   156
OilFunctionImpl* __oil_function_impl_splat_u8_ns_mmx_unroll4() {
sl@0
   157
		return &_oil_function_impl_splat_u8_ns_mmx_unroll4;
sl@0
   158
}
sl@0
   159
#endif
sl@0
   160