10 #include "cblas_f77.h" 11 void cblas_strmv(
const CBLAS_LAYOUT layout,
const CBLAS_UPLO Uplo,
12 const CBLAS_TRANSPOSE TransA,
const CBLAS_DIAG Diag,
13 const CBLAS_INT N,
const float *A,
const CBLAS_INT lda,
14 float *X,
const CBLAS_INT incX)
21 F77_CHAR F77_TA, F77_UL, F77_DI;
28 F77_INT F77_N=N, F77_lda=lda, F77_incX=incX;
34 extern int CBLAS_CallFromC;
35 extern int RowMajorStrg;
39 if (layout == CblasColMajor)
41 if (Uplo == CblasUpper) UL =
'U';
42 else if (Uplo == CblasLower) UL =
'L';
45 cblas_xerbla(2,
"cblas_strmv",
"Illegal Uplo setting, %d\n", Uplo);
50 if (TransA == CblasNoTrans) TA =
'N';
51 else if (TransA == CblasTrans) TA =
'T';
52 else if (TransA == CblasConjTrans) TA =
'C';
55 cblas_xerbla(3,
"cblas_strmv",
"Illegal TransA setting, %d\n", TransA);
60 if (Diag == CblasUnit) DI =
'U';
61 else if (Diag == CblasNonUnit) DI =
'N';
64 cblas_xerbla(4,
"cblas_strmv",
"Illegal Diag setting, %d\n", Diag);
70 F77_UL = C2F_CHAR(&UL);
71 F77_TA = C2F_CHAR(&TA);
72 F77_DI = C2F_CHAR(&DI);
74 F77_strmv( F77_UL, F77_TA, F77_DI, &F77_N, A, &F77_lda, X,
77 else if (layout == CblasRowMajor)
80 if (Uplo == CblasUpper) UL =
'L';
81 else if (Uplo == CblasLower) UL =
'U';
84 cblas_xerbla(2,
"cblas_strmv",
"Illegal Uplo setting, %d\n", Uplo);
90 if (TransA == CblasNoTrans) TA =
'T';
91 else if (TransA == CblasTrans) TA =
'N';
92 else if (TransA == CblasConjTrans) TA =
'N';
95 cblas_xerbla(3,
"cblas_strmv",
"Illegal TransA setting, %d\n", TransA);
101 if (Diag == CblasUnit) DI =
'U';
102 else if (Diag == CblasNonUnit) DI =
'N';
105 cblas_xerbla(4,
"cblas_strmv",
"Illegal Diag setting, %d\n", Diag);
111 F77_UL = C2F_CHAR(&UL);
112 F77_TA = C2F_CHAR(&TA);
113 F77_DI = C2F_CHAR(&DI);
115 F77_strmv( F77_UL, F77_TA, F77_DI, &F77_N, A, &F77_lda, X,
118 else cblas_xerbla(1,
"cblas_strmv",
"Illegal layout setting, %d\n", layout);