75 Int Np, Iam, msgid, Rmsgid, i, j;
88 if (REBS = (dest == -1)) dest = 0;
90 mydist = (Np + Iam - dest) % Np;
97 if (nbranches ==
FULLCON) nbranches = Np;
98 rightedge = Np - 1 - (Np-1)%nbranches;
100 for (i=1; (i < Np); i *= nbranches)
102 if (mydist%nbranches)
104 BI_Ssend(ctxt, (dest + (mydist-mydist%nbranches)*i)%Np, msgid, bp);
109 if (mydist != rightedge) nrcvs = nbranches - 1;
110 else nrcvs = (Np + i - 1) / i - rightedge - 1;
112 rightedge /= nbranches;
113 rightedge -= (rightedge % nbranches);
117 for (j=nrcvs; j; j--)
125 src = (Iam + i) % Np;
126 for (j=nrcvs; j; j--)
130 src = (src + i) % Np;
142 for (i=2; i < Np; i <<= 1);
151 if (dist < Np)
BI_Rsend(ctxt, dist, Rmsgid, bp);
void BI_Arecv(BLACSCONTEXT *ctxt, Int src, Int msgid, BLACBUFF *bp)
Int BI_BuffIsFree(BLACBUFF *bp, Int Wait)
BLACBUFF * BI_GetBuff(Int length)
void BI_Rsend(BLACSCONTEXT *ctxt, Int dest, Int msgid, BLACBUFF *bp)
void BI_Srecv(BLACSCONTEXT *ctxt, Int src, Int msgid, BLACBUFF *bp)
void BI_Ssend(BLACSCONTEXT *ctxt, Int dest, Int msgid, BLACBUFF *bp)
void BI_TreeComb(BLACSCONTEXT *ctxt, BLACBUFF *bp, BLACBUFF *bp2, Int N, VVFUNPTR Xvvop, Int dest, Int nbranches)
void BI_UpdateBuffs(BLACBUFF *Newbp)
void(* VVFUNPTR)(Int, char *, char *)