10 void cblas_ztrsv(
const CBLAS_LAYOUT layout,
const CBLAS_UPLO Uplo,
11 const CBLAS_TRANSPOSE TransA,
const CBLAS_DIAG Diag,
12 const CBLAS_INT N,
const void *A,
const CBLAS_INT lda,
void *X,
19 F77_CHAR F77_TA, F77_UL, F77_DI;
26 F77_INT F77_N=N, F77_lda=lda, F77_incX=incX;
32 CBLAS_INT n, i=0, tincX;
33 double *st=0,*x=(
double *)X;
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_ztrsv",
"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_ztrsv",
"Illegal TransA setting, %d\n", TransA);
60 if (Diag == CblasUnit) DI =
'U';
61 else if (Diag == CblasNonUnit) DI =
'N';
64 cblas_xerbla(4,
"cblas_ztrsv",
"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_ztrsv( 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_ztrsv",
"Illegal Uplo setting, %d\n", Uplo);
90 if (TransA == CblasNoTrans) TA =
'T';
91 else if (TransA == CblasTrans) TA =
'N';
92 else if (TransA == CblasConjTrans)
117 cblas_xerbla(3,
"cblas_ztrsv",
"Illegal TransA setting, %d\n", TransA);
123 if (Diag == CblasUnit) DI =
'U';
124 else if (Diag == CblasNonUnit) DI =
'N';
127 cblas_xerbla(4,
"cblas_ztrsv",
"Illegal Diag setting, %d\n", Diag);
133 F77_UL = C2F_CHAR(&UL);
134 F77_TA = C2F_CHAR(&TA);
135 F77_DI = C2F_CHAR(&DI);
137 F77_ztrsv( F77_UL, F77_TA, F77_DI, &F77_N, A, &F77_lda, X,
139 if (TransA == CblasConjTrans)
152 else cblas_xerbla(1,
"cblas_ztrsv",
"Illegal layout setting, %d\n", layout);