mirror of
https://github.com/paboyle/Grid.git
synced 2025-04-04 19:25:56 +01:00
Uint64 sum for IO rates
This commit is contained in:
parent
a359f7a9f5
commit
d6b64f47d9
@ -86,6 +86,7 @@ class CartesianCommunicator {
|
|||||||
void GlobalSumVector(RealD *,int N);
|
void GlobalSumVector(RealD *,int N);
|
||||||
|
|
||||||
void GlobalSum(uint32_t &);
|
void GlobalSum(uint32_t &);
|
||||||
|
void GlobalSum(uint64_t &);
|
||||||
|
|
||||||
void GlobalSum(ComplexF &c)
|
void GlobalSum(ComplexF &c)
|
||||||
{
|
{
|
||||||
|
@ -53,6 +53,7 @@ void CartesianCommunicator::GlobalSum(float &){}
|
|||||||
void CartesianCommunicator::GlobalSumVector(float *,int N){}
|
void CartesianCommunicator::GlobalSumVector(float *,int N){}
|
||||||
void CartesianCommunicator::GlobalSum(double &){}
|
void CartesianCommunicator::GlobalSum(double &){}
|
||||||
void CartesianCommunicator::GlobalSum(uint32_t &){}
|
void CartesianCommunicator::GlobalSum(uint32_t &){}
|
||||||
|
void CartesianCommunicator::GlobalSum(uint64_t &){}
|
||||||
void CartesianCommunicator::GlobalSumVector(double *,int N){}
|
void CartesianCommunicator::GlobalSumVector(double *,int N){}
|
||||||
|
|
||||||
void CartesianCommunicator::SendRecvPacket(void *xmit,
|
void CartesianCommunicator::SendRecvPacket(void *xmit,
|
||||||
|
@ -101,6 +101,22 @@ void CartesianCommunicator::GlobalSum(uint32_t &u){
|
|||||||
shmem_barrier_all(); // necessary?
|
shmem_barrier_all(); // necessary?
|
||||||
u = dest;
|
u = dest;
|
||||||
}
|
}
|
||||||
|
void CartesianCommunicator::GlobalSum(uint64_t &u){
|
||||||
|
static long long source ;
|
||||||
|
static long long dest ;
|
||||||
|
static long long llwrk[_SHMEM_REDUCE_MIN_WRKDATA_SIZE];
|
||||||
|
static long psync[_SHMEM_REDUCE_SYNC_SIZE];
|
||||||
|
|
||||||
|
// int nreduce=1;
|
||||||
|
// int pestart=0;
|
||||||
|
// int logStride=0;
|
||||||
|
|
||||||
|
source = u;
|
||||||
|
dest = 0;
|
||||||
|
shmem_longlong_sum_to_all(&dest,&source,1,0,0,_Nprocessors,llwrk,psync);
|
||||||
|
shmem_barrier_all(); // necessary?
|
||||||
|
u = dest;
|
||||||
|
}
|
||||||
void CartesianCommunicator::GlobalSum(float &f){
|
void CartesianCommunicator::GlobalSum(float &f){
|
||||||
static float source ;
|
static float source ;
|
||||||
static float dest ;
|
static float dest ;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user