10 void cblas_strsv(
const CBLAS_LAYOUT layout,
const CBLAS_UPLO Uplo,
11 const CBLAS_TRANSPOSE TransA,
const CBLAS_DIAG Diag,
12 const CBLAS_INT N,
const float *A,
const CBLAS_INT lda,
float *X,
20 F77_CHAR F77_TA, F77_UL, F77_DI;
27 F77_INT F77_N=N, F77_lda=lda, F77_incX=incX;
33 extern int CBLAS_CallFromC;
34 extern int RowMajorStrg;
38 if (layout == CblasColMajor)
40 if (Uplo == CblasUpper) UL =
'U';
41 else if (Uplo == CblasLower) UL =
'L';
44 cblas_xerbla(2,
"cblas_strsv",
"Illegal Uplo setting, %d\n", Uplo);
49 if (TransA == CblasNoTrans) TA =
'N';
50 else if (TransA == CblasTrans) TA =
'T';
51 else if (TransA == CblasConjTrans) TA =
'C';
54 cblas_xerbla(3,
"cblas_strsv",
"Illegal TransA setting, %d\n", TransA);
59 if (Diag == CblasUnit) DI =
'U';
60 else if (Diag == CblasNonUnit) DI =
'N';
63 cblas_xerbla(4,
"cblas_strsv",
"Illegal Diag setting, %d\n", Diag);
69 F77_UL = C2F_CHAR(&UL);
70 F77_TA = C2F_CHAR(&TA);
71 F77_DI = C2F_CHAR(&DI);
73 F77_strsv( F77_UL, F77_TA, F77_DI, &F77_N, A, &F77_lda, X,
76 else if (layout == CblasRowMajor)
79 if (Uplo == CblasUpper) UL =
'L';
80 else if (Uplo == CblasLower) UL =
'U';
83 cblas_xerbla(2,
"cblas_strsv",
"Illegal Uplo setting, %d\n", Uplo);
89 if (TransA == CblasNoTrans) TA =
'T';
90 else if (TransA == CblasTrans) TA =
'N';
91 else if (TransA == CblasConjTrans) TA =
'N';
94 cblas_xerbla(3,
"cblas_strsv",
"Illegal TransA setting, %d\n", TransA);
100 if (Diag == CblasUnit) DI =
'U';
101 else if (Diag == CblasNonUnit) DI =
'N';
104 cblas_xerbla(4,
"cblas_strsv",
"Illegal Diag setting, %d\n", Diag);
110 F77_UL = C2F_CHAR(&UL);
111 F77_TA = C2F_CHAR(&TA);
112 F77_DI = C2F_CHAR(&DI);
114 F77_strsv( F77_UL, F77_TA, F77_DI, &F77_N, A, &F77_lda, X,
117 else cblas_xerbla(1,
"cblas_strsv",
"Illegal layout setting, %d\n", layout);