diff --git a/Grid/lattice/Lattice_reduction.h b/Grid/lattice/Lattice_reduction.h index 92eb0562..0bd1098e 100644 --- a/Grid/lattice/Lattice_reduction.h +++ b/Grid/lattice/Lattice_reduction.h @@ -290,8 +290,10 @@ template inline ComplexD innerProduct(const Lattice &left,const Lattice &right) { GridBase *grid = left.Grid(); + bool ok; #ifdef GRID_SYCL uint64_t csum=0; + uint64_t csum2=0; if ( FlightRecorder::LoggingMode != FlightRecorder::LoggingModeNone) { // Hack @@ -300,13 +302,33 @@ inline ComplexD innerProduct(const Lattice &left,const Lattice &righ Integer words = left.Grid()->oSites()*sizeof(vobj)/sizeof(uint64_t); uint64_t *base= (uint64_t *)&l_v[0]; csum=svm_xor(base,words); + ok = FlightRecorder::CsumLog(csum); + if ( !ok ) { + csum2=svm_xor(base,words); + std::cerr<< " Bad CSUM " << std::hex<< csum << " recomputed as "<GlobalSum(nrm); + ok = FlightRecorder::NormLog(real(nrm)); + if ( !ok ) { + ComplexD nrm2 = rankInnerProduct(left,right); + RealD local2 = real(nrm2); + std::cerr<< " Bad NORM " << local << " recomputed as "<GlobalSumP2P(nrm); + // grid->GlobalSum(nrm); + FlightRecorder::StepLog("Finished global sum"); + // std::cout << " norm "<< nrm << " p2p norm "<