SCALAPACK 2.2.2
LAPACK: Linear Algebra PACKage
Loading...
Searching...
No Matches
dgesd2d_.c
Go to the documentation of this file.
1#include "Bdef.h"
2
3
4#if (INTFACE == C_CALL)
5void Cdgesd2d(Int ConTxt, Int m, Int n, double *A, Int lda,
6 Int rdest, Int cdest)
7#else
8F_VOID_FUNC dgesd2d_(Int *ConTxt, Int *m, Int *n, double *A, Int *lda,
9 Int *rdest, Int *cdest)
10#endif
11/*
12 * -- V1.1 BLACS routine --
13 * University of Tennessee, May 1, 1996
14 * Written by Clint Whaley.
15 *
16 * Purpose
17 * =======
18 * Locally-blocking point-to-point general double precision send.
19 *
20 * Arguments
21 * =========
22 *
23 * ConTxt (input) Ptr to Int
24 * Index into MyConTxts00 (my contexts array).
25 *
26 * M (input) Ptr to Int
27 * The number of rows of the matrix A. M >= 0.
28 *
29 * N (input) Ptr to Int
30 * The number of columns of the matrix A. N >= 0.
31 *
32 * A (input) Ptr to double precision two dimensional array
33 * The m by n matrix A. Fortran77 (column-major) storage
34 * assumed.
35 *
36 * LDA (input) Ptr to Int
37 * The leading dimension of the array A. LDA >= M.
38 *
39 * RDEST (input) Ptr to Int
40 * The process row of the destination process.
41 *
42 * CDEST (input) Ptr to Int
43 * The process column of the destination process.
44 *
45 * ------------------------------------------------------------------------
46 */
47{
48 void BI_ArgCheck(Int, Int, char *, char, char, char, Int, Int, Int, Int,
49 Int *, Int *);
50 MPI_Datatype BI_GetMpiGeType(BLACSCONTEXT *, Int, Int, Int,
51 MPI_Datatype, Int *);
52 BLACBUFF *BI_Pack(BLACSCONTEXT *, BVOID *, BLACBUFF *, MPI_Datatype);
58
59 Int dest, tlda, ierr;
60 BLACBUFF *bp;
61 BLACSCONTEXT *ctxt;
62 MPI_Datatype MatTyp;
64
65 MGetConTxt(Mpval(ConTxt), ctxt);
66#if (BlacsDebugLvl > 0)
67 BI_ArgCheck(Mpval(ConTxt), RT_SD, "DGESD2D", 'a', 'u', 'u', Mpval(m),
68 Mpval(n), Mpval(lda), 1, Mpaddress(rdest), Mpaddress(cdest));
69#endif
70 if (Mpval(lda) < Mpval(m)) tlda = Mpval(m);
71 else tlda = Mpval(lda);
72 dest = Mvkpnum(ctxt, Mpval(rdest), Mpval(cdest));
73 ctxt->scp = &ctxt->pscp;
74
75 MatTyp = BI_GetMpiGeType(ctxt, Mpval(m), Mpval(n), tlda,
76 MPI_DOUBLE, &BI_AuxBuff.N);
77#ifdef SndIsLocBlk
78 BI_AuxBuff.Buff = (char *) A;
79 BI_AuxBuff.dtype = MatTyp;
80 BI_Ssend(ctxt, dest, PT2PTID, &BI_AuxBuff);
81#else
82 bp = BI_Pack(ctxt, (BVOID *) A, NULL, MatTyp);
83 BI_Asend(ctxt, Mkpnum(ctxt, Mpval(rdest), Mpval(cdest)), PT2PTID, bp);
84#endif
85 ierr=BI_MPI_TYPE_FREE(&MatTyp);
86
87/*
88 * Having started the async send, update the buffers (reform links, check if
89 * active buffers have become inactive, etc.)
90 */
91#ifdef SndIsLocBlk
92 if (BI_ActiveQ) BI_UpdateBuffs(NULL);
93#else
95#endif
96} /* end of dgesd2d */
void BI_ArgCheck(Int ConTxt, Int RoutType, char *routine, char scope, char uplo, char diag, Int m, Int n, Int lda, Int nprocs, Int *prows, Int *pcols)
Definition BI_ArgCheck.c:4
void BI_Asend(BLACSCONTEXT *ctxt, Int dest, Int msgid, BLACBUFF *bp)
Definition BI_Asend.c:3
Int BI_BuffIsFree(BLACBUFF *bp, Int Wait)
BLACBUFF * BI_GetBuff(Int length)
Definition BI_GetBuff.c:37
MPI_Datatype BI_GetMpiGeType(BLACSCONTEXT *ctxt, Int m, Int n, Int lda, MPI_Datatype Dtype, Int *N)
BLACBUFF * BI_ActiveQ
BLACBUFF BI_AuxBuff
BLACBUFF * BI_Pack(BLACSCONTEXT *ctxt, BVOID *A, BLACBUFF *bp, MPI_Datatype Dtype)
Definition BI_Pack.c:2
void BI_Ssend(BLACSCONTEXT *ctxt, Int dest, Int msgid, BLACBUFF *bp)
Definition BI_Ssend.c:3
void BI_UpdateBuffs(BLACBUFF *Newbp)
#define Int
Definition Bconfig.h:22
#define BI_MPI_TYPE_FREE(t)
Definition Bdef.h:305
#define Mvkpnum(ctxt, prow, pcol)
Definition Bdef.h:174
#define MGetConTxt(Context, ctxtptr)
Definition Bdef.h:200
#define F_VOID_FUNC
Definition Bdef.h:232
#define Mpaddress(para)
Definition Bdef.h:262
#define Mpval(para)
Definition Bdef.h:261
#define Mkpnum(ctxt, prow, pcol)
Definition Bdef.h:173
#define RT_SD
Definition Bdef.h:105
#define PT2PTID
Definition Bdef.h:77
#define BVOID
Definition Bdef.h:136
void Cdgesd2d()
F_VOID_FUNC dgesd2d_(Int *ConTxt, Int *m, Int *n, double *A, Int *lda, Int *rdest, Int *cdest)
Definition dgesd2d_.c:8
Int N
Definition Bdef.h:61
MPI_Datatype dtype
Definition Bdef.h:60
char * Buff
Definition Bdef.h:56
BLACSSCOPE pscp
Definition Bdef.h:25
BLACSSCOPE * scp
Definition Bdef.h:26