os/ossrv/genericopenlibs/liboil/src/fb/fbmmx.h
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 © 2004 Red Hat, Inc.
sl@0
     3
 * Copyright © 2005 Trolltech AS
sl@0
     4
 *
sl@0
     5
 * Permission to use, copy, modify, distribute, and sell this software and its
sl@0
     6
 * documentation for any purpose is hereby granted without fee, provided that
sl@0
     7
 * the above copyright notice appear in all copies and that both that
sl@0
     8
 * copyright notice and this permission notice appear in supporting
sl@0
     9
 * documentation, and that the name of Red Hat not be used in advertising or
sl@0
    10
 * publicity pertaining to distribution of the software without specific,
sl@0
    11
 * written prior permission.  Red Hat makes no representations about the
sl@0
    12
 * suitability of this software for any purpose.  It is provided "as is"
sl@0
    13
 * without express or implied warranty.
sl@0
    14
 *
sl@0
    15
 * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
sl@0
    16
 * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
sl@0
    17
 * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
sl@0
    18
 * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
sl@0
    19
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
sl@0
    20
 * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
sl@0
    21
 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
sl@0
    22
 * SOFTWARE.
sl@0
    23
 *
sl@0
    24
 * Author:  Søren Sandmann (sandmann@redhat.com)
sl@0
    25
 *          Lars Knoll (lars@trolltech.com)
sl@0
    26
 * 
sl@0
    27
 * Based on work by Owen Taylor
sl@0
    28
 */
sl@0
    29
sl@0
    30
sl@0
    31
#define MmxNegate(x) _mm_xor_si64((x), mmx_4x00ff)
sl@0
    32
#define MmxAlpha(x) _mm_shuffle_pi16 ((x), _MM_SHUFFLE(3, 3, 3, 3));
sl@0
    33
#define MmxTo(x) _mm_unpacklo_pi8 (_mm_cvtsi32_si64((x)), mmx_0)
sl@0
    34
#define MmxFrom(x) (uint32_t)_mm_cvtsi64_si32(_mm_packs_pu16((x), mmx_0))
sl@0
    35
#define MmxAdd(x, y) _mm_adds_pu16 ((x), (y))
sl@0
    36
sl@0
    37
#define MmxMulAdd(x, a, y) do {                     \
sl@0
    38
        x = _mm_mullo_pi16 (x, a);                  \
sl@0
    39
        x = _mm_adds_pu16 (x, _mm_srli_pi16 (x, 8)); \
sl@0
    40
        x = _mm_adds_pu16 (x, mmx_4x0080);           \
sl@0
    41
        x = _mm_srli_pi16 (x, 8);                   \
sl@0
    42
        x = _mm_adds_pu16(x, y);                    \
sl@0
    43
    } while (0)
sl@0
    44
sl@0
    45
#define MmxMul(x, a) do {                           \
sl@0
    46
        x = _mm_mullo_pi16 (x, a);                  \
sl@0
    47
        x = _mm_adds_pu16 (x, _mm_srli_pi16 (x, 8)); \
sl@0
    48
        x = _mm_adds_pu16 (x, mmx_4x0080);           \
sl@0
    49
        x = _mm_srli_pi16 (x, 8);                   \
sl@0
    50
    } while (0)
sl@0
    51
sl@0
    52
#define MmxAddMul(x, a, y, b) do {                  \
sl@0
    53
        x = _mm_mullo_pi16 (x, a);                  \
sl@0
    54
        y = _mm_mullo_pi16 (y, b);                  \
sl@0
    55
        x = _mm_srli_pi16(x, 1);                    \
sl@0
    56
        y = _mm_srli_pi16(y, 1);                    \
sl@0
    57
        x = _mm_adds_pu16 (x, y);                    \
sl@0
    58
        x = _mm_adds_pu16 (x, _mm_srli_pi16 (x, 8)); \
sl@0
    59
        x = _mm_adds_pu16 (x, mmx_4x0080);           \
sl@0
    60
        x = _mm_srli_pi16 (x, 7);                   \
sl@0
    61
    } while (0)
sl@0
    62