Raw File
Intel512double.h
    /*************************************************************************************

    Grid physics library, www.github.com/paboyle/Grid 

    Source file: ./lib/simd/Avx512Asm.h

    Copyright (C) 2015

Author: paboyle <paboyle@ph.ed.ac.uk>

    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License along
    with this program; if not, write to the Free Software Foundation, Inc.,
    51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

    See the full license in the file "LICENSE" in the top level distribution directory
    *************************************************************************************/
    /*  END LEGAL */
// No guard can be multiply included as undef clearage
#undef VZERO
#undef VMOV
#undef VLOAD
#undef VSTORE
#define VZERO(A)                  VZEROd(A)
#define VMOV(A,B)                 VMOVd(A,B)
#define VLOAD(OFF,PTR,DEST)       VLOADd(OFF,PTR,DEST)
#define VSTORE(OFF,PTR,SRC)       VSTOREd(OFF,PTR,SRC)

#undef VADD
#undef VSUB
#undef VMUL
#undef VMADD
#define VADD(A,B,C)               VADDd(A,B,C)
#define VSUB(A,B,C)               VSUBd(A,B,C)
#define VMUL(Uri,Uir,Chi)         VMULd(Uri,Uir,Chi)
#define VMADD(Uri,Uir,Chi)        VMADDd(Uri,Uir,Chi)


#undef VTIMESI
#undef VTIMESI0 
#undef VTIMESI1
#undef VTIMESI2 
#define VTIMESI(A,B,C)                 VTIMESId(A,B,C)
#define VTIMESI0(A,B,C)                VTIMESI0d(A,B,C)
#define VTIMESI1(A,B,C)                VTIMESI1d(A,B,C)
#define VTIMESI2(A,B,C)                VTIMESI2d(A,B,C)

#undef VTIMESMINUSI
#undef VTIMESMINUSI0
#undef VTIMESMINUSI1
#undef VTIMESMINUSI2
#define VTIMESMINUSI(A,B,C)            VTIMESMINUSId(A,B,C)
#define VTIMESMINUSI0(A,B,C)           VTIMESMINUSI0d(A,B,C)
#define VTIMESMINUSI1(A,B,C)           VTIMESMINUSI1d(A,B,C)
#define VTIMESMINUSI2(A,B,C)           VTIMESMINUSI2d(A,B,C)

#undef VACCTIMESI
#undef VACCTIMESI0
#undef VACCTIMESI1
#undef VACCTIMESI2
#define VACCTIMESI(A,B,C)         VACCTIMESId(A,B,C)
#define VACCTIMESI0(A,B,C)             VACCTIMESI0d(A,B,C)
#define VACCTIMESI1(A,B,C)             VACCTIMESI1d(A,B,C)
#define VACCTIMESI2(A,B,C)             VACCTIMESI2d(A,B,C)

#undef VACCTIMESMINUSI
#undef VACCTIMESMINUSI0
#undef VACCTIMESMINUSI1
#undef VACCTIMESMINUSI2
#define VACCTIMESMINUSI(A,B,C)    VACCTIMESMINUSId(A,B,C)
#define VACCTIMESMINUSI0(A,B,C)        VACCTIMESMINUSI0d(A,B,C)
#define VACCTIMESMINUSI1(A,B,C)        VACCTIMESMINUSI1d(A,B,C)
#define VACCTIMESMINUSI2(A,B,C)        VACCTIMESMINUSI2d(A,B,C)

#undef VACCTIMESI1MEM
#undef VACCTIMESI2MEM
#define VACCTIMESI1MEM(A,ACC,O,P)      VACCTIMESI1MEMd(A,ACC,O,P)
#define VACCTIMESI2MEM(A,ACC,O,P)      VACCTIMESI2MEMd(A,ACC,O,P)

#undef VACCTIMESMINUSI1MEM
#undef VACCTIMESMINUSI2MEM
#define VACCTIMESMINUSI1MEM(A,ACC,O,P) VACCTIMESMINUSI1MEMd(A,ACC,O,P)
#define VACCTIMESMINUSI2MEM(A,ACC,O,P) VACCTIMESMINUSI2MEMd(A,ACC,O,P)

#undef VPERM0
#undef VPERM1
#undef VPERM2
#undef VPERM3
#define VPERM0(A,B)               VPERM0d(A,B)
#define VPERM1(A,B)               VPERM1d(A,B)
#define VPERM2(A,B)               VPERM2d(A,B)
#define VPERM3(A,B)               VPERM3d(A,B)

#undef VSHUFMEM
#undef VADDMEM
#undef VSUBMEM
#define VSHUFMEM(OFF,A,DEST)      VSHUFMEMd(OFF,A,DEST)
#define VADDMEM(O,A,B,C)                                 VADDMEMd(O,A,B,C)
#define VSUBMEM(O,A,B,C)                                 VSUBMEMd(O,A,B,C)

#undef VMOVIDUP
#undef VMOVRDUP
#undef VMADDSUB
#undef VSHUF
#define VMOVIDUP(A,B,C)                                  VMOVIDUPd(A,B,C)
#define VMOVRDUP(A,B,C)                                  VMOVRDUPd(A,B,C)
#define VMADDSUB(A,B,accum)                              VMADDSUBd(A,B,accum) 
#define VSHUF(A,B)                                       VSHUFd(A,B)


#undef ZEND1
#undef ZEND2
#undef ZLOAD
#undef ZMUL
#undef ZMADD
#undef ZMULMEM2SP
#undef ZMADDMEM2SP

#define ZEND1(A,B,C)                                     ZEND1d(A,B,C)
#define ZEND2(A,B,C)                                     ZEND2d(A,B,C)
#define ZLOAD(A,B,C,D)                                   ZLOADd(A,B,C,D)
#define ZMUL(A,B,C,D,E)                                  ZMULd(A,B,C,D,E)
#define ZMADD(A,B,C,D,E)                                 ZMADDd(A,B,C,D,E)
#define ZMULMEM2SP(O,P,tmp,B,C,Briir,Biirr,Criir,Ciirr)  ZMULMEM2SPd(O,P,tmp,B,C,Briir,Biirr,Criir,Ciirr) 
#define ZMADDMEM2SP(O,P,tmp,B,C,Briir,Biirr,Criir,Ciirr) ZMADDMEM2SPd(O,P,tmp,B,C,Briir,Biirr,Criir,Ciirr) 


#undef VRDUP
#undef VIDUP
#undef VMADDSUBMEM
#undef VMADDMEM
#undef VMULMEM
#define VRDUP(SRC,DEST) VRDUPd(SRC,DEST) 
#define VIDUP(SRC,DEST) VIDUPd(SRC,DEST) 
#define VMADDSUBMEM(O,P,B,accum) VMADDSUBMEMd(O,P,B,accum)
#define VMADDMEM(O,P,B,accum)    VMADDMEMd(O,P,B,accum)
#define VMULMEM(O,P,B,accum)     VMULMEMd(O,P,B,accum)
#undef VMADDRDUP   
#undef VMADDSUBRDUP   
#undef VMADDSUBIDUP   
#undef VMULRDUP   
#undef VMULIDUP   
#define VMADDRDUP(O,P,B,accum)    VMADDRDUPd(O,P,B,accum) 
#define VMADDSUBRDUP(O,P,B,accum) VMADDSUBRDUPd(O,P,B,accum) 
#define VMADDSUBIDUP(O,P,B,accum) VMADDSUBIDUPd(O,P,B,accum) 
#define VMULRDUP(O,P,B,accum)     VMULRDUPd(O,P,B,accum)      
#define VMULIDUP(O,P,B,accum)     VMULIDUPd(O,P,B,accum) 
back to top