10 #include "cblas_f77.h" 11 void cblas_dgemv(
const CBLAS_LAYOUT layout,
12 const CBLAS_TRANSPOSE TransA,
const CBLAS_INT M,
const CBLAS_INT N,
13 const double alpha,
const double *A,
const CBLAS_INT lda,
14 const double *X,
const CBLAS_INT incX,
const double beta,
15 double *Y,
const CBLAS_INT incY)
24 F77_INT F77_M=M, F77_N=N, F77_lda=lda, F77_incX=incX, F77_incY=incY;
32 extern int CBLAS_CallFromC;
33 extern int RowMajorStrg;
37 if (layout == CblasColMajor)
39 if (TransA == CblasNoTrans) TA =
'N';
40 else if (TransA == CblasTrans) TA =
'T';
41 else if (TransA == CblasConjTrans) TA =
'C';
44 cblas_xerbla(2,
"cblas_dgemv",
"Illegal TransA setting, %d\n", TransA);
50 F77_TA = C2F_CHAR(&TA);
52 F77_dgemv(F77_TA, &F77_M, &F77_N, &alpha, A, &F77_lda, X, &F77_incX,
55 else if (layout == CblasRowMajor)
58 if (TransA == CblasNoTrans) TA =
'T';
59 else if (TransA == CblasTrans) TA =
'N';
60 else if (TransA == CblasConjTrans) TA =
'N';
63 cblas_xerbla(2,
"cblas_dgemv",
"Illegal TransA setting, %d\n", TransA);
69 F77_TA = C2F_CHAR(&TA);
71 F77_dgemv(F77_TA, &F77_N, &F77_M, &alpha, A, &F77_lda, X,
72 &F77_incX, &beta, Y, &F77_incY);
74 else cblas_xerbla(1,
"cblas_dgemv",
"Illegal layout setting, %d\n", layout);