Merge pull request #54 from reyoung/fix_calc_batch_size_deadlock

Fix a PyDataProvider2 bug when use calc_batch_size
avx_docs
emailweixu 9 years ago committed by GitHub
commit 1c5514f4ff

@ -340,6 +340,7 @@ private:
size_t additionalBatchSize = 1; size_t additionalBatchSize = 1;
if (calcBatchSize_) { if (calcBatchSize_) {
PyGuard guard;
py::CallableHelper calcBatchSize(this->calcBatchSize_); py::CallableHelper calcBatchSize(this->calcBatchSize_);
calcBatchSize.setArgsSize(1); calcBatchSize.setArgsSize(1);
calcBatchSize.getArgs().set(0, data); calcBatchSize.getArgs().set(0, data);
@ -513,6 +514,7 @@ public:
} }
{ {
if (calcBatchSize_) { // custom calc batch size. if (calcBatchSize_) { // custom calc batch size.
PyGuard guard;
Py_INCREF(data.back().get()); Py_INCREF(data.back().get());
py::CallableHelper calcBatchSize(calcBatchSize_); py::CallableHelper calcBatchSize(calcBatchSize_);
calcBatchSize.setArgsSize(1); calcBatchSize.setArgsSize(1);
@ -575,6 +577,11 @@ public:
scanners[i]->finishFill(inArgs[i]); scanners[i]->finishFill(inArgs[i]);
} }
{
PyGuard g;
cache_->drop(&data);
}
DBG << "Reading CPU Batch Done."; DBG << "Reading CPU Batch Done.";
if (useGpu_) { if (useGpu_) {
@ -592,10 +599,6 @@ public:
*batch = cpuBatch; *batch = cpuBatch;
} }
{
PyGuard g;
cache_->drop(&data);
}
return bsize; return bsize;
} }
}; };

Loading…
Cancel
Save