atl_dmm_sse2_k.c

来自「基于Blas CLapck的.用过的人知道是干啥的」· C语言 代码 · 共 2,149 行 · 第 1/5 页

C
2,149
字号
         vec_add_rr(reg6,reg2);         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0+6+3*KB,reg4);         vec_add_rr(reg4,reg3);         vec_sum(reg0);         vec_sum(reg1);         vec_sum(reg2);         vec_sum(reg3);         vec_mov_rm_1(reg0,pC0);         vec_mov_rm_1(reg1,pC1);         vec_mov_rm_1(reg2,pC2);         vec_mov_rm_1(reg3,pC3);         pA0 += incAm;         pB0 += incBm;         pC0 += incCm;         pC1 += incCm;         pC2 += incCm;         pC3 += incCm;      }      while(pA0 != stM);      pA0 += incAn;      pB0 += incBn;      pC0 += incCn;      pC1 += incCn;      pC2 += incCn;      pC3 += incCn;   }   while(pB0 != stN);   }/*****************************************************************************//*                             ATL_mm_p4_d_10K.c                             *//*****************************************************************************/#elif (KB == 10)#define SSE2#include "SSE3Dnow.h"#include "atlas_misc.h"void ATL_USERMM(const int M, const int N, const int K, const double alpha, const double *A, const int lda, const double *B, const int ldb, const double beta, double *C, const int ldc){   /*--- program info ---*/   /*  $Revision: 1.3 $  */   /*  loadfirst = 'a'  */   /*  nu = 4  */   /*  k_loop = 'for'  */   /*  problem = 'gemm'  */   /*  nregs = 8  */   /*  split = 1  */   /*  n_cleanup = {}  */   /*  mu = 1  */   /*  ku = 8  */   /*  rev = '$Revision: 1.3 $'  */   /*  applyfilter = 0  */   /*  align_jumps = 0  */   /*  prec = 'double'  */   /*  m_cleanup = {}  */   /*  used_outside_len = 2  */   /*  k_cleanup = {}  */   /*  outputdir = 'Linux_P4/'  */   /*  arch = 'sse2'  */   /*  pipelength = 3  */   /*  atlasname = 'Linux_P4'  */   /*  method = 'acc'  */   /*  used_lastuse = None  */   /*  used_directload_a = 0  */   /*  outside_len = 2  */   /*  veclen = 2  */   /*  sched = ['spread', 'fuse']  */   /*  used_directload_b = 1  */   /*  lastuse = 0  */   /*--- achitecture specific declarations ---*/   /*--- program specific declarations ---*/   int i, j, k;   vector betavec;   vector zerovec = {0.0,0.0};   const double *pA0 = A;   const double *pB0 = B;   double *pC0 = C;   double *pC1 = C+(ldc SHIFT);   double *pC2 = C+(2*ldc SHIFT);   double *pC3 = C+(3*ldc SHIFT);   const double *stM = A + MB*KB;   const double *stN = B + NB*KB;   const int incAm = 1*KB-KB+2;   const int incBm = -KB+2;   const int incCm = (1 SHIFT);   const int incAn = -MB*KB;   const int incBn = 4*KB;   const int incCn = ((ldc*4-MB) SHIFT);   /*--- initial arhitecture specific statements ---*/   /*--- main program statements ---*/   vec_mov_mr_1(&beta,reg0);   vec_mov_rm(reg0,betavec);   do /* N-loop */   {      do /* M-loop */      {#ifdef BETA0         vec_mov_mr(zerovec,reg7);         vec_mov_rr(reg7,reg0);         vec_mov_rr(reg7,reg1);         vec_mov_rr(reg7,reg2);         vec_mov_rr(reg7,reg3);#elif defined(BETA1)         vec_mov_mr_1(pC0,reg0);         vec_mov_mr_1(pC1,reg1);         vec_mov_mr_1(pC2,reg2);         vec_mov_mr_1(pC3,reg3);#else         vec_mov_mr(betavec,reg7);         vec_mov_mr_1(pC0,reg0);         vec_mul_rr(reg7,reg0);         vec_mov_mr_1(pC1,reg1);         vec_mul_rr(reg7,reg1);         vec_mov_mr_1(pC2,reg2);         vec_mul_rr(reg7,reg2);         vec_mov_mr_1(pC3,reg3);         vec_mul_rr(reg7,reg3);#endif         vec_mov_mr_a(pA0,reg7);         for (k=0; k<KB-2; k+=8)         {            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+2,reg7);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+2,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+2+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+2+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+2+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+4,reg7);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+4,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+4+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+4+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+4+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+6,reg7);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+6,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+6+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+6+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+6+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+8,reg7);            pA0 += 8;            pB0 += 8;         }         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0,reg4);         vec_add_rr(reg4,reg0);         vec_mov_rr(reg7,reg5);         vec_mul_mr_a(pB0+KB,reg5);         vec_add_rr(reg5,reg1);         vec_mov_rr(reg7,reg6);         vec_mul_mr_a(pB0+2*KB,reg6);         vec_add_rr(reg6,reg2);         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0+3*KB,reg4);         vec_add_rr(reg4,reg3);         vec_sum(reg0);         vec_sum(reg1);         vec_sum(reg2);         vec_sum(reg3);         vec_mov_rm_1(reg0,pC0);         vec_mov_rm_1(reg1,pC1);         vec_mov_rm_1(reg2,pC2);         vec_mov_rm_1(reg3,pC3);         pA0 += incAm;         pB0 += incBm;         pC0 += incCm;         pC1 += incCm;         pC2 += incCm;         pC3 += incCm;      }      while(pA0 != stM);      pA0 += incAn;      pB0 += incBn;      pC0 += incCn;      pC1 += incCn;      pC2 += incCn;      pC3 += incCn;   }   while(pB0 != stN);   }/*****************************************************************************//*                             ATL_mm_p4_d_12K.c                             *//*****************************************************************************/#elif (KB == 12)#define SSE2#include "SSE3Dnow.h"#include "atlas_misc.h"void ATL_USERMM(const int M, const int N, const int K, const double alpha, const double *A, const int lda, const double *B, const int ldb, const double beta, double *C, const int ldc){   /*--- program info ---*/   /*  $Revision: 1.3 $  */   /*  loadfirst = 'a'  */   /*  nu = 4  */   /*  k_loop = 'for'  */   /*  problem = 'gemm'  */   /*  nregs = 8  */   /*  split = 1  */   /*  n_cleanup = {}  */   /*  mu = 1  */   /*  ku = 8  */   /*  rev = '$Revision: 1.3 $'  */   /*  applyfilter = 0  */   /*  align_jumps = 0  */   /*  prec = 'double'  */   /*  m_cleanup = {}  */   /*  used_outside_len = 4  */   /*  k_cleanup = {}  */   /*  outputdir = 'Linux_P4/'  */   /*  arch = 'sse2'  */   /*  pipelength = 3  */   /*  atlasname = 'Linux_P4'  */   /*  method = 'acc'  */   /*  used_lastuse = None  */   /*  used_directload_a = 0  */   /*  outside_len = 4  */   /*  veclen = 2  */   /*  sched = ['spread', 'fuse']  */   /*  used_directload_b = 1  */   /*  lastuse = 0  */   /*--- achitecture specific declarations ---*/   /*--- program specific declarations ---*/   int i, j, k;   vector betavec;   vector zerovec = {0.0,0.0};   const double *pA0 = A;   const double *pB0 = B;   double *pC0 = C;   double *pC1 = C+(ldc SHIFT);   double *pC2 = C+(2*ldc SHIFT);   double *pC3 = C+(3*ldc SHIFT);   const double *stM = A + MB*KB;   const double *stN = B + NB*KB;   const int incAm = 1*KB-KB+4;   const int incBm = -KB+4;   const int incCm = (1 SHIFT);   const int incAn = -MB*KB;   const int incBn = 4*KB;   const int incCn = ((ldc*4-MB) SHIFT);   /*--- initial arhitecture specific statements ---*/   /*--- main program statements ---*/   vec_mov_mr_1(&beta,reg0);   vec_mov_rm(reg0,betavec);   do /* N-loop */   {      do /* M-loop */      {#ifdef BETA0         vec_mov_mr(zerovec,reg7);         vec_mov_rr(reg7,reg0);         vec_mov_rr(reg7,reg1);         vec_mov_rr(reg7,reg2);         vec_mov_rr(reg7,reg3);#elif defined(BETA1)         vec_mov_mr_1(pC0,reg0);         vec_mov_mr_1(pC1,reg1);         vec_mov_mr_1(pC2,reg2);         vec_mov_mr_1(pC3,reg3);#else         vec_mov_mr(betavec,reg7);         vec_mov_mr_1(pC0,reg0);         vec_mul_rr(reg7,reg0);         vec_mov_mr_1(pC1,reg1);         vec_mul_rr(reg7,reg1);         vec_mov_mr_1(pC2,reg2);         vec_mul_rr(reg7,reg2);         vec_mov_mr_1(pC3,reg3);         vec_mul_rr(reg7,reg3);#endif         vec_mov_mr_a(pA0,reg7);         for (k=0; k<KB-4; k+=8)         {            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+2,reg7);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+2,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+2+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+2+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+2+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+4,reg7);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+4,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+4+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+4+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+4+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+6,reg7);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+6,reg4);            vec_add_rr(reg4,reg0);            vec_mov_rr(reg7,reg5);            vec_mul_mr_a(pB0+6+KB,reg5);            vec_add_rr(reg5,reg1);            vec_mov_rr(reg7,reg6);            vec_mul_mr_a(pB0+6+2*KB,reg6);            vec_add_rr(reg6,reg2);            vec_mov_rr(reg7,reg4);            vec_mul_mr_a(pB0+6+3*KB,reg4);            vec_add_rr(reg4,reg3);            vec_mov_mr_a(pA0+8,reg7);            pA0 += 8;            pB0 += 8;         }         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0,reg4);         vec_add_rr(reg4,reg0);         vec_mov_rr(reg7,reg5);         vec_mul_mr_a(pB0+KB,reg5);         vec_add_rr(reg5,reg1);         vec_mov_rr(reg7,reg6);         vec_mul_mr_a(pB0+2*KB,reg6);         vec_add_rr(reg6,reg2);         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0+3*KB,reg4);         vec_add_rr(reg4,reg3);         vec_mov_mr_a(pA0+2,reg7);         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0+2,reg4);         vec_add_rr(reg4,reg0);         vec_mov_rr(reg7,reg5);         vec_mul_mr_a(pB0+2+KB,reg5);         vec_add_rr(reg5,reg1);         vec_mov_rr(reg7,reg6);         vec_mul_mr_a(pB0+2+2*KB,reg6);         vec_add_rr(reg6,reg2);         vec_mov_rr(reg7,reg4);         vec_mul_mr_a(pB0+2+3*KB,reg4);         vec_add_rr(reg4,reg3);         vec_sum(reg0);         vec_sum(reg1);         vec_sum(reg2);         vec_sum(reg3);         vec_mov_rm_1(reg0,pC0);         vec_mov_rm_1(reg1,pC1);         vec_mov_rm_1(reg2,pC2);         vec_mov_rm_1(reg3,pC3);         pA0 += incAm;         pB0 += incBm;         pC0 += incCm;         pC1 += incCm;         pC2 += incCm;         pC3 += incCm;      }      while(pA0 != stM);      pA0 += incAn;      pB0 += incBn;      pC0 += incCn;      pC1 += incCn;      pC2 += incCn;      pC3 += incCn;   }   while(pB0 != stN);

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?