shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; jfdctflt.asm - floating-point FDCT (3DNow!)
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB</ossman@cendio.se>
shun-iwasawa 82a8f5
; Copyright (C) 2016, D. R. Commander.
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; Based on the x86 SIMD extension for IJG JPEG library
shun-iwasawa 82a8f5
; Copyright (C) 1999-2006, MIYASAKA Masaru.
shun-iwasawa 82a8f5
; For conditions of distribution and use, see copyright notice in jsimdext.inc
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; This file should be assembled with NASM (Netwide Assembler),
shun-iwasawa 82a8f5
; can *not* be assembled with Microsoft's MASM or any compatible
shun-iwasawa 82a8f5
; assembler (including Borland's Turbo Assembler).
shun-iwasawa 82a8f5
; NASM is available from http://nasm.sourceforge.net/ or
shun-iwasawa 82a8f5
; http://sourceforge.net/project/showfiles.php?group_id=6208
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; This file contains a floating-point implementation of the forward DCT
shun-iwasawa 82a8f5
; (Discrete Cosine Transform). The following code is based directly on
shun-iwasawa 82a8f5
; the IJG's original jfdctflt.c; see the jfdctflt.c for more details.
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
%include "jsimdext.inc"
shun-iwasawa 82a8f5
%include "jdct.inc"
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
; --------------------------------------------------------------------------
shun-iwasawa 82a8f5
    SECTION     SEG_CONST
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    alignz      32
shun-iwasawa 82a8f5
    GLOBAL_DATA(jconst_fdct_float_3dnow)
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
EXTN(jconst_fdct_float_3dnow):
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
PD_0_382 times 2 dd 0.382683432365089771728460
shun-iwasawa 82a8f5
PD_0_707 times 2 dd 0.707106781186547524400844
shun-iwasawa 82a8f5
PD_0_541 times 2 dd 0.541196100146196984399723
shun-iwasawa 82a8f5
PD_1_306 times 2 dd 1.306562964876376527856643
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    alignz      32
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
; --------------------------------------------------------------------------
shun-iwasawa 82a8f5
    SECTION     SEG_TEXT
shun-iwasawa 82a8f5
    BITS        32
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; Perform the forward DCT on one block of samples.
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
; GLOBAL(void)
shun-iwasawa 82a8f5
; jsimd_fdct_float_3dnow(FAST_FLOAT *data)
shun-iwasawa 82a8f5
;
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
%define data(b)       (b) + 8           ; FAST_FLOAT *data
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
%define original_ebp  ebp + 0
shun-iwasawa 82a8f5
%define wk(i)         ebp - (WK_NUM - (i)) * SIZEOF_MMWORD  ; mmword wk[WK_NUM]
shun-iwasawa 82a8f5
%define WK_NUM        2
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    align       32
shun-iwasawa 82a8f5
    GLOBAL_FUNCTION(jsimd_fdct_float_3dnow)
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
EXTN(jsimd_fdct_float_3dnow):
shun-iwasawa 82a8f5
    push        ebp
shun-iwasawa 82a8f5
    mov         eax, esp                    ; eax = original ebp
shun-iwasawa 82a8f5
    sub         esp, byte 4
shun-iwasawa 82a8f5
    and         esp, byte (-SIZEOF_MMWORD)  ; align to 64 bits
shun-iwasawa 82a8f5
    mov         [esp], eax
shun-iwasawa 82a8f5
    mov         ebp, esp                    ; ebp = aligned ebp
shun-iwasawa 82a8f5
    lea         esp, [wk(0)]
shun-iwasawa 82a8f5
    pushpic     ebx
shun-iwasawa 82a8f5
;   push        ecx                     ; need not be preserved
shun-iwasawa 82a8f5
;   push        edx                     ; need not be preserved
shun-iwasawa 82a8f5
;   push        esi                     ; unused
shun-iwasawa 82a8f5
;   push        edi                     ; unused
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    get_GOT     ebx                     ; get GOT address
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; ---- Pass 1: process rows.
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    mov         edx, POINTER [data(eax)]  ; (FAST_FLOAT *)
shun-iwasawa 82a8f5
    mov         ecx, DCTSIZE/2
shun-iwasawa 82a8f5
    alignx      16, 7
shun-iwasawa 82a8f5
.rowloop:
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm0, MMWORD [MMBLOCK(0,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm1, MMWORD [MMBLOCK(1,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm2, MMWORD [MMBLOCK(0,3,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm3, MMWORD [MMBLOCK(1,3,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; mm0=(00 01), mm1=(10 11), mm2=(06 07), mm3=(16 17)
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm0                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm0, mm1                ; mm0=(00 10)=data0
shun-iwasawa 82a8f5
    punpckhdq   mm4, mm1                ; mm4=(01 11)=data1
shun-iwasawa 82a8f5
    movq        mm5, mm2                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm2, mm3                ; mm2=(06 16)=data6
shun-iwasawa 82a8f5
    punpckhdq   mm5, mm3                ; mm5=(07 17)=data7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm6, mm4
shun-iwasawa 82a8f5
    movq        mm7, mm0
shun-iwasawa 82a8f5
    pfsub       mm4, mm2                ; mm4=data1-data6=tmp6
shun-iwasawa 82a8f5
    pfsub       mm0, mm5                ; mm0=data0-data7=tmp7
shun-iwasawa 82a8f5
    pfadd       mm6, mm2                ; mm6=data1+data6=tmp1
shun-iwasawa 82a8f5
    pfadd       mm7, mm5                ; mm7=data0+data7=tmp0
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm1, MMWORD [MMBLOCK(0,1,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm3, MMWORD [MMBLOCK(1,1,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm2, MMWORD [MMBLOCK(0,2,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm5, MMWORD [MMBLOCK(1,2,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; mm1=(02 03), mm3=(12 13), mm2=(04 05), mm5=(14 15)
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        MMWORD [wk(0)], mm4     ; wk(0)=tmp6
shun-iwasawa 82a8f5
    movq        MMWORD [wk(1)], mm0     ; wk(1)=tmp7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm1                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm1, mm3                ; mm1=(02 12)=data2
shun-iwasawa 82a8f5
    punpckhdq   mm4, mm3                ; mm4=(03 13)=data3
shun-iwasawa 82a8f5
    movq        mm0, mm2                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm2, mm5                ; mm2=(04 14)=data4
shun-iwasawa 82a8f5
    punpckhdq   mm0, mm5                ; mm0=(05 15)=data5
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm3, mm4
shun-iwasawa 82a8f5
    movq        mm5, mm1
shun-iwasawa 82a8f5
    pfadd       mm4, mm2                ; mm4=data3+data4=tmp3
shun-iwasawa 82a8f5
    pfadd       mm1, mm0                ; mm1=data2+data5=tmp2
shun-iwasawa 82a8f5
    pfsub       mm3, mm2                ; mm3=data3-data4=tmp4
shun-iwasawa 82a8f5
    pfsub       mm5, mm0                ; mm5=data2-data5=tmp5
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; -- Even part
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm2, mm7
shun-iwasawa 82a8f5
    movq        mm0, mm6
shun-iwasawa 82a8f5
    pfsub       mm7, mm4                ; mm7=tmp13
shun-iwasawa 82a8f5
    pfsub       mm6, mm1                ; mm6=tmp12
shun-iwasawa 82a8f5
    pfadd       mm2, mm4                ; mm2=tmp10
shun-iwasawa 82a8f5
    pfadd       mm0, mm1                ; mm0=tmp11
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    pfadd       mm6, mm7
shun-iwasawa 82a8f5
    pfmul       mm6, [GOTOFF(ebx,PD_0_707)]  ; mm6=z1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm2
shun-iwasawa 82a8f5
    movq        mm1, mm7
shun-iwasawa 82a8f5
    pfsub       mm2, mm0                ; mm2=data4
shun-iwasawa 82a8f5
    pfsub       mm7, mm6                ; mm7=data6
shun-iwasawa 82a8f5
    pfadd       mm4, mm0                ; mm4=data0
shun-iwasawa 82a8f5
    pfadd       mm1, mm6                ; mm1=data2
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(0,2,edx,SIZEOF_FAST_FLOAT)], mm2
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(0,3,edx,SIZEOF_FAST_FLOAT)], mm7
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(0,0,edx,SIZEOF_FAST_FLOAT)], mm4
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(0,1,edx,SIZEOF_FAST_FLOAT)], mm1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; -- Odd part
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm0, MMWORD [wk(0)]     ; mm0=tmp6
shun-iwasawa 82a8f5
    movq        mm6, MMWORD [wk(1)]     ; mm6=tmp7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    pfadd       mm3, mm5                ; mm3=tmp10
shun-iwasawa 82a8f5
    pfadd       mm5, mm0                ; mm5=tmp11
shun-iwasawa 82a8f5
    pfadd       mm0, mm6                ; mm0=tmp12, mm6=tmp7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    pfmul       mm5, [GOTOFF(ebx,PD_0_707)]  ; mm5=z3
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm2, mm3                     ; mm2=tmp10
shun-iwasawa 82a8f5
    pfsub       mm3, mm0
shun-iwasawa 82a8f5
    pfmul       mm3, [GOTOFF(ebx,PD_0_382)]  ; mm3=z5
shun-iwasawa 82a8f5
    pfmul       mm2, [GOTOFF(ebx,PD_0_541)]  ; mm2=MULTIPLY(tmp10,FIX_0_54119610)
shun-iwasawa 82a8f5
    pfmul       mm0, [GOTOFF(ebx,PD_1_306)]  ; mm0=MULTIPLY(tmp12,FIX_1_30656296)
shun-iwasawa 82a8f5
    pfadd       mm2, mm3                     ; mm2=z2
shun-iwasawa 82a8f5
    pfadd       mm0, mm3                     ; mm0=z4
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm7, mm6
shun-iwasawa 82a8f5
    pfsub       mm6, mm5                ; mm6=z13
shun-iwasawa 82a8f5
    pfadd       mm7, mm5                ; mm7=z11
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm6
shun-iwasawa 82a8f5
    movq        mm1, mm7
shun-iwasawa 82a8f5
    pfsub       mm6, mm2                ; mm6=data3
shun-iwasawa 82a8f5
    pfsub       mm7, mm0                ; mm7=data7
shun-iwasawa 82a8f5
    pfadd       mm4, mm2                ; mm4=data5
shun-iwasawa 82a8f5
    pfadd       mm1, mm0                ; mm1=data1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(1,1,edx,SIZEOF_FAST_FLOAT)], mm6
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(1,3,edx,SIZEOF_FAST_FLOAT)], mm7
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(1,2,edx,SIZEOF_FAST_FLOAT)], mm4
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(1,0,edx,SIZEOF_FAST_FLOAT)], mm1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    add         edx, byte 2*DCTSIZE*SIZEOF_FAST_FLOAT
shun-iwasawa 82a8f5
    dec         ecx
shun-iwasawa 82a8f5
    jnz         near .rowloop
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; ---- Pass 2: process columns.
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    mov         edx, POINTER [data(eax)]  ; (FAST_FLOAT *)
shun-iwasawa 82a8f5
    mov         ecx, DCTSIZE/2
shun-iwasawa 82a8f5
    alignx      16, 7
shun-iwasawa 82a8f5
.columnloop:
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm0, MMWORD [MMBLOCK(0,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm1, MMWORD [MMBLOCK(1,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm2, MMWORD [MMBLOCK(6,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm3, MMWORD [MMBLOCK(7,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; mm0=(00 10), mm1=(01 11), mm2=(60 70), mm3=(61 71)
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm0                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm0, mm1                ; mm0=(00 01)=data0
shun-iwasawa 82a8f5
    punpckhdq   mm4, mm1                ; mm4=(10 11)=data1
shun-iwasawa 82a8f5
    movq        mm5, mm2                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm2, mm3                ; mm2=(60 61)=data6
shun-iwasawa 82a8f5
    punpckhdq   mm5, mm3                ; mm5=(70 71)=data7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm6, mm4
shun-iwasawa 82a8f5
    movq        mm7, mm0
shun-iwasawa 82a8f5
    pfsub       mm4, mm2                ; mm4=data1-data6=tmp6
shun-iwasawa 82a8f5
    pfsub       mm0, mm5                ; mm0=data0-data7=tmp7
shun-iwasawa 82a8f5
    pfadd       mm6, mm2                ; mm6=data1+data6=tmp1
shun-iwasawa 82a8f5
    pfadd       mm7, mm5                ; mm7=data0+data7=tmp0
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm1, MMWORD [MMBLOCK(2,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm3, MMWORD [MMBLOCK(3,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm2, MMWORD [MMBLOCK(4,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
    movq        mm5, MMWORD [MMBLOCK(5,0,edx,SIZEOF_FAST_FLOAT)]
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; mm1=(20 30), mm3=(21 31), mm2=(40 50), mm5=(41 51)
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        MMWORD [wk(0)], mm4     ; wk(0)=tmp6
shun-iwasawa 82a8f5
    movq        MMWORD [wk(1)], mm0     ; wk(1)=tmp7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm1                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm1, mm3                ; mm1=(20 21)=data2
shun-iwasawa 82a8f5
    punpckhdq   mm4, mm3                ; mm4=(30 31)=data3
shun-iwasawa 82a8f5
    movq        mm0, mm2                ; transpose coefficients
shun-iwasawa 82a8f5
    punpckldq   mm2, mm5                ; mm2=(40 41)=data4
shun-iwasawa 82a8f5
    punpckhdq   mm0, mm5                ; mm0=(50 51)=data5
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm3, mm4
shun-iwasawa 82a8f5
    movq        mm5, mm1
shun-iwasawa 82a8f5
    pfadd       mm4, mm2                ; mm4=data3+data4=tmp3
shun-iwasawa 82a8f5
    pfadd       mm1, mm0                ; mm1=data2+data5=tmp2
shun-iwasawa 82a8f5
    pfsub       mm3, mm2                ; mm3=data3-data4=tmp4
shun-iwasawa 82a8f5
    pfsub       mm5, mm0                ; mm5=data2-data5=tmp5
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; -- Even part
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm2, mm7
shun-iwasawa 82a8f5
    movq        mm0, mm6
shun-iwasawa 82a8f5
    pfsub       mm7, mm4                ; mm7=tmp13
shun-iwasawa 82a8f5
    pfsub       mm6, mm1                ; mm6=tmp12
shun-iwasawa 82a8f5
    pfadd       mm2, mm4                ; mm2=tmp10
shun-iwasawa 82a8f5
    pfadd       mm0, mm1                ; mm0=tmp11
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    pfadd       mm6, mm7
shun-iwasawa 82a8f5
    pfmul       mm6, [GOTOFF(ebx,PD_0_707)]  ; mm6=z1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm2
shun-iwasawa 82a8f5
    movq        mm1, mm7
shun-iwasawa 82a8f5
    pfsub       mm2, mm0                ; mm2=data4
shun-iwasawa 82a8f5
    pfsub       mm7, mm6                ; mm7=data6
shun-iwasawa 82a8f5
    pfadd       mm4, mm0                ; mm4=data0
shun-iwasawa 82a8f5
    pfadd       mm1, mm6                ; mm1=data2
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(4,0,edx,SIZEOF_FAST_FLOAT)], mm2
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(6,0,edx,SIZEOF_FAST_FLOAT)], mm7
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(0,0,edx,SIZEOF_FAST_FLOAT)], mm4
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(2,0,edx,SIZEOF_FAST_FLOAT)], mm1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    ; -- Odd part
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm0, MMWORD [wk(0)]     ; mm0=tmp6
shun-iwasawa 82a8f5
    movq        mm6, MMWORD [wk(1)]     ; mm6=tmp7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    pfadd       mm3, mm5                ; mm3=tmp10
shun-iwasawa 82a8f5
    pfadd       mm5, mm0                ; mm5=tmp11
shun-iwasawa 82a8f5
    pfadd       mm0, mm6                ; mm0=tmp12, mm6=tmp7
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    pfmul       mm5, [GOTOFF(ebx,PD_0_707)]  ; mm5=z3
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm2, mm3                     ; mm2=tmp10
shun-iwasawa 82a8f5
    pfsub       mm3, mm0
shun-iwasawa 82a8f5
    pfmul       mm3, [GOTOFF(ebx,PD_0_382)]  ; mm3=z5
shun-iwasawa 82a8f5
    pfmul       mm2, [GOTOFF(ebx,PD_0_541)]  ; mm2=MULTIPLY(tmp10,FIX_0_54119610)
shun-iwasawa 82a8f5
    pfmul       mm0, [GOTOFF(ebx,PD_1_306)]  ; mm0=MULTIPLY(tmp12,FIX_1_30656296)
shun-iwasawa 82a8f5
    pfadd       mm2, mm3                     ; mm2=z2
shun-iwasawa 82a8f5
    pfadd       mm0, mm3                     ; mm0=z4
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm7, mm6
shun-iwasawa 82a8f5
    pfsub       mm6, mm5                ; mm6=z13
shun-iwasawa 82a8f5
    pfadd       mm7, mm5                ; mm7=z11
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        mm4, mm6
shun-iwasawa 82a8f5
    movq        mm1, mm7
shun-iwasawa 82a8f5
    pfsub       mm6, mm2                ; mm6=data3
shun-iwasawa 82a8f5
    pfsub       mm7, mm0                ; mm7=data7
shun-iwasawa 82a8f5
    pfadd       mm4, mm2                ; mm4=data5
shun-iwasawa 82a8f5
    pfadd       mm1, mm0                ; mm1=data1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(3,0,edx,SIZEOF_FAST_FLOAT)], mm6
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(7,0,edx,SIZEOF_FAST_FLOAT)], mm7
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(5,0,edx,SIZEOF_FAST_FLOAT)], mm4
shun-iwasawa 82a8f5
    movq        MMWORD [MMBLOCK(1,0,edx,SIZEOF_FAST_FLOAT)], mm1
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    add         edx, byte 2*SIZEOF_FAST_FLOAT
shun-iwasawa 82a8f5
    dec         ecx
shun-iwasawa 82a8f5
    jnz         near .columnloop
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
    femms                               ; empty MMX/3DNow! state
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
;   pop         edi                     ; unused
shun-iwasawa 82a8f5
;   pop         esi                     ; unused
shun-iwasawa 82a8f5
;   pop         edx                     ; need not be preserved
shun-iwasawa 82a8f5
;   pop         ecx                     ; need not be preserved
shun-iwasawa 82a8f5
    poppic      ebx
shun-iwasawa 82a8f5
    mov         esp, ebp                ; esp <- aligned ebp
shun-iwasawa 82a8f5
    pop         esp                     ; esp <- original ebp
shun-iwasawa 82a8f5
    pop         ebp
shun-iwasawa 82a8f5
    ret
shun-iwasawa 82a8f5
shun-iwasawa 82a8f5
; For some reason, the OS X linker does not honor the request to align the
shun-iwasawa 82a8f5
; segment unless we do this.
shun-iwasawa 82a8f5
    align       32