1
0
mirror of https://github.com/paboyle/Grid.git synced 2025-10-25 18:19:34 +01:00

Merge pull request #233 from giltirn/lanczos_fix

A few run /compile / memory leak fixes
This commit is contained in:
Chris K
2019-10-30 10:21:59 -04:00
committed by GitHub
2 changed files with 14 additions and 9 deletions

View File

@@ -62,9 +62,12 @@ void basisRotate(std::vector<Field> &basis,Eigen::MatrixXd& Qt,int j0, int j1, i
basis_v[k] = basis[k].View(); basis_v[k] = basis[k].View();
} }
std::vector < vobj , commAllocator<vobj> > Bt(thread_max() * Nm); // Thread private
thread_region thread_region
{ {
std::vector < vobj , commAllocator<vobj> > B(Nm); // Thread private vobj* B = Bt.data() + Nm * thread_num();
thread_for_in_region(ss, grid->oSites(),{ thread_for_in_region(ss, grid->oSites(),{
for(int j=j0; j<j1; ++j) B[j]=0.; for(int j=j0; j<j1; ++j) B[j]=0.;

View File

@@ -178,8 +178,8 @@ public:
private: private:
void dealloc(void) void dealloc(void)
{ {
alignedAllocator<vobj> alloc;
if( this->_odata_size ) { if( this->_odata_size ) {
alignedAllocator<vobj> alloc;
alloc.deallocate(this->_odata,this->_odata_size); alloc.deallocate(this->_odata,this->_odata_size);
this->_odata=nullptr; this->_odata=nullptr;
this->_odata_size=0; this->_odata_size=0;
@@ -187,16 +187,18 @@ private:
} }
void resize(uint64_t size) void resize(uint64_t size)
{ {
alignedAllocator<vobj> alloc;
if ( this->_odata_size != size ) { if ( this->_odata_size != size ) {
alignedAllocator<vobj> alloc;
dealloc(); dealloc();
}
this->_odata_size = size; this->_odata_size = size;
if ( size ) if ( size )
this->_odata = alloc.allocate(this->_odata_size); this->_odata = alloc.allocate(this->_odata_size);
else else
this->_odata = nullptr; this->_odata = nullptr;
} }
}
public: public:
///////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////////
// Return a view object that may be dereferenced in site loops. // Return a view object that may be dereferenced in site loops.
@@ -346,7 +348,7 @@ public:
void reset(GridBase* grid) { void reset(GridBase* grid) {
if (this->_grid != grid) { if (this->_grid != grid) {
this->_grid = grid; this->_grid = grid;
this->_odata.resize(grid->oSites()); this->resize(grid->oSites());
this->checkerboard = 0; this->checkerboard = 0;
} }
} }