10 void cblas_ctbsv(
const CBLAS_LAYOUT layout,
const CBLAS_UPLO Uplo,
11 const CBLAS_TRANSPOSE TransA,
const CBLAS_DIAG Diag,
12 const CBLAS_INT N,
const CBLAS_INT K,
const void *A,
const CBLAS_INT lda,
13 void *X,
const CBLAS_INT incX)
19 F77_CHAR F77_TA, F77_UL, F77_DI;
26 F77_INT F77_N=N, F77_lda=lda, F77_K=K, F77_incX=incX;
33 CBLAS_INT n, i=0, tincX;
34 float *st=0,*x=(
float *)X;
35 extern int CBLAS_CallFromC;
36 extern int RowMajorStrg;
40 if (layout == CblasColMajor)
42 if (Uplo == CblasUpper) UL =
'U';
43 else if (Uplo == CblasLower) UL =
'L';
46 cblas_xerbla(2,
"cblas_ctbsv",
"Illegal Uplo setting, %d\n", Uplo);
51 if (TransA == CblasNoTrans) TA =
'N';
52 else if (TransA == CblasTrans) TA =
'T';
53 else if (TransA == CblasConjTrans) TA =
'C';
56 cblas_xerbla(3,
"cblas_ctbsv",
"Illegal TransA setting, %d\n", TransA);
61 if (Diag == CblasUnit) DI =
'U';
62 else if (Diag == CblasNonUnit) DI =
'N';
65 cblas_xerbla(4,
"cblas_ctbsv",
"Illegal Diag setting, %d\n", Diag);
71 F77_UL = C2F_CHAR(&UL);
72 F77_TA = C2F_CHAR(&TA);
73 F77_DI = C2F_CHAR(&DI);
75 F77_ctbsv( F77_UL, F77_TA, F77_DI, &F77_N, &F77_K, A, &F77_lda, X,
78 else if (layout == CblasRowMajor)
81 if (Uplo == CblasUpper) UL =
'L';
82 else if (Uplo == CblasLower) UL =
'U';
85 cblas_xerbla(2,
"cblas_ctbsv",
"Illegal Uplo setting, %d\n", Uplo);
91 if (TransA == CblasNoTrans) TA =
'T';
92 else if (TransA == CblasTrans) TA =
'N';
93 else if (TransA == CblasConjTrans)
121 cblas_xerbla(3,
"cblas_ctbsv",
"Illegal TransA setting, %d\n", TransA);
127 if (Diag == CblasUnit) DI =
'U';
128 else if (Diag == CblasNonUnit) DI =
'N';
131 cblas_xerbla(4,
"cblas_ctbsv",
"Illegal Diag setting, %d\n", Diag);
137 F77_UL = C2F_CHAR(&UL);
138 F77_TA = C2F_CHAR(&TA);
139 F77_DI = C2F_CHAR(&DI);
142 F77_ctbsv( F77_UL, F77_TA, F77_DI, &F77_N, &F77_K, A, &F77_lda, X,
145 if (TransA == CblasConjTrans)
158 else cblas_xerbla(1,
"cblas_ctbsv",
"Illegal layout setting, %d\n", layout);